chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于CW32的儀表精度測量實現(xiàn)(三):標(biāo)定與校準(zhǔn)

CW32生態(tài)社區(qū) ? 來源:CW32生態(tài)社區(qū) ? 作者:CW32生態(tài)社區(qū) ? 2024-09-02 10:07 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

標(biāo)定的概念

標(biāo)定是一種校準(zhǔn)過程,它通過與已知的標(biāo)準(zhǔn)或參考值進(jìn)行比較來確保測量設(shè)備、儀器或系統(tǒng)的準(zhǔn)確性和可靠性。這個過程涉及調(diào)整設(shè)備,以消除系統(tǒng)誤差和提高測量結(jié)果與真實值的一致性,從而確保數(shù)據(jù)的精確度和可重復(fù)性。

1.為什么去標(biāo)定

我們使用單片機(jī)ADC讀取的電壓電流值由于制造公差、溫度變化、時間老化、電源波動等因素引起的初始誤差和漂移,我們需要對電壓電流進(jìn)行標(biāo)定校準(zhǔn),使得我們得到的電壓電流值是正確的。

2.標(biāo)定的方法

標(biāo)定的方法多種多樣,我們需要根據(jù)自己的需求來選擇相應(yīng)的方法,常見的標(biāo)定方法如下所示:

(1)直接比較法:

將待標(biāo)定的測量設(shè)備與一個已知準(zhǔn)確度的標(biāo)準(zhǔn)設(shè)備進(jìn)行比較,直接讀取并記錄差異。

(2)多點標(biāo)定法:在多個已知的標(biāo)準(zhǔn)點上進(jìn)行測量,收集數(shù)據(jù)點,然后通過數(shù)學(xué)模型(如多項式擬合)來確定設(shè)備輸出與標(biāo)準(zhǔn)值之間的關(guān)系。(3)線性回歸法:使用最小二乘法等統(tǒng)計技術(shù),通過擬合最佳擬合線來確定設(shè)備輸出與標(biāo)準(zhǔn)輸入值之間的線性關(guān)系。(4)分段線性標(biāo)定:當(dāng)測量設(shè)備的響應(yīng)在不同輸入范圍內(nèi)呈現(xiàn)不同的線性度時,可以采用分段線性標(biāo)定,即在不同的輸入范圍內(nèi)使用不同的線性模型。

(5)非線性標(biāo)定:

對于非線性設(shè)備,使用非線性函數(shù)(如指數(shù)、對數(shù)或S形曲線)來描述輸入與輸出之間的關(guān)系。

標(biāo)定的實現(xiàn)

1.CW32開發(fā)板的實物圖和原理圖

wKgZombRpWeAaSMEAABpnBq-Jys92.webp

wKgaombRpWiAUdKPAACQegNOZ1A90.webp

2.軟件代碼講解

(1)濾波算法在做電壓值的校準(zhǔn)之前,我們根據(jù)傳感器采集到的是連續(xù)性的時間序列信號,所以我們可以采用了均值濾波對單片機(jī)采集到的AD值進(jìn)行濾波處理。在程序中我首先初始化總和、最大值和最小值變量,然后在一個循環(huán)中累加數(shù)組 value 中所有元素的值,并同時更新最大值和最小值。循環(huán)結(jié)束后,從總和中減去最大值和最小值,以排除可能的異常數(shù)據(jù)點,最后將調(diào)整后的總和除以數(shù)組元素數(shù)減去2,得到并返回一個濾除極端值后的均值。這種方法有助于減少數(shù)據(jù)中的噪聲,特別是當(dāng)數(shù)據(jù)集中包含異常高值或低值時。代碼如下所示:

uint32_t Mean_Value_Filter(uint16_t *value, uint32_t size) //均值濾波 { uint32_t sum = 0; //ADC采樣數(shù)據(jù)和 uint16_t max = 0; uint16_t min = 0xffff; //min初值取最大是為了將第一個數(shù)據(jù)記錄 int i; for(i = 0; i < size; i++) { sum += value[i]; if(value[i] > max) { max = value[i]; } if(value[i] < min) { min = value[i]; } } sum -= max + min; //去除最大最小值 sum = sum / (size - 2); return sum; }

