用STM32F072实现的示波器、频谱仪、波形发生器、PWM发生器和直流电压源

原创 电子森林 2021-09-12 12:23



这是一位参加“暑期一起练”活动的同学完成的项目,基于下面的这个平台:

硬禾“暑假一起练”平台4&5 - 产品级的多功能测量掌中宝 - 可自己编程、基于STM32或LPC微处理器

以下是这位同学分享在电子森林项目平台的项目报告(完整的报告以及开源的代码可以点击左下角的“阅读原文”跳转):


写在前面

今年寒假我完成了硬禾学堂的STM32G0简易示波器与信号发生器项目(网址:https://www.eetree.cn/project/detail/167),暑假这次活动的开发板是上次活动的升级版,屏幕换成了彩屏,功能更多,也有了更好看的外壳,于是果断白嫖下单。

本项目中示波器与频谱仪部分代码框架与前述项目基本一致,信号发生器部分改动较大,另外添加了PWM波形发生器和直流电源的功能,作为“口袋仪器”的功能更加完善。

工程中共有7个文件夹:

  • Core:工程核心代码,如main函数,外设初始化函数等;

  • Drivers:stm32的HAL库和LL库驱动;

  • common:不同功能的公用部分,包括按键读取和LCD驱动;

  • dc_source:直流电压源功能的实现代码;

  • pwm:PWM发生器功能的实现代码;

  • scope_spectrum:示波器和频谱仪功能的实现代码;

  • signal_source:波形发生器功能的实现代码。

每个口袋仪器的功能都有自己的主函数(如示波器部分的主函数为scope_main,定义在scope.c中),实现某一项功能时程序只在自己的主函数中循环运行,直到切换至另一功能。

 

1 项目需求

综合性项目 - 实现一个完整的口袋仪器的功能

  • 双通道示波器:采集最大10Vpp、最高100KHz的模拟信号,FFT并频谱显示

  • 波形发生器:正弦波、三角波、方波,频率可调,最高为100KHz,可调输出幅度,最大8Vpp,可调直流偏移,从-4V到+4V

  • PWM发生器,可调频率和占空比

  • 双路可编程直流电压源,-4V到+4V可调,可以设置为独立模式和跟踪模式

  • 2个按键、一个拨轮开关控制菜单的所有操作

  • 240 * 240的LCD显示波形、参数、菜单

 

2 完成的功能及达到的性能

2.1 功能切换

我设计的口袋仪器一共有5个功能/页面,分别为:示波器、频谱仪、波形发生器、PWM发生器、直流电源,长按拨轮可以在这几个页面之间切换。

2.2 示波器页面

波形显示页面如上图所示,页面包含以下信息:

  1. 时间分度值:5ms、2ms、1ms、500us、200us、100us、50us,分别对应采样率3.2kHz、8kHz、16 kHz、32 kHz、80 kHz、160 kHz、320 kHz;

  2. 自动(A)或手动(M)Y轴缩放;

  3. 电压分度值:0.02V、0.04 V、0.1 V、0.16 V、0.2 V、0.24 V、0.3 V、0.36 V、0.4 V、0.5 V、0.8 V、1 V;

  4. 主通道,即Y轴自动缩放和触发功能的基准通道;

  5. 触发边沿:上升沿或者下降沿;

  6. 触发状态及模式:字母代表触发模式(C:连续触发,S:单次触发,X:关闭触发),颜色代表触发状态(红色:触发失败,青绿色:触发成功,棕色:触发关闭);

  7. 波形显示区:显示两个输入通道的波形(CH1:黄色,CH2:绿色);

  8. Y轴电压指示:坐标区顶部、中间和底部的电压值;

  9. 通道开关:CH1开启:黄色,CH2开启:绿色,通道关闭:棕色;

  10. 通道信息:通道直流电压值、电压峰峰值、频率。

除②、⑦、⑧、⑩项以外,其余均可手动调节,按下设备左上方的两个按键可以切换当前选中的项,选中项背景变为灰色,再通过左右调节拨轮可以改变该项的内容,调节完毕后长按左上方两个按键可以取消选中。第②项(Y轴缩放)由手动缩放改为自动缩放的方式为将电压分度值调至1V,再往上调节一档,此时即为自动缩放;由自动缩放改为手动缩放方式为向任意方向调节电压分度值。⑦、⑧、⑩项仅为信息显示,无法手动更改。

按下拨轮可以暂停/继续波形刷新。

2.3 频谱仪页面

频谱显示页面如上图所示,页面包含以下信息:

  1. 信号频谱(CH1:黄色,CH2:绿色);

  2. 频率轴刻度,单位为kHz;

  3. 当前采样率(同示波器);

  4. 通道开关:CH1开启:黄色,CH2开启:绿色,通道关闭:棕色。

其中③、④项可以手动调节,调节方式与示波器的相同,②跟随采样率自动调节。

由于采样率最高为320kHz,根据奈奎斯特采样定理,频谱最高可以显示160kHz的频率分量。

2.4  波形发生器页面

波形发生器页面如上图所示,页面包含以下信息(均可手动调节):

  1. 输出开关;

  2. 波形类型:正弦波、方波、三角波;

  3. 频率:调节范围为0.1kHz至100kHz;

  4. 电压幅值(峰峰值一半):调节范围为0V~4V;

  5. 直流偏移:调节范围为-4V至4V。

2.5 PWM发生器页面

PWM发生器页面如上图所示,页面包含以下信息(均可手动调节):

  1. 输出开关;

  2. 频率:调节范围为1kHz至100kHz;

  3. 占空比:0%至100%。

2.6 直流电源页面

直流电源页面如上图所示,页面包含以下信息(均可手动调节):

  1. 跟踪开关:若开启跟踪,则只能手动调节通道1的参数,通道2跟随通道1自动调整,电压为通道1电压的相反数;

  2. 通道1/2输出开关;

  3. 通道1/2输出电压:范围为-4V至4V。

3 实现思路

3.1 示波器与频谱仪

  • ADC对模拟输入进行采样,采样由定时器触发,采样结果由DMA搬运;

  • 将采样得到的ADC量化值映射到屏幕坐标点上,实现波形显示;

  • 对采样序列进行FFT变换,绘制频谱;

  • 按下按键调整采样频率,实现波形在时间轴上的扩展与压缩;

  • 信号参数的显示,如峰峰值、直流分量、信号频率等。

3.2 波形发生器

  • 根据预设的输出信号波形信息生成查找表;

  • DMA将查找表数据逐项搬运至DAC进行输出,搬运由定时器触发;

  • 按键调整输出使能、信号参数等。

3.3 PWM发生器

  • 使用STM32定时器自带的PWM功能输出PWM信号;

  • 按键调整输出使能、频率与占空比,并进行定时器参数的更新。

3.4 直流电源

  • 使用STM32定时器自带的PWM功能生成PWM信号,经低通滤波器后输出直流信号;

  • 改变PWM的占空比即可改变直流电压值。

 

4 示波器与频谱仪实现过程

4.1 ADC对信号进行采样

为了方便进行FFT计算,ADC在每个通道共采集256个采样点。每次ADC转换由定时器1触发,触发频率最高为320kHz,即ADC采样率最高为320ksps。ADC的转换结果直接由DMA搬运至内存。

ADC转换开始函数(定义位置:sample.c,调用位置:scope.c):

/**
* @brief Start a new sample sequence.
* @param[in] ADCValue_raw Array to store incoming sample values.
* @retval None
*/

void start_sample(uint16_t *ADCValue_raw)
{
HAL_Delay(1);
HAL_ADCEx_Calibration_Start(&hadc);
HAL_ADC_Start_DMA(&hadc, (uint32_t *)ADCValue_raw, SAMPLE_POINTS * 2);
}

256次转换结束后进入中断,置位结束标志位,进入后续的数据处理程序。

ADC转换结束中断回调函数(定义位置:stm32f0xx_it.c):

void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef *hadc)
{
finish_sample();
}

