国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

DSP初學者入門

發布時間:2010-1-5 10:57    發布者:李寬
關鍵詞: dsp , 初學者 , 入門
DSP的特點

對于沒有使用過DSP的初學者來說,第一個困惑就是DSP其他的嵌入式處理器究竟有什么不同,它和單片機,ARM有什么區別.事實上,DSP也是一種嵌入式處理器,它完全可以完成單片機的功能.

唯一的重要的區別在于DSP支持單時鐘周期的"乘-加"運算.這幾乎是所有廠家的DSP芯片的一個共有特征.幾乎所有的DSP處理器的指令集中都會有一條 MAC指令,這條指令可以把兩個操作數從RAM中取出相乘,然后加到一個累加器中,所有這些操作都在一個時鐘周期內完成.擁有這樣一條指令的處理器就具備了DSP功能.

具有這條指令就稱之為數字信號處理器的原因在于,所有的數字信號處理算法中最為常見的算術操作就是"乘-加".這是因為數字信號處理中大量使用了內積,或稱"點積"的運算.無論是FIR濾波,FFT,信號相關,數字混頻,下變頻.所有這些數字信號處理的運算經常是將輸入信號與一個系數表或者與一個本地參考信號相乘然后積分(累加),這就表現為將兩個向量(或稱序列)進行點積,在編程上就變成將輸入的采樣放在一個循環buffer里,本地的系數表或參考信號也放在一個buffer里,然后使用兩個指針指向這兩個buffer.這樣就可以在一個loop里面使用一個MAC指令將二者進行點積運算.這樣的點積運算對與處理器來說是最快的,因為僅需一個始終周期就可以完成一次乘加.

了解DSP的這一特點后,當我們設計一個嵌入式系統時,首先要考慮處理器所實現的算法中是否有點積運算,即是否要經常進行兩個數組的乘加,(記住數字濾波,相關等都表現為兩個數組的點積)如果有的話,每秒要做多少次,這樣就能夠決定是否采用DSP,采用多高性能的DSP了.

浮點與定點

浮點與定點也是經常是初學者困惑的問題,在選擇DSP器件的時候,是采用浮點還是采用定點,如果用定點是16位還是32位?其實這個問題和你的算法所要求的信號的動態范圍有關.

定點的計算不過是把一個數據當作整數來處理,通常AD采樣來的都是整數,這個數相對于真實的模擬信號有一個刻度因子,大家都知道用一個16位的AD去采樣一個0到5V的信號,那么AD輸出的整數除以2^16再乘以5V就是對應的電壓.在定點DSP中是直接對這個16位的采樣進行處理,并不將它轉換成以小數表示的電壓,因為定點DSP無法以足夠的精度表示一個小數,它只能對整數進行計算.

而浮點DSP的優勢在于它可以把這個采樣得到的整數轉換成小數表示的電壓,并不損失精度(這個小數用科學記數法來表示),原因在于科學記數法可以表示很大的動態范圍的一個信號,以IEEE754浮點數為例,

單精度浮點格式: [31] 1位符號 [30-23]8位指數 [22-00]23位小數

這樣的能表示的最小的數是+-2^-149,最大的數是+-(2-2^23)*2^127.動態范圍為20*log(最大的數/最小的數)=1667.6dB 這樣大的動態范圍使得我們在編程的時候幾乎不必考慮乘法和累加的溢出,而如果使用定點處理器編程,對計算結果進行舍入和移位則是家常便飯,這在一定程度上會損失是精度.原因在于定點處理處理的信號的動態范圍有限,比如16位定點DSP,可以表示整數范圍為1-65536,其動態范圍為 20*log(65536/1)=96dB.對于32定點DSP,動態范圍為20*log(2^32/1)=192dB,遠小于32位ieee浮點數的 1667.6dB,但是,實際上192dB對絕大多數應用所處理的信號已經足夠了.

由于AD轉換器的位數限制,一般輸入信號的動態范圍都比較小,但在DSP的信號處理中,由于點積運算會使中間節點信號的動態范圍增加,所以主要考慮信號處理流程中中間結果的動態范圍,以及算法對中間結果的精度要求,來選擇相應的DSP.另外就是浮點的DSP更易于編程,定點DSP編程中程序員要不斷調整中間結果的P,Q值,實際就是不斷對中間結果進行移位調整和舍入.

DSP與RTOS

