|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
怎样判断一个变量是否有连续性( b$ z, m) I1 G' H$ ^! j
3 x3 \: e9 M+ C1 {! j/ @ b y. M+ l) _. N: I8 x _" @
/ D5 i; h! q& z8 k: O
% D: G) A4 r# N$ R" k
有没有好的方法(C语言)判断:一个16bit变量里面是否有连续8个以上的1?$ n" U9 T& i5 s6 ]
如0xFF00就有,0xFEFE就没有, 0x7F80就有,等等。1 L& j$ r6 h* [% k! f
方法有,比如我想到的是用窗口法:先和0xFF00比较,然后和0x7F80比较.....最后和0xFF比较。 但这个方法太蠢了。
: s, E' j z! d. r. G16bit数据其实是输入码流,你不能随便改变它的值,因为它随时(2kHz速率)被中断更改。我想到的方式是:! y* M: g' e2 A7 _/ t3 n
disableInt();7 ` |% C, l: J, G
data=buf;+ t* H) G- P. v. t0 g& V* U) M' Q! k
buf=0;
4 u" I6 i6 v" s$ ?# F0 JenableInt();7 ~* e/ d* A* F1 E+ [7 C( |
这样就用data把buf里面的数据取出。但后期处理更复杂。因为要做数据拼接。我不知道怎么做拼接数据,因为第二次的数据要哪一段拼接到第一次数据我还没有想清楚。拼接好了后再判断,就像T叔说的那样没有问题了。
0 M* ^/ ?- J) V f; A8 F所以,对这样的码流信号,有什么好办法判断8个连1信号(帧头)?) H0 q+ ^# R2 ~% G
4 I0 u5 f. Q4 w
当然可以在中断服务程序里面1bit1bit地处理,这样逻辑比较简单。
# y4 u6 D0 h; ~1 Y/ d% p n, ^8 [2 s) e' M5 ?. o, _! P$ z
但如果在中断处理bit数据,带来的问题是所有的收数据处理都必须在中断中处理,这样中断函数太大了,不合理。! x; B, V* Q! N+ O! Q$ N4 _- K
所以还是回到初始,在主程序中处理input data。这样中断函数必须记录接收到的数据序列和bit个数。: i) f& b7 r1 G6 }
回到主程序中,问题又来了:bit个数不一定是16位,而是一个变化数字。要考虑的事情有:
0 e8 B2 b; l6 O6 t1. 等待与下一批数据拼接.1 o3 z9 Q. P. F1 G
2. 检查bit个数是否大于7,如果没有,则跳到5;(其实处理也可以,比如记录现有的1bit,但太复杂了)
0 ?! o: o2 b6 G/ `) s3. 查数列中有没有连续8个1,检测的办法总是有的;8 H1 o) \, |' K. [+ f3 {
4. 如果检测到了,则到7
6 m8 g3 ~! q6 f9 X$ R5 W5. 找到最后一个0bit,保留右边的全部1bit,左边的数据全部丢弃,更新有效bit个数
) I+ K5 r( o3 H% J& [6. 回到1;. S9 \4 }, l& n) g, g8 a. S
7. 到下一个状态( w( p/ o; k& u& A% O
|
|