4.2 采样结果的处理

由于ADC一次触发对两个通道进行采样,在采样后的数组里两个通道的采样信息是交替的,需要对其分开,即将采样后的原始数组转化为二维数组,二维数组每一行代表一个通道的ADC量化值。

ADC数据转换部分代码(定义位置:sample.c,调用位置:scope.c):

/**
* @brief Split raw ADCValue array to a 2-D array based on channels.
* @param[in] ADCValue_raw Array to store raw sample values.
* @param[out] ADCValue 2-D array of split sample values.
* @note Each row in ADCValue contains sample values in a channel.
* @retval None
*/

void ADCValue_split(uint16_t *ADCValue_raw, uint16_t ADCValue[][SAMPLE_POINTS])
{
uint16_t i;
for (i = 0; i < SAMPLE_POINTS; i++)
{
ADCValue[CH2][i] = ADCValue_raw[2*i];
ADCValue[CH1][i] = ADCValue_raw[2*i+1];
}
}

得到每个通道256个ADC量化值后,根据触发电平(0V)选择波形起始点,返回起始点在数组中的下标,显示从起始点开始的192个点。

波形触发部分代码(定义位置:wave.c,调用位置:scope.c,其中total_points=256, GRAPH_WIDTH=193):

/**
* @brief Wave trigger.
* @param[in] ADCValue Array of sampled ADC values (one channel).
* @param[in] total_points Total sampled points.
* @retval Index of the trigger start point(>1). 0 means trigger off or failed.
*/

