單片機+CPLD的多路精確延時(shí)控制系統
每個(gè)系統由n(本系統設計中n=9)個(gè)輸出控制單元組成,這n個(gè)單元輸出控制獨立并行工作,如圖4所示。N0.1~N0.n以ATMEL公司5l系列單片機AT89C2051為核心。AT89C205l是低功耗、高性能CMOS 8位單片機,具有15個(gè)雙向輸入/輸出(I/O)端口、片內含2 K字節的可反復擦寫(xiě)的只讀Flash程序存儲器和128字節的隨機存取數據存儲器(RAM);采用ATMEL公司的高密度、非易失性存儲技術(shù)生產(chǎn),兼容標準MCS一5l指令系統。輸出控制單元(NO.1~NO.n)并行工作,完成延時(shí)時(shí)間設置、μs/ms變換設置、控制信號輸出和延時(shí)顯示等功能,延時(shí)時(shí)間顯示通過(guò)單片機串口實(shí)現,由3片串/并變換器件74LSl64驅動(dòng)3個(gè)共陽(yáng)數碼管。本文引用地址:http://dyxdggzs.com/article/162113.htm
4 系統軟件設計
本系統軟件設計包括CPUO單元、NO.1~NO.n輸出單元及CPLD單元程序設計。由于對時(shí)間要求嚴格,采用匯編語(yǔ)言編寫(xiě),信號輸出由中斷程序完成,由于中斷響應過(guò)程、現場(chǎng)保護以及中斷后必要的設置條件檢測需要時(shí)間,所以軟件必須通過(guò)容余指令(比如NOP)的延時(shí),可保證counter0輸出和控制信號延時(shí)起點(diǎn)在同一時(shí)刻。
CPU0單元程序流程如圖5所示。CPU0主程序完成系統初始化、按鍵檢測、去抖動(dòng)信號輸出和工作狀態(tài)提示音輸出等工作,中斷服務(wù)程序計時(shí)基準信號counterO輸出。輸出控制單元NO.1一NO.n程序流程如圖6所示,各單元主程序完成μs/ms設置檢測,延時(shí)設置讀取,延時(shí)時(shí)間顯示,中斷程序完成控制信號輸出功能。CPLD程序采用VHDL語(yǔ)言編寫(xiě),采用QHalftusⅡ軟件編譯仿真。
5 結語(yǔ)
該系統設計可應用于電容組(9只)放電控制系統,在放電電子開(kāi)關(guān)控制端、
評論