(2)分段線性標(biāo)定

在代碼中定義了電壓校準(zhǔn)的相關(guān)變量X06和X12,分別代表著6V對應(yīng)的AD代碼值和12V對應(yīng)的AD代碼值。其中還定義了縱坐標(biāo)的變量Y06和Y12,這個對應(yīng)著電壓值6V和12V。最后定義了坐標(biāo)軸的斜率K,如下所示:

//5V與15V 校準(zhǔn) unsigned int X06=0; unsigned int X12=0; unsigned int Y06=6; unsigned int Y12=12; float K; //斜率

在標(biāo)定校準(zhǔn)之前,我們需要計算斜率,根據(jù)兩點確定一條直線算出該區(qū)間內(nèi)的斜率K,如下圖所示:

void Count_K(void) { K = (Y12 - Y06); K = K/(X12 - X06); }

我們還需要存儲校準(zhǔn)值,我們在一個數(shù)組中存了三個數(shù)據(jù),第一個數(shù)據(jù)是判斷位(0xaa),判斷當(dāng)前是否存儲過校準(zhǔn)值。其中兩個是6V對應(yīng)的AD代碼值和12V對應(yīng)的AD代碼值。存儲之前需要擦除然后才能寫入數(shù)據(jù)。代碼如下所示:

void flash_calibration(void) { uint16_t dat[5]; dat[0]=0xaa; dat[1]=X06; dat[2]=X12; flash_erase(); flash_write(0,dat,5); }

我們除了寫入校準(zhǔn)值還要讀取校準(zhǔn)值,先讀取校準(zhǔn)值,判斷第一個數(shù)據(jù)是否為0xaa,如果不是0xaa,代表沒校準(zhǔn)過,需要賦一個初始化進(jìn)行存儲。例如

X06 = 6.0/23/1.5*4096;如果第一個值是0xaa,那就可以把存儲過的值賦給我們的變量就可以了,代碼如下所示。

void judge_calibration(void) { uint16_t dat[5]; flash_read(0,dat, 5); if(dat[0]!=0xaa) { X06 = 6.0/23/1.5*4096; X12 = 12.0/23/1.5*4096; flash_calibration(); } else { X06=dat[1]; X12=dat[2]; } }

我們可以通過按鍵對每一個區(qū)間的信號進(jìn)行校準(zhǔn),比如說我們這次校準(zhǔn)的是6~12V區(qū)間內(nèi)的信號,初始化時可以通過按下一次按鍵對6V時候的數(shù)據(jù)校準(zhǔn),再按一次按鍵就可以對12V時候的數(shù)據(jù)校準(zhǔn),代碼如下所示:

