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

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

3天內不再提示

數字信號處理DSP庫文件的使用方法和功能實現

瑞薩MCU小百科 ? 來源:瑞薩嵌入式小百科 ? 作者:徐晶 ? 2024-04-03 14:09 ? 次閱讀

概述

本文首先介紹數字信號處理(DSP),是指將連續的模擬信號轉換為不連續、離散的數字信號并進行處理以提取所需的信號(信息)的過程。然后通過一個簡單的Lab來說明DSP庫文件的使用方法和功能實現。

DSP系統工程如下

將模擬(連續)信號轉換為數字信號。

通過專用DSP、MCU等對信號進行處理(噪聲濾波、頻率分析等),并提取所需信號。

輸出處理后的信號。

43785916-f17a-11ee-a297-92fbcf53809c.png

過去,DSP系統需要多個芯片,例如MCU和專用DSP。而RX MCU使得在單芯片上配置DSP系統成為可能,并具有多種優勢。

438679e2-f17a-11ee-a297-92fbcf53809c.png

使用DSP庫,可以在RX系列MCU上輕松執行FIR、IIR濾波器和FFT等數字信號處理。RX系列MCU支持執行高速數字信號處理所需的乘法和累加運算等DSP指令。

RX DSP庫的目標設備有以下這些RX MCU

439a8608-f17a-11ee-a297-92fbcf53809c.png

43b4fa4c-f17a-11ee-a297-92fbcf53809c.png

RX DSP庫版本5.0包含以下5個API,API為RX CPU的浮點和DSP指令運算提供了高效的操作。

統計操作API

過濾操作API

線性變換API

復數運算API

矩陣運算API

如下表所示,RX DSP庫版本5.0由多個文檔、庫文件和示例項目組成。庫文件針對每個RXv1、RXv2和Xv3 CPU進行了優化,并且示例項目針對每個CPU進行了配置。

表1 DSP庫的構成

43c5dace-f17a-11ee-a297-92fbcf53809c.png

每個CPU的“dsplib-rxv*”文件夾中有8種類型的庫文件和8個頭文件。庫文件根據支持的FPU、字節序模式和錯誤檢查進行分類。頭文件分為API專用定義和通用定義。所有通用定義均在r_dsp_types.h中描述,該文件包含在每個API頭文件中。詳細信息請參閱“RX DSP Library APIs Version 5.0 User’s Manual: Software (R01UW0200)”。

下面通過一個簡單的Lab了解RX DSP庫和如何使用DSP庫實現對信號的低通濾波,使用RX23E-A(RXv2 CPU)為例。

本Lab主要介紹如何添加DSP庫,然后完成對采集到的信號進行IIR濾波。由于本次實驗中采集到的數據是溫度結果,所以使用IIR濾波的效果不明顯。這里用一組特定的數據為例,來展示IIR濾波的效果。

步驟

● 解壓縮an-r01an4359ej0100-rx-dsplib.zip文件,將其中的dsplib-rxv2文件夾拷貝到工程中。

43d60200-f17a-11ee-a297-92fbcf53809c.png

●在src文件夾中新建r_dsp文件夾。解壓縮r01an4431xx0160-rx-apl.zip文件,workspace_dsp_example→dsp_demo_rx231_tb→src→r_dsp文件夾中的r_dsp_iirbiquad.h、r_dsp_iirbiquad.c、wave_sample1.h、wave_sample2.h拷貝到新建的r_dsp文件夾中。

43d9e118-f17a-11ee-a297-92fbcf53809c.png

●在工程屬性中添加DSP Lib和新加文件夾的路徑。

鼠標右鍵點擊工程名,選擇Properties。

43ee5fee-f17a-11ee-a297-92fbcf53809c.png

選擇C/C++ Build→Settings→Compiler→Source,點擊右上角的4415270a-f17a-11ee-a297-92fbcf53809c.png。

44266736-f17a-11ee-a297-92fbcf53809c.png

添加dsplib-rxv2文件夾的路徑。

Add directory path對話框中,點擊Workspace。

4440b50a-f17a-11ee-a297-92fbcf53809c.png

選擇dsplib-rxv2文件夾,點擊OK。

4452d208-f17a-11ee-a297-92fbcf53809c.png

點擊OK,完成路路徑的添加。

4464f3ca-f17a-11ee-a297-92fbcf53809c.png

用上面同樣的方式,添加r_dsp文件夾的路徑。

4475bd90-f17a-11ee-a297-92fbcf53809c.png

添加Library。

選擇Linkeryou6Input,點擊右上角的4415270a-f17a-11ee-a297-92fbcf53809c.png。

44a1522a-f17a-11ee-a297-92fbcf53809c.png

Format選擇library,點擊Workspace。

44bf906e-f17a-11ee-a297-92fbcf53809c.png

選擇dsplib-rxv2文件夾中的RX_DSP_FPU_LE_Check.lib文件。

44dd06a8-f17a-11ee-a297-92fbcf53809c.png

點擊OK。

44ff4e70-f17a-11ee-a297-92fbcf53809c.png

