|
此程序是基于STM32F103 的PT100測(cè)溫程序
充分利用pt100鉑電阻的電阻與溫度的線(xiàn)性 可以直接用串口工具讀出當(dāng)前溫度
1.電流調(diào)試成功
2.電流補(bǔ)償調(diào)試成功
3.PT100程序調(diào)試成功
增加
1.電壓測(cè)試
2.增加結(jié)構(gòu)體
3.增加溫度檢測(cè)
單片機(jī)源程序如下:
- #include "bsp_adc.h"
- #define ADC1_DR_Address ((u32)0x40012400+0x4c)
- __IO uint16_t ADC_ConvertedValue;
- //__IO u16 ADC_ConvertedValueLocal;
- /**
- * @brief 使能ADC1和DMA1的時(shí)鐘,初始化PC.0
- * @param 無(wú)
- * @retval 無(wú)
- */
- static void ADC1_GPIO_Config(void)
- {
- GPIO_InitTypeDef GPIO_InitStructure;
-
- /* Enable DMA clock */
- RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
-
- /* Enable ADC1 and GPIOC clock */
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 | RCC_APB2Periph_GPIOC, ENABLE);
-
- /* Configure PC.0 as analog input */
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
- GPIO_Init(GPIOC, &GPIO_InitStructure); // PC0,輸入時(shí)不用設(shè)置速率
- }
- /**
- * @brief 配置ADC1的工作模式為MDA模式
- * @param 無(wú)
- * @retval 無(wú)
- */
- static void ADC1_Mode_Config(void)
- {
- DMA_InitTypeDef DMA_InitStructure;
- ADC_InitTypeDef ADC_InitStructure;
-
- /* DMA channel1 configuration */
- DMA_DeInit(DMA1_Channel1);
-
- DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address; //ADC地址
- DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&ADC_ConvertedValue; //內(nèi)存地址
- DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
- DMA_InitStructure.DMA_BufferSize = 1;
- DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //外設(shè)地址固定
- DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Disable; //內(nèi)存地址固定
- DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord; //半字
- DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
- DMA_InitStructure.DMA_Mode = DMA_Mode_Circular; //循環(huán)傳輸
- DMA_InitStructure.DMA_Priority = DMA_Priority_High;
- DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
- DMA_Init(DMA1_Channel1, &DMA_InitStructure);
-
- /* Enable DMA channel1 */
- DMA_Cmd(DMA1_Channel1, ENABLE);
-
- /* ADC1 configuration */
- ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; //獨(dú)立ADC模式
- ADC_InitStructure.ADC_ScanConvMode = DISABLE ; //禁止掃描模式,掃描模式用于多通道采集
- ADC_InitStructure.ADC_ContinuousConvMode = ENABLE; //開(kāi)啟連續(xù)轉(zhuǎn)換模式,即不停地進(jìn)行ADC轉(zhuǎn)換
- ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; //不使用外部觸發(fā)轉(zhuǎn)換
- ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; //采集數(shù)據(jù)右對(duì)齊
- ADC_InitStructure.ADC_NbrOfChannel = 1; //要轉(zhuǎn)換的通道數(shù)目1
- ADC_Init(ADC1, &ADC_InitStructure);
-
- /*配置ADC時(shí)鐘,為PCLK2的8分頻,即9MHz*/
- RCC_ADCCLKConfig(RCC_PCLK2_Div8);
- /*配置ADC1的通道11為55. 5個(gè)采樣周期,序列為1 */
- ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 1, ADC_SampleTime_55Cycles5);
-
- /* Enable ADC1 DMA */
- ADC_DMACmd(ADC1, ENABLE);
-
- /* Enable ADC1 */
- ADC_Cmd(ADC1, ENABLE);
-
- /*復(fù)位校準(zhǔn)寄存器 */
- ADC_ResetCalibration(ADC1);
- /*等待校準(zhǔn)寄存器復(fù)位完成 */
- while(ADC_GetResetCalibrationStatus(ADC1));
-
- /* ADC校準(zhǔn) */
- ADC_StartCalibration(ADC1);
- /* 等待校準(zhǔn)完成*/
- while(ADC_GetCalibrationStatus(ADC1));
-
- /* 由于沒(méi)有采用外部觸發(fā),所以使用軟件觸發(fā)ADC轉(zhuǎn)換 */
- ADC_SoftwareStartConvCmd(ADC1, ENABLE);
- }
- /**
- * @brief ADC1初始化
- * @param 無(wú)
- * @retval 無(wú)
- */
- void ADC1_Init(void)
- {
- ADC1_GPIO_Config();
- ADC1_Mode_Config();
- }
- /**
- * @brief 獲取PT100的阻值
- * @param 無(wú)
- * @retval 無(wú)
- */
- float getPT100Value(float AdValue)
- {
- float BaseValue = 2.460;
- float AD623A = 27.3,AD620A = 27.0;
- float R1=1999.0,R2=1999.0,R3=100.0;
- float Rx = 0;
- float Uo = AdValue/AD623A;
- printf("%f\n",Uo);
- Rx = (BaseValue*(R3*R1)+Uo*(R1*R2+R1*R3))/((double)((BaseValue*R2))-(Uo*(R2+R3)));
- return Rx;
- }
- /**
- * @brief 獲取AD的平均值
- * @param 無(wú)
- * @retval 無(wú)
- */
- float getAdcAverage(uint8_t times)
- {
- uint8_t i = 0;
- double temp = 0;
- for(i = 0;i<times;i++)
- {
- temp+=(float) ADC_ConvertedValue/4096*3.3; // 讀取轉(zhuǎn)換的AD值
- }
- return (temp/(float)times);
- }
- /**
- * @brief 獲取PT100溫度值 Rt = Ro(1+A*t+B*t*t)
- * @param 無(wú)
- * @retval 無(wú)
- */
- float getTValue(float PT100Value)
- {
- float A = 0.003940;
- float B = -0.0000005802;
- float C = -0.000000000004274;
-
-
- }
- /*********************************************END OF FILE**********************/
復(fù)制代碼
所有資料51hei提供下載:
PT100測(cè)試程序.rar
(313.64 KB, 下載次數(shù): 417)
2018-10-31 16:30 上傳
點(diǎn)擊文件名下載附件
|
|