r8c 2l 单片机ad转换换一直为0怎么回事

电脑的内存条是海力士 DDR3 1333MHz 2GB 型号是AD HMT325S6BFR8C-H9 N0_百度知道
电脑的内存条是海力士 DDR3 1333MHz 2GB 型号是AD HMT325S6BFR8C-H9 N0
想再加个2G的内存条,用什么牌子的可以兼容啊?或者我可以直接把原来的海力士内存条换成其他牌子的吗?
提问者采纳
以加内存。如果有空的内存插槽可直接加进去,另一种接笔记本,主板会自动平衡的,DDR3的无非就是两种型号一种DIMM接台式机。主频不同没关系,只要买好了就不会存在兼容性问题
提问者评价
其他类似问题
般正品的DDR3内存条的兼容性已经提高很多了,基本不存在兼容性的问题,很多主板厂商都把内存兼容性提高了,不过要加的话最好加同频率的
为您推荐:
其他3条回答
可以加快运行速度。呵呵,只是看原装的最下面那条可能不一定一样,都可以,建议买条一样的,组成2乘2G的内存双通道这个不存在的,但是上面的插口那条肯定是通用的
来自:求助得到的回答
什么牌子都兼容
我在京东商城看到那金士顿的,有人问了,但回复说兼容性安装之前无法确定啊。
最好是同牌子的,可以用不同牌子,我推荐你用同牌子
然后呢?打算换内存吗?
内存条的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁DIMM0:海力士DDR31600MHz2GB制造日期2012年08月型号ADHMT325U6CFR8C-PBN0序列号:3DB37227_百度知道
DIMM0:海力士DDR31600MHz2GB制造日期2012年08月型号ADHMT325U6CFR8C-PBN0序列号:3DB37227
请问我可以把它换成品牌: Hynix/海力士现代型号: 4G DDR3 1333适用对象: 台式机内存容量: 8GB传输类型: DDR3内存频率供礌垛啡艹独讹扫番激: 2400MHz组合形式: 双通道2根的可以吗,更换后会不会不兼容呢,求高手指教
我有更好的答案
你好!组装电脑换内存条,首先确认供礌垛啡艹独讹扫番激是哪一代:ddr266/ddr333/ddr400是第一代;ddr667/800是第二代;ddr1333之后是第三代;每一代内存是兼容的,插口的位置是一样的,希望我的回答对你有所帮助
我原来的是型号 DIMM 0: 海力士 DDR3 1600MHz 2GB型号 AD HMT325U6CFR8C-PB
戴尔品牌机买来就带有的,还有要不要跟换电源呢
其他类似问题
为您推荐:
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁关于AD637交流有效值测量电路的问题_百度知道
关于AD637交流有效值测量电路的问题
我参照别人的电路搭了一个用AD637测交流有效值的电路,但是测试的时后发现用AD去采这个输出信号时显示的是65535,最大也是4095,如果直接接地显哗讥糕客蕹九革循宫末示为0,说明AD是没问题的。按理说没接交流信号的时候输出应该是0,我不知道怎么回事,如果有这方面经验的能否提个醒,指点一下看哪里不对了。底下是一个变-5电源的电路
你的文字还是没把问题叙述得明白无误,还得让人去猜测实际的意思。你的意思是P1的1脚接地时,AD637的输出为0,当P4的1脚悬空时,AD637的输出不为0。是这意思吗?还是哗讥糕客蕹九革循宫末说当P2的1脚接地时,后边接的AD转换器的输出为0,当P2的1脚不接地时(接AD637的输出),后边AD转换器的输出不为0?
来自团队:
其他类似问题
为您推荐:
测量电路的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁新手求助~~~STM32F051 ADC出来的数据一直为0【悬赏问答】 - STM32 - 意法半导体STM32/STM8技术社区
后使用快捷导航没有帐号?
查看: 4680|回复: 9
新手求助~~~STM32F051 ADC出来的数据一直为0【悬赏问答】
主题帖子积分
新手上路, 积分 25, 距离下一级还需 25 积分
新手上路, 积分 25, 距离下一级还需 25 积分
用STM32F051调试AD转换程序,出来的数据一直是0.0V,不知道哪边有问题,以下是程序代码,请游过的大虾帮帮忙呗,万分感激!!
#include &stm32f0xx.h&
//这个头文件包括STM32F0xx所有外围寄存器、位、内存映射的定义
#include &delay.h&
#include &type_def.h&
USART1_BaudRate
#define ADC1_DR_Address
//用来存放ADC转换结果,也是DMA的目标地址
#ifdef __GNUC__
/* With GCC/RAISONANCE, small printf (option LD Linker-&Libraries-&Small printf
set to 'Yes') calls __io_putchar() */
#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif /* __GNUC__ */
/*GPIO管脚的配置
选用ADC的通道9,分别对应的管脚为PB1
串口使用USART1其中TX为PA9,RX为PA10 */
void GPIO_Configuration(void)
GPIO_InitTypeDef
GPIO_InitS
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOB, ENABLE);
//PB1 作为模拟通道输入引脚
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN;
//模拟输入引脚
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
GPIO_Init(GPIOB, &GPIO_InitStructure);
/*USART1管脚的配置
串口使用USART1其中TX为PA9,RX为PA10 */
void USART_Configuration(void)
GPIO_InitTypeDef
GPIO_InitS
USART_InitTypeDef USART_InitS
RCC_AHBPeriphClockCmd( RCC_AHBPeriph_GPIOA, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE );
GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_1);
GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_1);
USART1_TX -& PA9 , USART1_RX -&
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
USART_InitStructure.USART_BaudRate = USART1_BaudR
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_Parity = USART_Parity_No;
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_N
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART1, &USART_InitStructure);
USART_Cmd(USART1, ENABLE);
/*配置ADC1*/
void ADC1_Configuration(void)
ADC_InitTypeDef
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE );
ADC_DeInit(ADC1);
//将外设 ADC1 的全部寄存器重设为缺省值
ADC_StructInit(&ADC_InitStructure);
/* ADC1 configuration ------------------------------------------------------*/
ADC_InitStructure.ADC_Resolution = ADC_Resolution_12b;
//ADC1分辨率12位
ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;
//模数转换工作在连续转换模式
ADC_InitStructure.ADC_ExternalTrigConvEdge=ADC_ExternalTrigConvEdge_N
//外部触发转换关闭
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_R
//ADC数据右对齐
ADC_InitStructure.ADC_ScanDirection = ADC_ScanDirection_B
//顺序进行规则转换的ADC通道的数目
ADC_Init(ADC1, &ADC_InitStructure);
//根据ADC_InitStruct中指定的参数初始化外设ADCx的寄存器
ADC_ChannelConfig(ADC1, ADC_Channel_9, ADC_SampleTime_239_5Cycles );
ADC_GetCalibrationFactor(ADC1);
/* Enable ADC1 */
ADC_Cmd(ADC1, ENABLE);
//使能指定的ADC1
while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_ADEN));
//获取指定ADC1的校准程序,设置状态则等待
ADC_StartOfConversion(ADC1);
/*配置DMA*/
void DMA_Configuration(void)
DMA1 Channel Config */
DMA_InitTypeDef DMA_InitS
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
DMA_DeInit(DMA1_Channel1);
//将DMA的通道1寄存器重设为缺省值
DMA_InitStructure.DMA_PeripheralBaseAddr =
(u32)ADC1_DR_A
//DMA外设ADC基地址
DMA_InitStructure.DMA_MemoryBaseAddr = (u32)AD_V
//DMA内存基地址
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
//内存作为数据传输的目的地
DMA_InitStructure.DMA_BufferSize = 2;
//DMA通道的DMA缓存的大小
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_D
//外设地址寄存器不变
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_E
//内存地址寄存器递增
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfW
//数据宽度为16位
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfW //数据宽度为16位
DMA_InitStructure.DMA_Mode = DMA_Mode_C
//工作在循环缓存模式
DMA_InitStructure.DMA_Priority = DMA_Priority_H //DMA通道 x拥有高优先级
DMA_InitStructure.DMA_M2M = DMA_M2M_D
//DMA通道x没有设置为内存到内存传输
DMA_Init(DMA1_Channel1, &DMA_InitStructure);
//根据DMA_InitStruct中指定的参数初始化DMA的通道
DMA_Cmd(DMA1_Channel1, ENABLE);
ADC_DMARequestModeConfig(ADC1, ADC_DMAMode_Circular);
ADC_DMACmd(ADC1, ENABLE);
//配置所有外设
void Init_All_Periph(void)
GPIO_Configuration();
USART_Configuration();
DMA_Configuration();
ADC1_Configuration();
/*获取ADC的值,将二进制换算为十进制*/
u16 GetVolt(u16 advalue)
return (u16)(advalue * 330 / 4096);
//求的结果扩大了100倍,方便下面求出小数
PUTCHAR_PROTOTYPE
/* Place your implementation of fputc here */
/* e.g. write a character to the USART */
USART_SendData(USART1, (uint8_t) ch);
/* Loop until the end of transmission */
while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET)
int main(void)
Init_All_Periph();
while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);//等待传输完成否则第一位数据容易丢失
value = GetVolt(AD_Value);
printf(&value:\t%d.%dv\n
&,value/100,value%100) ;
Delay_ms(100);
主题帖子积分
新手上路, 积分 25, 距离下一级还需 25 积分
新手上路, 积分 25, 距离下一级还需 25 积分
RE:新手求助~~~STM32F051 ADC出来的数据一直为0
主题帖子积分
新手上路, 积分 25, 距离下一级还需 25 积分
新手上路, 积分 25, 距离下一级还需 25 积分
RE:新手求助~~~STM32F051 ADC出来的数据一直为0
在线等大婶的到来
主题帖子积分
金牌会员, 积分 2623, 距离下一级还需 377 积分
金牌会员, 积分 2623, 距离下一级还需 377 积分
回复:新手求助~~~STM32F051 ADC出来的数据一直为0【悬赏问答】
社区第3期悬赏问答活动开始咯~详见:
无论你是大神还是大婶,都快来帮忙吧!
主题帖子积分
论坛元老, 积分 3939, 距离下一级还需 9996060 积分
论坛元老, 积分 3939, 距离下一级还需 9996060 积分
RE:新手求助~~~STM32F051 ADC出来的数据一直为0【悬赏问答】
不知到你有没有好好的看一下,官方的例程呢
#define ADC1_DR_Address
/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
__IO uint16_t
ADC1ConvertedValue = 0, ADC1ConvertedVoltage = 0;
__IO uint16_t RegularConvData_Tab[4];
/* Private function prototypes -----------------------------------------------*/
/* Private functions ---------------------------------------------------------*/
Main program.
* @retval None
int main(void)
/*!& At this stage the microcontroller clock setting is already configured,
this is done through SystemInit() function which is called from startup
file (startup_stm32f0xx.s) before to branch to application main.
To reconfigure the default setting of SystemInit() function, refer to
system_stm32f0xx.c file
/* LCD Display init
Display_Init();
/* ADC1 and DMA configuration */
ADC1_DMA_Config();
/* Infinite loop */
/* Test DMA1 TC flag */
while((DMA_GetFlagStatus(DMA1_FLAG_TC1)) == RESET );
/* Clear DMA TC flag */
DMA_ClearFlag(DMA1_FLAG_TC1);
/* Display converted data on the LCD */
Display();
ADC1 channel with DMA configuration
* @retval None
void ADC1_DMA_Config(void)
ADC_InitTypeDef
GPIO_InitTypeDef
GPIO_InitS
DMA_InitTypeDef
/* 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_A
DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)RegularConvData_T
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
DMA_InitStructure.DMA_BufferSize = 4;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_D
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_E
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfW
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfW
DMA_InitStructure.DMA_Mode = DMA_Mode_C
DMA_InitStructure.DMA_Priority = DMA_Priority_H
DMA_InitStructure.DMA_M2M = DMA_M2M_D
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_N
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_R
ADC_InitStructure.ADC_ScanDirection = ADC_ScanDirection_B
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);
Display ADC converted value on LCD
* @retval None
void Display(void)
uint32_t v=0,mv=0;
uint8_t text[50],
/* Set the LCD Back Color and Text Color*/
LCD_SetBackColor(White);
LCD_SetTextColor(Green);
for(index=0;index
主题帖子积分
新手上路, 积分 192, 距离下一级还需 -142 积分
新手上路, 积分 192, 距离下一级还需 -142 积分
回复:新手求助~~~STM32F051 ADC出来的数据一直为0【悬赏问答】
DMA_InitStructure.DMA_MemoryBaseAddr = (u32)AD_V&&//DMA内存基地址
这句话有问题,你应该把AD-Value的地址赋值过去,而不是把AD_Value的内容赋值过去,改成这样试试 DMA_InitStructure.DMA_MemoryBaseAddr = (&AD_Value);
主题帖子积分
新手上路, 积分 196, 距离下一级还需 -146 积分
新手上路, 积分 196, 距离下一级还需 -146 积分
RE:新手求助~~~STM32F051 ADC出来的数据一直为0【悬赏问答】
不懂,学习学习。
主题帖子积分
论坛元老, 积分 11146, 距离下一级还需 9988853 积分
论坛元老, 积分 11146, 距离下一级还需 9988853 积分
RE:新手求助~~~STM32F051 ADC出来的数据一直为0【悬赏问答】
尝试吧DMA关掉,然后一步一步调试观察。
主题帖子积分
初级会员, 积分 58, 距离下一级还需 142 积分
初级会员, 积分 58, 距离下一级还需 142 积分
RE:新手求助~~~STM32F051 ADC出来的数据一直为0【悬赏问答】
6楼说的对,我看官方的是个数组,数组名本身就是个地址,而你的AD_VALUE只是个数据!所以没有数据传到AD_VALUE这个变量,只能是0,DMA只是负,内存和CPU ,内存和内存,内存和外设通道之间的数据传输,其实你想得到的AD_VALUE值,是DMA负责从AD通道寄存器那取回来的,其实你也可以自己取,等它AD转换完,你自己手动就可以数据寄存器中拿回来!
主题帖子积分
新手上路, 积分 10, 距离下一级还需 40 积分
新手上路, 积分 10, 距离下一级还需 40 积分
RE:新手求助~~~STM32F051 ADC出来的数据一直为0【悬赏问答】
我用没问题,1年了,不知道是否还需要回答?
Tel: 3-8056
备案号: 苏ICP备号-2
Powered by

我要回帖

更多关于 ad转换原理 的文章

 

随机推荐