国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

【GD32L233C-START】DAC輸出(正弦波、鋸齒波、方波)

西安樂拓精益 ? 2022-07-11 09:43 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1.介紹
GD32L233C采用的是一款M23的內核。這個芯片據說功耗非常的低,低到什么程度呢?等后面我們再進行測試,今天我們主要來測試GD32L233C-STARTDAC,既然要測試DAC,示波器是不可少的,這個實驗在家做,然而LZ家里并沒有示波器,不過最近看到一款好東西,LOTO虛擬示波器,看過這款示波器的參數,還不錯。所以入手了一款,測量芯片輸出的DAC應該沒什么問題,接下來開始測試吧。
2.設計
首先需要輸出讓芯片輸出DAC,而且還需要輸出波形,這個稍微費點功夫,之前在GD32L233C-START移植了RTThread,現在在這個代碼的基礎上添加DAC的輸出程序,這個程序移植了其他網友的,代碼我也貼出來,經過測試,代碼沒有啥問題:
比較麻煩的是正弦波的代碼:

const float sinus_I_quarter[91] =
{
0.0000, 0.0175, 0.0349, 0.0523, 0.0698, 0.0872, 0.1045, 0.1219, 0.1392, 0.1564, // 00 .. 09
0.1736, 0.1908, 0.2079, 0.2250, 0.2419, 0.2588, 0.2756, 0.2924, 0.3090, 0.3256, // 10 .. 19
0.3420, 0.3584, 0.3746, 0.3907, 0.4067, 0.4226, 0.4384, 0.4540, 0.4695, 0.4848, // 20 .. 29
0.5000, 0.5150, 0.5299, 0.5446, 0.5592, 0.5736, 0.5878, 0.6018, 0.6157, 0.6293, // 30 .. 39
0.6428, 0.6561, 0.6691, 0.6820, 0.6947, 0.7071, 0.7193, 0.7314, 0.7431, 0.7547, // 40 .. 49
0.7660, 0.7771, 0.7880, 0.7986, 0.8090, 0.8192, 0.8290, 0.8387, 0.8480, 0.8572, // 50 .. 59
0.8660, 0.8746, 0.8829, 0.8910, 0.8988, 0.9063, 0.9135, 0.9205, 0.9272, 0.9336, // 60 .. 69
0.9397, 0.9455, 0.9511, 0.9563, 0.9613, 0.9659, 0.9703, 0.9744, 0.9781, 0.9816, // 70 .. 79
0.9848, 0.9877, 0.9903, 0.9925, 0.9945, 0.9962, 0.9976, 0.9986, 0.9994, 0.9998, // 80 .. 89
1.0000 // 90
};

#define CIRCLE_QUARTER_1 1
#define CIRCLE_QUARTER_2 2
#define CIRCLE_QUARTER_3 3
#define CIRCLE_QUARTER_4 4
float sinus_lookup (unsigned int angle)
{
float sin_value;
unsigned int circle_quarter;
// correct angles outside the accepted angle range into 0 .. 359
if (angle > 359u)
angle = angle % 360u;
circle_quarter = 1 + (angle / 90u);
switch (circle_quarter)
{
case CIRCLE_QUARTER_1: // 00 .. 89
sin_value = sinus_I_quarter[angle];
break;
case CIRCLE_QUARTER_2: // 90 .. 179
sin_value = sinus_I_quarter[180 - angle];
break;
case CIRCLE_QUARTER_3: // 180 .. 269
sin_value = -sinus_I_quarter[angle - 180];
break;
case CIRCLE_QUARTER_4: // 270 .. 359
sin_value = -sinus_I_quarter[360 - angle];
break;
}
return sin_value;
}

void plot_sin(uint32_t f, uint32_t delta_f)
{
/* 定時周期為T=1/delta_f, f=1/(pMax*T) */
static uint32_t point = 0;
uint32_t pMAX = delta_f/f;
uint32_t value = 0;
if (point++ > pMAX) point = 0;
value = (uint32_t)((sinus_lookup(360*point/pMAX)+1)*10000)*2047/10000;
dac_software_trigger_enable();
dac_data_set(DAC_ALIGN_12B_R, value);
}

接下來是鋸齒波和方波的代碼,這兩個代碼比較簡單:

