打印

求助:AD采集总么做?

[复制链接]
2722|18
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
firstblood|  楼主 | 2012-9-13 15:15 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
沙发
MrWang_| | 2012-9-13 15:30 | 只看该作者
你可以看看他的官方例程吧!

使用特权

评论回复
板凳
IJK| | 2012-9-13 17:54 | 只看该作者
每秒需要采集1000个点。
应该不难,才相当于 1k采样率。可以用定时器定时触发,然后转换结束读数即可。

使用特权

评论回复
地板
wjzx111056| | 2012-9-13 20:47 | 只看该作者
LZ,我现在用的芯片的MSP430F147,这个芯片的AD模块的12位的,要利用芯片自带的AD转换模块进行AD转换是很方便的,只需要对这个模块里面涉及的几个寄存器进行设置就可以了,并利用定时器产生1/1k的中断,在中断服务程序中进行处理转换后的数字量即可,不复杂的。

使用特权

评论回复
5
springspring| | 2012-9-13 21:12 | 只看该作者
找个例程看看知道基本原理就会了

使用特权

评论回复
6
lzmm| | 2012-9-13 22:37 | 只看该作者
可以使用定时采样

使用特权

评论回复
7
figo20042005| | 2012-9-13 23:22 | 只看该作者
按照3L的做比较合理

使用特权

评论回复
8
rupply| | 2012-9-14 08:06 | 只看该作者
看官方的固件库,里面有ADC的代码,加上个定时器就可以实现.下面代码是抄过来的,你能看懂吗?

/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
__IO uint16_t  ADC1ConvertedValue = 0, ADC1ConvertedVoltage = 0;
__IO uint16_t RegularConvData_Tab[4];

void ADC1_DMA_Config(void)
{
  ADC_InitTypeDef     ADC_InitStructure;
  GPIO_InitTypeDef    GPIO_InitStructure;
  DMA_InitTypeDef   DMA_InitStructure;
  /* ADC1 DeInit */  
  ADC_DeInit(ADC1);
  
  /* GPIOC Periph clock enable */
  RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOC, ENABLE);
  
   /* ADC1 Periph clock enable */
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);
  
  /* DMA1 clock enable */
  RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1 , ENABLE);
  
  /* Configure ADC Channel11 as analog input */
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 ;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL ;
  GPIO_Init(GPIOC, &GPIO_InitStructure);
  
  /* DMA1 Channel1 Config */
  DMA_DeInit(DMA1_Channel1);
  DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)ADC1_DR_Address;
  DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)RegularConvData_Tab;
  DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
  DMA_InitStructure.DMA_BufferSize = 4;
  DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
  DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
  DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
  DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
  DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;
  DMA_InitStructure.DMA_Priority = DMA_Priority_High;
  DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
  DMA_Init(DMA1_Channel1, &DMA_InitStructure);
  /* DMA1 Channel1 enable */
  DMA_Cmd(DMA1_Channel1, ENABLE);
  
  /* ADC DMA request in circular mode */
  ADC_DMARequestModeConfig(ADC1, ADC_DMAMode_Circular);
  
  /* Enable ADC_DMA */
  ADC_DMACmd(ADC1, ENABLE);  
  
  /* Initialize ADC structure */
  ADC_StructInit(&ADC_InitStructure);
  
  /* Configure the ADC1 in continous mode withe a resolutuion equal to 12 bits  */
  ADC_InitStructure.ADC_Resolution = ADC_Resolution_12b;
  ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;
  ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_ExternalTrigConvEdge_None;
  ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
  ADC_InitStructure.ADC_ScanDirection = ADC_ScanDirection_Backward;
  ADC_Init(ADC1, &ADC_InitStructure);

  /* Convert the ADC1 Channel 1 with 55.5 Cycles as sampling time */
  ADC_ChannelConfig(ADC1, ADC_Channel_11 , ADC_SampleTime_55_5Cycles);   
  
  
  /* Convert the ADC1 temperature sensor  with 55.5 Cycles as sampling time */
  ADC_ChannelConfig(ADC1, ADC_Channel_TempSensor , ADC_SampleTime_55_5Cycles);  
  ADC_TempSensorCmd(ENABLE);
  
  /* Convert the ADC1 Vref  with 55.5 Cycles as sampling time */
  ADC_ChannelConfig(ADC1, ADC_Channel_Vrefint , ADC_SampleTime_55_5Cycles);
  ADC_VrefintCmd(ENABLE);
  
  /* Convert the ADC1 Vbat with 55.5 Cycles as sampling time */
  ADC_ChannelConfig(ADC1, ADC_Channel_Vbat , ADC_SampleTime_55_5Cycles);  
  ADC_VbatCmd(ENABLE);
  
  /* ADC Calibration */
  ADC_GetCalibrationFactor(ADC1);
  
  /* Enable ADC1 */
  ADC_Cmd(ADC1, ENABLE);     
  
  /* Wait the ADCEN falg */
  while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_ADEN));
  
  /* ADC1 regular Software Start Conv */
  ADC_StartOfConversion(ADC1);
}

使用特权

评论回复
9
vivilzb1985| | 2012-9-14 15:04 | 只看该作者
每秒中采集1000个数据点还是很好做的啊,利用单片机的相关ADC寄存器配置好采集的类型、时钟、采集转换时间等就可以了啊,然后利用时间分配启动数据的采集就可以实现的

使用特权

评论回复
10
comeon201208| | 2012-9-14 16:15 | 只看该作者
若单纯是每秒采集1000个数据点的话,还是很容易实现的,请问楼主,除开采集数据还有其他啥操作功能么?这个涉及到整个系统的运行的主频快慢的问题的啊

使用特权

评论回复
11
firstblood|  楼主 | 2012-10-10 15:03 | 只看该作者
每采集一个数据点为2个字节的数据,单片机定时的话是可实现的,不过这个时间间隔很短的,还是有些不可取的,大家还有其他啥办法的么?

使用特权

评论回复
12
Redstar2012| | 2012-10-10 16:12 | 只看该作者
对于每秒采集1000个数据点,相当于1kHz的采样频率,不用定时器,采用分时复用怎么样?

使用特权

评论回复
13
hawksabre| | 2012-10-10 18:51 | 只看该作者
多看官方例程   这个TI的官方网站上都有的   自己多看看   平时多逛21IC论坛   呵呵

使用特权

评论回复
14
comeon201208| | 2012-10-11 13:40 | 只看该作者
楼主可以将采集数据的程序放在while循环里面,加上适当的延时或者让你的CPU在采集数据的间隔时间内干其他事情也是可以的啊

使用特权

评论回复
15
comeon201208| | 2012-10-11 13:42 | 只看该作者
只要控制好延时,1s钟采集1000个数据点是完全没有问题的啊,另外每隔数据点上不要只采集一个数据的,可以多采集几个数据求平均值就可以了啊

使用特权

评论回复
16
firstblood|  楼主 | 2012-10-29 14:28 | 只看该作者
谢谢楼上各位的意见的啊,这个AD数据采集的已解决了

使用特权

评论回复
17
firstblood|  楼主 | 2012-10-29 14:28 | 只看该作者
恩,我结贴算了啊,谢谢楼上各位的参与!

使用特权

评论回复
18
wrigleymint| | 2012-10-29 17:14 | 只看该作者
学习下

使用特权

评论回复
19
永远的不知| | 2012-10-30 22:09 | 只看该作者
11# firstblood 按照3楼的方法,应该是可行的。

使用特权

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

本版积分规则

86

主题

4492

帖子

9

粉丝