關 閉

        新聞中心

        EEPW首頁 > 工控自動化 > 設計應用 > 軟PLC編譯系統(tǒng)的開發(fā)與實現

        軟PLC編譯系統(tǒng)的開發(fā)與實現

        作者: 時間:2010-04-26 來源:網絡 收藏

          為了便于分析,用單個小寫字母代替指令,即LD,LDI→a;AND,ANI→b;OR,ORI→c;ANB→d;ORB→e;0UT→f。指令表的文法可表示為1個四元式(Vt,VN,S,φ),其中,Vt是終結符號集,包括{a,b,e,d,e,f};VN是非終結符號集,包括{S,H,K,A,B,D,E};S是開始符號;φ中是產生式集(@代表空集)。因

          此,指令表程序的文法G[S]為S→aHfS; S→AfS;S→@;H→EH;H→@;K→EK;K→@,A→DA;A→@;B→e;D→b;D→c;E→D;E→aKB。

          由G[S]產生式,可推出空串的非終結符集合為{S,H,K,A}。

          4.2 軟程序的語法分析

          語法分析選用自頂向下的LL(1)分析方法。為使用LL(1)分析方法,首先構造預測分析表,并先求取所有非終結符號的FIRST集和FELLOW集。

          FIRST集:FIRST(S)={a,@,b,c};FIRST(H)={@,b,c,a};FIRST(K)={@,b,c,a};FIRST(A)={@,b,c};FIRST(B)={e,d};FIRST(D)={b,c};FIRST(E)={b,c,a}。

          FOLLOW集:FOLLOW(S)={#};FOLLOW(H)= {f};FOLLOW(K)={e,d};FOLLOW(A)={f};

          FOLLOW(B)={b,c,a,f,e,d};FOLLOW(D)={b,c,f,a,e,d};FOLLOW(E)={b,C,a,f,e,d}。

          各產生式的SELECT集:SELECT(S→aHfS)={a};SELECT(S→AfS)={b,c,f};SELECT(S→@)={@,#};SELECT(H→EH)={b,c,a};SELECT(H→@)={@,f};SELECT(K→EK)={b,c,a};SELECT(K→@)={@,e,d};SELECT(A→DA)={b,c};SELECT(A→@)={@,f};SELECT(B→e)={e};SELECT(B→d)=1xhvv99hnvjz;SELECT(D→b)={b};SELECT(D→c)={c};SELECT(E→D)={b,c};SELECT(E→aKB)={a}

          根據上述計算。生成的文法預測分析表如表1所示。


          表1 文法預測分析表

          通過表1,采用非遞歸的預測分析方法,構造預測分析器模型,如圖2所示。


          圖2 非遞歸的預測分析器模型

          預測分析器的控制程序總是根據棧頂符號和當前輸入符號來決定預測分析器的動作,預測分析器的控制程序算法如下:

          置指針ip指向輸入符號串的第1個字符

          while(1)

          令X是棧頂符號。a是ip所指的符號;

          if(X是終結符號或$)

          if X==a

          pop(X),更新ip;

          else

          error();

          else(X是非終結符號)

          if M[X,a]:X―yly2?K

          pop(X);

        塵埃粒子計數器相關文章:塵埃粒子計數器原理


        評論


        相關推薦

        技術專區(qū)

        關閉
        主站蜘蛛池模板: 马龙县| 攀枝花市| 雷波县| 高唐县| 永宁县| 明光市| 宁化县| 峡江县| 金昌市| 禄劝| 漾濞| 鄂伦春自治旗| 色达县| 广安市| 宁明县| 贵德县| 贺州市| 楚雄市| 宝应县| 临夏县| 崇信县| 河北省| 鹤山市| 淳化县| 永善县| 正蓝旗| 延庆县| 临邑县| 清水河县| 沅陵县| 玉溪市| 比如县| 贞丰县| 牡丹江市| 平武县| 成武县| 阿拉尔市| 南京市| 巫溪县| 时尚| 漳州市|