uint16_t trigger(uint16_t *ADCValue, uint16_t total_points)
{
uint16_t i;
uint16_t trigger_value = VOL2ADC(0);

if (!is_trigger_on())
return 0;

for (i = 1; i < total_points - GRAPH_WIDTH + 2; i++)
{
if (!get_trigger_edge()) // falling edge
{
if (ADCValue[i-1] > trigger_value && ADCValue[i] <= trigger_value)
{
trigger_success();
if (is_trigger_single())
pause();
return i;
}
}
else
{
if (ADCValue[i-1] <= trigger_value && ADCValue[i] > trigger_value)
{
trigger_success();
if (is_trigger_single())
pause();
return i;
}
}
}

trigger_fail();
return 0;
}

为显示上述192个点,需要将ADC量化值与LCD屏幕上的坐标进行线性映射,线性映射需考虑:ADC量化值向ADC输入电压值的映射,ADC输入电压值向运放输入电压值的映射,ADC量化值向LCD屏幕纵坐标的映射。

在自动模式(自动缩放y轴)中,程序以主通道为基准,自动找出量化值中的最大最小值,并使最大最小值也能不超出绘制范围以外,这样屏幕就可以显示主通道完整的波形。在手动缩放模式中,可以手动调节y轴的缩放范围,但此时波形不一定会完整显示。

得到采样点坐标后,使用st7789库的绘制直线函数,连接屏幕上各个离散的点,就可以得到信号的波形。此外,若在绘制波形之前刷新屏幕或者一次性删除掉上次的波形,会有非常明显的闪屏现象。所以绘制波形的过程中需要边删除边绘制,即删除一小段上次的波形,再绘制一小段新的波形,重复以上操作,直至整个波形绘制完毕。

自动缩放y轴代码(定义位置:wave.c,调用位置:scope.c):

/**
* @brief Automatically find the central/max/min voltage on y-axis.
* @param[in] ADCValue Array of sampled ADC values (one channel).
* @note The function calculates the min/max voltage of the main channel signal,
* then find a proper scale voltage and a central voltage on y-axis.
* @retval None
*/

void auto_scale(uint16_t *ADCValue)
{
uint16_t a_max_value, a_min_value, a_pp_value;
get_max_min_pp_value(ADCValue, &a_max_value, &a_min_value, &a_pp_value);
voltage_range_auto_select(ADC2VOL(a_min_value) > -ADC2VOL(a_max_value) ? ADC2VOL(a_min_value) : -ADC2VOL(a_max_value));
volt_on_y_axis.center_voltage = 0;
volt_on_y_axis.max_voltage = volt_on_y_axis.center_voltage + v_scale_list[v_scale_index];
volt_on_y_axis.min_voltage = volt_on_y_axis.center_voltage - v_scale_list[v_scale_index];
}

坐标映射代码(定义位置:wave.c,调用位置:scope.c):

/**
* @brief Generate y-coordinates of the wave.
* @param[in] ADCValue 2-D array of sampled ADC values (all channels).
* @param[in] trigger_index index of the first point of triggered wave
* @param[out] y 2-D Y-coordinate array of the wave.
* @note The function map ADCValues to LCD y coordinates.
* @retval None
*/