void plot_triangle(uint32_t f, uint32_t delta_f)
{
/* 定時周期為T=1/delta_f, f=1/(pMax*T) */
static uint32_t point = 0;
uint32_t pMAX = delta_f/f;
uint32_t pMAX2 = pMAX/2;
uint32_t value = 0;
if (++point > pMAX) point = 0;
if (point < pMAX2)
{
value = point * 4095 / pMAX2;
}
else
{
value = (pMAX - point) * 4095 / pMAX2;
}
dac_software_trigger_enable();
dac_data_set(DAC_ALIGN_12B_R, value);
}
void plot_square(uint32_t f, uint32_t delta_f)
{
/* 定時周期為T=1/delta_f, f=1/(pMax*T) */
static uint32_t point = 0;
uint32_t pMAX = delta_f/f;
uint32_t pMAX2 = pMAX/2;
uint32_t value = 0;
if (++point > pMAX) point = 0;
if (point < pMAX2)
{
value = 0;
}
else
{
value = 0xFFF;
}
dac_software_trigger_enable();
dac_data_set(DAC_ALIGN_12B_R, value);
}

最后需要開啟一個定時器,還有DAC的初始化:

void timerx_init(uint32_t timer_periph, uint16_t period, uint16_t prescaler)
{
/* TIMER1 configuration: input capture mode -------------------
the external signal is connected to TIMER1 CH0 pin (PA0)
the rising edge is used as active edge
the TIMER1 CH0CV is used to compute the frequency value
------------------------------------------------------------ */
timer_parameter_struct timer_initpara;
timer_ic_parameter_struct timer_icinitpara;

/* enable the peripherals clock */
rcu_periph_clock_enable(RCU_TIMER2);

/* deinit a TIMER */
timer_deinit(timer_periph);
/* initialize TIMER init parameter struct */
timer_struct_para_init(&timer_initpara);
/* TIMER1 configuration */
timer_initpara.prescaler = prescaler;
timer_initpara.alignedmode = TIMER_COUNTER_EDGE;
timer_initpara.counterdirection = TIMER_COUNTER_UP;
timer_initpara.period = period;
timer_initpara.clockdivision = TIMER_CKDIV_DIV1;
timer_init(timer_periph, &timer_initpara);

/* TIMER1 CH0 input capture configuration */
timer_icinitpara.icpolarity= TIMER_IC_POLARITY_RISING;
timer_icinitpara.icselection = TIMER_IC_SELECTION_DIRECTTI;
timer_icinitpara.icprescaler = TIMER_IC_PSC_DIV1;
timer_icinitpara.icfilter = 0x00;
timer_input_capture_config(timer_periph, TIMER_CH_0, &timer_icinitpara);

/* auto-reload preload enable */
timer_auto_reload_shadow_enable(timer_periph);
/* clear channel 0 interrupt bit */
timer_interrupt_flag_clear(timer_periph, TIMER_INT_CH0);
/* channel 0 interrupt enable */
timer_interrupt_enable(timer_periph, TIMER_INT_CH0);

/* enable a TIMER */
timer_enable(timer_periph);
}

#define DAC_WAVE_TEST

void timer2_init(void)
{
timer_deinit(TIMER2);
rcu_periph_clock_enable(RCU_TIMER2);
#ifdef DAC_WAVE_TEST
timerx_init(TIMER2, 639, 9);// 100KHz 0.1ms
#endif
timer_interrupt_enable(TIMER2, TIMER_INT_UP);
nvic_irq_enable(TIMER2_IRQn, 3);
}

void TIMER2_IRQHandler(void)
{
#ifdef DAC_WAVE_TEST
plot_sin(100, 10000); //正弦波
//plot_triangle(1, 10000);//鋸齒波
//plot_square(1, 10000); //方波
#endif
timer_interrupt_flag_clear(TIMER2, TIMER_INT_FLAG_UP);
}

