1 引言 隨著用電量的增加,電網的諧波污染變得日益嚴重,這就要求電力監控設備能夠及時準確地對電網諧波分量進行監測,在筆者研制的電網諧波分析儀中,使用ADS7864對各相關點的波形信號進行采集,實踐證明,ADS7864的采樣精度及穩定性是令人滿意的。 ADS7864是Burr-Brown公司(已被德州儀器收購)開發的12位6通道A/D轉換器,其主要特點如下: 6個模擬輸入通道同時采樣與保持; 2μs轉換時間,500kS/s采樣速率; 全差分輸入; 功耗低,為50mW; 6個FIFO寄存器; 全硬件控制。 2 內部結構和引腳說明 圖1所示為AD7864內部結構框圖,該器件含有2個2μs的逐次逼近模數轉換器,6個差分采樣與保持放大器、1個帶REFIN和REFOUT引腳的+2.5V內部電壓基準以及1個高速并行接口。6個模擬輸入通道分成3對(A、B、C)。每個A/D轉換器都有3對輸入端(A0/A1、B0/B1、C0/C1),可以同時采樣、轉換,因此可以保持兩個模擬輸入信號的相對相位信息。每對通道都有一個保持信號(HOLDA、HOLDB、HOLDC)使6個通道上的采樣可同時進行,圖2為ADS7864的引腳封裝圖,其引腳說明如圖1所示。 ADS7864既可以使用內部參考電壓源,也可以使用外部參考電壓源,從圖1可以看出,當使用內部2.5V參考電壓源時,REFOUT引腳應該連接至REFIN引腳,這是一種常用方式,當輸入模擬信號為2.4V-5.2V之間時,可以使用1.2V-2.6V范圍內的外部參考電壓源。 ADS7864只采用外部時鐘(CLOCK),當外部時鐘為8KHz時,A/D采樣速率為500KHz,與2μs的最小轉換時間相對應。 3 工作及控制模式 與MAX197不同,ADS7864不采用寄存器進行轉換控制,而是完全依靠外部引腳進行控制,雖然控制比較簡單,但是卻需占用部分硬件資源。 (1)A/D轉換的啟動 ADS7864的轉換啟動控制使用HOLDx引腳(LOLDA、HOLDB、HOLDC),將一個或者所有的HOLDx信號拉低,則相應通道x的輸入數據立即被置為保持模式,通道x的轉換隨即開始,如果其他通道已處于保持模式但還沒有開始轉換,通道x的轉換則需列隊等候直到上一輪轉換完成為止。如果在一個時鐘周期內不止一個通道進入保持模式,并且HOLDA也是被觸發的保持信號時,通道A將首先開始轉換,接著是通道B,最后是通道C,一旦某個特定的保持信號變為低,其隨后的脈沖被忽略,直到這次轉換完成或器件復位。 在轉換完成時(BUSY信號變高),采樣開關將關閉并且對選擇的通道進行采樣,延遲隨后的轉換,以便對ADS7864的輸入電容完全充電,延遲時間取決于驅動放大器,但應該至少有175ns。 (2)轉換結果的讀取 ADS7864有3種不同的數據輸出模式,用A2、A1和A0引腳選擇,如表2所列。 第一種是地址模式,在(A2A1A0)=從000到101時,可以直接對特定的通道尋址,該通道的地址在RD的下降沿之前應保持至少10ns,并且只要RD為低就不能改變。 第二種是循環模式,在(A2A1A0)=110時,接口以循環模式工作,此時,數據在第一個RD信號時從通道A0讀取,接著是通道A1,隨后是B0、B1、C0,最后是C1(再次讀取A0之前),在一個復位信號之后或者對器件上電之后,通道A0的數據首先輸出。 第三種是FIFO模式,在(A2A1A0)=111時,該模式中,先讀取首先被轉換的數據,此時,如果某個特定的通道最受關注、轉換較頻繁(例如,獲取特定通道的歷史記錄),則每個通道就有3個輸出寄存器用于存儲數據。 ADS7864的輸入為16位、12位輸出數據存儲于DB11(最高有效位)到DB0(最低有效位)。當DB11-DB0輸出有效數據時,DB15為1,這點對于FIFO模式非常重要,在DB15變為0之前可以讀取有效數據。DB14、DB13、DB12輸出通道地址,其具體信息與表2中A2、A1、A0的地址設置相對應。 為了增加設計的靈活性,ADS7864支持不同寬度的數據總線。當數據寬度控制端BYTE被置為高電平時,ADS7864的16位數據輸出端直接與16位數據總線相連,當BYTE端被置為低電平時,可以與8位數據總線連接,在第一個DR信號時低8位數據在輸出引腳DB7到DB0讀取,第二個RD信號時則讀取高8位數據。 4 在電網諧波分析儀中的應用 電網諧波分析需要采集的數據包括三相線路的電壓、電流共6個量(對于每條輸電線路),在以往的開發過程中采用MAX197進行數據采集,但是MAX197不具備多通道同時采樣保持功能,在轉換時不能保證6個模擬量采樣時間的一致性,影響了諧波分析的準確性。 在諧波分析儀的設計中,使用了TI公司的定點數字信號處理器TMS320F206(采用20MHz有源晶體振蕩器作為外部時鐘)進行數據采集控制和分析,由于DSP需要對采樣數據進行每周期64點的連續FFT變換,運算比較復雜,所以最理想的采樣數據位數應該為12位,留出4位作為運算時的溢出保護位,而不需要在軟件設計過程中頻繁地進行歸一化處理,由于12位精度的ADS7864具有6通道同時保持放大、適中的轉換速率與精度以及雙極性輸入等特點,非常使用于電網諧波分析儀的數據采集。TMS320F206(以下簡稱F206)與ADS7864的接口示意圖如圖3所示。 在許多相關文獻中,為保證DSP運行速度與A/D轉換器響應速度相匹配,往往采用片內I/O口與A/D轉換器接口,依靠軟件實現A/D轉換器的片選(CS)與數據讀取控制(RD),這種方式雖然可保證操作的可靠性,但同時也占用了DSP上的I/O口資源,而且具有接口連接的A/D轉換器數量非常有限。 經過仔細分析,在電網諧波分析儀的硬件設計中F206與ADS7864仍然采用了傳統的地址譯碼片選的接口方式,將F206的I/O空間選擇端IS與地址線AD12-AD15先輸入可編程邏輯器件GAL22V10,再輸出片選信號CS,F206的RD端直接與ADS7864的讀數據控制端DR端連接。 由于F206外部數據總線為16位,可將ADS7864的輸出數據寬度控制端BYTE接地,16位輸出直接與F206的數據總線相連。 由于在電網諧波分析中要求同時對三相電壓、電流信號進行采集,所以ADS7864的采樣保持啟動控制端HOLDA、HOLDB、HOLDC直接與F206的IO1端連接,當IO1輸出低電平時,同時啟動三組6路信號的采樣保持并進行轉換。 在諧波分析儀的設計中,ADS7864的數據讀取采用地址模式,每次轉換結束后,由ADS7864的BUSY端通過反相器向F206的INT2端發出中斷信號,完成一次6路信號的采樣轉換共響應3次中斷,在每次中斷服務程序中讀取相應地址的轉換數據。 5 結束語 根據筆者長期的設計體會,在DSP與A/D轉換器接口的硬件與軟件設計過程中,有幾個帶有共性的問題需要引起足夠的重視: (1)地址建立時間對接口的影響 在微處理器系統中為保證正確讀取數據,在讀數據控制信號RD有效前,需要提前建立地址中線信號,這一時間稱為地址建立時間,40MHz主頻時,F206的地址建立時間最小值為8.5ns,而ADS7864要求的地址建立時間至少為10ns(使用8MHz外部時鐘時,下同)。顯然,由于地址建立時間的約束,F206在40MHz主頻時不能采用傳統的地址譯碼片選方式與ADS7864接口,為保證時序的要求,必須使用I/O口。 206工作在20MHz主頻時,地址建立時間為21ns,則可以采用傳統的地址譯碼片選方式與ADS7864接口,這也是本文實際應用的接口方式。 (2)數據建立時間對接口的影響 證微處理器可靠地讀取數據,在距讀數據控制信號RD上升沿一段時間時,數據就應穩定地出現在數據總線上,這一時間稱為數據建立時間,在ADS7864中,要求讀數據控制信號RD和片選信號CS在輸出數據有效前必須保持低電平至少30ns,但是當工作在20MHz主頻時,F206的讀數據控制信號RD所能提供的數據建立時間在20MHz主頻時最少為30ns,顯然是不能可靠滿足要求的,必須使用F206的軟件狀態等待發生器來產生等待信號以讀取數據。 綜上所述,在DSP與A/D轉換器的接口設計中,只要仔細分析并充分考慮DSP運行速度與A/D轉換器響應時間之間的關系,并充分發揮DSP上軟件等待狀態發生器的作用,完全可以采用傳統的地址譯碼片選方式實現DSP與A/D轉換器之間的可靠接口,從而節約寶貴的I/O口資源。 |