女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當(dāng)前位置:首頁 > 測試測量 > 測試測量
[導(dǎo)讀]狀態(tài)機(jī)是在工程應(yīng)用中使用最多的設(shè)計模型。使用狀態(tài)機(jī),我們可以很容易的實現(xiàn)程序流程圖中的判斷、分支。 狀態(tài)機(jī)是由一系列的狀態(tài)構(gòu)成的,其中包括一個“初始化”狀態(tài),和一個“停止”狀態(tài)。程

狀態(tài)機(jī)是在工程應(yīng)用中使用最多的設(shè)計模型。使用狀態(tài)機(jī),我們可以很容易的實現(xiàn)程序流程圖中的判斷、分支。 狀態(tài)機(jī)是由一系列的狀態(tài)構(gòu)成的,其中包括一個“初始化”狀態(tài),和一個“停止”狀態(tài)。程序油“初始化”狀態(tài)開始,由“停止”狀態(tài)結(jié)束。一般來說,在“初始化”狀態(tài)中進(jìn)行控件與變量的初始化、打開文件以及創(chuàng)建引用等操作,而在“停止”狀態(tài)中進(jìn)行清除臨時數(shù)據(jù)、關(guān)閉文件和結(jié)束引用等操作。在狀態(tài)機(jī)中,每一個狀態(tài)都可能導(dǎo)致一個或多個狀態(tài)的發(fā)生,其下一狀態(tài)是由用戶的輸入信息和當(dāng)前狀態(tài)所決定的。 在決定使用狀態(tài)機(jī)作為我們的設(shè)計模型后,我們首先要畫出一個狀態(tài)轉(zhuǎn)換圖。在圖中要列出系統(tǒng)中的所有狀態(tài),以及各個狀態(tài)之間的轉(zhuǎn)換關(guān)系。而且要標(biāo)明轉(zhuǎn)換所需要的條件。 舉個例子,要編程實現(xiàn)以下功能:隨機(jī)生成100個[0,100]內(nèi)的自然數(shù),并判斷生成的自然數(shù)是否在[30,60]的區(qū)間內(nèi)。如果不在該區(qū)間內(nèi)給出報警信息,如果在區(qū)間內(nèi)則將該數(shù)累加。 實際上如果我們把生成的隨機(jī)數(shù)看作系統(tǒng)采集到的數(shù)據(jù)的話,這到題就是模擬了一個采集數(shù)據(jù)并且在數(shù)據(jù)不符合要求時報警,并將復(fù)合要求的數(shù)據(jù)進(jìn)行進(jìn)一步分析的系統(tǒng)。 要完成這道題目,需要要先畫出它的狀態(tài)轉(zhuǎn)換圖: 有了這個狀態(tài)轉(zhuǎn)換圖,我們就可以清晰的看到程序要實現(xiàn)的所有狀態(tài)以及狀態(tài)之間的關(guān)系。 畫好狀態(tài)轉(zhuǎn)換圖,我們就可以清晰的看到程序要實現(xiàn)的所有狀態(tài)以及狀態(tài)之間的關(guān)系。下面的工作就是用LabVIEW來實現(xiàn)這個狀態(tài)機(jī)。 狀態(tài)機(jī)是由一個While循環(huán)、一個條件結(jié)構(gòu)和一個移位寄存器組成的。其中While循環(huán)用來保證程序可以連續(xù)的運(yùn)行;條件結(jié)構(gòu)的各種分支中的代碼用來描述狀態(tài)機(jī)的各種狀態(tài),以及下一狀態(tài)的選擇;移位寄存器用來將之前狀態(tài)所作出的選擇傳遞到下一次循環(huán)的選擇端子。 下面我們就一步一步的實現(xiàn)這個狀態(tài)機(jī)。 首先,新建一個工程,并且在工程中建立“控件”和“子VI”兩個虛擬文件夾來放置自定義控件和子VI。在“控件”文件夾中新建一個控件。 在控件的編輯面板上放置一個枚舉類型的控件,并且編輯枚舉類型控件的項目,輸入所有狀態(tài)裝換圖中的狀態(tài)的名稱。如下圖所示。 可以看到,上圖中的項目比狀態(tài)轉(zhuǎn)換圖中多了一個“空白”狀態(tài)。這只是為了修改程序方便才添加的,具體情況會在下文中提到。 編輯完成之后,將控件的類型更改為嚴(yán)格自定義類型(Strict Type Define),然后保存。建立這樣一個嚴(yán)格自定義類型控件用來控制狀態(tài)的轉(zhuǎn)換有很大的好處,就是在我們?nèi)f一要添加新的狀態(tài)或者要刪除一些無用的狀態(tài)時,只要修改我們建立的控件就可以了,不用在程序中一處一處的尋找、修改,可以節(jié)省很多時間,且不易出錯。 做好以上控件后,就要在工程中新建一個狀態(tài)機(jī)VI。我們可以先新建一個空白VI,然后在里面添加狀態(tài)機(jī)所需要的While循環(huán)、條件結(jié)構(gòu)和移位寄存器。而更方便的方法是,點擊“文件-->新建”,然后在彈出的“新建”對話框中選擇“標(biāo)準(zhǔn)狀態(tài)機(jī)”(Standard State Machine),來建立一個狀態(tài)機(jī)VI。如下圖所示。 在利用模版建立了狀態(tài)機(jī)VI后,我們要刪除其中的介紹性文字,因為這些文字是用來介紹模版功能和提醒編程者某些注意事項的。在最終程序中保留這些文字是非常不專業(yè)的。 接下來就是把我們事先建立好的嚴(yán)格自定義類型的枚舉控件拖入程序框圖中,來獲得它所對應(yīng)的常量,用來替換原模版中的枚舉類型常量。然后,在條件結(jié)構(gòu)中加入足夠的分支來放置不同狀態(tài)下的代碼;添加足夠的移位寄存器來在各個狀態(tài)之間傳遞參數(shù);在各個狀態(tài)(分支)下添加代碼,包括實現(xiàn)狀態(tài)功能的功能代碼以及確定下一個狀態(tài)的流程代碼。如下圖所示。 大家可以看到,程序在執(zhí)行時是不會進(jìn)入最后一個“空白”狀態(tài)的,添加這個狀態(tài)的目的就是為了在添加新的狀態(tài)時,可以通過復(fù)制空白狀態(tài)來得到,可以大大提高編程效率。 以上所說的狀態(tài)機(jī)叫做標(biāo)準(zhǔn)狀態(tài)機(jī),是最常用也是最基本的狀態(tài)機(jī)。其實狀態(tài)機(jī)還有一些變種的形式,以后再介紹吧。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

