久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3785|回復: 1
打印 上一主題 下一主題
收起左側

怎樣判斷一個變量是否有連續性

[復制鏈接]
跳轉到指定樓層
樓主
ID:183246 發表于 2017-4-7 15:15 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
有沒有好的方法(C語言)判斷:一個16bit變量里面是否有連續8個以上的1?
如0xFF00就有,0xFEFE就沒有, 0x7F80就有,等等。
方法有,比如我想到的是用窗口法:先和0xFF00比較,然后和0x7F80比較.....最后和0xFF比較。 但這個方法太蠢了。
16bit數據其實是輸入碼流,你不能隨便改變它的值,因為它隨時(2kHz速率)被中斷更改。我想到的方式是:
disableInt();
data=buf;
buf=0;
enableInt();
這樣就用data把buf里面的數據取出。但后期處理更復雜。因為要做數據拼接。我不知道怎么做拼接數據,因為第二次的數據要哪一段拼接到第一次數據我還沒有想清楚。拼接好了后再判斷,就像T叔說的那樣沒有問題了。
所以,對這樣的碼流信號,有什么好辦法判斷8個連1信號(幀頭)?

當然可以在中斷服務程序里面1bit1bit地處理,這樣邏輯比較簡單。

但如果在中斷處理bit數據,帶來的問題是所有的收數據處理都必須在中斷中處理,這樣中斷函數太大了,不合理。
所以還是回到初始,在主程序中處理input data。這樣中斷函數必須記錄接收到的數據序列和bit個數。
回到主程序中,問題又來了:bit個數不一定是16位,而是一個變化數字。要考慮的事情有:
1.    等待與下一批數據拼接.
2.   檢查bit個數是否大于7,如果沒有,則跳到5;(其實處理也可以,比如記錄現有的1bit,但太復雜了)
3.   查數列中有沒有連續8個1,檢測的辦法總是有的;
4.   如果檢測到了,則到7
5.   找到最后一個0bit,保留右邊的全部1bit,左邊的數據全部丟棄,更新有效bit個數
6.   回到1;
7.   到下一個狀態

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:187614 發表于 2017-4-9 09:53 | 只看該作者
很簡單:可采用定值比較法,僅僅8個值而已!
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 91欧美精品成人综合在线观看 | 国产在线观看免费 | 日日操夜夜操视频 | 爱综合| 性色视频 | 国产视频中文字幕 | 久久久www成人免费无遮挡大片 | 亚洲色图在线观看 | 国产精品久久久久无码av | 国产欧美精品一区二区 | av日韩在线播放 | 一本岛道一二三不卡区 | 精品国产91久久久久久 | 欧美乱做爰xxxⅹ久久久 | 九九伦理电影 | 国产伦精品一区二区 | 精品久久久久久 | 久久福利| 人人人人干 | 国产精品一区二区三区四区五区 | 又黑又粗又长的欧美一区 | 日本色高清 | 中文字幕在线观看 | 欧美一区二区三区在线免费观看 | 免费视频一区二区 | 日韩免费网 | 国产精品欧美一区二区三区不卡 | 蜜桃视频一区二区三区 | 亚洲视频免费播放 | 久久精品视频网站 | 成人在线视频网 | 久久亚洲国产 | 羞羞网站在线免费观看 | 国产欧美一区二区三区在线看蜜臀 | 黑人性hd | 97精品一区二区 | 国产精品久久久久久久久久免费看 | 成人久久18免费网站麻豆 | 亚洲精品区| www.黄网| 美女天天干天天操 |