void generate_wave(uint16_t ADCValue[][SAMPLE_POINTS], uint16_t trigger_index, uint8_t y[][GRAPH_WIDTH])
{
// Quantize y-axis min/max voltages to ADC values.
int16_t a_max_value = VOL2ADC(volt_on_y_axis.min_voltage);
int16_t a_min_value = VOL2ADC(volt_on_y_axis.max_voltage);
uint8_t i;
enum channel ch;

for (ch = 0; ch < NUM_CH; ch++)
{
// Linearly map every ADC value to its coordinate.
for (i = 0; i < GRAPH_WIDTH - 1; i++)
{
if (ADCValue[ch][i+trigger_index] <= a_max_value && ADCValue[ch][i+trigger_index] >= a_min_value)
y[ch][i] = (GRAPH_HEIGHT - 1) * (ADCValue[ch][i+trigger_index] - a_min_value) / (a_max_value - a_min_value) + GRAPH_START_Y;
else if (ADCValue[ch][i+trigger_index] > a_max_value)
y[ch][i] = GRAPH_HEIGHT + GRAPH_START_Y - 1;
else if (ADCValue[ch][i+trigger_index] < a_min_value)
y[ch][i] = GRAPH_START_Y;
}
}

}

波形显示代码(定义位置:scope_display.c,调用位置:scope.c):

/**
* @brief Display wave on LCD.
* @param[in] y Y-coordinate array of the wave.
* @param[in] y_prev Y-coordinate array of the wave to be cleared.
* @param[in] ch channel of the wave
* @retval None
*/

void display_wave(const uint8_t *y, const uint8_t *y_prev, enum channel ch)
{
uint8_t x;
for (x = GRAPH_START_X; x < GRAPH_WIDTH - 1; x++)
{
ST7789_DrawLine(x, y_prev[x-GRAPH_START_X], x + 1, y_prev[x-GRAPH_START_X+1], BLACK);
ST7789_DrawLine(x, y[x-GRAPH_START_X], x + 1, y[x-GRAPH_START_X+1], ch_color[ch]);
}
}

4.3 频谱显示

在频谱显示页面,需要对各通道的ADC的量化值分别进行256点FFT变换。去掉低频、直流和无效部分,保留FFT序号为8~127的结果,进行线性映射后显示在屏幕上。

FFT的代码定义在fftutil.c中,对变换结果的处理及显示分别定义在spectrum.c和spectrum_display.c中。

5 波形发生器实现过程

波形发生器部分主要参考https://www.emoe.xyz/archives/1469设计,设计思路在3.2节中已经介绍,这里对一些实现细节与修改部分进行分析。

5.1 查找表

由dds原理可知,输出信号频率的计算公式为

其中f_MCLK为dds主频率(查找表步进频率),为定时器溢出频率的二倍(DMA Double Data Mode,见前文链接);N_max为查找表表长,查找表储存了待输出信号一个周期内的幅度值。在stm32中,为保证输出频率f_out取在0.1kHz~100kHz范围内且频率误差足够小,且防止查找表占用过大空间,f_MCLK和N_max必须是可变的,即对于不同的f_out,需要规定一个合适的f_MCLK,并算出对应的N_max。

设置N_max和f_MCLK的代码如下(DDS_setWaveParams函数,定义在dds.c中):

// Select frequency range and register timer's parameters
if (freq >= 100 && freq < 1000)
{
// FMCLK = 100kHz, 48M / 960 * 2 = 100kHz
__HAL_TIM_SET_AUTORELOAD(&htim3, 960-1);
dds.lutLen = (uint32_t)(100000 / freq);
getNewWaveLUT(dds.lutLen, dds.waveType, dds.amp, dds.offset);
}
else if (freq >= 1000 && freq < 10000)
{
// FMCLK = 1MHz, 48M / 96 * 2 = 1MHz
__HAL_TIM_SET_AUTORELOAD(&htim3, 96-1);
dds.lutLen = (uint32_t)(1000000 / freq);
getNewWaveLUT(dds.lutLen, dds.waveType, dds.amp, dds.offset);
}
else if (freq >= 10000 && freq < 100000)
{
// FMCLK = 2MHz, 48M / 48 * 2 = 2MHz
__HAL_TIM_SET_AUTORELOAD(&htim3, 48-1);
dds.lutLen = (uint32_t)(2000000 / freq);
getNewWaveLUT(dds.lutLen, dds.waveType, dds.amp, dds.offset);
}

getNewWaveLUT为查找表生成函数,前面算出的N_max(代码中为dds.lutlen)即为查找表表长。我对原作者的getNewWaveLUT函数进行了修改,使其能直接生成信号幅度、直流偏移可变的查找表,代码如下:(定义位置:dds.c,其中DAC_AMP=2046代表输出为0V时DAC量化值为2046,DDS_MAX_AMP=40代表最大幅度为4.0V)