void dac1_init(void)
{
rcu_periph_clock_enable(RCU_GPIOA);
rcu_periph_clock_enable(RCU_DAC);
gpio_mode_set(GPIOA, GPIO_MODE_ANALOG, GPIO_PUPD_NONE, GPIO_PIN_4);
dac_deinit();
/* software trigger */
dac_trigger_enable();
dac_trigger_source_config(DAC_TRIGGER_SOFTWARE);
/* no noise wave */
dac_wave_mode_config(DAC_WAVE_DISABLE);
/* noise wave - triangle */
//dac_wave_mode_config(DAC_WAVE_MODE_TRIANGLE);
//dac_triangle_noise_config(DAC_TRIANGLE_AMPLITUDE_4095);
/* noise wave - lfsr */
//dac_wave_mode_config(DAC_WAVE_MODE_LFSR);
//dac_lfsr_noise_config(DAC_LFSR_BITS11_0);
dac_output_buffer_enable();
/* enable DAC and set data */
dac_enable();
dac_software_trigger_enable();
dac_data_set(DAC_ALIGN_12B_R, 0);
}

這樣就可以輸出正弦波、鋸齒波和方波了。
3.波形測量
接下來我們來看一下輸出的波形是否符合要求,首先需要將【GD32L233C-START】開發板連接LOTO示波器,分別連接GND和PA4管教,連接效果圖如下圖1所示。

pYYBAGLLgA-ALleqAAEijK3TbPg311.png

圖1


然后讓DAC輸出正弦波,看一下波形如何。

poYBAGLLgA-ACO87AACyN65vJzA238.png

圖2


從上圖2中可以看到,一個周期大約在10ms,所以正弦波的周期為100Hz,輸出還是聽精準的。
然后輸出鋸齒波看看波形如何。

poYBAGLLgA-AP8vpAACyQLQS5Hk395.png

圖3


從上圖3可以得出,鋸齒波的波形頻率為1Hz。
最后我們來看看方波的波形圖如何。

pYYBAGLLgA-AUNobAACvY54PfmY014.png

圖4