TI的CCS提供BIOS,ADI的VDSP提供VDK,都是基于各自DSP的嵌入式多任務內核.DSP編程可以用單用C,也可以用匯編,或者二者結合, 一般軟件編譯工具都提供了很好的支持.我不想在這里多說BIOS,VDK怎么用這在相應的文檔里說的很詳細.我想給初學者說說DSP的RTOS原理.用短短幾段話說這個復雜的東西也是挑戰!

其實DSP的RTOS和基于其他處理器的通用RTOS沒什么大的區別,現在幾乎人人皆知的uCOSii也很容易移植到DSP上來,只要把寄存器保存與恢復部分和堆棧部分改改就可以.一般在用BIOS和VDK之前,先看看操作系統原理的書比較好.uCOS那本書也不錯.

BIOS和VDK其實是一個RTOS內核函數集,DSP的應用程序會和這些函數連接成一個可執行文件.其實實現一個簡單的多任務內核并不復雜,首先定義好內核的各種數據結構,然后寫一個scheduler函數,功能是從所有就緒任務中(通過查找就緒任務隊列或就緒任務表)找出優先級最高的任務,并恢復其執行.然后在此基礎上寫幾個用于任務間通信的函數就可以了,比如event,message box,等等.

RTOS一般采用搶先式的任務調度方式,舉例說當任務A等待的資源available的時候,DSP會執行一個任務調度函數scheduler,這個函數會檢查當前任務是否比任務A優先級低,如果是的話,就會把它當前掛起,然后把任務A保存在堆棧里寄存器值全部pop到DSP處理器中(這就是所謂的任務現場恢復).接著scheduler還會把從堆棧中取出任務A掛起時的程序執行的地址,pop到PC,使任務A繼續執行.這樣當前任務就被任務A搶先了.

使用RTOS之后,每個任務都會有一個主函數,這個函數的起始地址就是該任務的入口.一般每個任務的主函數里有一個死循環,這個循環使該任務周期地執行, 完成一部分算法模塊的功能,其實這個函數跟普通函數沒任何區別,類似于C語言中的main函數.一個任務創建的時候,RTOS會把這個函數入口地址壓入任務的堆棧中,好象這個函數(任務)剛發生過一次中斷一樣.一旦這個新創建任務的優先級在就緒隊列中是最高的,RTOS就會從其堆棧中彈出其入口地址開始執行.

有一個疑問是,不使用RTOS,而是簡單使用一個主循環在程序中調用各個函數模塊,一樣可以實現軟件的調度執行.那么,這種常用的方法與使用RTOS相比有什么區別呢?其實,使用主循環的方法不過是一種沒有優先級的順序執行的調度策略而已.這種方法的缺點在于,主循環中調用的各個函數是順序執行的,那么, 即使是一個無關緊要的函數(比如閃爍一個LED),只要他不主動返回,也會一直執行直到結束,這時,如果發生一個重要的事件(比如DMA buffer full 中斷),就會得不到及時的響應和處理,只能等到那個閃爍LED的函數執行完畢.這樣就使整個DSP處理的優先次序十分不合理.而在使用了RTOS之后,當一個重要的事件發生時,中斷處理會進入RTOS,并調用scheduler,這時scheduler 會讓處理這一事件的任務搶占DSP處理器(因為它的優先級高).而哪個閃爍LED任務即使晚執行幾毫秒都沒任何影響.這樣整個DSP的調度策略就十分合理.

RTOS要說的內容太多,我只能講一下自己的一點體會吧

DSP與正(余)弦波

在DSP的應用中,我們經常要用到三角函數,或者合成一個正(余)弦波.這是因為我們喜歡把信號通過傅立葉變換映射到三角函數空間來理解信號的頻率特性. 信號處理的一些計算技巧都需要在DSP軟件中進行三角函數計算.然而三角函數計算是非線性的計算,DSP并沒有專門的指令來求一個數的正弦或余弦.于是我們需要用線性方法來近似求解.

一個直接的想法是用多項式擬合,這也正是大多數DSP C編譯器提供正余弦庫函數所采用的方法.其原理是把三角函數向函數空間{1,x,x^2,x^3....}上投影,從而獲得一系列的系數,用這些系數就可以擬合出三角函數.比如,我們在[0,pi/2]區間上擬合sin,只需在matlab中輸入以下命令:

x=0:0.05:pi/2;
p=polyfit(x,sin(x),5)

就得到5階的多項式系數:

