打印

DSP2812AD转换后的结果不理解

[复制链接]
1720|5
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
wangchao1607|  楼主 | 2015-9-15 10:47 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
DSP2812 AD转换后结果存到了哪里?怎么读出来? 我需要根据AD 的结果由2812发出不同的指令!程序如下。   2812怎么读出结果  是在某个寄存器里吗?怎么读

/*********************************************************************
**        Module Name:                ADC                                                                         **
**        Author:                                Cbq                                                                              **
**        Version:                        1.0                                                                                    **
**        CreateDate:                        2008-05-23                                                                    **
**        Description:                                                                                        **
**        Remark:                                Huozq                                                                            **
**        Revision History:        2008-11-10                                                                    **
**********************************************************************/

/*********************************************************************
**        实验目的:学习DSP内部AD转换器,掌握它的所有寄存器功能配置,这是比  **
**           较重要的在控制行业中.                                  **
**        实验说明:外接信号进行采集                                       **
**           注意:DSP2812芯片中的AD的模拟输入范围为:0~3V,切勿超过,**
**           否则可能烧毁DSP芯片!                                   **
**        实验结果:观测a1,由于AD本身精度问题,可能会有一些误差。         **
**********************************************************************/



#include "DSP28_Device.h"

float        a1[16];
//0~15信道经过DAAD转换后,在用ADC转换公式得到的模拟值。
//本程序只针对了a1[0]和a1[1]两信道

unsigned int a2=0;                //采样次数的统计
float        adclo=0.0;                //0位调整

interrupt void ad(void);//AD中断子程序
void delay();
void WriteDAC(unsigned char add,unsigned char rng,unsigned char vol);//DA转换程序
main()
{       
    unsigned int temp;
    InitSysCtrl();

        DINT;
        IER = 0x0000;
        IFR = 0x0000;

        InitPieCtrl();

    InitPieVectTable();       
       
        InitPeripherals();
       
        InitGpio();
       
        EALLOW;        // This is needed to write to EALLOW protected registers
        PieVectTable.ADCINT=&ad;////中断向量表中的ADCINT中断指向AD中断函数
        EDIS;   // This is needed to disable write to EALLOW protected registers
   
    InitAdc();

    // Enable INT14 which is connected to CPU-Timer 2:
        IER |= M_INT1;                                //使能中断第一组
        PieCtrl.PIEIER1.bit.INTx6=1;//第一组的第6位正好ADINT
        //KickDog();
    // Enable global Interrupts and higher priority real-time debug events:
       
        EINT;   // Enable Global interrupt INTM
        ERTM;        // Enable Global realtime interrupt DBGM
        while(AdcRegs.ADC_ST_FLAG.bit.SEQ1_BSY==0)//读排序器1的忙状态位,为0是空闲
        {                       

                AdcRegs.ADCTRL2.bit.SOC_SEQ1=1;                //启动SEQ1开始转换

        }


        GpioDataRegs.GPASET.all|=0x8000;        //设置串行数据载入控制,具体可查看TLV5620英文资料,
                                                 //这里是先置高

    temp=57;
         
        for(;;)
        {
           KickDog();
          
           /*下面这里输出的四个电压值可在DA输出口,即J15分别对应测到0.4V,0.8V,1.2V,.1.6V*/
       //WriteDAC(0,0,temp);          ///0.4V
           //WriteDAC(1,0,temp*2);  ///0.8V          
           //WriteDAC(2,0,temp*3);  ///1.2V
           //WriteDAC(3,0,temp*4);  ///1.6V
        }

}        

/*
void WriteDAC(unsigned char add,unsigned char rng,unsigned char vol)
{
        unsigned short int data;
          data = 0x0000;
          data = ((add<<14) | (rng<<13) | (vol<<5));

     
          if(Spi_TxReady() == 1)
             SpiaRegs.SPITXBUF = data;
    delay(50000);
     
    GpioDataRegs.GPACLEAR.all|=0x8000;        //产生一突变负脉冲,锁定串行数据
        delay(1000);
    GpioDataRegs.GPASET.all|=0x8000;
               
}
*/

void delay(unsigned int t)
{
        while(t>0)
            t--;
}


interrupt void ad(void)
{
    adclo=0;                //每块板的零位不一样,在这儿设一个合适的数以扣掉零位
        IFR=0x0000;

        PieCtrl.PIEACK.all=0xffff;
        a2++;
        a1[0]=((AdcRegs.RESULT0>>4)*3)/4095.0+adclo;//采集0.4V的DA输入电压后转换值,也为0.4V左右
        a1[1]=((AdcRegs.RESULT1>>4)*3)/4095.0+adclo;//0.8V左右
        a1[2]=((AdcRegs.RESULT2>>4)*3)/4095.0+adclo;
        a1[3]=((AdcRegs.RESULT3>>4)*3)/4095.0+adclo;
        a1[4]=((AdcRegs.RESULT4>>4)*3)/4095.0+adclo;
        a1[5]=((AdcRegs.RESULT5>>4)*3)/4095.0+adclo;
        a1[6]=((AdcRegs.RESULT6>>4)*3)/4095.0+adclo;
        a1[7]=((AdcRegs.RESULT7>>4)*3)/4095.0+adclo;
        a1[8]=((AdcRegs.RESULT8>>4)*3)/4095.0+adclo;
        a1[9]=((AdcRegs.RESULT9>>4)*3)/4095.0+adclo;
        a1[10]=((AdcRegs.RESULT10>>4)*3)/4095.0+adclo;
        a1[11]=((AdcRegs.RESULT11>>4)*3)/4095.0+adclo;
        a1[12]=((AdcRegs.RESULT12>>4)*3)/4095.0+adclo;
        a1[13]=((AdcRegs.RESULT13>>4)*3)/4095.0+adclo;
        a1[14]=((AdcRegs.RESULT14>>4)*3)/4095.0+adclo;
        a1[15]=((AdcRegs.RESULT15>>4)*3)/4095.0+adclo;
        AdcRegs.ADC_ST_FLAG.bit.INT_SEQ1_CLR=1;
        AdcRegs.ADCTRL2.bit.SOC_SEQ1=1; //在这儿设一断点,程序执行到这儿停下后,查看变量数组a1即可看到ADC各通道的采样值。
        EINT;
       
}



//===========================================================================
// No more.
//===========================================================================

相关帖子

沙发
angerbird| | 2015-9-15 23:14 | 只看该作者
这个不太清楚的,先帮着顶下

使用特权

评论回复
板凳
smilingangel| | 2015-9-16 21:24 | 只看该作者
这个就是渡相关额度寄存器中的值就可以的么。

使用特权

评论回复
地板
angerbird| | 2015-9-16 23:07 | 只看该作者
AdcRegs.RESULTx中存储的是ad采集到的数据的。

使用特权

评论回复
5
baimiaocun2015| | 2015-9-17 22:32 | 只看该作者
这个注意采集的方式设置。

使用特权

评论回复
6
米尔豪斯| | 2015-9-18 19:31 | 只看该作者
不是存到变量数组a1了吗

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

11

主题

25

帖子

1

粉丝