從上圖4可以看到,方波的波形頻率為1Hz。
從上面波形可以得出,【GD32L233C-START】的定時器比較精準,DAC的輸出值也比較穩定,性能還是不錯的!
4.總結
剛入手的LOTO示波器還不錯,測量的精度挺高的,不過還有好多設置沒弄明白,等后續多琢磨琢磨。做電子的示波器是必不可少的,我先替你們測試測試這個示波器如何。
GD32L233C是新出來的芯片,整體功能還需要多進行測試,它最突出的低功耗后續要好好測量一下,這次就先到這里了。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 示波器
    +關注

    關注

    113

    文章

    7075

    瀏覽量

    196045
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    基于STM32F103驅動AD9833模塊 DDS信號發生器輸出正弦波/三角/方波可編程信號

    AD9833是一款低功耗可編程波形發生器,能輸出正弦波、三角方波,頻率范圍為1Hz-9MHz,采用SPI串行通信。具有28位頻率寄存器和12位相位寄存器,可通過公式計算
    的頭像 發表于 01-10 10:30 ?2107次閱讀
    基于STM32F103驅動AD9833模塊 DDS信號發生器<b class='flag-5'>輸出</b><b class='flag-5'>正弦波</b>/三角<b class='flag-5'>波</b>/<b class='flag-5'>方波</b>可編程信號

    晶振的輸出波形:TTL、CMOS、LVPECL、LVDS和正弦波

    晶振(XO)輸出波形(Output Type)是與封裝尺寸一樣重要的一個技術指標,這些輸出波形可簡單歸為兩種:正弦波、方波。
    的頭像 發表于 11-21 15:37 ?1.1w次閱讀
    晶振的<b class='flag-5'>輸出</b>波形:TTL、CMOS、LVPECL、LVDS和<b class='flag-5'>正弦波</b>

    普源DG1022Z信號發生器正弦波頻率調節指南

    普源DG1022Z信號發生器作為一款高性能的雙通道波形發生器,可靈活輸出正弦波、方波、三角等多種波形,廣泛應用于電子測試、科研實驗及教學場景。本文將詳細介紹如何通過該設備生成并調節
    的頭像 發表于 10-14 16:53 ?797次閱讀
    普源DG1022Z信號發生器<b class='flag-5'>正弦波</b>頻率調節指南

    經典1000W純正弦波逆變器原理圖資料

    經典1000W純正弦波逆變器原理圖
    發表于 10-11 15:32 ?21次下載

    信號發生器產生正弦波的頻率精準調節方法

    與相位累加器。 特點:頻率分辨率高(可達微赫茲級)、相位連續、易于程控,適用于精密測試場景。 2. 高速數模轉換(DAC)與濾波 將離散的數字信號轉換為模擬波形,通過低通濾波器平滑輸出正弦波。 關鍵參數:
    的頭像 發表于 08-27 17:49 ?1015次閱讀
    信號發生器產生<b class='flag-5'>正弦波</b>的頻率精準調節方法

    正弦波逆變器的工作原理與控制方式

    介紹了采用Boost PWM DC/DC變換器的正弦波逆變器的工作原理與控制方式,這是一種新型的正弦波逆變器。 純分享帖,點擊下方附件免費獲取完整資料~~~ 內容有幫助可以關注、點贊、評論支持一下
    發表于 07-23 13:22

    磁性元件變革:告別正弦波激勵源,擁抱方波

    扮演著極為重要的角色,它貫穿于整個磁特性研究的諸多環節。 本文將結合福州大學汪晶慧教授的公開演講內容,深入剖析以正弦波為標準時在測量與計算過程中遭遇的重重挑戰,同時詳細闡述引入方波作為標準后為解決這些難題所帶
    的頭像 發表于 07-10 15:25 ?784次閱讀
    磁性元件變革:告別<b class='flag-5'>正弦波</b>激勵源,擁抱<b class='flag-5'>方波</b>

    無刷直流電機方波正弦波復合驅動器設計

    摘要:針對無刷直流電機方波驅動出力大,正弦波驅動轉矩脈動和噪聲小的特點,設計了基于霍耳傳感器信號的無刷直流電機方波正弦波復合驅動器。在不改動硬件電路的前提下,利用軟件編程實現了無刷直
    發表于 06-27 16:39

    TI 正弦波發生器電路

    該文檔介紹了德州儀器的一款正弦波發生器電路,其設計目標為實現8V/V的交流增益、10kHz的振蕩頻率,采用±2.5V電源供電;電路通過四通道運放TLV9064緩沖各RC濾波級以生成低失真正弦波
    的頭像 發表于 06-23 14:23 ?2442次閱讀
    TI <b class='flag-5'>正弦波</b>發生器電路

    第二十六章 DAC——輸出正弦波

    本文介紹了W55MH32的DAC模塊,其可配置8位或12位分辨率。兩通道。詳解功能框圖、參考電壓等,還通過實驗展示用定時器觸發、DMA傳輸實現雙聲道正弦波輸出,配置含GPIO、DAC
    的頭像 發表于 06-20 14:06 ?1290次閱讀
    第二十六章 <b class='flag-5'>DAC</b>——<b class='flag-5'>輸出</b><b class='flag-5'>正弦波</b>

    實用電源——正弦波逆變器

    資料全面詳細地介紹了正弦波逆變器技術,闡述正弦波逆變器發展過程中各階段典型逆變方式的工作原理,以及典型逆變器的工作過程。 主要內容包括:多重疊加式逆變器,如電壓型電流型逆變器的多重疊加,PWM
    發表于 06-11 16:19

    基于C51單片機使用DAC0832生成正弦波

    請問各位為什么并沒有正弦波輸出呢?問題出在哪里呢?為什么連一點波形都沒有呢,已經試著調各個xy軸了,一點波形都沒有
    發表于 04-22 15:29

    正弦波經運放后變成三角是什么原因?不像是壓擺率的問題

    本帖最后由 王小佳6565 于 2025-4-18 09:36 編輯 正弦波經運放后變成三角了,如圖是我的電路圖,我測量的是C2兩端的電壓,我算了我的壓擺率需求2*π*100hz*10v
    發表于 04-17 20:29

    IGBT正弦波調光器的工作原理和優勢

    IGBT正弦波調光器是一種用于調節燈光亮度的設備,其工作原理主要基于IGBT的開關特性和對正弦波信號的控制。
    的頭像 發表于 04-11 15:47 ?2525次閱讀
    IGBT<b class='flag-5'>正弦波</b>調光器的工作原理和優勢

    直流無刷電機SPWM正弦波控制原理(可下載)

    等問題,在一些對噪聲有要求的應用領域存在局限性。針對這些應用,采用正弦波控制 可以很好的解決這個問題二、直流無刷電機的正弦波控制簡介直流無刷電機的正弦波控制即通過
    發表于 03-28 14:19 ?7次下載