找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 12608|回復(fù): 11
打印 上一主題 下一主題
收起左側(cè)

基于stm32f103的PT100測(cè)溫源程序有問(wèn)題

  [復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:417178 發(fā)表于 2018-10-29 12:27 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
此程序是基于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ī)源程序如下:
  1. #include "bsp_adc.h"

  2. #define ADC1_DR_Address    ((u32)0x40012400+0x4c)

  3. __IO uint16_t ADC_ConvertedValue;
  4. //__IO u16 ADC_ConvertedValueLocal;

  5. /**
  6.   * @brief  使能ADC1和DMA1的時(shí)鐘,初始化PC.0
  7.   * @param  無(wú)
  8.   * @retval 無(wú)
  9.   */
  10. static void ADC1_GPIO_Config(void)
  11. {
  12.         GPIO_InitTypeDef GPIO_InitStructure;
  13.         
  14.         /* Enable DMA clock */
  15.         RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
  16.         
  17.         /* Enable ADC1 and GPIOC clock */
  18.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 | RCC_APB2Periph_GPIOC, ENABLE);
  19.         
  20.         /* Configure PC.0  as analog input */
  21.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
  22.         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
  23.         GPIO_Init(GPIOC, &GPIO_InitStructure);                                // PC0,輸入時(shí)不用設(shè)置速率
  24. }

  25. /**
  26.   * @brief  配置ADC1的工作模式為MDA模式
  27.   * @param  無(wú)
  28.   * @retval 無(wú)
  29.   */
  30. static void ADC1_Mode_Config(void)
  31. {
  32.         DMA_InitTypeDef DMA_InitStructure;
  33.         ADC_InitTypeDef ADC_InitStructure;
  34.         
  35.         /* DMA channel1 configuration */
  36.         DMA_DeInit(DMA1_Channel1);
  37.         
  38.         DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address;                                 //ADC地址
  39.         DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&ADC_ConvertedValue;        //內(nèi)存地址
  40.         DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
  41.         DMA_InitStructure.DMA_BufferSize = 1;
  42.         DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;        //外設(shè)地址固定
  43.         DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Disable;                                  //內(nèi)存地址固定
  44.         DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;        //半字
  45.         DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
  46.         DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;                                                                                //循環(huán)傳輸
  47.         DMA_InitStructure.DMA_Priority = DMA_Priority_High;
  48.         DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
  49.         DMA_Init(DMA1_Channel1, &DMA_InitStructure);
  50.         
  51.         /* Enable DMA channel1 */
  52.         DMA_Cmd(DMA1_Channel1, ENABLE);
  53.         
  54.         /* ADC1 configuration */        
  55.         ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;                        //獨(dú)立ADC模式
  56.         ADC_InitStructure.ADC_ScanConvMode = DISABLE ;                                          //禁止掃描模式,掃描模式用于多通道采集
  57.         ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;                        //開(kāi)啟連續(xù)轉(zhuǎn)換模式,即不停地進(jìn)行ADC轉(zhuǎn)換
  58.         ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;        //不使用外部觸發(fā)轉(zhuǎn)換
  59.         ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;         //采集數(shù)據(jù)右對(duì)齊
  60.         ADC_InitStructure.ADC_NbrOfChannel = 1;                                                                         //要轉(zhuǎn)換的通道數(shù)目1
  61.         ADC_Init(ADC1, &ADC_InitStructure);
  62.         
  63.         /*配置ADC時(shí)鐘,為PCLK2的8分頻,即9MHz*/
  64.         RCC_ADCCLKConfig(RCC_PCLK2_Div8);
  65.         /*配置ADC1的通道11為55.        5個(gè)采樣周期,序列為1 */
  66.         ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 1, ADC_SampleTime_55Cycles5);
  67.         
  68.         /* Enable ADC1 DMA */
  69.         ADC_DMACmd(ADC1, ENABLE);
  70.         
  71.         /* Enable ADC1 */
  72.         ADC_Cmd(ADC1, ENABLE);
  73.         
  74.         /*復(fù)位校準(zhǔn)寄存器 */   
  75.         ADC_ResetCalibration(ADC1);
  76.         /*等待校準(zhǔn)寄存器復(fù)位完成 */
  77.         while(ADC_GetResetCalibrationStatus(ADC1));
  78.         
  79.         /* ADC校準(zhǔn) */
  80.         ADC_StartCalibration(ADC1);
  81.         /* 等待校準(zhǔn)完成*/
  82.         while(ADC_GetCalibrationStatus(ADC1));
  83.         
  84.         /* 由于沒(méi)有采用外部觸發(fā),所以使用軟件觸發(fā)ADC轉(zhuǎn)換 */
  85.         ADC_SoftwareStartConvCmd(ADC1, ENABLE);
  86. }

  87. /**
  88.   * @brief  ADC1初始化
  89.   * @param  無(wú)
  90.   * @retval 無(wú)
  91.   */
  92. void ADC1_Init(void)
  93. {
  94.         ADC1_GPIO_Config();
  95.         ADC1_Mode_Config();
  96. }

  97. /**
  98.   * @brief  獲取PT100的阻值
  99.   * @param  無(wú)
  100.   * @retval 無(wú)
  101.   */
  102. float getPT100Value(float AdValue)
  103. {
  104.         float BaseValue = 2.460;
  105.         float AD623A = 27.3,AD620A = 27.0;
  106.         float R1=1999.0,R2=1999.0,R3=100.0;
  107.         float Rx = 0;
  108.         float Uo = AdValue/AD623A;
  109.         printf("%f\n",Uo);
  110.         Rx = (BaseValue*(R3*R1)+Uo*(R1*R2+R1*R3))/((double)((BaseValue*R2))-(Uo*(R2+R3)));
  111.         return Rx;
  112. }

  113. /**
  114.   * @brief  獲取AD的平均值
  115.   * @param  無(wú)
  116.   * @retval 無(wú)
  117.   */
  118. float getAdcAverage(uint8_t times)
  119. {
  120.                 uint8_t i = 0;
  121.                 double temp = 0;
  122.         for(i = 0;i<times;i++)
  123.         {
  124.                 temp+=(float) ADC_ConvertedValue/4096*3.3; // 讀取轉(zhuǎn)換的AD值               
  125.         }
  126.         return (temp/(float)times);
  127. }

  128. /**
  129.   * @brief  獲取PT100溫度值 Rt = Ro(1+A*t+B*t*t)
  130.   * @param  無(wú)
  131.   * @retval 無(wú)
  132.   */
  133. float getTValue(float PT100Value)
  134. {
  135.         float A = 0.003940;
  136.         float B = -0.0000005802;
  137.         float C = -0.000000000004274;
  138.         
  139.         
  140. }
  141. /*********************************************END OF FILE**********************/
