十六進制單精度浮點數轉十進制數的小工具
標簽: HexSingleToDecimal 十六進制 精度 浮點數
上傳時間: 2013-11-15
上傳用戶:bpgfl
注:1.這篇文章斷斷續續寫了很久,畫圖技術也不精,難免錯漏,大家湊合看.有問題可以留言. 2.論壇排版把我的代碼縮進全弄沒了,大家將代碼粘貼到arduino編譯器,然后按ctrl+T重新格式化代碼格式即可看的舒服. 一、什么是PWM PWM 即Pulse Wavelength Modulation 脈寬調制波,通過調整輸出信號占空比,從而達到改 變輸出平均電壓的目的。相信Arduino 的PWM 大家都不陌生,在Arduino Duemilanove 2009 中,有6 個8 位精度PWM 引腳,分別是3, 5, 6, 9, 10, 11 腳。我們可以使用analogWrite()控 制PWM 腳輸出頻率大概在500Hz 的左右的PWM 調制波。分辨率8 位即2 的8 次方等于 256 級精度。但是有時候我們會覺得6 個PWM 引腳不夠用。比如我們做一個10 路燈調光, 就需要有10 個PWM 腳。Arduino Duemilanove 2009 有13 個數字輸出腳,如果它們都可以 PWM 的話,就能滿足條件了。于是本文介紹用軟件模擬PWM。 二、Arduino 軟件模擬PWM Arduino PWM 調壓原理:PWM 有好幾種方法。而Arduino 因為電源和實現難度限制,一般 使用周期恒定,占空比變化的單極性PWM。 通過調整一個周期里面輸出腳高/低電平的時間比(即是占空比)去獲得給一個用電器不同 的平均功率。 如圖所示,假設PWM 波形周期1ms(即1kHz),分辨率1000 級。那么需要一個信號時間 精度1ms/1000=1us 的信號源,即1MHz。所以說,PWM 的實現難點在于需要使用很高頻的 信號源,才能獲得快速與高精度。下面先由一個簡單的PWM 程序開始: const int PWMPin = 13; int bright = 0; void setup() { pinMode(PWMPin, OUTPUT); } void loop() { if((bright++) == 255) bright = 0; for(int i = 0; i < 255; i++) { if(i < bright) { digitalWrite(PWMPin, HIGH); delayMicroseconds(30); } else { digitalWrite(PWMPin, LOW); delayMicroseconds(30); } } } 這是一個軟件PWM 控制Arduino D13 引腳的例子。只需要一塊Arduino 即可測試此代碼。 程序解析:由for 循環可以看出,完成一個PWM 周期,共循環255 次。 假設bright=100 時候,在第0~100 次循環中,i 等于1 到99 均小于bright,于是輸出PWMPin 高電平; 然后第100 到255 次循環里面,i 等于100~255 大于bright,于是輸出PWMPin 低電平。無 論輸出高低電平都保持30us。 那么說,如果bright=100 的話,就有100 次循環是高電平,155 次循環是低電平。 如果忽略指令執行時間的話,這次的PWM 波形占空比為100/255,如果調整bright 的值, 就能改變接在D13 的LED 的亮度。 這里設置了每次for 循環之后,將bright 加一,并且當bright 加到255 時歸0。所以,我們 看到的最終效果就是LED 慢慢變亮,到頂之后然后突然暗回去重新變亮。 這是最基本的PWM 方法,也應該是大家想的比較多的想法。 然后介紹一個簡單一點的。思維風格完全不同。不過對于驅動一個LED 來說,效果與上面 的程序一樣。 const int PWMPin = 13; int bright = 0; void setup() { pinMode(PWMPin, OUTPUT); } void loop() { digitalWrite(PWMPin, HIGH); delayMicroseconds(bright*30); digitalWrite(PWMPin, LOW); delayMicroseconds((255 - bright)*30); if((bright++) == 255) bright = 0; } 可以看出,這段代碼少了一個For 循環。它先輸出一個高電平,然后維持(bright*30)us。然 后輸出一個低電平,維持時間((255-bright)*30)us。這樣兩次高低就能完成一個PWM 周期。 分辨率也是255。 三、多引腳PWM Arduino 本身已有PWM 引腳并且運行起來不占CPU 時間,所以軟件模擬一個引腳的PWM 完全沒有實用意義。我們軟件模擬的價值在于:他能將任意的數字IO 口變成PWM 引腳。 當一片Arduino 要同時控制多個PWM,并且沒有其他重任務的時候,就要用軟件PWM 了。 多引腳PWM 有一種下面的方式: int brights[14] = {0}; //定義14個引腳的初始亮度,可以隨意設置 int StartPWMPin = 0, EndPWMPin = 13; //設置D0~D13為PWM 引腳 int PWMResolution = 255; //設置PWM 占空比分辨率 void setup() { //定義所有IO 端輸出 for(int i = StartPWMPin; i <= EndPWMPin; i++) { pinMode(i, OUTPUT); //隨便定義個初始亮度,便于觀察 brights[ i ] = random(0, 255); } } void loop() { //這for 循環是為14盞燈做漸亮的。每次Arduino loop()循環, //brights 自增一次。直到brights=255時候,將brights 置零重新計數。 for(int i = StartPWMPin; i <= EndPWMPin; i++) { if((brights[i]++) == PWMResolution) brights[i] = 0; } for(int i = 0; i <= PWMResolution; i++) //i 是計數一個PWM 周期 { for(int j = StartPWMPin; j <= EndPWMPin; j++) //每個PWM 周期均遍歷所有引腳 { if(i < brights[j])\ 所以我們要更改PWM 周期的話,我們將精度(代碼里面的變量:PWMResolution)降低就行,比如一般調整LED 亮度的話,我們用64 級精度就行。這樣速度就是2x32x64=4ms。就不會閃了。
上傳時間: 2013-10-08
上傳用戶:dingdingcandy
十六進制單精度浮點數轉十進制數的小工具
標簽: HexSingleToDecimal 十六進制 精度 浮點數
上傳時間: 2013-11-15
上傳用戶:yupw24
PADS2007 Router茂積教程
上傳時間: 2013-10-14
上傳用戶:完瑪才讓
FPGA實現多進制FSK的調制解調
上傳時間: 2013-11-19
上傳用戶:xjy441694216
知識_熱轉印PCB制板過程實錄熱轉印做PCB板的
上傳時間: 2013-11-07
上傳用戶:蒼山觀海
本文介紹了AT24C01系列二線制串行EEPROM的使用方法及串行EEPROM與單片機的軟件接口,簡要說明其在電機控制中保存控制參數的應用
上傳時間: 2013-11-21
上傳用戶:lps11188
CAM350軟件的學習筆記目錄1. CAM3501. 一. Gerber知識2. 二.CAM3503. 三.CAM350操作4. 附錄Gerber知識l Gerber 文件的格式包括:¡ RS-274-X (常用)¡ RS-274-D (常用)¡ RS-274¡ Fire 9000¡ Mda 9000¡ Barco DPFl 標準的gerber file 格式可分為RS-274 與RS-274X 兩種,其不同在于:¡ RS-274 格式的gerber file 與aperture 是分開的不同文件。¡ RS-274X 格式的aperture 是整合在gerber file 中的,因此不需要aperture文件(即,內含D 碼)。PCB生成Gerber最好就是選用RS-274x格式,既標準,又兼容性高。l 數據格式:整數位+小數位 。常用:¡ 3:3(公制,整數3 位,小數3 位)¡ 2:4(英制,整數2 位,小數4 位)¡ 2:3(英制,整數2 位,小數3 位)¡ 3:3(英制,整數3 位,小數3 位)l 前導零、后導零和不導零:¡ 例:025690 前導零后變為:25690 (Leading)¡ 025690 后導零后變為:02569 (Trailing)¡ 025690 不導零后變為:025690 (None)l 單位:¡ METRIC(mm)¡ ENGLISH(inch or mil)l 單位換算:¡ 1 inch = 1000 mil = 2.54 cm = 25.4 mm¡ 1 mm = 0.03937 inch = 39.37 mill GERBER 格式的數據特點:
上傳時間: 2013-10-17
上傳用戶:yzy6007
過孔(via)是多層PCB的重要組成部分之一,鉆孔的費用通常占PCB制板費用的30%到40%。簡單的說來,PCB上的每一個孔都可以稱之為過孔。從作用上看,過孔可以分成兩類:一是用作各層間的電氣連接;二是用作器件的固定或定位。如果從工藝制程上來說,這些過孔一般又分為三類,即盲孔(blind via)、埋孔(buried via)和通孔(through via)。盲孔位于印刷線路板的頂層和底層表面,具有一定深度,用于表層線路和下面的內層線路的連接,孔的深度通常不超過一定的比率(孔徑)。埋孔是指位于印刷線路板內層的連接孔,它不會延伸到線路板的表面。上述兩類孔都位于線路板的內層,層壓前利用通孔成型工藝完成,在過孔形成過程中可能還會重疊做好幾個內層。第三種稱為通孔,這種孔穿過整個線路板,可用于實現內部互連或作為元件的安裝定位孔。由于通孔在工藝上更易于實現,成本較低,所以絕大部分印刷電路板均使用它,而不用另外兩種過孔。以下所說的過孔,沒有特殊說明的,均作為通孔考慮。
上傳時間: 2013-11-06
上傳用戶:gaoliangncepu
第一章 傳輸線理論一 傳輸線原理二 微帶傳輸線三 微帶傳輸線之不連續分析第二章 被動組件之電感設計與分析一 電感原理二 電感結構與分析三 電感設計與模擬四 電感分析與量測傳輸線理論與傳統電路學之最大不同,主要在于組件之尺寸與傳導電波之波長的比值。當組件尺寸遠小于傳輸線之電波波長時,傳統的電路學理論才可以使用,一般以傳輸波長(Guide wavelength)的二十分之ㄧ(λ/20)為最大尺寸,稱為集總組件(Lumped elements);反之,若組件的尺寸接近傳輸波長,由于組件上不同位置之電壓或電流的大小與相位均可能不相同,因而稱為散布式組件(Distributed elements)。 由于通訊應用的頻率越來越高,相對的傳輸波長也越來越小,要使電路之設計完全由集總組件所構成變得越來越難以實現,因此,運用散布式組件設計電路也成為無法避免的選擇。 當然,科技的進步已經使得集總組件的制作變得越來越小,例如運用半導體制程、高介電材質之低溫共燒陶瓷(LTCC)、微機電(MicroElectroMechanical Systems, MEMS)等技術制作集總組件,然而,其中電路之分析與設計能不乏運用到散布式傳輸線的理論,如微帶線(Microstrip Lines)、夾心帶線(Strip Lines)等的理論。因此,本章以討論散布式傳輸線的理論開始,進而以微帶傳輸線為例介紹其理論與公式,并討論微帶傳輸線之各種不連續之電路,以作為后續章節之被動組件的運用。
標簽: 傳輸線
上傳時間: 2013-11-10
上傳用戶:瀟湘書客