p =
0.00581052047605 0.00580963216172 -0.17193865685360
0.00209002716293 0.99969270087312 0.00000809543448

于是在[0,pi/2]區間上:

sin(x)= 0.00000809543448+0.99969270087312*x+ 0.00209002716293*x^2-0.17193865685360*x^3+
0.00580963216172*x^4+0.00581052047605*x^5

于是在DSP程序中,我們可以通過用乘加(MAC)指令計算這個多項式來近似求得sin(x)

當然如果用定點DSP還要把P這個多項式系數表用一定的Q值來改寫成定點數.

這樣的三角函數計算一般都需要幾十個cycle 的開銷.這對于某些場合是不能容忍的

另一種更快的方法是借助于查表,比如,我們將[0,pi/2]分成32個區間,每個區間長度就為pi/64,在每個區間上我們使用直線段擬合sin曲線,每個區間線段起點的正弦值和線段斜率事先算好,存在RAM里,這樣就需要在在RAM里存儲64個
常數:

32個起點的精確的正弦值(事先算好):

s[32]={0,sin(pi/64),sin(pi/32),sin(pi/16)....}
32個線段的斜率: f[32]={0.049,.....}

對于輸入的每一個x,先根據其大小找到所在區間i,通常x用定點表示,一般取其高幾位就是系數i了,然 后通過下式即可求出sin(x):

sin(x)= s*f

這樣一般只需幾個CYCLE就可以算出正弦值,如果需要更高的精度,可以將區間分得更細,當然,也就需 要更多的RAM去存儲常數表.

事實上,不僅三角函數,其他的各種非線性函數都是這樣近似計算的.

1. 接觸DSP

在參加過一次社會上多的盡乎到了泛濫地步的"DSPxxx"培訓班之后,我"自信"已經具備DSP工師資格,便欣喜若狂跑道書店買了一本名為"DSP xxx應用"的書,作者叫xxx,并且是這個領域的牛人,這本書確實是很出色的書籍.但是當時,對于我這個對DSP一竅不通、剛剛入門的人來說卻建立了一個錯誤的概念——DSP是個很容易的領域,只要培訓一下,再稍微看看書,就可以成為專家.所以,現在看來,這些都是誤導,我認為學習DSP技術應該分為兩個階段,第一階段學習DSP技術基礎概念;第二階段學習DSP技術的行業應用.那本"DSP xxx應用"的書,它更適合書名應叫做"DSP中的數學或物理運用"...什么的.

2. 購買DSP學習套件

有了興趣,就要去學習,于是我攛掇領導批準購買了DSP學習入門套件(DSK),許多公司均有銷售,如TI等,大概是需要3000-4000人民幣.買后不久,我就發現,這種套件對于我來說一點用處都沒有.因為我的基礎知識實在是太差了.這些套件對于我來說,只是另一種涵義的PC機及一些外圍設備,想要懂的這些東西,我就需要去讀更多的相關書籍,這時,很難沒有想要放棄的念頭,我開始有點畏懼DSP這種技術,門檻太高了.可是,我不能放棄,我已經投入了許多的金錢和時間,我不想丟掉這4000元錢,也不能對領導沒有交待.事實上,我沒有想到,我將付出更多的錢和時間去學習.

3. 再次參加培訓班,再次購買DSP書籍

在我就感到了無助,困惑之際.我又想到了放棄.雖然我的數學還算不錯,但其中遇到的一些問題在我思考后,還是無法解決,我越來越畏懼DSP了.于是,我開始在"google"上搜索DSP培訓相關的信息,終于發現聞亭公司"DSP培訓中心"的教程和內容正是我一直尋找的東西.也許是DSP技術對我的有著巨大的誘惑力,也許是我的之直著,我又一次勇敢的報名參加了培訓.32個課時之后,解決了我半年多來積累的很多粗淺的問題.再翻開培訓教材剛剛復讀了第一章時,我想如果這本教材是我讀到的第一本書,并且我沒有花4000元買那個可*的學習套件,我會毫不猶豫的投降,放棄學習DSP,但.......那個可* 的xxx作者,他的書怎么可以用作教學呀.他的書雖然讓我對DSP產生了濃厚的興趣,卻把我引到了一條艱難的路上,而且花了那么多的冤枉錢....既然事已如此,我只有慢慢的去讀這些書籍,在我讀到教材的后面章節以后,我開始明白前面章節的內容,所以當你讀書遇到不明白的時候,千萬不要氣餒.有時,一個內容,可能需要讀上幾遍,才能明白,這比一開始的感覺要好的多了.