在嵌入式系統(tǒng)與底層軟件開發(fā)中,C語言的枚舉類型(enum)因其強(qiáng)大的語義表達(dá)能力,成為狀態(tài)機(jī)設(shè)計和位域操作的核心工具。本文將從底層原理出發(fā),解析枚舉類型在狀態(tài)機(jī)實現(xiàn)中的優(yōu)化策略,并探討其與位域(bit-field)的協(xié)同...

關(guān)鍵字: C語言 嵌入式系統(tǒng) 狀態(tài)機(jī)

在SIP終端在同一個函數(shù)中同時作為主叫方和被叫方的情況。即在RequestINVITE函數(shù)中,這個SIP終端需要能夠構(gòu)造INVITE請求(作為主叫方),同時還需要處理作為被叫方時的各種響應(yīng),比如發(fā)送100 Trying、...

關(guān)鍵字: INVITE 狀態(tài)機(jī)

下面的項目包括一個機(jī)器人完成各種任務(wù)。這是通過在機(jī)器人上使用和實現(xiàn)各種傳感器來完成的。機(jī)器人能夠在一個封閉的區(qū)域內(nèi)移動,收集球,并在最后的一個點上放下球。機(jī)器人將繪制出它去過的位置和該區(qū)域內(nèi)的障礙物。

關(guān)鍵字: 傳感器 機(jī)器人 LabVIEW

在嵌入式系統(tǒng)開發(fā)中,有限狀態(tài)機(jī)(FSM)是一種強(qiáng)大的工具,它能夠幫助開發(fā)者以清晰、結(jié)構(gòu)化的方式管理復(fù)雜的狀態(tài)轉(zhuǎn)換邏輯。FSM通過將系統(tǒng)行為劃分為一系列狀態(tài)和狀態(tài)之間的轉(zhuǎn)換,簡化了系統(tǒng)的設(shè)計和調(diào)試過程。在第一部分中,我們已...

關(guān)鍵字: 嵌入式系統(tǒng) 狀態(tài)機(jī) FSM C++

自動飲料售賣機(jī)作為一種自助式零售設(shè)備,近年來在國內(nèi)外得到了廣泛應(yīng)用。本文將詳細(xì)介紹一款功能完善、操作簡便的自動飲料售賣機(jī)的設(shè)計與實現(xiàn)過程,包括有限狀態(tài)機(jī)(FSM)的設(shè)計、Verilog編程、以及設(shè)計工程中可使用的工具及大...

關(guān)鍵字: Verilog 狀態(tài)機(jī) FSM

在現(xiàn)代電子系統(tǒng)中,同步信號處理和模式識別是至關(guān)重要的。特別是在通信、數(shù)據(jù)處理和控制系統(tǒng)等領(lǐng)域,對輸入信號進(jìn)行實時分析以檢測特定模式或字符串是常見的需求。本文將介紹如何使用Verilog語言設(shè)計一個有限狀態(tài)機(jī)(FSM),以...

關(guān)鍵字: Verilog 狀態(tài)機(jī)

在數(shù)字電路與系統(tǒng)設(shè)計領(lǐng)域,有限狀態(tài)機(jī)(Finite State Machine,F(xiàn)SM)是一種重要的設(shè)計工具。FSM能夠基于輸入信號和當(dāng)前狀態(tài),通過狀態(tài)轉(zhuǎn)移和輸出邏輯,實現(xiàn)復(fù)雜的時序控制功能。Moore狀態(tài)機(jī)和Mealy...

關(guān)鍵字: Moore Mealy 狀態(tài)機(jī)

狀態(tài)機(jī)的全稱是有限狀態(tài)自動機(jī),自動兩個字也是包含重要含義的。給定一個狀態(tài)機(jī),同時給定它的當(dāng)前狀態(tài)以及輸入,那么輸出狀態(tài)是可以明確地運(yùn)算出來的。

關(guān)鍵字: 狀態(tài)機(jī) 自動門

在數(shù)字電路與系統(tǒng)設(shè)計的廣闊天地中,Verilog HDL(硬件描述語言)以其強(qiáng)大的描述能力和靈活性,成為了設(shè)計師們不可或缺的利器。而在Verilog的眾多特性中,狀態(tài)機(jī)(Finite State Machine, FSM...

關(guān)鍵字: Verilog 狀態(tài)機(jī)

在這篇文章中,小編將為大家?guī)鞦PGA三段式狀態(tài)機(jī)設(shè)計的相關(guān)內(nèi)容。如果你對本文即將要講解的內(nèi)容存在一定興趣,不妨繼續(xù)往下閱讀哦。

關(guān)鍵字: FPGA 狀態(tài)機(jī)
關(guān)閉