AVR单片机8路AD如何采样

2019-11-16来源: 51hei关键字:AVR单片机  8路AD  采样

//*********ATmega128,8channel ADC sampling + LED display + USART*******
#include
#include

#define uchar unsigned char
#define uint unsigned int
#define ulong unsigned long
#define FOSC   1843200
#define baud   9600
#define MyUBBR   (uint)((ulong)FOSC/(16*(ulong)baud)-1)
const uchar table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
uchar Data[4]={0};
uchar adcon0_table[]={0x40,0x41,0x42,0x43,0x44,0x45,0x46,0x47};
uchar num1,num2;
uint data_buf[10]={0};

void delay_ms(uint x);                       
void PORT_init();
void USART_Init(uint ubbr); 
void USART_Transmit(uchar data);
uchar USART_Receive(void);
void NumericalLED_display(void);
uint data_average(uint buffer[30]);
void get_AD(void);

void main()
{
  uchar i;
  PORT_init();
  USART_Init(MyUBBR);

    while(1)
    {
          NumericalLED_display();
      get_AD();
      if(USART_Receive()==0x01)
      {
        num1=PORTD;
        num2=PORTB&0X03;
        if((num1==0xff)&&(num2==0x03))
        {
           USART_Transmit(num1);
                   USART_Transmit(num2);
                   
           for(i=0;i<8;i++)
            {   
                 num1=data_buf[i]/255;
                 num2=data_buf[i]%255;
                                 USART_Transmit(num1);
                         USART_Transmit(num2);
                 delay_ms(1000);
            }
         } 
      }
    }
}

void delay_ms(uint x)
{
  uint y,z;
  for(y=x;y>0;y--)
   for(z=110;z>0;z--);
}