4. 實驗——至關重要的一步

現在,從你的架子上取下那套DSK,去嘗試做一些小實驗,我的第一個實驗是"正弦發生器",這個實驗比較簡單,但是它也花費了我幾周的時間去讀大量的關于串口、編碼、寄存器等的書并且進行大量的實驗.這個執行半小時的"正弦發生器",讓我查閱了恨不得夠組建一個圖書館的書籍,而且這個東西沒有任何用途.我是用匯編語言在54x中執行,這個實驗讓我很好的理解了什么是DSP,什么是McBSP, DMA, 等.當然問題也同步產生了,我就又不得不做了許多的實驗去驗證.我建議,在系統未定型之前,使用mathlab/simulink進行仿真,并且可以多實驗幾種芯片,這樣可以讓你明白更多的內容.我覺得我就要成為一個真正的DSP工程師了,我度過了最困難的時期.我覺得自己是個英雄.

5. 去尋找一份與DSP相關的工作,去當個DSP工程師

我希望困難已經過去,但這種愿望為時過早了.在DSP的研究中,我還遇到了很多的困難,由于篇幅有限,我就不在進行描述了.反正,如果想成為真正的DSP 專家,就不要期望事情會變得容易.有些DSP開發人員并不知道什么是真正的0和1,他們只會查閱各種參考書籍和參數表,我們并不提倡這種做法.因為這些人選擇了一種簡單的做法,但是他們并不是真正的DSP開發人員.他們只是編寫一些他們不理解的代碼,他們似乎在擔當著一臺"編碼器"的角色.

6. 總結

這篇文章只是我的一點感慨,可能并不是很適用現在的DSP開發工程師,因為,市面上已經有了供你學習的DSP教學套件,搭配了多種實驗供你參考,輕松入門,如:聞亭公司的"大學實驗箱"什么的.這個實驗箱提供了一個很好的實驗環境,并且為初學的你設計了多種實驗、教材,讓你由淺入深的學習.不會向我似的,繞一大圈才走到正確的路上.另外,你也可以向他們的工程師咨詢.
本文地址:http://m.qingdxww.cn/thread-7258-1-1.html     【打印本頁】

本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
lelee007 發表于 2010-1-5 21:36:40
有木有站內收藏的哦?!
admin 發表于 2010-1-7 10:32:48
站內收藏按鈕已添加
您需要登錄后才可以發表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區
  • 使用SAM-IoT Wx v2開發板演示AWS IoT Core應用程序
  • 使用Harmony3加速TCP/IP應用的開發培訓教程
  • 集成高級模擬外設的PIC18F-Q71家族介紹培訓教程
  • 探索PIC16F13145 MCU系列——快速概覽
  • 貿澤電子(Mouser)專區

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 色五五月五月开 | 老子影院午夜精品欧美视频 | 亚洲日本中文字幕永久 | 日韩欧美一区二区三区免费看 | 亚洲色图视频在线 | 国产成人禁片免费观看 | 国产一在线精品一区在线观看 | 91久久老司机福利精品网 | 成人精品视频一区二区三区尤物 | 每日更新国产精品视频 | 99热成人精品免费久久 | 四虎在线观看免费视频 | 免费看黄网站入口 | 日韩欧美国产另类 | 色婷婷久久久swag精品 | 国产偷自拍 | 午夜免费观看_视频在线观看 | 亚洲国产精品ⅴa在线观看 亚洲国产精品91 | 欧美国产日韩在线 | 羞羞视频破解版免费观看 | 久久99精品综合国产首页 | 最近韩国日本高清免费观看 | 久久国产一区二区 | 国产欧美精品专区一区二区 | 高清不卡免费一区二区三区 | 失乐园在线观看 | 成年黄网站在线观看免费 | 国产女乱淫真高清免费视频 | 免费亚洲一区 | 天堂亚洲欧美日韩一区二区 | 国产传媒一区二区三区呀 | 青青青国产精品手机在线观看 | 在线播放亚洲 | 欧美一区二区二区 | 亚洲欧美乱 | 天天摸日日舔 | 人间正道是沧桑全集免费下载高清 | 五月婷婷六月丁香 | 操操综合 | 国产午夜精品一区二区 | 欧美激情视频一区二区三区 |