久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2742|回復: 6
收起左側

關于單片機+PCF8591 AD轉換的一些問題

[復制鏈接]
回帖獎勵 50 黑幣 回復本帖可獲得 10 黑幣獎勵! 每人限 1 次
ID:508775 發表于 2019-4-23 21:49 | 顯示全部樓層 |閱讀模式
各位老師好,我是一個小白,這里用PCF8591(八位ad轉換)和STC8592來進行的模擬轉換,但是在串口接受數據的時候呢,顯示數值一直是255,我發現即使將讀地址換成別的地址也是255(在模擬信號輸出端口為AIN0的情況下,直接將讀地址改為AIN1的地址,也是255),所以我懷疑是不是我沒有把地址寫進去呢,下面是程序,和結果,希望各位大佬能幫我看下謝謝各位大佬了。
QQ截圖20190423214652.jpg

單片機源程序如下:
  1. #include "reg52.h"
  2. #include <intrins.h>

  3. #define unchar unsigned char
  4. #define uint unsigned int

  5. sbit scl=P2^1;
  6. sbit sda=P2^0;

  7. unchar dat[4]={'0','0','0','0'};


  8. void delay_4us()
  9. {
  10.         _nop_();
  11.         _nop_();
  12.         _nop_();
  13.         _nop_();
  14.         
  15. }


  16. void delay(uint i)
  17. {
  18.         while(i--);
  19. }

  20. void i2c_init()
  21. {
  22.         scl=0;
  23.         sda=1;
  24.         delay_4us();
  25.         scl=1;
  26.         delay_4us();
  27.         scl=0;
  28. }

  29. void i2c_start()
  30. {
  31.         scl=0;
  32.         delay_4us();
  33.         sda=1;
  34.         delay_4us();
  35.         scl=1;
  36.         delay_4us();
  37.         sda=0;
  38.         delay_4us();
  39.         scl=0;
  40. }


  41. void i2c_stop()
  42. {
  43.         scl=0;
  44.         delay_4us();
  45.         sda=0;
  46.         delay_4us();
  47.         scl=1;
  48.         delay_4us();
  49.         sda=1;
  50.         delay_4us();
  51.         scl=0;
  52.         delay_4us();
  53. }


  54. void i2c_ack(unchar ackbit)
  55. {
  56.         if(!ackbit)
  57.         {
  58.                 sda=0;
  59.         }
  60.         else
  61.         {
  62.                 sda=1;
  63.         }
  64.         delay_4us();
  65.         scl=1;
  66.         delay_4us();
  67.         scl=0;
  68.         delay_4us();
  69.         sda=1;
  70.         delay_4us();
  71.         scl=1;
  72.         delay_4us();
  73.         scl=0;
  74.         
  75. }


  76. bit i2c_waitack()
  77. {
  78.         sda=1;
  79.         delay_4us();
  80.         scl=1;
  81.         delay_4us();
  82.         if(sda)
  83.         {
  84.                 scl=0;
  85.                 i2c_stop();
  86.                 return 0;
  87.         }
  88.         else
  89.         {
  90.                 scl=0;
  91.                 return 1;
  92.         }
  93. }


  94. void i2c_send(unchar byte)
  95. {
  96.         unchar i;
  97.         for(i=0;i++;i<8)
  98.         {
  99.                 if(byte&0x80)
  100.                 {
  101.                         sda=1;
  102.                 }
  103.                 else
  104.                 {
  105.                         sda=0;
  106.                 }
  107.                 delay_4us();
  108.                 byte<<=1;
  109.                 delay_4us();
  110.                 scl=0;
  111.         }
  112.         
  113. }


  114. unchar i2c_receive()
  115. {
  116.         unchar dat,i;
  117.         for(i=0;i<8;i++)
  118.         {
  119.                 scl=1;
  120.                 delay_4us();
  121.                 dat <<=1;
  122.                 if(sda)
  123.                 {
  124.                         dat|=0x01;
  125.                 }
  126.                 scl=0;
  127.                 delay_4us();
  128.         }
  129.         return dat;
  130. }


  131. void ustart_init()
  132. {
  133.         PCON= 0x80;                //????????SMOD
  134.         SCON= 0x50;                //8???,?????
  135.   TMOD= 0x20;                //?????1?8???????
  136.   TL1 = 0xF3;                //??????
  137.   TH1 = 0xF3;
  138.   ET1 = 0;                //?????1??
  139.   TR1 = 1;                //?????1
  140.   ES=1;                                                
  141.   EA=1;
  142. }

  143. void ustart_send(unchar c)
  144. {
  145.         SBUF=c;
  146.         while(!TI);
  147.         TI=0;
  148. }

  149. void pcf8591_init()
  150. {
  151.         i2c_start();
  152.         i2c_send(0x90);
  153.         i2c_waitack();
  154.         i2c_send(0x00);
  155.         i2c_waitack();
  156.         i2c_stop();
  157. }

  158. unchar pcf8591_adc()
  159. {
  160.         unchar temp;
  161.         i2c_start();
  162.         i2c_send(0x91);
  163.         i2c_waitack();
  164.         temp=i2c_receive();
  165.         i2c_ack(1);
  166.         i2c_stop();
  167.         return temp;
  168. }

  169. void main()
  170. {
  171.         unchar temp[12] ="hguangqiang:";
  172.         unchar i,j;
  173.         unchar shuju;
  174.         while(1)
  175.         {
  176.                
  177.                 i2c_start();
  178.                 i2c_send(0x90);
  179.                 i2c_waitack();
  180.                 i2c_send(0x01);
  181.                 i2c_waitack();
  182.                 //i2c_stop();
  183.                
  184.                 //i2c_start();
  185.                 i2c_send(0x9);
  186.                 i2c_waitack();
  187.                 i2c_send(0x02);
  188.                 i2c_waitack();
  189.                 shuju=i2c_receive();
  190.                 i2c_ack(1);
  191.                 i2c_stop();
  192.                 dat[0]='0'+shuju/1000;
  193.                 dat[1]='0'+shuju%1000/100;
  194.                 dat[2]='0'+shuju%100/10;
  195.                 dat[3]='0'+shuju%10;
  196.                 ustart_init();
  197.                 for(i=0;i<12;i++)
  198.                 {
  199.                         ustart_send(temp[i]);
  200.                 }
  201.                 delay(10000);
  202.                 for(j=0;j<4;j++)
  203.                 {
  204.                         ustart_send(dat[j]);
  205.                 }
  206.                 delay(10000);
  207.                
  208.         }

  209. }

  210.         
  211.         


  212. void zhognduan() interrupt 4
  213. {
  214.         unchar receiveData;
  215.         RI=0;
  216.         receiveData=SBUF;
  217.         SBUF=receiveData;
  218.         while(!TI);
  219.         TI=0;
  220. }

