找回密码
 注册
关于网站域名变更的通知
查看: 370|回复: 1
打印 上一主题 下一主题

怎样判断一个变量是否有连续性

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2019-1-9 09:44 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
怎样判断一个变量是否有连续性
5 n: k4 l9 X. _! M. N0 I$ }
& @7 J; q& D/ E0 L
( V" k! U$ U0 O/ w  B

9 X; v/ b- o! I9 c3 F$ ?
0 P- `7 g$ |2 b& \- M2 w" s5 {% ^2 r% k  y- U
有没有好的方法(C语言)判断:一个16bit变量里面是否有连续8个以上的1?: W! n- u  q2 [) f7 s: l; t
如0xFF00就有,0xFEFE就没有, 0x7F80就有,等等。% M: S, m$ E- T+ `7 q
方法有,比如我想到的是用窗口法:先和0xFF00比较,然后和0x7F80比较.....最后和0xFF比较。 但这个方法太蠢了。
$ j8 v2 D% H( A8 a7 s, M  u16bit数据其实是输入码流,你不能随便改变它的值,因为它随时(2kHz速率)被中断更改。我想到的方式是:; S" ~- h+ b' c2 C1 ]$ w" `
disableInt();
( Z. @5 X: h& N3 I/ xdata=buf;
/ J" b7 }' z+ u5 O1 A* c+ h3 xbuf=0;
- T5 o6 h' T# D  jenableInt();
3 ?2 L" e8 e. [' c* O" W; [$ J这样就用data把buf里面的数据取出。但后期处理更复杂。因为要做数据拼接。我不知道怎么做拼接数据,因为第二次的数据要哪一段拼接到第一次数据我还没有想清楚。拼接好了后再判断,就像T叔说的那样没有问题了。
$ ~1 ^. c$ n9 b所以,对这样的码流信号,有什么好办法判断8个连1信号(帧头)?
) b; V2 S' d& B! p7 `' ]. V6 J
0 O  W1 V" x& n* z  K/ N当然可以在中断服务程序里面1bit1bit地处理,这样逻辑比较简单。
6 Y6 ]1 n" V7 H$ p7 ]- {' v
2 |* Q2 `" B2 a8 m8 U但如果在中断处理bit数据,带来的问题是所有的收数据处理都必须在中断中处理,这样中断函数太大了,不合理。( R4 Y2 p% ^7 t6 k! F2 n6 Z3 \" M
所以还是回到初始,在主程序中处理input data。这样中断函数必须记录接收到的数据序列和bit个数。* l& E" m4 N( A2 h+ v
回到主程序中,问题又来了:bit个数不一定是16位,而是一个变化数字。要考虑的事情有:
7 Q- y! M! I; v+ U6 h1.    等待与下一批数据拼接.
4 o  h; o9 A( c2.   检查bit个数是否大于7,如果没有,则跳到5;(其实处理也可以,比如记录现有的1bit,但太复杂了)
( L1 B0 _, n9 K6 o$ I3 z7 Q, x! x8 w; U3.   查数列中有没有连续8个1,检测的办法总是有的;3 v. V" B6 Y# r% F+ e
4.   如果检测到了,则到7
  c4 W) i- s: \* u+ g. Q* x. @4 x5.   找到最后一个0bit,保留右边的全部1bit,左边的数据全部丢弃,更新有效bit个数8 b% m/ C/ P; k, y1 M
6.   回到1;" v1 `5 u2 O! N; |# _, J
7.   到下一个状态
3 V, \1 ]+ `0 O" V+ x
  • TA的每日心情
    开心
    2019-11-20 15:05
  • 签到天数: 2 天

    [LV.1]初来乍到

    2#
    发表于 2019-1-9 11:15 | 只看该作者
    看看楼主怎么说的
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-8-2 23:15 , Processed in 0.109375 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表