void PORT_init()
{
    DDRA=0x00;
    DDRB=0xFF;
        PORTB=0xFF;
        DDRC=0xFF;
        PORTC=0xFF;
    PORTD=0xFF;             
    DDRD=0xFF;

}
void USART_Init(uint ubbr)
{
   
   UBRR1H= (uchar)(ubbr>>8);
   UBRR1L= (uchar)ubbr;
   UCSR1A= 0x00;
   UCSR1B|=(1<   UCSR1C=0x06;//(0<
}

void USART_Transmit(uchar data)
{
  while(!(UCSR1A&(UDRE1)));
  UDR1=data;

}

uchar USART_Receive(void)
{
   while(!(UCSR1A&(1<   return UDR1;
}

void NumericalLED_display(void)
{
   static uchar i,temp=0x01;//temp=0x7f;
   for (i=0; i<4; i++)
   {
     PORTC=table[Data[i]];
         temp=1<         PORTB&=~temp;
         delay_ms(10);
          
     //PORTC=table[Data[i]];
     //PORTB=temp;
     //temp=(temp>>1)|0x80;
     //__delay_cycles(100);
  
   }
}
           
uint data_average(uint buffer[30])
{
  uchar i,j;
  
  uint temp;
  float temp1;
  for(i=1; i<30; i++)    
  for(j=29; j>=i; --j)
  {
   if(buffer[j-1] > buffer[j])
   {
    temp = buffer[j-1];
    buffer[j-1] = buffer[j];
    buffer[j] = temp;
   }
  }

temp1 = 0;
for(i=5; i<25; i++)
{
  temp1 += buffer[i];
}   
temp = (uint)(((float)temp1) / 20 + 0.5);

return(temp);
}


void get_AD(void)
{
  uchar i,j;
  uint adcbuf[30]={0};  
   static uchar ADC_channel=0;
   //ADMUX=0x40;                              
   ADCSRA=0x83;                             
   SFIOR=0x00;  
   delay_ms(1);
   for (i=0; i<8; i++)
    {
      ADMUX=adcon0_table[ADC_channel];
      for(j=0; j<30; j++)
       {
          asm("NOP");           
          asm("NOP");
          ADCSRA|=BIT(6); 
          while(((1<         // adcbuf[j]=(ADCH*256)+ADCL;   
                 adcbuf[j]=(ADCH<<8)|ADCL;
       }
      data_buf[i]=data_average(adcbuf); 
          Data[3]=data_buf[i]/1000;
          Data[2]=data_buf[i]%1000/100;
          Data[1]=data_buf[i]%100/10;
          Data[0]=data_buf[i]%10;
      if (++ADC_channel>8)ADC_channel=0;
      delay_ms(1);
    }
}

//PIC Multi_CD channel source code,

//******Multi_ADChannel converter**********//
#include    

__PROG_CONFIG(1,0xc200);
__PROG_CONFIG(2,0x0a16);
__PROG_CONFIG(3,0x8100);
__PROG_CONFIG(4,0x0081);
__PROG_CONFIG(5,0xc00f);
__PROG_CONFIG(6,0xe00f);
__PROG_CONFIG(7,0x400f);

#define uchar unsigned char
#define uint  unsigned int
uchar temp;
void multi_convertor(void);
void port_check(void);

uint ADbuf[10]; 
void delay_ms(uint t)
{
   uint m,n;
   for (m=0;m     for (n=0; n<1140;n++);
}


void GPIO_Init(void)
{
  TRISA=0xff;
  TRISB=0xff;
  TRISC=0xff;
  TRISD=0xff;
  TRISE=0xff;
  PSPMODE=0;
  PSPIE=0;
  PSPIP=0;
                
  TRISBbits.RB2 =1;                  //set direction of RB2 to be An input;
  TRISBbits.RB3 =1;                  //set direction of RB3 to be An input;

}

void ADC_Init(void)
{
  ADCON1 = 0x05;                  //seting AN0~AN9 to be analog input;
  ADCON2 = 0xBE;                  //20TAD,FOSC/64 and right justified;              
}

void timer0_init(void)
{
  INTCON =0xE0;//GIE,PEIE,TMR0IE to set;
  T0CON = 0x1F;// timer0 to be 16-bit;
  TMR0H = (65536-1000)/256;
  TMR0L = (65536-1000)%256; 
  T0CON |=0x80;
  TMR0ON=1;
}


void EUART_init(void)
{
  TRISC7=1;
  TRISC6=1;
  SPBRG=0x40;
  TXSTA=0x24;
  RCSTA=0x90;
  RCIE=0;
  TXIE=0;
  PEIE=1;
  GIE=1;

}

void transmit_udata(uchar udata)
{
   TXREG=udata;
   while(!TRMT);
}

uchar receive_udata(void)
{
   uchar temp;
   if (RCIF==1)
   {
     temp=RCREG;
   }
   return temp;

}
uint data_average(uint buffer[30])
{
  uchar i,j;
  uint temp;
  float temp1;
  for(i=1; i<30; i++)    
  for(j=29; j>=i; --j)
  {
   if(buffer[j-1] > buffer[j])
   {
    temp = buffer[j-1];
    buffer[j-1] = buffer[j];
    buffer[j] = temp;
   }
  }

temp1 = 0;
for(i=5; i<25; i++)
{
  temp1 += buffer[i];
}   
temp = (uint)(((float)temp1) / 20 + 0.5);

return(temp);
}


void main(void)

  EUART_init();
  GPIO_Init();
  ADC_Init();
  timer0_init();  
  while(1)
    {
       temp=receive_udata();
      if (temp==0x01)
       {
         temp=0; 
         port_check();
         multi_convertor();
        
       }
    }
}
void port_check(void)
{
   uchar num1, num2;

   num1=PORTD;
   num2=PORTB&0X03;
   transmit_udata(num2);
   transmit_udata(num1);
}

void multi_convertor(void)
{
   uchar data1,data2,i;
   static uchar ADC_channel=0;
   uint adc[30]={0};
     // ADC_channel++;
      for (ADC_channel=0; ADC_channel<10; ADC_channel++)
        {
        
               switch(ADC_channel) 
                {
                        case 0: ADCON0=0x01;break;//AN0 channel;
                        case 1: ADCON0=0x05;break;//AN1 channel;
                        case 2: ADCON0=0x09;break;//AN2 channel;
                        case 3: ADCON0=0x0D;break;//AN3 channel;
                        case 4: ADCON0=0x11;break;//AN4 channel;
                        case 5: ADCON0=0x15;break;//AN5 channel;
                        case 6: ADCON0=0x19;break;//AN6 channel;
                        case 7: ADCON0=0x1D;break;//AN7 channel;
                        case 8: ADCON0=0x21;break;//AN8 channel;
                        case 9: ADCON0=0x25;break;//AN9 channel;
                        default:break;
                }
     
                     for(i=0;i<30;i++)  
                       {    
                            ADCON0 |=0x01;
                            asm("NOP");           
                            asm("NOP");           
                            GODONE=1;               
                            while(GODONE);
                            adc[i]=(ADRESH*256)+ADRESL;      
                            
                        }
                        ADbuf[ADC_channel]=data_average(adc);
                        data1=ADbuf[ADC_channel]/255;
                        data2=ADbuf[ADC_channel]%255;
                        transmit_udata(data1);
                        transmit_udata(data2);
    
        }
}

关键字:AVR单片机  8路AD  采样 编辑:什么鱼 引用地址:http://news.eeworld.com.cn/mcu/ic480223.html 本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:DHT11温湿度传感器的AVR单片机例程
下一篇:avr单片机双通信C程序

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

avr单片机功能特性介绍
RISC 优先选取使用频率最高的简单指令,避免复杂指令:并固定指令宽度,减少指令格式和寻址方式的种类,从而缩短指令周期,提高运行速度。由于 AVR 采用了 RISC 的这种结构,使AVR系列单片机都具备了1MIPS/MHz(百万条指令每秒/兆赫兹)的高速处理能力。早期单片机主要由于工艺及设计水平不高、功耗高和抗干扰性能差等原因,所以采取稳妥方案:即采用较高的分频系数对时钟分频,使得指令周期长,执行速度慢。以后的CMOS单片机虽然采用提高时钟频率和缩小分频系数等措施,但这种状态并未被彻底改观(51以及51兼容)。此间虽有某些精简指令集单片机(RISC)问世,但依然沿袭对时钟分频的作法。AVR单片机的推出,彻底打破这种旧设计格局,废除
发表于 2019-12-14
avr单片机功能特性介绍
avr单片机按键程序
  什么是avr单片机  AVR单片机是1997年由ATMEL公司研发出的增强型内置Flash的RISC(Reduced InstrucTIon Set CPU) 精简指令集高速8位单片机。可以广泛应用于计算机外部设备、工业实时控制、仪器仪表、通讯设备、家用电器等各个领域。AVR单片机是 Atmel 公司 1997 年推出的 RISC 单片机。RISC(精简指令系统计算机)是相对于CISC(复杂指令系统计算机)而言的。RISC 并非只是简单地去减少指令,而是通过使计算机的结构更加简单合理而提高运算速度的。  RISC 优先选取使用频率最高的简单指令,避免复杂指令:并固定指令宽度,减少指令格式和寻址方式的种类,从而缩短指令周期,提高
发表于 2019-12-14
avr单片机按键程序
三分钟告诉你:AVR单片机的熔丝与解锁
AVR单片机的熔丝位配置是AVR单片机初学者很容易出错的地方,其实只要注意一些事项,还是能够尽量避免单片机被锁死,即使单片机被锁死,也可以使用一些方法解锁,本文讲述我在刚开始接触AVR单片机时熔丝位配置出现的一些问题。1、AVR单片机的熔丝位是比较独到的特征,可以控制系统的时钟,JTAG调试、看门狗、芯片加密等等。图1是progisp软件,对于初学者来说,对熔丝位不熟悉,可以先将2处的编程熔丝对勾去掉,这样在编程的时候,就不会对熔丝位进行编程,单片机出厂的默认设置就可以使用。点击1处进入熔丝位配置界面。图1图2为位配置方式,这里的每一位都不能随意点击,尤其是熔丝低位控制时钟的地方,一般来说,直接对位进行配置并不安全,一定要确定是
发表于 2019-12-14
三分钟告诉你:AVR单片机的熔丝与解锁
avr单片机和stm32区别与优缺点分析
  摘要:avr单片机和stm32单片机是目前使用较广泛的单片机,那么avr单片机和stm32单片机有什么区别呢?有什么优劣势呢?  一、AVR单片机介绍  AVR单片机是1997年由ATMEL公司研发出的增强型内置Flash的RISC(Reduced InstrucTIon Set CPU) 精简指令集高速8位单片机。可以广泛应用于计算机外部设备、工业实时控制、仪器仪表、通讯设备、家用电器等各个领域。  avr单片机特点:  1. avr系列没有类似累加器A的结构,它主要是通过R16~R31寄存器来实现A的功能。在avr中,没有像51系列的数据指针DPTR,而是由X(由 R26、R27组成)、Y(由R28、R29组成)、Z
发表于 2019-12-14
如何设计一个以AVR单片机为控制芯片的电子镇流器?
引言电子镇流器是新型节能产品,不仅能带动一些照明灯具,还可以和一些紫外灯结合在一起,对于空气净化和水源净化都有着非常大的作用。当前,全世界都在大力提倡环境保护,电子镇流器间接地为环保提供了原动力。AVR单片机是一款性价比较高的单片机,用这种单片机来对电子镇流器进行调光和时间采样非常合适,首先是AVR单片机本身较稳定,抗干扰能力比较强,其次是其本身的Harvard结构使得运行速度比较快,数据回读时间较快,可以实现实时在线控制。1 AVR单片机介绍1.1 AVR单片机的特点与以往的8位单片机相比,AVR单片机采用Harvard结构,也就是程序总线和数据总线分开,并采用两级流水线,具备1MIPS/MHz的高速运行处理能力。片内集成多种
发表于 2019-12-14
如何设计一个以AVR单片机为控制芯片的电子镇流器?
AVR单片机高压解锁器的制作设计
概述:利用常用的AVR单片机ATmega16制作的高压解锁器,可以解开所有芯片锁死的情况(除非芯片损坏、烧毁)。制作作品经实验验证,解开了山东大学物理学院AVR单片机实验室所有近40片锁死的单片机以及许多同学锁死的单片机。制作方法简单,保证你一小时之内做完。所需元件极少(如电路图所示):仅一只三极管、一片7805,三支电阻、一只LED、三个小电容,一片可用的单片机,一个12V电源。程序与电路连接可方便的移植到其它型号单片机上(凡支持高压编程的,都可以)。希望能对初学单片机的同学有所帮助,特别是我们学校暑假参加电子设计比赛的同学。制作背景(常见芯片锁死情况与高压解锁介绍):AVR单片机是我们学校同学经常使用的单片机,尤其是中高档
发表于 2019-12-12
AVR单片机高压解锁器的制作设计
小广播
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2019 EEWORLD.com.cn, Inc. All rights reserved