void getNewWaveLUT(uint32_t length, uint8_t type, uint8_t amp, int8_t offset)
{
uint16_t a_offset_value = DAC_AMP - (int32_t)DAC_AMP * offset / DDS_MAX_AMP;
char str[6];
sprintf(str, "%5u", a_offset_value);
ST7789_WriteString(10, 220, str, Font_11x18, WHITE, BLACK);
if (type == SINE_WAVE)
{
float sin_step = 2.0f * 3.14159f / (float)(length-1);
for (uint16_t i = 0; i < length; i++)
{
dds_lut[i] = (uint16_t)(a_offset_value - (DAC_AMP * sinf(sin_step*(float)i) * amp / DDS_MAX_AMP));
}
}

else if (type == SQUARE_WAVE)
{
for(uint16_t i = 0; i < length / 2; i++)
{
dds_lut[i] = a_offset_value - DAC_AMP * amp / DDS_MAX_AMP;
dds_lut[i + (length / 2)] = a_offset_value + DAC_AMP * amp / DDS_MAX_AMP;
}
}

else if (type == TRIANGLE_WAVE)
{
uint16_t tri_step = DAC_AMP * 2 * amp / DDS_MAX_AMP / (length/2);

for(uint16_t i = 0; i < length / 2; i++)
{
dds_lut[i] = a_offset_value - DAC_AMP * amp / DDS_MAX_AMP + tri_step*i;
dds_lut[length - i - 1] = dds_lut[i];
}
}
}

5.2 DAC Output Buffer

原作者提到关闭DAC Output Buffer可以提升DAC输出速率,但是关闭DAC Output Buffer会使DAC端口的输出电阻变大,在本项目中会导致输出电压有很大的误差。为保证输出电压的准确性,本项目需要开启DAC Output Buffer。

 

6 遇到的主要难题

