国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

RT-Thread驅動篇:hwtimer重載值算法

RTThread物聯網操作系統 ? 來源:RTThread物聯網操作系統 ? 作者:RTThread物聯網操作 ? 2022-04-01 10:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

硬件定時器

區別于 rt-thread 內核實現的兩種定時器,這種定時器依賴芯片內置的定時器外設,依靠穩定高速的晶振實現精確定時,可以實現 rt_timer 無法達到的定時精度。硬件定時器最重要的兩個參數是定時器時鐘和定時器重載值。

定時器時鐘越高,定時器精度越高;重載值越大,實現的定時時間越長。

在定時器時鐘一定的前提下,重載值就決定了定時器定時時間的準確性。

兩種計算重載值算法

hwtimer.c 文件timeout_calc函數實現

 1floatoverflow;
 2floattimeout;
 3rt_uint32_tcounter;
 4inti,index=0;
 5floattv_sec;
 6floatdevi_min=1;
 7floatdevi;
 8
 9/*changedtosecond*/
10overflow=timer->maxcnt/(float)timer->freq;
11tv_sec=tv->sec+tv->usec/(float)1000000;
12
13if(tv_sec1/(float)timer->freq))
14{
15/*littletimeout*/
16i=0;
17timeout=1/(float)timer->freq;
18}
19else
20{
21for(i=1;i>0;i++)
22{
23timeout=tv_sec/i;
24
25if(timeout<=?overflow)
26{
27counter=timeout*timer->freq;
28devi=tv_sec-(counter/(float)timer->freq)*i;
29/*Minimumcalculationerror*/
30if(devi>devi_min)
31{
32i=index;
33timeout=tv_sec/i;
34break;
35}
36elseif(devi==0)
37{
38break;
39}
40elseif(devi41{
42devi_min=devi;
43index=i;
44}
45}
46}
47}
48
49timer->cycles=i;
50timer->reload=i;
51timer->period_sec=timeout;
52counter=timeout*timer->freq;
53
54returncounter;

第二種實現,

 1rt_uint32_tcounter,reload;
 2rt_uint32_ttimer_cnt;
 3inti,index=0,n0,n1;
 4floattv_sec;
 5rt_uint32_tdev,dev_min;
 6
 7/*changedtosecond*/
 8tv_sec=tv->sec+tv->usec/(float)1000000.0;
 9timer_cnt=tv_sec*timer->freq;
10
11if(timer_cnt==0){
12timer_cnt=1;
13}
14if(timer_cntmaxcnt){
15timer->cycles=timer->reload=1;
16timer->period_sec=tv_sec;
17counter=timer_cnt;
18returncounter;
19}
20if(timer_cnt%timer->maxcnt==0){
21timer->cycles=timer->reload=timer_cnt/timer->maxcnt;
22timer->period_sec=tv_sec;
23counter=timer_cnt;
24returncounter;
25}
26n0=timer_cnt/timer->maxcnt+1;
27n1=timer_cnt/2;
28dev_min=n0;
29for(i=n0;i30reload=(rt_uint32_t)(timer_cnt/i);
31dev=timer_cnt-reload*i;
32if(dev==0){
33//end
34index=i;
35break;
36}elseif(dev37dev_min=dev;
38index=i;
39}
40}
41timer->cycles=timer->reload=index;
42timer->period_sec=index/timer->freq;
43counter=timer_cnt/index;
44returncounter;

測試環境

定時器頻率設定 1M。定時器最大重載值 65535。

系統:win10

IDE:Qt Creator

最大定時范圍

兩種算法,最主要的差別在于前一種用 float 運算,因為 float 可以表達的值范圍更大,定時時間可以更長。

而在 1M 定時器時鐘前提下,用 32 位無符號整型 timer_cnt,最大可以處理時間僅有 4294.967295s。

精度 PK

5bb68cf0-b15d-11ec-aa7f-dac502259ad0.jpg

這里不支持嵌入 html 表格,只好貼圖了

分別選各個量級的時間,用兩種算法計算,第二種算法可以把誤差降低到0,但是也暴露出一些問題,在某些時間,例如 3.230970s、12.230970s、14.230970s... 誤差是很小,定時器重載值也很小,這是我們不愿意看到的。

第一種算法,在計算大于 1000 的數時,誤差也隨之增大。比如 1000s 誤差為 3.236ms;4293.0s 誤差為 64.080ms。

運算速度

測試方法:抽取某幾個時間值,循環 1M 次運算,計量 1M 次運算總耗時時間。

5bcaf226-b15d-11ec-aa7f-dac502259ad0.png

從抽取的幾個值測試結果看,第一種算法耗時比較穩定,第二種算法對不同值的運算時間差異很大。特別的,3.317s 這個值用第二種算法,1M 次運算總耗時時間可能達到 3000s。

從上一小節的精度比對可以看出,第二種算法對精度要求太高了。下面降低第二種算法的精度,達到和第一種一樣的精度再重復一次。修改代碼如下

 1if(dev==0){
 2//end
 3index=i;
 4break;
 5}elseif(dev>dev_min){
 6break;
 7}elseif(dev 8dev_min=dev;
 9index=i;
10}

再次測試結果:

5bdeafc8-b15d-11ec-aa7f-dac502259ad0.png

我們可以看出來,在相同精度條件下,第二種算法的運算速度比第一種快很多,而且耗時反而變得更集中。

其實,對結束條件再次修正,將dev == 0的嚴苛誤差條件換成dev <= 1也不會出現上面 3000+s 慢速。

 1if(dev<=?1){
 2//end
 3index=i;
 4break;
 5}elseif(dev>dev_min){
 6break;
 7}elseif(dev 8dev_min=dev;
 9index=i;
10}

超過 4295s 的超長定時

需要修改rt_uint64_t timer_cnt的定義為 64 位無符號整型rt_uint64_t timer_cnt

又因為定時時間很長很長,對誤差要求可以降低一些,對第二種算法做的第二處修改:

1if(dev<=?500){
2//end
3index=i;
4break;
5}elseif(dev6dev_min=dev;
7index=i;
8}

5bee09be-b15d-11ec-aa7f-dac502259ad0.png

超長時間,第二種算法的表現也很優秀。第三組數據第一種方法竟然出錯了,沒算出結果。

下面是 10k 次(沒有進行 1W 次是因為有些時間太長了)運算時間統計

5c062dd2-b15d-11ec-aa7f-dac502259ad0.png

返璞歸真

以上是對兩種算法從不同角度進行的比對測驗。看似用 float 可以計算更大的定時數,但是,測試結果并不那么理想。使用 64位整型數計算,可能得到比用 float 更精確的結果。

使用 32 位無符號整型數運算雖然最大定時時間只有 4294.9s 。但是我們也看到了,第一種方法有可能出現計算誤差的,當誤差超過 1ms 我們用 rt_thread_mdelay 或者 rt-thread 的軟/硬定時器,可能結果比硬件定時器更精確了,反而失去了精確定時器的意義。在這個前提下,使用 32 位無符號整型數已經足夠了。

算法及測試源碼見:

https://gitee.com/thewon/rt_thread_repo/tree/master/user

審核編輯 :李倩


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 算法
    +關注

    關注

    23

    文章

    4784

    瀏覽量

    98038
  • 定時器
    +關注

    關注

    23

    文章

    3368

    瀏覽量

    123584
  • RT-Thread
    +關注

    關注

    32

    文章

    1613

    瀏覽量

    44820

原文標題:RT-Thread 驅動篇 之 hwtimer 重載值算法

文章出處:【微信號:RTThread,微信公眾號:RTThread物聯網操作系統】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    恩智浦亮相RT-Thread 20周年開發者大會

    日前,“開源向實·生產力進化啟示錄”全球峰會暨RT-Thread 20周年開發者大會在上海成功舉辦,恩智浦作為RT-Thread的緊密合作伙伴,在活動中重磅亮相,展示雙方在共建RT-Thread OS開發生態方面的新成果、新方案
    的頭像 發表于 01-26 09:07 ?548次閱讀

    基于RT-Thread和兆易創新GD32F527系列MCU的健康監測站 | 技術集結

    本項目為RT-Thread嵌入式大賽獲獎作品,基于RT-Thread和兆易創新GD32F527I-EVAL的健康監測站。目錄項目概述系統硬件框架結構基礎驅動程序實現整體驅動實現工程效果
    的頭像 發表于 01-20 17:37 ?3918次閱讀
    基于<b class='flag-5'>RT-Thread</b>和兆易創新GD32F527系列MCU的健康監測站 | 技術集結

    首搭RT-Thread程翧車控平臺| RT-Thread程翧 S32K344 快速原型開發平臺正式上市!| 產品動態

    在智能汽車邁向高集成與高安全的時代,VCU/ECU開發正面臨效率與可靠性的雙重考驗。依賴單一硬件或拼湊軟件方案的傳統模式,已成為制約創新的瓶頸。為此,RT-Thread帶來里程碑式的解決方案
    的頭像 發表于 10-31 11:53 ?991次閱讀
    首搭<b class='flag-5'>RT-Thread</b>程翧車控平臺| <b class='flag-5'>RT-Thread</b>程翧 S32K344 快速原型開發平臺正式上市!| 產品動態

    基于RT-Thread的EK-RA2E2 設備驅動移植與應用 | 技術集結

    目錄前言環境配置HelloRT-ThreadGPIO輸入與中斷I2C主機驅動SPI主機驅動ADC設備驅動PWM設備驅動Flash設備驅動WD
    的頭像 發表于 10-05 10:06 ?6161次閱讀
    基于<b class='flag-5'>RT-Thread</b>的EK-RA2E2 設備<b class='flag-5'>驅動</b>移植與應用 | 技術集結

    2025年RT-Thread開發者巡回培訓報名正式啟動!

    親愛的RT-Thread社區成員們:新程再啟,共赴熱愛!2025年RT-Thread開發者巡回培訓正式啟動報名!今年,我們選擇了西安、武漢、北京、杭州、深圳、上海、成都這7座城市,為大家帶來
    的頭像 發表于 09-27 10:39 ?1962次閱讀
    2025年<b class='flag-5'>RT-Thread</b>開發者巡回培訓報名正式啟動!

    使用RT-Thread studio 開發RT-Thread Nano項目的時候 串口的驅動是要自己寫嗎?

    剛入坑。使用RT-Thread studio 開發RT-Thread 標準板項目的時候直接使用里邊的串口uart_dev=rt_device_find(“uart5”);然后操作設備,在開發R
    發表于 09-26 08:14

    rt-thread studio 2.2.9如何使用最新的RT-Thread v5.2.0 released?

    rt-thread studio2.2.9如何使用最新的RT-Thread v5.2.0 released? 原先以為修改index_all.json,發現聯網的時候,會自動覆蓋 另lastet版本
    發表于 09-16 06:06

    明晚!基于RT-Thread 的 PID 控制實踐,從驅動算法到監控,一次學會!| 問學直播

    RT-Thread簡單PID控制實踐》精彩直播!本次直播將基于RT-Thread實時操作系統與NXPFRDM-MCXA156開發板,圍繞驅動配置、控制算法實現、遠
    的頭像 發表于 09-01 17:04 ?1317次閱讀
    明晚!基于<b class='flag-5'>RT-Thread</b> 的 PID 控制實踐,從<b class='flag-5'>驅動</b>到<b class='flag-5'>算法</b>到監控,一次學會!| 問學直播

    【好書推薦】RT-Thread第20本相關書籍!《嵌入式實時操作系統RT-Thread原理與應用》| 技術集結

    01內容簡介ContentSummary本書為讀者提供了一個全面、系統的RT-Thread學習指南,旨在幫助初學者及有經驗的開發者掌握RT-Thread實時操作系統和STM32嵌入式微控制器的核心
    的頭像 發表于 08-24 10:05 ?1017次閱讀
    【好書推薦】<b class='flag-5'>RT-Thread</b>第20本相關書籍!《嵌入式實時操作系統<b class='flag-5'>RT-Thread</b>原理與應用》| 技術集結

    RT-Thread Nano硬核移植指南:手把手實現VGLite圖形驅動適配 | 技術集結

    VGLite是NXP提供的輕量級2D圖形API,本文將手把手帶你實現VGLite圖形驅動適配RT-Thread。文章分為上、下兩,將手把手教您移植。上篇對RT-ThreadNano內
    的頭像 發表于 07-17 14:40 ?3388次閱讀
    <b class='flag-5'>RT-Thread</b> Nano硬核移植指南:手把手實現VGLite圖形<b class='flag-5'>驅動</b>適配 | 技術集結

    用SPI玩轉WiFi,RT-Thread ESP-Hosted驅動深度適配指南 | 技術集結

    還在為MCU的WiFi連接方案發愁?RT-Thread社區開源ESP-Hosted驅動,通過標準SPI接口即可實現,并且該倉庫已整理成RT-Thread軟件包。RT
    的頭像 發表于 07-09 19:03 ?1648次閱讀
    用SPI玩轉WiFi,<b class='flag-5'>RT-Thread</b> ESP-Hosted<b class='flag-5'>驅動</b>深度適配指南 | 技術集結

    RT-Thread榮獲2025優秀開源項目 | 新聞速遞

    貢獻,榮獲年度“優秀開源項目獎”。RT-Thread睿賽德榮獲2025優秀開源項目獎目前,開源已從軟件領域延展至硬件、數據、算法、標準、內容等多領域。作為國內開源
    的頭像 發表于 07-04 09:04 ?2640次閱讀
    <b class='flag-5'>RT-Thread</b>榮獲2025優秀開源項目 | 新聞速遞

    深度剖析 RT-Thread 線程調度流程

    RT-Thread調度第一個線程的主要流程分如下:rtthread_startup:RTT的啟動函數,主要負責板級驅動,調度器,系統線程初始化,啟動調度的工作
    的頭像 發表于 06-25 18:24 ?1766次閱讀
    深度剖析 <b class='flag-5'>RT-Thread</b> 線程調度流程

    揭秘RT-Thread上的AUTOSAR CP系統

    本文探討了RT-Thread與AUTOSARCP的融合,解決車載ECU開發中實時性、安全性與靈活性的平衡問題。通過分層安全內核(rt-safetyos/autoos)和工具鏈整合,兼容AUTOSAR
    的頭像 發表于 06-23 20:22 ?3218次閱讀
    揭秘<b class='flag-5'>RT-Thread</b>上的AUTOSAR CP系統

    RT-Thread審核團招募: 深度參與開源RTOS社區治理與演進

    全球開發者招募:RT-Thread審核團(ReviewTeam)正式開放申請!在開源的世界里,代碼審查(CodeReview)是保證軟件質量、促進技術交流的關鍵環節。RT-Thread作為全球領先
    的頭像 發表于 05-21 18:02 ?1254次閱讀
    <b class='flag-5'>RT-Thread</b>審核團招募: 深度參與開源RTOS社區治理與演進