●打開rx23ea_local_board_lab.c文件,main()函數前添加以下頭文件、宏定義和變量。

#include "r_sensor_common_api.h"
#include "r_rtd_api.h"
#include "r_dsp_types.h"
#include "r_dsp_iirbiquad.h"


bool timer_flag = false;
static volatile int32_t s_dsad0_value;         /** DSAD0 24bit A/D value storage variable     */
static volatile float  s_temp   = 0;        /** Measurement temperature storage variable    */


/* Filter Characteristic definition */
#define IIRBIQUAD_COEF_FLAT (0)  /* Pass-through characteristics */
#define IIRBIQUAD_COEF_HPF (1)  /* High pass filter characteristics */
#define IIRBIQUAD_COEF_LPF (2)  /* Low pass filter characteristics */


static volatile int32_t gs_intermediate_buffer[2][1024]; /* buffer to interface DSP module */
static volatile int32_t gs_output_buffer[1024/2];     /* Output Buffer for DSP to store the result */
static uint8_t gs_coef_select;      /* Number of filter Characteristic */
static const int32_t gs_sample_wave_data[1024] =
{
  #include "wave_sample2.h"
};

●在main()函數中添加以下代碼

  uint32_t dsad0_reg;                 /** DSAD0.DR register storage variable                          */
  float rtd_temp = 0;                             /** Measurement temperature */


    memset((void *)gs_intermediate_buffer, 0, sizeof(gs_intermediate_buffer));  /* Clears Intermediate Buffer to zero */
    memset((void *)gs_output_buffer, 0, sizeof(gs_output_buffer));  /* Clears Output Buffer to zero */


    /*** Initializes IIR filter & FFT processing ***/
    gs_coef_select = IIRBIQUAD_COEF_HPF;


    R_DSP_IIRBiquad_Init();
    R_DSP_IIRBiquad_UpdateCoef(gs_coef_select);


    R_Config_TMR0_TMR1_Start();


while(1)中最后加入DSP處理部分代碼
      /* Executes IIRbiquad processing */
      R_DSP_IIRBiquad_Operation((int32_t *)gs_sample_wave_data,
                                (int32_t *)gs_intermediate_buffer[1]);
    }
}

while(1)中最后加入DSP處理部分代碼

   /* Executes IIRbiquad processing */
   R_DSP_IIRBiquad_Operation((int32_t *)gs_sample_wave_data,
                (int32_t *)gs_intermediate_buffer[1]);
  }
}

●對工程進行編譯450c6c04-f17a-11ee-a297-92fbcf53809c.png和調試45136db0-f17a-11ee-a297-92fbcf53809c.png。

●打開Memory窗口,點擊451df47e-f17a-11ee-a297-92fbcf53809c.png。

4524db72-f17a-11ee-a297-92fbcf53809c.png

添加變量gs_sample_wave_data和gs_intermediate_buffer[1]。

45376c1a-f17a-11ee-a297-92fbcf53809c.png

點擊45583526-f17a-11ee-a297-92fbcf53809c.png

456a3686-f17a-11ee-a297-92fbcf53809c.png

選擇Waveform,點擊Add Rendering(s)。

457e635e-f17a-11ee-a297-92fbcf53809c.png

點擊Wave Properties。

458e0002-f17a-11ee-a297-92fbcf53809c.png

設定屬性,Data Size選擇32bit,Buffer Size填寫2048,點擊OK。

4598adfe-f17a-11ee-a297-92fbcf53809c.png

并點擊459c5bf2-f17a-11ee-a297-92fbcf53809c.png,進行實時刷新。

45a3533a-f17a-11ee-a297-92fbcf53809c.png

兩個變量用同樣的方法進行設置。

注 意

如果找不到Memory窗口,可以使用下面的方法,其他窗口同理。

點擊Window→Show View→Other…

45b37648-f17a-11ee-a297-92fbcf53809c.png

按分類查找,或者直接在上面的框中進行關鍵字搜索。

45bb0c00-f17a-11ee-a297-92fbcf53809c.png

●運行代碼45d57b9e-f17a-11ee-a297-92fbcf53809c.png,需要點擊兩次,在Memory窗口觀察DSP結果。

45e1719c-f17a-11ee-a297-92fbcf53809c.png45ef1716-f17a-11ee-a297-92fbcf53809c.png

可以把鼠標放在波形上,按住Ctrl鍵通過滾動鼠標滾輪放大或者縮小波形。

●按下斷開按鈕45fbcfc4-f17a-11ee-a297-92fbcf53809c.png,或者終止按鈕45ff6c10-f17a-11ee-a297-92fbcf53809c.png。

審核編輯:劉清

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

    關注

    545

    文章

    7668

    瀏覽量

    345028
  • 單芯片
    +關注

    關注

    3

    文章

    401

    瀏覽量

    34325
  • 數字信號處理

    關注

    15

    文章

    523

    瀏覽量

    45383
  • FFT
    FFT
    +關注

    關注

    15

    文章

    427

    瀏覽量

    58746
  • IIR濾波器
    +關注

    關注

    0

    文章

    26

    瀏覽量

    11479
  • 頻率分析
    +關注

    關注

    0

    文章

    4

    瀏覽量

    4932
  • 庫文件
    +關注

    關注

    5

    文章

    33

    瀏覽量

    14410