在寒假我参与了“STM32G0简易示波器与信号发生器”项目,遇到的一些主要困难可以在该项目的主页中找到(网址:https://www.eetree.cn/project/detail/167)。虽然两个项目都是基于STM32CUBEIDE开发,不过将程序从G0芯片移植到F0芯片,还是遇到了许多问题:

  • 时钟频率的问题:G0芯片的时钟频率是64M,而F0芯片是48M,代码中许多与时钟相关的地方需要重新调整频率值。

  • ADC转换通道问题:寒假的项目中ADC每次只需要对一个通道进行采样,通过按键切换到另一通道;而F0芯片需要对两个ADC通道同时采样,而且转换结果也是放在一个数组里交替存储的,需要将其分开,因此很多函数的输入参数都需要从原来的一维数组改为二维数组,以同时处理两个通道的数据。

  • 屏幕驱动及显示问题:寒假的项目使用的是OLED屏幕,本次项目使用的是LCD屏幕,且两个屏幕的分辨率、驱动等均不同。本次项目LCD显示部分我使用了Floyd-Fish的ST7789库(链接:https://github.com/Floyd-Fish/ST7789-STM32),该库底层使用HAL库实现,但作为示波器显示波形时波形刷新速度很慢,经常卡顿,我将其改为LL库后刷新速度有了很大提升。HAL库的SPI发送函数调用了很多子函数,非常繁琐耗时,而LL库的SPI发送函数只有几步寄存器操作,极为高效。

 

7 未来的计划建议

该项目已经成功实现了口袋仪器的基本功能,并达到了预期指标。然而还有一些可以提升与扩展的地方:

  • 可以引出调试接口(UART或SWD)或增加LED指示灯,在这次活动中我主要使用LCD显示调试内容,较为不便。

  • 主控芯片STM32F072的资源有限。可以更换更好的主控芯片,来提高采样率,采样点数等从而实现更高的性能,也能实现更快的屏幕刷新速度。

  • 示波器测得的电压与波形发生器输出的电压值有一些误差,误差来源可能是算法中的误差或者是运放电路中元件参数的误差。虽然可以通过软件进行线性矫正或利用反馈端口进行调节,但由于时间精力有限未能完成。

  • 当前触发电平被固定在0V,且无法(不修改代码)调节,导致一些波形(如PWM波,电压值恒≥0V)无法准确被触发,以后可以添加调节触发电平的功能。



这款基于STM32F072的口袋仪器是一款专用于嵌入式编程学习的平台,硬禾学堂同时开发了一款基于STM32G491的商用版本,已经上线Kickstarter众筹平台:Kickstarter上众筹的多功能袖珍仪器 - 随时、随地学习电路、调试电路的好帮手

硬件设计跟这款STM32F072的平台基本一致。


祝周末愉快!


电子森林 讲述电子工程师需要掌握的重要技能: PCB设计、FPGA应用、模拟信号链路、电源管理等等;不断刷新的行业新技术 - 树莓派、ESP32、Arduino等开源系统;随时代演进的热点应用 - 物联网、无人驾驶、人工智能....
评论
  • 【萤火工场CEM5826-M11测评】OLED显示雷达数据本文结合之前关于串口打印雷达监测数据的研究,进一步扩展至 OLED 屏幕显示。该项目整体分为两部分: 一、框架显示; 二、数据采集与填充显示。为了减小 MCU 负担,采用 局部刷新 的方案。1. 显示框架所需库函数 Wire.h 、Adafruit_GFX.h 、Adafruit_SSD1306.h . 代码#include #include #include #include "logo_128x64.h"#include "logo_
    无垠的广袤 2024-12-10 14:03 69浏览
  • 习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-10 16:13 105浏览
  • 我的一台很多年前人家不要了的九十年代SONY台式组合音响,接手时只有CD功能不行了,因为不需要,也就没修,只使用收音机、磁带机和外接信号功能就够了。最近五年在外地,就断电闲置,没使用了。今年9月回到家里,就一个劲儿地忙着收拾家当,忙了一个多月,太多事啦!修了电气,清理了闲置不用了的电器和电子,就是一个劲儿地扔扔扔!几十年的“工匠式”收留收藏,只能断舍离,拆解不过来的了。一天,忽然感觉室内有股臭味,用鼻子的嗅觉功能朝着臭味重的方向寻找,觉得应该就是这台组合音响?怎么会呢?这无机物的东西不会腐臭吧?
    自做自受 2024-12-10 16:34 136浏览
  •         在有电流流过的导线周围会感生出磁场,再用霍尔器件检测由电流感生的磁场,即可测出产生这个磁场的电流的量值。由此就可以构成霍尔电流、电压传感器。因为霍尔器件的输出电压与加在它上面的磁感应强度以及流过其中的工作电流的乘积成比例,是一个具有乘法器功能的器件,并且可与各种逻辑电路直接接口,还可以直接驱动各种性质的负载。因为霍尔器件的应用原理简单,信号处理方便,器件本身又具有一系列的du特优点,所以在变频器中也发挥了非常重要的作用。  &nb
    锦正茂科技 2024-12-10 12:57 76浏览
  • 概述 通过前面的研究学习,已经可以在CycloneVGX器件中成功实现完整的TDC(或者说完整的TDL,即延时线),测试结果也比较满足,解决了超大BIN尺寸以及大量0尺寸BIN的问题,但是还是存在一些之前系列器件还未遇到的问题,这些问题将在本文中进行详细描述介绍。 在五代Cyclone器件内部系统时钟受限的情况下,意味着大量逻辑资源将被浪费在于实现较大长度的TDL上面。是否可以找到方法可以对此前TDL的长度进行优化呢?本文还将探讨这个问题。TDC前段BIN颗粒堵塞问题分析 将延时链在逻辑中实现后
    coyoo 2024-12-10 13:28 101浏览
  • 一、SAE J1939协议概述SAE J1939协议是由美国汽车工程师协会(SAE,Society of Automotive Engineers)定义的一种用于重型车辆和工业设备中的通信协议,主要应用于车辆和设备之间的实时数据交换。J1939基于CAN(Controller Area Network)总线技术,使用29bit的扩展标识符和扩展数据帧,CAN通信速率为250Kbps,用于车载电子控制单元(ECU)之间的通信和控制。小北同学在之前也对J1939协议做过扫盲科普【科普系列】SAE J
    北汇信息 2024-12-11 15:45 74浏览
  • RK3506 是瑞芯微推出的MPU产品,芯片制程为22nm,定位于轻量级、低成本解决方案。该MPU具有低功耗、外设接口丰富、实时性高的特点,适合用多种工商业场景。本文将基于RK3506的设计特点,为大家分析其应用场景。RK3506核心板主要分为三个型号,各型号间的区别如下图:​图 1  RK3506核心板处理器型号场景1:显示HMIRK3506核心板显示接口支持RGB、MIPI、QSPI输出,且支持2D图形加速,轻松运行QT、LVGL等GUI,最快3S内开
    万象奥科 2024-12-11 15:42 66浏览
  •         霍尔传感器是根据霍尔效应制作的一种磁场传感器。霍尔效应是磁电效应的一种,这一现象是霍尔(A.H.Hall,1855—1938)于1879年在研究金属的导电机构时发现的。后来发现半导体、导电流体等也有这种效应,而半导体的霍尔效应比金属强得多,利用这现象制成的各种霍尔元件,广泛地应用于工业自动化技术、检测技术及信息处理等方面。霍尔效应是研究半导体材料性能的基本方法。通过霍尔效应实验测定的霍尔系数,能够判断半导体材料的导电类型、载流子浓度及载流子
    锦正茂科技 2024-12-10 11:07 64浏览
  • 天问Block和Mixly是两个不同的编程工具,分别在单片机开发和教育编程领域有各自的应用。以下是对它们的详细比较: 基本定义 天问Block:天问Block是一个基于区块链技术的数字身份验证和数据交换平台。它的目标是为用户提供一个安全、去中心化、可信任的数字身份验证和数据交换解决方案。 Mixly:Mixly是一款由北京师范大学教育学部创客教育实验室开发的图形化编程软件,旨在为初学者提供一个易于学习和使用的Arduino编程环境。 主要功能 天问Block:支持STC全系列8位单片机,32位
    丙丁先生 2024-12-11 13:15 47浏览
  • 时源芯微——RE超标整机定位与解决详细流程一、 初步测量与问题确认使用专业的电磁辐射测量设备,对整机的辐射发射进行精确测量。确认是否存在RE超标问题,并记录超标频段和幅度。二、电缆检查与处理若存在信号电缆:步骤一:拔掉所有信号电缆,仅保留电源线,再次测量整机的辐射发射。若测量合格:判定问题出在信号电缆上,可能是电缆的共模电流导致。逐一连接信号电缆,每次连接后测量,定位具体哪根电缆或接口导致超标。对问题电缆进行处理,如加共模扼流圈、滤波器,或优化电缆布局和屏蔽。重新连接所有电缆,再次测量
    时源芯微 2024-12-11 17:11 70浏览
  • 智能汽车可替换LED前照灯控制运行的原理涉及多个方面,包括自适应前照灯系统(AFS)的工作原理、传感器的应用、步进电机的控制以及模糊控制策略等。当下时代的智能汽车灯光控制系统通过车载网关控制单元集中控制,表现特殊点的有特斯拉,仅通过前车身控制器,整个系统就包括了灯光旋转开关、车灯变光开关、左LED前照灯总成、右LED前照灯总成、转向柱电子控制单元、CAN数据总线接口、组合仪表控制单元、车载网关控制单元等器件。变光开关、转向开关和辅助操作系统一般连为一体,开关之间通过内部线束和转向柱装置连接为多,
    lauguo2013 2024-12-10 15:53 78浏览
  • 全球知名半导体制造商ROHM Co., Ltd.(以下简称“罗姆”)宣布与Taiwan Semiconductor Manufacturing Company Limited(以下简称“台积公司”)就车载氮化镓功率器件的开发和量产事宜建立战略合作伙伴关系。通过该合作关系,双方将致力于将罗姆的氮化镓器件开发技术与台积公司业界先进的GaN-on-Silicon工艺技术优势结合起来,满足市场对高耐压和高频特性优异的功率元器件日益增长的需求。氮化镓功率器件目前主要被用于AC适配器和服务器电源等消费电子和
    电子资讯报 2024-12-10 17:09 84浏览
  • 近日,搭载紫光展锐W517芯片平台的INMO GO2由影目科技正式推出。作为全球首款专为商务场景设计的智能翻译眼镜,INMO GO2 以“快、准、稳”三大核心优势,突破传统翻译产品局限,为全球商务人士带来高效、自然、稳定的跨语言交流体验。 INMO GO2内置的W517芯片,是紫光展锐4G旗舰级智能穿戴平台,采用四核处理器,具有高性能、低功耗的优势,内置超微高集成技术,采用先进工艺,计算能力相比同档位竞品提升4倍,强大的性能提供更加多样化的应用场景。【视频见P盘链接】 依托“
    紫光展锐 2024-12-11 11:50 47浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