ADC采集+乒乓FIFO+USB2.0传输

近红外探测器+ADC采集+乒乓FIFO+USB2.0传输:
功能:主动式光源打到物体上,反射通过探测器输出物体的光谱曲线。
1.近红外探测器测量范围:
型号G11478 InGaAs线性图像传感器,
900-2500nm 256个像元。每一个像元需要用单色仪去校准确定像元的波段。
高分辨率25um间距(主要是用来分光的,识别不同nm的芯片像元当信号照射后,产生不同的电压/电流输出,可以用于物体的识别)。
2.功能:
光谱仪主要是对物体做定量/定性的测量,定性分析的目的是确定物质的组成与结构,而定量分析则是为了确定物质中某些组分的含量或是物质的品质属性的值。
G11478-256
3.探测器电气特性:
(1)输入信号(光),输出单端模拟电压(1.2-4.0V),暗电流100pa。
(2)电压(4.7-5.3V),功耗(400mw),输出的信号电压在(1.2-4.0V)。
(3).探测器的主时钟(50Mhz,
(4)采样频率(0.1M-5M,选择1M),
(5)工作模式(先积分在读出),积分为了读取每个像素信号,
(6&#x

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是使用STM32F4库函数编写的ADC采样数据存储到乒乓buffer并通过DMA切换buffer的示例代码: 首先,需要定义两个大小为缓冲区大小的数组作为乒乓buffer: ``` #define BUFFER_SIZE 1024 volatile uint16_t buffer1[BUFFER_SIZE]; volatile uint16_t buffer2[BUFFER_SIZE]; volatile uint16_t* current_buffer = buffer1; // 当前使用的缓冲区 ``` 接下来,需要配置ADC和DMA: ``` // 配置ADC ADC_InitTypeDef ADC_InitStruct; ADC_CommonInitTypeDef ADC_CommonInitStruct; DMA_InitTypeDef DMA_InitStruct; // 配置 ADC ADC_CommonInitStruct.ADC_Prescaler = ADC_Prescaler_Div4; ADC_CommonInit(&ADC_CommonInitStruct); ADC_InitStruct.ADC_Resolution = ADC_Resolution_12b; ADC_InitStruct.ADC_ScanConvMode = DISABLE; ADC_InitStruct.ADC_ContinuousConvMode = ENABLE; ADC_InitStruct.ADC_ExternalTrigConvEdge = ADC_ExternalTrigConvEdge_None; ADC_InitStruct.ADC_DataAlign = ADC_DataAlign_Right; ADC_InitStruct.ADC_NbrOfConversion = 1; ADC_Init(ADC1, &ADC_InitStruct); ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_3Cycles); // 配置 DMA DMA_InitStruct.DMA_Channel = DMA_Channel_0; DMA_InitStruct.DMA_PeripheralBaseAddr = (uint32_t) &ADC1->DR; DMA_InitStruct.DMA_Memory0BaseAddr = (uint32_t) buffer1; DMA_InitStruct.DMA_DIR = DMA_DIR_PeripheralToMemory; DMA_InitStruct.DMA_BufferSize = BUFFER_SIZE; DMA_InitStruct.DMA_PeripheralInc = DMA_PeripheralInc_Disable; DMA_InitStruct.DMA_MemoryInc = DMA_MemoryInc_Enable; DMA_InitStruct.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord; DMA_InitStruct.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord; DMA_InitStruct.DMA_Mode = DMA_Mode_Circular; DMA_InitStruct.DMA_Priority = DMA_Priority_High; DMA_InitStruct.DMA_FIFOMode = DMA_FIFOMode_Disable; DMA_InitStruct.DMA_FIFOThreshold = DMA_FIFOThreshold_HalfFull; DMA_InitStruct.DMA_MemoryBurst = DMA_MemoryBurst_Single; DMA_InitStruct.DMA_PeripheralBurst = DMA_PeripheralBurst_Single; DMA_Init(DMA2_Stream0, &DMA_InitStruct); DMA_Cmd(DMA2_Stream0, ENABLE); // 启动 ADC ADC_Cmd(ADC1, ENABLE); ADC_SoftwareStartConv(ADC1); ``` 其中,ADC使用了PA0作为输入通道,DMA使用了DMA2的stream0通道。注意,这里开启了循环模式,即DMA会一直从ADC采样数据并存储到缓冲区中。 接下来,需要在DMA的中断回调函数中进行缓冲区的切换: ``` void DMA2_Stream0_IRQHandler(void) { if (DMA_GetITStatus(DMA2_Stream0, DMA_IT_TCIF0)) { DMA_ClearITPendingBit(DMA2_Stream0, DMA_IT_TCIF0); // 切换缓冲区 if (current_buffer == buffer1) { current_buffer = buffer2; DMA2_Stream0->M0AR = (uint32_t) buffer1; } else { current_buffer = buffer1; DMA2_Stream0->M0AR = (uint32_t) buffer2; } } } ``` 在这里,使用了一个volatile指针current_buffer来指向当前使用的缓冲区。在中断回调函数中,如果检测到了DMA传输完成的中断,就进行缓冲区的切换,并更新DMA的M0AR寄存器指向新的缓冲区地址。 最后,可以使用current_buffer指针来获取当前正在使用的缓冲区中的采样数据: ``` uint16_t sample = current_buffer[index]; ``` 其中,index是采样数据的索引,可以在0到BUFFER_SIZE-1之间取值。注意,由于current_buffer是一个volatile指针,编译器可能会产生额外的代码来保证读写操作的正确性,因此在频繁读取采样数据时需要注意性能问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值