服務(wù)熱線
MCU是Microcontroller Unit 的簡(jiǎn)稱,中文叫微控制器,俗稱單片機(jī),是把CPU的頻率與規(guī)格做適當(dāng)縮減,并將內(nèi)存、計(jì)數(shù)器、USB、A/D轉(zhuǎn)換、UART、PLC、DMA等周邊接口,甚至LCD驅(qū)動(dòng)電路都整合在單一芯片上,形成芯片級(jí)的計(jì)算機(jī),為不同的應(yīng)用場(chǎng)合做不同組合控制,諸如手機(jī)、PC外圍、遙控器,至汽車電子、工業(yè)上的步進(jìn)馬達(dá)、機(jī)器手臂的控制等,都可見到MCU的身影。
一
單片機(jī)發(fā)展簡(jiǎn)史
單片機(jī)出現(xiàn)的歷史并不長(zhǎng),但發(fā)展十分迅猛。它的產(chǎn)生與發(fā)展和微處理器(CPU)的產(chǎn)生與發(fā)展大體同步,自1971年美國(guó)英特爾公司首先推出4位微處理器以來(lái),它的發(fā)展到目前為止大致可分為5個(gè)階段。下面以英特爾公司的單片機(jī)發(fā)展為代表加以介紹。
1971年~1976年
單片機(jī)發(fā)展的初級(jí)階段。1971年11月英特爾公司首先設(shè)計(jì)出集成度為2000只晶體管/片的4位微處理器英特爾4004,并配有RAM、 ROM和移位寄存器, 構(gòu)成了第一臺(tái)MCS—4微處理器, 而后又推出了8位微處理器英特爾8008, 以及其它各公司相繼推出的8位微處理器。
1976年~1980年
低性能單片機(jī)階段。以1976年英特爾公司推出的MCS—48系列為代表, 采用將8位CPU、 8位并行I/O接口、8位定時(shí)/計(jì)數(shù)器、RAM和ROM等集成于一塊半導(dǎo)體芯片上的單片結(jié)構(gòu), 雖然其尋址范圍有限(不大于4 KB), 也沒有串行I/O, RAM、 ROM容量小, 中斷系統(tǒng)也較簡(jiǎn)單, 但功能可滿足一般工業(yè)控制和智能化儀器、儀表等的需要。
1980年~1983年
高性能單片機(jī)階段。這一階段推出的高性能8位單片機(jī)普遍帶有串行口,有多級(jí)中斷處理系統(tǒng), 多個(gè)16位定時(shí)器/計(jì)數(shù)器。片內(nèi)RAM、 ROM的容量加大,且尋址范圍可達(dá)64 KB,個(gè)別片內(nèi)還帶有A/D轉(zhuǎn)換接口。
1983年~80年代末
16位單片機(jī)階段。1983年英特爾公司又推出了高性能的16位單片機(jī)MCS-96系列,由于其采用了最新的制造工藝, 使芯片集成度高達(dá)12萬(wàn)只晶體管/片。
1990年代
單片機(jī)在集成度、功能、速度、可靠性、應(yīng)用領(lǐng)域等全方位向更高水平發(fā)展。
二
單片機(jī)的分類及應(yīng)用
MCU按其存儲(chǔ)器類型可分為無(wú)片內(nèi)ROM型和帶片內(nèi)ROM型兩種。對(duì)于無(wú)片內(nèi)ROM型的芯片,必須外接EPROM才能應(yīng)用(典型為8031);帶片內(nèi)ROM型的芯片又分為片內(nèi)EPROM型(典型芯片為87C51)、MASK片內(nèi)掩模ROM型(典型芯片為8051)、片內(nèi)Flash型(典型芯片為89C51)等類型。
按用途可分為通用型和專用型;根據(jù)數(shù)據(jù)總線的寬度和一次可處理的數(shù)據(jù)字節(jié)長(zhǎng)度可分為8、16、32位MCU。
目前,國(guó)內(nèi)MCU應(yīng)用市場(chǎng)最廣泛的是消費(fèi)電子領(lǐng)域,其次是工業(yè)領(lǐng)域、和汽車電子市場(chǎng)。消費(fèi)電子包括家用電器、電視、游戲機(jī)和音視頻系統(tǒng)等。工業(yè)領(lǐng)域包括智能家居、自動(dòng)化、醫(yī)療應(yīng)用及新能源生成與分配等。汽車領(lǐng)域包括汽車動(dòng)力總成和安全控制系統(tǒng)等。
三
單片機(jī)的基本功能
對(duì)于絕大多數(shù)MCU,下列功能是最普遍也是最基本的,針對(duì)不同的MCU,其描述的方式可能會(huì)有區(qū)別,但本質(zhì)上是基本相同的:
1、TImer(定時(shí)器):TImer的種類雖然比較多,但可歸納為兩大類:一類是固定時(shí)間間隔的TImer,即其定時(shí)的時(shí)間是由系統(tǒng)設(shè)定的,用戶程序不可控制,系統(tǒng)只提供幾種固定的時(shí)間間隔給用戶程序進(jìn)行選擇,如32Hz,16Hz,8Hz等,此類TImer在4位MCU中比較常見,因此可以用來(lái)實(shí)現(xiàn)時(shí)鐘、計(jì)時(shí)等相關(guān)的功能。
另一類則是Programmable Timer(可編程定時(shí)器),顧名思義,該類Timer的定時(shí)時(shí)間是可以由用戶的程序來(lái)控制的,控制的方式包括:時(shí)鐘源的選擇、分頻數(shù)(Prescale)選擇及預(yù)制數(shù)的設(shè)定等,有的MCU三者都同時(shí)具備,而有的則可能是其中的一種或兩種。此類Timer應(yīng)用非常靈活,實(shí)際的使用也千變?nèi)f化,其中最常見的一種應(yīng)用就是用其實(shí)現(xiàn)PWM輸出。
由于時(shí)鐘源可以自由選擇,因此,此類Timer一般均與Event Counter(事件計(jì)數(shù)器)合在一起。
2、IO口:任何MCU都具有一定數(shù)量的IO口,沒有IO口,MCU就失去了與外部溝通的渠道。根據(jù)IO口的可配置情況,可以分為如下幾種類型:
純輸入或純輸出口:此類IO口由MCU硬件設(shè)計(jì)決定,只能是輸入或輸出,不可用軟件來(lái)進(jìn)行實(shí)時(shí)的設(shè)定。
直接讀寫IO口:如MCS-51的IO口就屬于此類IO口。當(dāng)執(zhí)行讀IO口指令時(shí),就是輸入口;當(dāng)執(zhí)行寫IO口指令則自動(dòng)為輸出口。
程序編程設(shè)定輸入輸出方向的:此類IO口的輸入或輸出由程序根據(jù)實(shí)際的需要來(lái)進(jìn)行設(shè)定,應(yīng)用比較靈活,可以實(shí)現(xiàn)一些總線級(jí)的應(yīng)用,如I2C總線,各種LCD、LED Driver的控制總線等。
對(duì)于IO口的使用,重要的一點(diǎn)必須牢記的是:對(duì)于輸入口,必須有明確的電平信號(hào),確保不能浮空(可以通過(guò)增加上拉或下拉電阻來(lái)實(shí)現(xiàn));而對(duì)于輸出口,其輸出的狀態(tài)電平必須考慮其外部的連接情況,應(yīng)保證在Standby或靜態(tài)狀態(tài)下不存在拉電流或灌電流。
3、外部中斷:外部中斷也是絕大多數(shù)MCU所具有的基本功能,一般用于信號(hào)的實(shí)時(shí)觸發(fā),數(shù)據(jù)采樣和狀態(tài)的檢測(cè),中斷的方式由上升沿、下降沿觸發(fā)和電平觸發(fā)幾種。外部中斷一般通過(guò)輸入口來(lái)實(shí)現(xiàn),若為IO口,則只有設(shè)為輸入時(shí)其中斷功能才會(huì)開啟;若為輸出口,則外部中斷功能將自動(dòng)關(guān)閉(ATMEL的ATiny系列存在一些例外,輸出口時(shí)也能觸發(fā)中斷功能)。外部中斷的應(yīng)用如下:
外部觸發(fā)信號(hào)的檢測(cè):一種是基于實(shí)時(shí)性的要求,比如可控硅的控制,突發(fā)性信號(hào)的檢測(cè)等,而另一種情況則是省電的需要。
信號(hào)頻率的測(cè)量:為了保證信號(hào)不被遺漏,外部中斷是最理想的選擇。
數(shù)據(jù)的解碼:在遙控應(yīng)用領(lǐng)域,為了降低設(shè)計(jì)的成本,經(jīng)常需要采用軟件的方式來(lái)對(duì)各種編碼數(shù)據(jù)進(jìn)行解碼,如Manchester和PWM編碼的解碼。
按鍵的檢測(cè)和系統(tǒng)的喚醒:對(duì)于進(jìn)入sleep狀態(tài)的MCU,一般需要通過(guò)外部中斷來(lái)進(jìn)行喚醒,最基本的形式則是按鍵,通過(guò)按鍵的動(dòng)作來(lái)產(chǎn)生電平的變化。
4、通訊接口:MCU所提供的通訊接口一般包括SPI接口,UART,I2C接口等,其分別描述如下:
SPI接口:此類接口是絕大多數(shù)MCU都提供的一種最基本通訊方式,其數(shù)據(jù)傳輸采用同步時(shí)鐘來(lái)控制,信號(hào)包括:SDI(串行數(shù)據(jù)輸入)、SDO(串行數(shù)據(jù)輸出)、SCLK(串行時(shí)鐘)及Ready信號(hào);有些情況下則可能沒有Ready信號(hào);此類接口可以工作在master方式或Slave方式下,通俗說(shuō)法就是看誰(shuí)提供時(shí)鐘信號(hào),提供時(shí)鐘的一方為master,相反的一方則為Slaver。
UART(Universal Asynchronous Receive Transmit):屬于最基本的一種異步傳輸接口,其信號(hào)線只有Rx和Tx兩條,基本的數(shù)據(jù)格式為:Start Bit + Data Bit(7-bits/8-bits) + Parity Bit(Even, Odd or None) + Stop Bit(1~2Bit)。一位數(shù)據(jù)所占的時(shí)間稱為Baud Rate(波特率)。
對(duì)于大多數(shù)的MCU來(lái)講,數(shù)據(jù)位的長(zhǎng)度、數(shù)據(jù)校驗(yàn)方式(奇校驗(yàn)、偶校驗(yàn)或無(wú)校驗(yàn))、停止位(Stop Bit)的長(zhǎng)度及Baud Rate是可以通過(guò)程序編程進(jìn)行靈活設(shè)定。此類接口最常用的方式就是與PC機(jī)的串口進(jìn)行數(shù)據(jù)通訊。
I2C接口:I2C是由Philips開發(fā)的一種數(shù)據(jù)傳輸協(xié)議,同樣采用2根信號(hào)來(lái)實(shí)現(xiàn):SDAT(串行數(shù)據(jù)輸入輸出)和SCLK(串行時(shí)鐘)。其最大的好處是可以在此總線上掛接多個(gè)設(shè)備,通過(guò)地址來(lái)進(jìn)行識(shí)別和訪問;I2C總線的一個(gè)最大的好處就是非常方便用軟件通過(guò)IO口來(lái)實(shí)現(xiàn),其傳輸?shù)臄?shù)據(jù)速率完全由SCLK來(lái)控制,可快可慢,不像UART接口,有嚴(yán)格的速率要求。
5、Watchdog(看門狗定時(shí)器):Watchdog也是絕大多數(shù)MCU的一種基本配置(一些4位MCU可能沒有此功能),大多數(shù)的MCU的Watchdog只能允許程序?qū)ζ溥M(jìn)行復(fù)位而不能對(duì)其關(guān)閉(有的是在程序燒入時(shí)來(lái)設(shè)定的,如Microchip PIC系列MCU),而有的MCU則是通過(guò)特定的方式來(lái)決定其是否打開,如Samsung的KS57系列,只要程序訪問了Watchdog寄存器,就自動(dòng)開啟且不能再被關(guān)閉。一般而言watchdog的復(fù)位時(shí)間是可以程序來(lái)設(shè)定的。Watchdog的最基本的應(yīng)用是為MCU因?yàn)橐馔獾墓收隙鴮?dǎo)致死機(jī)提供了一種自我恢復(fù)的能力。
四
全球主流單片機(jī)制造商
單片機(jī)的學(xué)習(xí)竅門
單片機(jī)的程序編寫
要防止在中斷和主程序體中同時(shí)訪問或設(shè)置同一個(gè)變量或數(shù)據(jù)的情況。有效的預(yù)防方法是,將此類數(shù)據(jù)的處理安排在一個(gè)模塊中,通過(guò)判斷觸發(fā)標(biāo)志來(lái)決定是否執(zhí)行該數(shù)據(jù)的相關(guān)操作;而在其他的程序體中(主要是中斷),對(duì)需要進(jìn)行該數(shù)據(jù)的處理的地方只設(shè)置觸發(fā)的標(biāo)志。――這可以保證數(shù)據(jù)的執(zhí)行是可預(yù)知和唯一的。
在單片機(jī)應(yīng)用開發(fā)中,代碼的使用效率問題、單片機(jī)抗干擾性和可靠性等問題仍困擾著。現(xiàn)歸納出單片機(jī)開發(fā)中應(yīng)掌握的幾個(gè)基本技巧。
八
單片機(jī)開發(fā)技巧
1 如何減少程序中的bug
對(duì)于如何減少程序的bug,應(yīng)該先考慮系統(tǒng)運(yùn)行中應(yīng)考慮的超范圍管理參數(shù)如下。
- 物理參數(shù):這些參數(shù)主要是系統(tǒng)的輸入?yún)?shù),它包括激勵(lì)參數(shù)、采集處理中的運(yùn)行參數(shù)和處理結(jié)束的結(jié)果參數(shù)。
- 資源參數(shù):這些參數(shù)主要是系統(tǒng)中的電路、器件、功能單元的資源,如記憶體容量、存儲(chǔ)單元長(zhǎng)度、堆疊深度。
- 應(yīng)用參數(shù):這些應(yīng)用參數(shù)常表現(xiàn)為一些單片機(jī)、功能單元的應(yīng)用條件。過(guò)程參數(shù):指系統(tǒng)運(yùn)行中的有序變化的參數(shù)。
2 如何提高C語(yǔ)言編程代碼的效率
用C語(yǔ)言進(jìn)行單片機(jī)程序設(shè)計(jì)是單片機(jī)開發(fā)與應(yīng)用的必然趨勢(shì)。如果使用C編程時(shí),要達(dá)到最高的效率,最好熟悉所使用的C編譯器。先試驗(yàn)一下每條C語(yǔ)言編譯以后對(duì)應(yīng)的匯編語(yǔ)言的語(yǔ)句行數(shù),這樣就可以很明確的知道效率。在今后編程的時(shí)候,使用編譯效率最高的語(yǔ)句。各家的C編譯器都會(huì)有一定的差異,故編譯效率也會(huì)有所不同,優(yōu)秀的嵌入式系統(tǒng)C編譯器代碼長(zhǎng)度和執(zhí)行時(shí)間僅比以匯編語(yǔ)言編寫的同樣功能程度長(zhǎng)5-20%。
對(duì)于復(fù)雜而開發(fā)時(shí)間緊的項(xiàng)目時(shí),可以采用C語(yǔ)言,但前提是要求你對(duì)該MCU系統(tǒng)的C語(yǔ)言和C編譯器非常熟悉,特別要注意該C編譯系統(tǒng)所能支持的數(shù)據(jù)類型和算法。雖然C語(yǔ)言是最普遍的一種高級(jí)語(yǔ)言,但由于不同的MCU廠家其C語(yǔ)言編譯系統(tǒng)是有所差別的,特別是在一些特殊功能模塊的操作上。所以如果對(duì)這些特性不了解,那么調(diào)試起來(lái)問題就會(huì)很多,反而導(dǎo)致執(zhí)行效率低于匯編語(yǔ)言。
防止干擾最有效的方法是去除干擾源、隔斷干擾路徑,但往往很難做到,所以只能看單片機(jī)抗干擾能力夠不夠強(qiáng)了。在提高硬件系統(tǒng)抗干擾能力的同時(shí),軟件抗干擾以其設(shè)計(jì)靈活、節(jié)省硬件資源、可靠性好越來(lái)越受到重視。
單片機(jī)干擾最常見的現(xiàn)象就是復(fù)位,至于程序跑飛,其實(shí)也可以用軟件陷阱和看門狗將程序拉回到復(fù)位狀態(tài),所以單片機(jī)軟件抗干擾最重要的是處理好復(fù)位狀態(tài)。
一般單片機(jī)都會(huì)有一些標(biāo)志寄存器,可以用來(lái)判斷復(fù)位原因;另外你也可以自己在RAM中埋一些標(biāo)志。在每次程序復(fù)位時(shí),通過(guò)判斷這些標(biāo)志,可以判斷出不同的復(fù)位原因;還可以根據(jù)不同的標(biāo)志直接跳到相應(yīng)的程序。這樣可以使程序運(yùn)行有連續(xù)性,用戶在使用時(shí)也不會(huì)察覺到程序被重新復(fù)位過(guò)。
4 如何測(cè)試單片機(jī)系統(tǒng)的可靠性
當(dāng)一個(gè)單片機(jī)系統(tǒng)設(shè)計(jì)完成,對(duì)于不同的單片機(jī)系統(tǒng)產(chǎn)品會(huì)有不同的測(cè)試項(xiàng)目和方法,但是有一些是必須測(cè)試的:
- 測(cè)試單片機(jī)軟件功能的完善性
- 上電、掉電測(cè)試
- 老化測(cè)試
- ESD和EFT等測(cè)試
有時(shí)候,我們還可以模擬人為使用中,可能發(fā)生的破壞情況。例如用人體或者衣服織物故意摩擦單片機(jī)系統(tǒng)的接觸端口,由此測(cè)試抗靜電的能力。用大功率電鉆靠近單片機(jī)系統(tǒng)工作,由此測(cè)試抗電磁干擾能力等。
此外在開發(fā)和應(yīng)用過(guò)程中我們更要掌握技巧,提高效率,以便于發(fā)揮它更加廣闊的用途。
九
芯片操作總結(jié)
對(duì)芯片的操作主要是對(duì)芯片內(nèi)寄存器的操作,芯片內(nèi)寄存器在存儲(chǔ)器上映射的都有自己的唯一地址,這也就是對(duì)相應(yīng)的地址的操作。看芯片,首先看時(shí)序圖,再了解相應(yīng)的寄存器,了解是如何操作的,定義需要的端口(程序可以識(shí)別),編寫寫操作程序和讀操作程序。
為了將漢字在顯示器或打印機(jī)上輸出,把漢字按圖形符號(hào)設(shè)計(jì)成點(diǎn)陣圖,就得到了相應(yīng)的點(diǎn)陣代碼(字形碼)。
GB1616.h//------------------ 漢字字模的數(shù)據(jù)結(jié)構(gòu)定義 ------------------------//structtypFNT_GB16 //漢字字模數(shù)據(jù)結(jié)構(gòu){unsignedcharIndex[3]; //漢字內(nèi)碼索引 unsignedchar Msk[32];//點(diǎn)陣碼數(shù)據(jù) };
/////////////////////////////////////////////////////////////////////////// 漢字字模表//// 漢字庫(kù): 宋體16.dot,橫向取模左高位,數(shù)據(jù)排列:從左到右從上到下///////////////////////////////////////////////////////////////////////////conststructtypFNT_GB16 codeGB_16[]= //數(shù)據(jù)表{/*------------------------------------------------------------------------------;源文件 /文字 :徐;寬×高(像素):16×16------------------------------------------------------------------------------*/"徐",0x10,0x80,0x10,0x80,0x21,0x40,0x42,0x20,0x94,0x10,0x1B,0xEC,0x20,0x80,0x60,0x80,0xAF,0xF8,0x20,0x80,0x22,0xA0,0x24,0x90,0x2A,0x88,0x21,0x00,0x00,0x00,0x00,0x00, 這個(gè)結(jié)構(gòu),很簡(jiǎn)單的:一個(gè)是內(nèi)碼,一個(gè)點(diǎn)陣序列,以前的點(diǎn)陣庫(kù)是按內(nèi)碼順序放的,不需要內(nèi)碼索引的,如果只放部分漢字,就需要內(nèi)碼索引了。(前面的漢字“徐”是為了要輸出“徐”的時(shí)候找到該字的點(diǎn)陣序列,這個(gè)點(diǎn)陣序列是自己寫的,當(dāng)用1602顯示時(shí),因?yàn)樵撔酒瑑?nèi)存在英文的點(diǎn)陣序列,所以就不用寫了)一般內(nèi)碼兩個(gè)字節(jié)就行了,多用1個(gè)字節(jié)是加了個(gè)尾0而已,這樣,漢字內(nèi)碼處直接放漢字字符串就可;
13、12864液晶:
每個(gè)顯示點(diǎn)對(duì)應(yīng)一位二進(jìn)制數(shù),1 表示亮,0 表示滅。存儲(chǔ)這些點(diǎn)陣信息的RAM稱為顯示數(shù)據(jù)存儲(chǔ)器。要顯示某個(gè)圖形或漢字就是將相應(yīng)的點(diǎn)陣信息寫入到相應(yīng)的存儲(chǔ)單元中。
繪圖RAM的地址計(jì)數(shù)器(AC)只會(huì)對(duì)水平地址(X 軸)自動(dòng)加一, 當(dāng)水平地址=0FH 時(shí)會(huì)重新設(shè)為00H 但并不會(huì)對(duì)垂直地址做進(jìn)位自動(dòng)加一,故當(dāng)連續(xù)寫入多筆資料時(shí),程序需自行判斷垂直地址是否需重新設(shè)定
繪圖顯示RAM提供128×8 個(gè)字節(jié)的記憶空間,在更改繪圖RAM時(shí),先連續(xù)寫入水平與垂直的坐標(biāo)值,再寫入兩個(gè)字節(jié)的數(shù)據(jù)到繪圖RAM,而地址計(jì)數(shù)器(AC)會(huì)對(duì)水平地址(X 地址)自動(dòng)加一,當(dāng)水平地址為0XFH 時(shí)會(huì)重新設(shè)為00H ;不會(huì)對(duì)垂直地址做進(jìn)位自動(dòng)加 1. 。在寫入繪圖 RAM的期間,繪圖顯示必須關(guān)閉,
[cpp] view plain copy// 顯示漢字voiddispString (uchar X, Y,uchar *msg)//X為哪一行,Y 為哪一列。msg為漢字 {if(X==0) X = 0x80;// 第一行,漢字顯示坐標(biāo) else if(X==1) X = 0x90; // 第二行else if(X==2) X = 0x88; // 第三行else X = 0x98;//第四行Y = X + Y;//Y 為1 往右移一位 write_com(Y); // 寫入坐標(biāo) while (*msg){ write_data(*msg++); //顯示漢字 }}//////////////////////////////// //////////////// ///////////////// 顯示圖象voiddisppicture(uchar code *adder){ uint i,j;//*******顯示上半屏內(nèi)容設(shè)置 for(i=0;i<32;i++)// 上半屏32個(gè)列地址 { write_com(0x80 + i);//SET垂直地址 VERTICALADD write_com(0x80);//SET 水平地址 HORIZONTAL ADDfor(j=0;j<16;j++) { write_data(*adder); adder++; }}//*******顯示下半屏內(nèi)容設(shè)置 for(i=0;i<32;i++) //{ write_com(0x80 + i); //SET 垂直地址 VERTICALADD write_com(0x88); //SET水平地址 HORIZONTAL ADDfor(j=0;j<16;j++){write_data(*adder);adder++;} }} 對(duì)于C語(yǔ)言,定義的變量,自動(dòng)為其分配空間,其地址為該變量的名稱。通過(guò)該名稱,可以在內(nèi)存中招到該數(shù)據(jù),經(jīng)過(guò)運(yùn)算得到新數(shù)據(jù),而匯編中需要編程者自己定義存儲(chǔ)空間及把數(shù)據(jù)送到累加器等進(jìn)行運(yùn)算,每一步都需要編程者操作。而C語(yǔ)言這些過(guò)程由編譯器去完成。
①、單片機(jī)C語(yǔ)言,其變量的內(nèi)存開辟是如何進(jìn)行的?難道是編譯器,在編譯過(guò)程中智能地加入分配與回收的代碼?關(guān)鍵之處在于我所做的程序,如何保證其沒有內(nèi)存溢出錯(cuò)誤?如果我進(jìn)行的是遞歸運(yùn)算,這樣的話,內(nèi)存需求是很難自己計(jì)算的。
如果變量過(guò)多,編譯會(huì)提示數(shù)據(jù)段too large,要保證其沒有內(nèi)存溢出錯(cuò)誤,主要考慮堆棧是否溢出,要靠經(jīng)驗(yàn)
單片機(jī)可以定義位變量,但是不可以定義位數(shù)組。用c語(yǔ)言寫只是看著簡(jiǎn)單,實(shí)際生成的代碼量是最多的,用于控制的單片機(jī)幾乎不用浮點(diǎn)數(shù)運(yùn)算,不僅慢還麻煩還占地方,如果是DSP芯片,本身有適合的硬件結(jié)構(gòu),會(huì)好很多。
公司電話:+86-0755-83044319
傳真/FAX:+86-0755-83975897
郵箱:1615456225@qq.com
QQ:3518641314 李經(jīng)理
QQ:332496225 丘經(jīng)理
地址:深圳市龍華新區(qū)民治大道1079號(hào)展滔科技大廈C座809室




粵公網(wǎng)安備44030002007346號(hào)