復制代碼


回復

使用道具 舉報

ID:231669 發表于 2019-4-23 22:04 | 顯示全部樓層
你的ADC通信是不是沒有成功,沒有接收到數據
回復

使用道具 舉報

ID:164602 發表于 2019-4-24 08:17 | 顯示全部樓層
第一:你的8591轉換的是什么AD呢?接了幾個?——8591可以接四個。
第二:這段程序:
unchar pcf8591_adc()
{
        unchar temp;
        i2c_start();
        i2c_send(0x91);
        i2c_waitack();
        temp=i2c_receive();
        i2c_ack(1);
        i2c_stop();
        return temp;
}
不應該是0x91吧,應該是0x90,8591的地址
回復

使用道具 舉報

ID:508775 發表于 2019-4-24 08:31 | 顯示全部樓層
飛機載白菜 發表于 2019-4-23 22:04
你的ADC通信是不是沒有成功,沒有接收到數據

一直收到255對于八位來說是沒有成功嗎,那是我的通信協議的問題嗎。
回復

使用道具 舉報

ID:508775 發表于 2019-4-24 08:41 來自手機 | 顯示全部樓層
飛機載白菜 發表于 2019-4-23 22:04
你的ADC通信是不是沒有成功,沒有接收到數據

如果不對的話要如何調試呢
回復

使用道具 舉報

ID:508775 發表于 2019-4-24 09:07 來自手機 | 顯示全部樓層
HC6800-ES-V2.0 發表于 2019-4-24 08:17
第一:你的8591轉換的是什么AD呢?接了幾個?——8591可以接四個。
第二:這段程序:
unchar pcf8591_adc ...

轉換的是光強,接了一個,我這部分函數其實并沒有調用,因為之前寫的時候照著寫了,但是后面在使用的時候還是自己在主函數里寫了一遍,
回復

使用道具 舉報

ID:508775 發表于 2019-4-24 09:28 來自手機 | 顯示全部樓層
HC6800-ES-V2.0 發表于 2019-4-24 08:17
第一:你的8591轉換的是什么AD呢?接了幾個?——8591可以接四個。
第二:這段程序:
unchar pcf8591_adc ...

您說的對,0x90是讀取,那么為什么要寫0x
91呢
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 懂色av一区二区三区在线播放 | 全免费a级毛片免费看视频免 | 黄色网毛片 | 四虎影 | 国产免费自拍 | 精品在线观看一区二区 | 日韩精品一区在线 | 精品久久成人 | 欧美激情精品久久久久久 | 97久久精品| 高清人人天天夜夜曰狠狠狠狠 | 国产在线中文字幕 | 老司机深夜福利网站 | 久久精品美女 | 在线日韩精品视频 | 国产在线一区二区 | 欧美小视频在线观看 | 午夜电影福利 | 在线视频亚洲 | 黄色大片免费网站 | 99久久精品一区二区成人 | 国产91亚洲精品 | 国产一区中文字幕 | 黑人巨大精品欧美一区二区一视频 | 国产99小视频| 欧美精选一区二区 | 国产高清亚洲 | www.99热这里只有精品 | 日韩欧美在线一区 | 欧美一区二区三区免费在线观看 | 中文字幕亚洲一区二区va在线 | 黑人精品 | 色吊丝2| 欧美精品二区 | 欧美日韩一区二区三区四区 | 欧美中文字幕在线 | 韩日一区二区 | 99久久婷婷| 久久高清 | 国产精品有限公司 | 国产欧美视频一区二区三区 |