<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • 時間片輪轉算法在單片機程序設計中的應用

    時間:2024-09-08 04:05:31 理工畢業論文 我要投稿
    • 相關推薦

    時間片輪轉算法在單片機程序設計中的應用

    傳統的單任務編程思想對于明顯的順序控制要求編程簡單、思路清晰、開發周期短;但對于任務較多、控制功能復雜的問題時,卻難以滿足要求。因此,有必要對傳統的單任務設計思想進行改進。時間片輪轉算法是實現多任務調度的一種常用算法。在這種算法中,系統將所有的任務按順序排成一個隊列,每次調度時把CPU分配給隊首的任務,并令其執行一個時間片,構成微觀上輪流運行、宏觀上并執行的多任務效果。作者在基于單片機的分級分布式控制系統——程控對講系統的用戶控制器程序中引入多任務機制,采用時間片輪轉算法極大地改善了程序結構,實現了對32個獨立用戶的有效控制。這種程序設計思想也可以到其它以單片機為核心的分級分布控制系統軟件設計中。

    1 系統組成

    程控對講系統是一個基于MCS-51的多級分布式系統,用戶控制器是其中的一級,整個系統總體結構如圖1所示。

    主控制器以單片機AT89C52為核心擴展非易失性存儲器及其它功能器件,完成系統各用戶對講關系的編程和存儲,并根據對講關系對用戶模塊進行實時控制。用戶控制器以單片機AT89C52為核心擴展用戶機接口模塊組成,每個用戶控制器負責對其下一級的32個用戶機進行管理與控制。

    主控制器與用戶控制器之間的信息交換采用主從方式的串行通信。主控制器對8個用戶控制器輪流查詢,各用戶控制器只對與本模塊相關的命令作出反應,用戶控制器通過雙絞線與用戶機相連,以降低系統成本。用戶機與用戶控制器之間傳輸距離較遠,最遠可達8km。為保證在復雜的環境中正確傳輸數據,兩者之間的通信采用DTMF編碼。

    2 任務的分配和時間片的劃分

    2.1 用戶控制器子任務的確定

    用戶控制器需要實時管理32個獨立的用戶機,一方面實時接收用戶機的呼叫信號進行處理后傳送給主控制器;另一方面根據系統工作狀況向用戶機發送被呼叫信息。

    用戶控制器接收來自用戶機的信號有兩類。一類是DTMF編碼信號,用于檢測用戶機是否需要呼叫其它用戶機。用戶機與控制器之間傳送數據的位數是不等長的,每位DTMF編碼數據的發送至少需要104ms,發送時間和空閑時間各占一半。另一類是話,DTMF編碼信號和話音信號的復用可以降低系統的線路成本。

    在每次通信結束后,為使用戶控制器能啟動下一輪的DTMF編碼數據的接收,用戶機需要給用戶控制器發送一個起始信號——掛機信號。用戶機的工作電源直接從用戶線路上提取,在話音和DTMF編碼傳送時用戶線路有一定的工作電流(大于20mA),掛機信號使用戶線路上電流接近于零(小于5mA),用戶控制器檢測用戶線路上電路的這種變化后,進入新一輪的DTMF編碼數據通信。掛機信號的持續時間為78ms。

    用戶控制器向用戶機發送的只有DTMF編碼數據,用于告訴用戶機誰正在呼叫它。

    要完成一個呼叫過程(即使通話時間為零),至少需要2×104ms(接收、發送DTMF編碼時間) 78ms(掛機時間)=286ms;完成一個被呼叫過程也至少需要2×104ms=208ms。如果每個用戶機的請求就不能實時作出響應。為解決這個問題,在用戶控制器程序設計過程中引入多任務機制。為便于任務調度程序的調度,根據用戶操作流程將用戶機的操作細分為16個字操作,每個子操作構成個子任務,用戶子任務分配表如表1所示。

    表1 用戶子任務分配表

    子任務號功 能執行時間0等待接收26×n1接收預處理262用戶機查詢26×43應答26×44接收第1位數據26×45接收第2位數據26×46接收第3位數據26×47等待上傳26×n8確認26×n9響應26×410通話26×n11掛機26×212發送預處理2613發送第1位數據26×414發送第2位數據26×415發送第3位數據26×4

    2.2 時間片的劃分

    在時間片的輪轉算法中,時間片的大小對系統性能有很大影響。如果時間片太大,大到每個任務都能在一個時間片內執行完畢,則時間片輪轉算法便退化為FCFS算法。時間片的確定通常要考慮三個因素:任務的數目、系統對響應時間的要求、系統的處理能力。

    本系統中用戶控制器需要對32個用戶機進行管理控制,應劃分成32個時間片。在不同時刻每個用戶機處于不同的工作狀況,用戶控制器需要執行不同的用戶機任務,其處理時間也不相同。為縮短程序運行時間把,時間片設置為可變的,時間片的長短取決于各個用戶機子任務的工作量。但用戶控制器與用戶機之間的通信時間要求很嚴,如DTMF的發送定時時間為104ms,包括52ms發送時間和52ms空閑時間,所以用戶控制器必須在52ms內對每個用戶機巡檢一次,才能正確地接收用戶機的編碼數據。也就是說一個任務調度周期不應大于52ms。為滿足用戶機與控制器之間的通信對時間要求,對整個任務調度周期進行精確定時。

    綜合考慮本系統中與時間片劃分相關的三種因素:單片機本身的運算速度、用戶機數目及用戶機與控制器之間信號的傳送要求,確定任務調度周期為26ms。即在26ms內用戶控制器對其下一級的32個用戶機的任務都要執行一次。一般完成一個任務占用一個時間片,較長任務可以占用多個時間片,如14號子任務(發送第2位DTMF編碼數據)需要占用4個時間片才能完成。

    為實時

    時間片輪轉算法在單片機程序設計中的應用

    【時間片輪轉算法在單片機程序設計中的應用】相關文章:

    MCMC算法在MIMO系統檢測中的應用03-07

    遺傳算法及其在求解TSP中的應用03-07

    淺談網絡拓撲發現算法在網管中的應用03-03

    談網絡拓撲發現算法在網管中的應用03-25

    PIC單片機在智能雙電源裝置中的應用03-19

    模擬退火算法在匹配場定位優化中的應用03-07

    信息紐扣DS1991在單片機系統中的應用03-18

    人工智能算法在自動化控制中的應用03-28

    期望最大算法的優化及其在神經放電尖峰分類中的應用03-07

    主站蜘蛛池模板: 久久成人精品| 久久Av无码精品人妻系列| 亚洲日韩精品无码专区网站| 久久91精品久久91综合| 日韩精品系列产品| 久久精品一区二区三区中文字幕 | 少妇人妻无码精品视频| 国产综合成人色产三级高清在线精品发布| 国产精品无码久久综合| 亚洲一区二区精品视频| 国模精品一区二区三区| 国产99久久九九精品无码| 国产亚洲精品国产| 精品9E精品视频在线观看| 亚洲精品亚洲人成在线观看| 久久97久久97精品免视看秋霞| 97精品国产高清自在线看超 | 精品无码人妻一区二区免费蜜桃| 区亚洲欧美一级久久精品亚洲精品成人网久久久久| 成人精品一区二区三区| 国产亚洲精品国产| 国产92成人精品视频免费| 久久精品国产网红主播| 无码人妻精品一区二区三区久久| 亚洲精品无码你懂的网站| 欧美日韩国产精品自在自线| 国产亚州精品女人久久久久久| 99精品电影一区二区免费看| 亚洲精品综合一二三区在线| 久久精品免费一区二区三区| 久久精品国产影库免费看| 亚洲国产精品lv| 丰满人妻熟妇乱又伦精品劲| 亚洲色图国产精品| 94久久国产乱子伦精品免费 | 久久e热在这里只有国产中文精品99 | 精品久久久久中文字幕一区| 国产激情精品一区二区三区| 99免费精品国产| 国产精品一级毛片无码视频| 国内精品视频在线观看|