void button_select_calibration(void) { if(GPIO_ReadPin(CW_GPIOB,GPIO_PIN_12) == GPIO_Pin_RESET)//按鍵按下 { mode++; if(mode >2) mode =0; while(GPIO_ReadPin(CW_GPIOB,GPIO_PIN_12) == GPIO_Pin_RESET); } if(mode == 0) { DisPlay_dianya(V_Buffer); } else if(mode == 1) { X06=Mean_Value_Filter(Volt_Buffer,ADC_SAMPLE_SIZE); flash_calibration(); Count_K(); Volt_Cal(); DisPlay_dianya(V_Buffer); } else if(mode == 2) { X12=Mean_Value_Filter(Volt_Buffer,ADC_SAMPLE_SIZE); flash_calibration(); Count_K(); Volt_Cal(); DisPlay_dianya(V_Buffer); } }

3.分段線性標(biāo)定分析和處理

在這個程序中,我們的思想是同時兩路AD采集,一個是測量電壓的,一個是測量電流的,同時讀取AD數(shù)據(jù),進(jìn)而能對二者一起校準(zhǔn)。代碼如下所示:

void Get_ADC_Value(void) { static uint8_t cnt; ADC_GetSqr0Result(&Volt_Buffer[cnt]); ADC_GetSqr3Result(&Curr_Buffer[cnt]); cnt++; if(cnt >= ADC_SAMPLE_SIZE) { cnt = 0; } }

我們在電壓電流表上測量了大量的數(shù)據(jù),如下圖所示:

wKgZombRpWiAWf-8AABvboEyiB421.webp

在上面圖中可以看出實際的電壓值和測量的電壓值存在一定的偏差,我們將它們的偏差值做成一個折線圖給大家看看,如下圖所示。

wKgaombRpWiAfqYBAAAf1kr476M66.webp

常見標(biāo)定的原理是:使用AD值作為X軸,電壓(電流)值作為Y軸;在電壓(電流)為0的時候標(biāo)定為Xmin,在電壓(電流)為最大量程的時候標(biāo)定為Xmax,根據(jù)數(shù)學(xué)公式兩點確定一條直線,可以得到這條直線的斜率K。根據(jù)Y=kx公式我們可以通過輸出每一個AD值得到對應(yīng)的電壓(電流)值。

wKgZombRpWmALqB1AAAUUga_egI43.webp

常見的標(biāo)定是在只有最小值和最大值之間做了標(biāo)定,如果這兩個值的范圍很大,使用中間的AD值也會出現(xiàn)誤差,所以我們就需要多做幾組標(biāo)定,使得數(shù)據(jù)更加準(zhǔn)確,這樣就形成了分段線性標(biāo)定。效果圖如下所示。

wKgaombRpWmAWHArAAASTNoL9KU43.webp

如果我們求X3到X2之間的電壓值,可以根據(jù)公式:Y=k×(Xad-X2)+5得到準(zhǔn)確的電壓值,在這條折線上標(biāo)的點越多,測量得到的電壓值就越準(zhǔn)確。

4.標(biāo)定的結(jié)果

標(biāo)定之前的實驗數(shù)據(jù)顯示,誤差在0.08V左右,數(shù)據(jù)如下所示:

wKgZombRpWiAWf-8AABvboEyiB421.webp

誤差的折線圖如下所示:

wKgZombRpWqABpTmAAAlwsAN6x428.webp

實物的測量圖顯示誤差在0.08左右,結(jié)果如下所示:

wKgaombRpWqAGX3zAABpQrAkGv819.webp

在6V標(biāo)定之后實驗數(shù)據(jù)顯示誤差在0.01V左右,數(shù)據(jù)如下所示:

wKgZombRpWqAQ8LMAABY5pnoZwo77.webp

標(biāo)定校準(zhǔn)后的誤差的折線圖如下所示,可以看出6V標(biāo)定后的誤差范圍在0V到0.03V之間的,所以證明了多處標(biāo)定,得到的測量值就越精確。

wKgaombRpWuAQBLZAAA4zBrY1Y483.webp

經(jīng)過標(biāo)定校準(zhǔn)后的電壓顯示沒有誤差,結(jié)果如下所示:

wKgZombRpWuABqhBAABkziS0Y7094.webp



審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 精度測量
    +關(guān)注

    關(guān)注

    0

    文章

    8

    瀏覽量

    8389
  • CW32
    +關(guān)注

    關(guān)注

    1

    文章

    299

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    CW32抗干擾能力有多強(qiáng)?

    CW32系列產(chǎn)品已通過第方權(quán)威機(jī)構(gòu)蘇軾宜特的測試認(rèn)證,HBM ESD、MM ESD、CDM ESD、Latch up@105℃全面達(dá)到JEDEC最高等級。
    發(fā)表于 01-13 07:41

    CW32仿真器是什么?

    CW32仿真器是什么
    發(fā)表于 01-05 08:04

    使用 CW32 實現(xiàn)電池備份(VBAT)功能

    檔介紹了如何CW32基于 CW32 系列 MCU,通過增加簡單的外部電路配合軟件實現(xiàn) VBAT 功能,在系統(tǒng)電源掉 電后仍能保持 RTC 時鐘正常計時,以及如何降低系統(tǒng)功耗,從而延長后備電池的使用壽命
    發(fā)表于 01-04 06:34

    請問CW32芯片的種工作模式是什么?

    CW32芯片的種工作模式是什么?
    發(fā)表于 12-26 06:48

    CW32單片機(jī)如何讓生活更便捷

    這是一種全新的生活方式,它通過接收并處理傳感器的數(shù)據(jù),以控制智能馬桶的所有功能。感謝CW32單片機(jī),我們可以在日常生活中無縫地融入這種新的科技。 決定我們?nèi)绾紊畹?,已?jīng)不再只是我們的選擇,更是我們
    發(fā)表于 12-11 06:11

    CW32時鐘運(yùn)行中失效檢測的流程是什么?CW32時鐘運(yùn)行中失效檢測注意事項有哪些呢?

    CW32時鐘運(yùn)行中失效檢測的流程是什么?CW32時鐘運(yùn)行中失效檢測注意事項有哪些?
    發(fā)表于 12-10 07:22

    可以使用CW32的ChirpIOT來實現(xiàn)芯片固件升級嗎

    可以使用CW32的ChirpIOT來實現(xiàn)芯片固件升級嗎?這種升級每包有限制嗎?一般是多少,可以實現(xiàn)組網(wǎng)內(nèi)的所有設(shè)備同時這種升級嗎?
    發(fā)表于 12-05 06:51

    基于芯源CW32 MCU的LED閃爍示例及代碼分析

    準(zhǔn)備: 芯源CW32開發(fā)板 一個LED 電阻及基礎(chǔ)連接線 開發(fā)環(huán)境:我使用的是Keil作為開發(fā)環(huán)境,同時利用官方提供的CW32庫函數(shù),這使得代碼更加簡潔清晰。 代碼實現(xiàn):這段代碼實現(xiàn)
    發(fā)表于 12-04 06:52

    CW32 MCU溫度監(jiān)測應(yīng)用

    最近,我在項目中使用CW32 MCU,來實現(xiàn)一個簡單的溫度監(jiān)測系統(tǒng)。CW32的靈活性和性能讓我在這個應(yīng)用中得心應(yīng)手。以下是我的實現(xiàn)過程和代碼示例。 應(yīng)用簡介本項目通過連接一個溫度傳感器
    發(fā)表于 12-03 08:03

    cw32 systick怎么用?

    cw32 systick怎么用
    發(fā)表于 12-01 08:10

    CW32 MCU用什么IDE開發(fā)?

    推薦使用IAR Embedded Workbench for ARM、Keil μVision for ARM等IDE開發(fā)CW32 MCU應(yīng)用,其中新版本IAR EWARM直接支持CW32 MCU,Keil MDK-ARM則需要安裝CW
    發(fā)表于 11-12 07:52

    CW32 MCU有哪些系列?

    目前CW32 MCU有通用高性能MCU、安全低功耗MCU、無線射頻MCU等3個系列。其中射頻MCU集成了無線收發(fā)器,主要包括CW32R031(2.4GHz BLE-Lite)系列和CW32W031(Sub-1G)系列。
    發(fā)表于 11-12 07:34

    CW32 MCU用什么仿真器開發(fā)?

    理論上各主流IDE枚舉的、支持ARM Cortex內(nèi)核的所有硬件仿真器,比如:J-LINK,ULINK,DAP,ST-Link等,都可以仿真、下載CW32 MCU的應(yīng)用代碼。如果想實現(xiàn)量產(chǎn)或者離線下載應(yīng)用代碼,則必須配套支持CW32
    發(fā)表于 11-12 06:01

    如何校準(zhǔn)坐標(biāo)測量機(jī)精度

    校準(zhǔn)坐標(biāo)測量機(jī)精度是確保其測量準(zhǔn)確性的重要環(huán)節(jié),通常可通過以下步驟進(jìn)行:1、日常校準(zhǔn)(簡單
    發(fā)表于 03-21 11:34 ?0次下載

    如何校準(zhǔn)坐標(biāo)測量機(jī)精度

    校準(zhǔn)坐標(biāo)測量機(jī)精度是確保其測量準(zhǔn)確性的重要環(huán)節(jié),通??赏ㄟ^以下步驟進(jìn)行:1、日常校準(zhǔn)(簡單
    的頭像 發(fā)表于 03-20 16:11 ?1332次閱讀
    如何<b class='flag-5'>校準(zhǔn)</b><b class='flag-5'>三</b>坐標(biāo)<b class='flag-5'>測量</b>機(jī)<b class='flag-5'>精度</b>