9.5
清單已經出了一段時間了,買的少部分元器件也到了,今天重新分析一遍清單,找找相關資料,
清單:

二維云臺和攝像頭很熟悉了,做控制題必選,鑒于TI杯2018年省賽和2019年國賽都出過無線充電小車,兩年的賽題出現重疊,因此可以猜一下2020年會不會出現電磁炮類似的題(純屬個人猜測),不過提前把云臺和攝像頭調好還是有必要的,
關于電磁炮前期的備賽情況,可以參考博主2019年的參賽筆記:
https://blog.csdn.net/weixin_44578655/article/details/99649173
控制題的備賽規劃:
使用stm32和MSP430分別實作二維云臺控制和openmv通訊、4輪小車控制,
MSP430最好前期準備一下,以防TI限定單片機,
除了控制題,清單中還有一個亮眼的地方,有兩個器件給出了具體型號和購買鏈接:
- 溫度傳感器LMT70
- 模擬前端芯片ADS1292
另外推薦的測驗儀器中也有一個顯眼的存在: - 心電信號模擬器
這已經暗示的很明顯了,去TI官網搜了一下,ADS1292是TI的一款心電檢測專用芯片,特點是小型、便攜;LMT70是接觸式溫度傳感器
ADS1292手冊截圖:

ADS1292可以測量心電信號、呼吸波,LMT70測體溫,二者共性:低功耗,
在eeworld搜索關鍵詞ADS1292:

這里有一篇2020年1月發表的、由TI 專家委員會成員 Haroad Chen 整理提供的問答貼,問答的大部分內容都是關于可穿戴設備的傳感器,其中就接連出現了ADS1292和LMT70,
看到這,題目名稱都呼之欲出了:
(我來猜一個)
低功耗穿戴式人體引數測量儀,
兩個傳感器的特點都是低功耗,那么MSP430基本沒跑了,
這應該算是道測量題,備賽目標:
畫一個ADS1292+LMT70評估板,使用MSP430調通,針對“低功耗、穿戴式”部分做好提前準備,
9.6
找ADS1292相關資料,在考慮是自己畫還是買,去淘寶買了個資料,包含原理圖和STM32驅動程式,參考價值還可以,
接著去TI官網找了找:
多引數患者生命體征監護儀前端參考設計:
https://www.ti.com.cn/cn/lit/ug/zhcu652a/zhcu652a.pdf?ts=1599364363678&ref_url=https%253A%252F%252Fwww.ti.com.cn%252Fsitesearch%252Fcn%252Fdocs%252Funiversalsearch.tsp%253FsearchTerm%253DADS1292
試著找了一下MSP430驅動ADS1292的韌體
開始繪制ADS1292評估板的PCB,計劃硬體部分包含:
ADS1292R心電采集模塊
STM32F103最小系統板
LMT70*2
按鍵、LED、LCD、藍牙
9.10
PCB繪制完成


- ADS1292R心電采集模塊
- STM32F103C8T6最小系統模塊
- LMT70模塊
三個模塊獨立,可以合在一起直接使用,如果要更換MSP430可以直接掰開更換,
9.15
焊接完成(除LMT70),簡單測驗了一下ADS1292部分(之前購買過例程),ADS1292能夠正常識別,
9.20
心電模擬器還沒買,接人體實驗了一下,能夠看到心電波形,效果還不錯,和隊友高興壞了!

藍牙除錯APP顯示的波形

10.7
這中間兩個多周的時間被其他事影響到心態(保研政策變動,成績不是很好的博主提前下車,打算去考研了),
電賽一直沒動,比賽日期臨近,又重新拾起來,電賽是信仰,不能丟,
使用LCD屏顯示出實時波形(圖上的波形來自心電模擬器)

10.8
解決了心率測量,使用心電模擬器可以準確算出心率,
加到人體上測驗了一下,發現跟第一次測驗結果不太一樣,心電波形干擾特別嚴重,出大問題,
圖上紅線是設定的動態閾值,用于檢測R波,計算心率,心率測的倒是很穩,

下午和晚上一直在搜心電波形去除噪聲的解決辦法,
10.9
晚上出題,看了兩三道題,果斷選了A題(無線運動傳感器節點設計):