原文標題:RX MCU DSP庫介紹及應用實例

文章出處:【微信號:瑞薩MCU小百科,微信公眾號:瑞薩MCU小百科】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    數字信號采集系統有哪些功能

    介紹數字信號采集系統的功能、組成、工作原理以及應用場景。 一、數字信號采集系統的功能 信號采集:數字信號
    的頭像 發表于 05-31 14:26 ?148次閱讀

    數字信號處理器的特點、作用及種類

    隨著信息技術的飛速發展,數字信號處理器(Digital Signal Processor,簡稱DSP)作為數字信號處理的核心設備,在通信、音
    的頭像 發表于 05-22 18:20 ?1040次閱讀

    數字信號電纜測試的重要性 數字信號電纜測試的方法和技術

    數字信號電纜測試的重要性 數字信號電纜測試的方法和技術 數字信號電纜測試的重要性: 隨著現代通信技術的發展,數字信號電纜在各種領域中扮演著重
    的頭像 發表于 02-01 15:48 ?249次閱讀

    2-22 AD采集DA輸出實驗(采集輸出正弦波) #教程 #DSP #數字信號處理

    dsp數字信號處理
    創龍教儀
    發布于 :2024年01月18日 09:53:10

    數字信號處理信號與系統區別

    數字信號處理信號與系統是兩個很重要的概念。雖然它們都涉及到信號處理和分析,但在很多方面有著不同的特點和應用。本文將詳細探討
    的頭像 發表于 01-18 09:30 ?1350次閱讀

    簡單認識數字信號處理

    數字信號處理器 (Digital Signal Processor, DSP)是一種專用微處理器,它在架構上對數字信號
    的頭像 發表于 11-30 09:07 ?699次閱讀
    簡單認識<b class='flag-5'>數字信號</b><b class='flag-5'>處理</b>器

    數字電源工作原理 數字電源使用方法

    數字電源工作原理 數字電源使用方法 數字電源是基于數字信號處理技術
    的頭像 發表于 10-16 16:16 ?1199次閱讀

    DSP原理及應用第2章 TMS320C54x數字信號處理器硬件結構

    電子發燒友網站提供《DSP原理及應用第2章 TMS320C54x數字信號處理器硬件結構.ppt》資料免費下載
    發表于 10-09 16:32 ?0次下載
    <b class='flag-5'>DSP</b>原理及應用第2章 TMS320C54x<b class='flag-5'>數字信號</b><b class='flag-5'>處理</b>器硬件結構

    信號發生器的功能 信號發生器的使用方法

    信號發生器是一種用于產生各種類型的電子信號的設備。它被廣泛應用于電子測試、儀器校準、電子設備研發等領域。信號發生器能夠產生多種波形信號,如正弦波、方波、三角波、脈沖波等,以及模擬
    的頭像 發表于 10-05 16:04 ?3980次閱讀

    數字信號處理MATLAB版資料分享

    的核心內容。如果僅僅用數字濾波器代替某個系統中的模擬濾波器,則還不能充分發揮數字技術的特長。事實上,對信號進行調制,濾波,變換.增強、壓縮、檢測、估計、識別等,都是數字信號
    發表于 09-28 06:34

    數字信號處理—理論、算法與實現

    與解調、反卷積、SVD、獨立分量分析及同太民濾波等)、平穩隨機信號的基本概念、經典功率譜估計、參數模型功率譜估計、數字信號處理中的有限字長問題及數字信號
    發表于 09-19 08:01

    數字信號處理的FPGA實現

    FPGA正在掀起一場數字信號處理的變革。本書旨在講解前端數字信號處理算法的高效實現。首先概述了當前的FPGA技術、器件以及用于設計最先進
    發表于 09-19 06:38

    數字信號處理器概論

    作為數字信號處理的一個實際任務就是要求能夠快速、高效、實時完成處理任務,這就要通過通用或專用的數字信號處理器來完成。因此,
    的頭像 發表于 08-07 16:58 ?723次閱讀

    數字信號處理知識點總結 數字信號處理綜合設計

      一、課程設計目的:  1. 進一步理解數字信號處理的基本概念、基本理論和基本方法;  2.熟悉在Windows環境下語音信號采集的方法;
    發表于 07-18 14:56 ?3次下載

    數字信號處理DSP系統設計入門課程

    在聽過很多關于數字信號處理DSP)技術的知識之后,您可能想了解DSP可以做什么,研究為什么DSP在許多類型的操作中比模擬電路更受歡迎,并了
    的頭像 發表于 06-17 11:47 ?2468次閱讀
    <b class='flag-5'>數字信號</b><b class='flag-5'>處理</b>:<b class='flag-5'>DSP</b>系統設計入門課程
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>