fl是什么单位

容积,bai体积单位。

fL:飞升,du1fl等于1立方微米。

正常zhi参考dao值:MCV=82~95fl 1000飞升等于1微升zhuan 1000微升等于1毫升,shu1000毫升等于1升,也就是1fL=10^(-9)L

1立方米=1000立方分米=1000000立方厘米=1000000000立方毫米

相邻体积或容积单位间的进率是1000。高级单位换算成低级单位乘以进率;低级单位换算成高级单位除以进率。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要采集交流电电压,需要使用模拟输入通道。在STM32F407中,可以使用内置的ADC模块进行模拟输入。下面是一个简单的示例代码,可以采集电压并转换为数字信号: ```c #include "stm32f4xx.h" #include <stdio.h> #include <math.h> #define ADC1_DR_ADDRESS ((uint32_t)0x4001204C) #define SAMPLES 512 #define PI 3.14159265358979323846 uint16_t ADCConvertedValues[SAMPLES]; float realValues[SAMPLES]; float imagValues[SAMPLES]; float magnitudeValues[SAMPLES/2]; float phaseValues[SAMPLES/2]; void GPIO_Configuration(void); void ADC_Configuration(void); void FFT(void); int main(void) { GPIO_Configuration(); ADC_Configuration(); while(1) { ADC_SoftwareStartConv(ADC1); while(ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET); FFT(); //找出最大幅值及其相应的频率 float max = magnitudeValues[0]; int index = 0; for(int i = 1; i < SAMPLES/2; i++) { if(magnitudeValues[i] > max) { max = magnitudeValues[i]; index = i; } } float frequency = (float)index / SAMPLES * 10000; //假设采样率为10kHz printf("Maximum magnitude: %f\n", max); printf("Frequency: %f Hz\n", frequency); printf("Phase: %f radians\n", phaseValues[index]); } } void GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; //使能GPIOA时钟 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE); //配置PA0为模拟输入 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL ; GPIO_Init(GPIOA, &GPIO_InitStructure); } void ADC_Configuration(void) { ADC_CommonInitTypeDef ADC_CommonInitStructure; ADC_InitTypeDef ADC_InitStructure; //使能ADC1时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE); //配置ADC1 ADC_CommonInitStructure.ADC_Mode = ADC_Mode_Independent; ADC_CommonInitStructure.ADC_Prescaler = ADC_Prescaler_Div2; ADC_CommonInitStructure.ADC_DMAAccessMode = ADC_DMAAccessMode_Disabled; ADC_CommonInitStructure.ADC_TwoSamplingDelay = ADC_TwoSamplingDelay_5Cycles; ADC_CommonInit(&ADC_CommonInitStructure); ADC_InitStructure.ADC_Resolution = ADC_Resolution_12b; ADC_InitStructure.ADC_ScanConvMode = DISABLE; ADC_InitStructure.ADC_ContinuousConvMode = ENABLE; ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_ExternalTrigConvEdge_None; ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; ADC_InitStructure.ADC_NbrOfConversion = 1; ADC_Init(ADC1, &ADC_InitStructure); //配置ADC1的通道0为模拟输入 ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_3Cycles); //启动ADC1的转换 ADC_Cmd(ADC1, ENABLE); } void FFT(void) { //将采样值转换为实数 for(int i = 0; i < SAMPLES; i++) { realValues[i] = (float)ADCConvertedValues[i] / 4096.0 * 3.3; imagValues[i] = 0.0; } //计算FFT for(int i = 0; i < SAMPLES/2; i++) { float realSum = 0.0; float imagSum = 0.0; for(int j = 0; j < SAMPLES; j++) { realSum += realValues[j] * cos(2 * PI * i * j / SAMPLES); imagSum -= realValues[j] * sin(2 * PI * i * j / SAMPLES); } realValues[i] = realSum; imagValues[i] = imagSum; } //计算幅值和相位 for(int i = 0; i < SAMPLES/2; i++) { magnitudeValues[i] = sqrt(realValues[i]*realValues[i] + imagValues[i]*imagValues[i]) / (SAMPLES/2); phaseValues[i] = atan2(imagValues[i], realValues[i]); } } ``` 在上面的代码中,我们采用了512点FFT计算电压的频谱,找出最大幅值及其相应的频率,以及该频率的相位。注意,这里假设采样率为10kHz,因此频率的单位是Hz,相位的单位是弧度。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

huayang183

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值