賽前備賽情況:
ADS1292已調通
已完成模擬器的心電信號LCD顯示和上位機顯示,能夠實作穩定的心率測量(使用心電信號模擬器)
接入人體測驗時,存在基線漂移和肌電信號干擾,開題前暫未得到解決(此前搜過不少相關文獻,處理辦法比較多,但一直沒測驗)
題目下發后,由于沒仔細讀要求,以為心電可以接模擬器測(我們此前使用模擬器的效果非常好),因此覺得第一問的分已經拿到,
第二問是送分題,第三題看起來不難,第四題備賽期間已經實作,
當晚很自信的回宿舍睡覺了,睡前水電賽群的時候,發現心電要接到人體上實測,又開始緊張起來,
波形干擾嚴重,由于此前沒有解決過相關的問題,不能保證5天可以調到很好的效果,
群里有大佬使用FIR帶通濾波器測驗過的,效果很好,交流了一下,當晚將FIR濾波器的相關內容安排給學霸隊友,
10.10
早上安排隊友任務:
隊友A:LMT70標定、解算
隊友B:嘗試FIR濾波解決心電圖的基線漂移和肌電干擾問題,
上午完成陀螺儀(9軸姿態傳感器模塊)的資料讀取,考慮通過加速度進行步數和距離測量(距離是加速的的兩次積分),搜文獻無獲
后在知乎找到大概的方案,首先需要將原始加速度資料變換到地面坐標系中(通過歐拉角解算),動手演算了一下,不簡單…
認真權衡后,放棄上述方案,作業量過大,僅僅加速度變換坐標可能就要花掉整整一天時間,且最終解算出來后加速度資料也不一定滿足測距精度要求,
在實驗室來回走了十多分鐘,觀察走路的運動特征,想到一個可行方案,9軸模塊綁在腿上,通過歐拉角判斷抬腿和落腿動作,計步,然后通過抬腿角度和步數大概推算出運動距離,
晚上7點完成上述方案的計步數部分,效果良好,10點測距完成,效果良好,

下午隊友的LMT70標定完成,測驗效果良好,
晚上隊友的FIR濾波基本移植完成,大概看了一下以后睡了,第二天早上再起來測驗,
FIR帶通濾波器移植參考安富萊的DSP教程:
https://www.stmcu.org.cn/module/forum/thread-601106-1-1.html
10.11
安排任務:
隊友A:LMT70部分設計報告
隊友B:FIR濾波器部分設計報告
上午完成FIR帶通濾波器實際測驗
200階、頻帶:0.5-30 、采樣頻率100HZ
matlab仿真出的濾波器幅頻特性:

測驗效果很好,肌電干擾可以基本濾除,今天給隊友測心電時發現他的未處理的心電圖基本沒有基線漂移,所以實際對于基線漂移的去除效果還未知,后面再測幾次,
濾波前效果:

濾波后效果:

圖中左下角的數字是每采樣10000次的用時(單位ms),可以看到FIR帶通濾波引入的延時是很小的,
中午去縫紉店買了松緊帶和魔術貼,自己縫了一個腿部的綁帶,用來加固腿部的9軸傳感器模塊,使用起來還不錯,

下午寫了寫設計報告,
此前因為已經使用藍牙測驗過上位機,上位機APP是應用市場下載的,界面可以二次開發,從功能指標上來說完全可以滿足要求,
但規則上說需要實作無線上網,藍牙和上網的概念匹不匹配不好說,

目前來看進度不錯,時間也還富余,為保險起見還是改成使用wifi模塊,晚上移植esp8266,
傍晚esp8266 TCP收發調通,
開始寫服務器端上位機,此前使用C#寫過示波器上位機,
這次的心電顯示直接使用winform的chart控制元件就可以方便地實作,除此之外還要搭建TCP服務器,
百度了一下,教程相當豐富,首先使用網上的代碼簡單完成了一個控制臺的服務器,測驗成功,參考博文:
https://www.jianshu.com/p/21bad87504fa

接下來做圖形界面,測驗一下chart控制元件,
搜了幾個chart控制元件的文章測驗了一下,看了一下實作方式,有個缺點:
每次有新的點要畫時,需要擦除頁面所有的點,再重新畫,
用這種方法測驗了一下,資料量一多就重繪不動了,chart控制元件好像不能滿足要求,
之前做過示波器上位機,是直接呼叫C#的畫線、畫點的庫,在視窗直接繪制,嘗試復現這種方法,
寫到凌晨3點多,沒做出來,放棄,睡覺,
10.12
早上起床又搜了幾篇chart控制元件做示波器的博客,找到一篇看起來可行的:
https://blog.csdn.net/ZLK961543260/article/details/80454009?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522160246573519724836704563%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=160246573519724836704563&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allfirst_rank_v2~rank_v28-1-80454009.pc_first_rank_v2_rank_v28&utm_term=C%23%E4%B8%ADchart%E6%8E%A7%E4%BB%B6–%EF%BC%88%E5%BD%93%E6%95%B0%E6%8D%AE%E9%87%8F%E8%BE%83%E5%A4%A7%E6%97%B6%EF%BC%8Cx%E8%BD%B4%E5%87%BA%E7%8E%B0%E6%BB%9A%E5%8A%A8%E6%9D%A1%EF%BC%89&spm=1018.2118.3001.4187
按照上面的博客,示波器效果實作了,重繪速度也滿足要求,但實時收發時,TCP存在拆包粘包現象,一上午又過了,
這還是有經驗能快速定位問題的速度,寫這種上位機就是小問題頗多,走一步百度一步,走不通就得退回去換條路,
中午睡了一覺,起床后思路清晰了一些,一開始以為是chart控制元件效率太低,重繪速度慢導致資料積累,后來發現是TCP本身存在粘包直接導致資料變成一大坨再傳入服務器,波形像一頁一頁ppt匯入,沒有動態重繪的效果,
查到UDP傳輸不存在粘包現象:
https://www.cnblogs.com/xwj517537691/archive/2013/06/05/3118971.html
如果改用UDP傳輸的話,ESP8266部分和服務器基本收發部分都需要重新來,權衡了一下,還是看看TCP透傳有沒有什么解決辦法,之前使用網路除錯助手的時候發現連續發送模式下最小發送周期是50ms,這樣看來是有道理的(防止TCP粘包)
因此發送端發送周期不超過50ms,就可以避免粘包了,雖然周期需要拉長,但實際波形不能變,所以需要設一個快取區間斷發送,
這樣會導致波形的快取區切換處不連續,不過影響不大,
上述改進方案測驗成功,后面又重新測驗了一下不使用快取區,直接實時發送資料,發現TCP粘包現象又消失了,因此在上位機和下位機都設了兩種模式,
一種是實時發送模式,另一種是快取區間斷發送模式,測評時默認為實時發送模式,如果在測評現場出現粘包問題,就改為快取區發送模式,
測驗發現資料重繪跟網速關聯比較大,存在延時,如果間歇性卡頓比較明顯,一樣可以采用之前的快取區發送法,降低資料量,
晚上完成服務器功能(忘了加溫度),