復(fù)制代碼

所有資料51hei提供下載:
PT100測(cè)試程序.rar (313.64 KB, 下載次數(shù): 417)



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

使用道具 舉報(bào)

沙發(fā)
ID:200813 發(fā)表于 2019-1-13 18:00 | 只看該作者
有人下載了這個(gè)程序麼,為什么我下載的程序打不開(kāi)呀
回復(fù)

使用道具 舉報(bào)

板凳
ID:302248 發(fā)表于 2019-2-27 21:01 | 只看該作者
程序是殘損的
回復(fù)

使用道具 舉報(bào)

地板
ID:421308 發(fā)表于 2019-7-13 12:35 | 只看該作者
能從新上次一下附件嗎
回復(fù)

使用道具 舉報(bào)

5#
ID:421308 發(fā)表于 2019-7-14 16:16 | 只看該作者
請(qǐng)問(wèn)有電路圖嗎
回復(fù)

使用道具 舉報(bào)

6#
ID:421308 發(fā)表于 2019-7-16 11:07 | 只看該作者
float getTValue(float PT100Value)
{
        float A = 0.003940;
        float B = -0.0000005802;
        float C = -0.000000000004274;
        
        
}
為什么沒(méi)有返回值啊
回復(fù)

使用道具 舉報(bào)

7#
ID:667303 發(fā)表于 2020-8-6 15:02 | 只看該作者
感謝大佬分享,馬上用到項(xiàng)目上
回復(fù)

使用道具 舉報(bào)

8#
ID:45026 發(fā)表于 2020-8-6 17:44 | 只看該作者
這個(gè)程序有錯(cuò)誤,不完整!不對(duì)呀!
回復(fù)

使用道具 舉報(bào)

9#
ID:628703 發(fā)表于 2020-8-7 11:45 | 只看該作者
可以打開(kāi),自己修改下
回復(fù)

使用道具 舉報(bào)

10#
ID:833491 發(fā)表于 2020-11-14 15:22 | 只看該作者
peeta 發(fā)表于 2020-8-7 11:45
可以打開(kāi),自己修改下

你的實(shí)現(xiàn)功能了嗎,可以分享我一份嗎
回復(fù)

使用道具 舉報(bào)

11#
ID:783854 發(fā)表于 2021-2-18 14:47 | 只看該作者
博主,這阻值是如何計(jì)算的呢
回復(fù)

使用道具 舉報(bào)

12#
ID:886390 發(fā)表于 2021-2-26 15:04 | 只看該作者
偏差有多大呢
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表