10.13
白天寫了一天設計報告,遇上統一核酸檢測,耽誤了好幾個小時,
下午測驗時發現波形完全沒法看,又重新改了FIR濾波器的引數,
晚上發現是RL導聯線接觸不良引起波形紊亂,實際FIR濾波器效果良好,
此前測量距離的方案是步長*步數,由于現場步確定是否找其他人測驗,步長不可控,因此加入步長校準功能,測距之前先校準:通過按鍵按照界面提示進入校準模式,走5m,系統會自動記錄步數,校準步長 = 5/步數,
由于此前TCP傳輸存在粘包問題,導致波形顯示像放PPT一樣,
使用快取區間斷發送后,雖然波形顯示順暢了,但引入了延時,比賽要求有一項是傳輸時延不能大于1秒,

怕在這栽了跟頭,晚上通宵把服務器改成了UDP協議,
結果發現還是一樣的效果(存在資料堆積),凌晨5點看到螢屏上一卡一卡的波形,宣告一晚上白給,睡覺去了,
10.14
早上爬起來花了1個多小時給PCB做了個外殼(可以搭配腰帶綁在身上),安裝好很精致!



還是很在意題目要求中的延時1s內的問題,由于對TCP粘包做了處理,服務器端的波形顯示并非完全實時,
如果在這一點扣分的話就太冤枉了,
重新想方案:藍牙傳輸不存在粘包問題,如果測評現場對WIFI和藍牙不區分的話,就改用藍牙模塊,
由于TCP和藍牙都是經過串口資料透傳,所以下位機端不需要改動,藍牙和WIFI可以無縫切換,
藍牙模塊在windows上可以映射出虛擬串口:
https://blog.csdn.net/px_528/article/details/70782059
這樣只需在上位機服務器上加入串口模式即可,之前寫過模板,移植很快,
一個小時完成,粘包終于沒了,波形可以實時顯示!!!
服務器的最終樣貌:

設備端的最終樣貌:

做到最后,溫度傳感器反而是最難調的,有的時候相當準,有的時候溫度亂漂,我們也不確定現場到底會怎么樣,在設備上加了溫度補償設定功能,防止現場誤差太大,
10.15
早上第一組測評:
測評表

第一問
連接心電模擬器:
波形 滿分
測量心率 滿分
連接人體:
波形 滿分
測量心率 滿分(老師拿小米手環比照的,資料一模一樣)
第二問測體溫:
滿分(老師測自己手掌,等我們緩過來分都打好了,還挺準的,校準功能沒有用到,萬幸!)
第三問:
測距離:
滿分(我們隊友控制步距控制的太棒了,標準20m,走了兩次,一次20.27m,另一次19.68m)
測步數:
滿分(只要走得慢點,可以百分百識別)
第四問服務器端:
滿分
第五問其他項:
可穿戴、螢屏顯示、WIFI藍牙雙模式自由切換
4分(老師原話:“不能全滿分吧,給4分”)
后面作品會開源出來
包括PCB、設備端程式、服務器程式、檔案
FIR濾波器測驗效果
濾波器階數:200
采樣率100HZ
最低截止頻率Fc1:0.5Hz
最高截至頻率Fc2:40Hz
Fir濾波器仿真幅頻特性:

濾波前心電波形:

測驗濾波后心電波形:

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/176936.html
標籤:其他
上一篇:機器學習案例實操——鳶尾花
下一篇:Python代碼練習
