一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于三叉樹鏈表的編譯器中間結(jié)構(gòu)的設(shè)計(jì)方案研究

牽手一起夢(mèng) ? 來源:電子元器件應(yīng)用 ? 作者:馬圣 ? 2020-05-14 09:13 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

引言

IEC61131—3組態(tài)軟件是分布式控制系統(tǒng)中的上位軟件,是工程師與系統(tǒng)的接口,可完成控制系統(tǒng)中現(xiàn)場(chǎng)設(shè)備運(yùn)行的邏輯組態(tài),從而實(shí)現(xiàn)對(duì)系統(tǒng)的控制。隨著PLCDCS系統(tǒng)的應(yīng)用日趨廣泛,IEC6113l一3已經(jīng)在工業(yè)自動(dòng)化中建立了牢固的國(guó)際標(biāo)準(zhǔn),國(guó)內(nèi)外大部分工業(yè)自動(dòng)化廠商都有提供基于國(guó)際標(biāo)準(zhǔn)IEC6113l一3的IEC組態(tài)編程系統(tǒng),IEC組態(tài)軟件的研發(fā)已經(jīng)成為工業(yè)自動(dòng)化廠商的核心技術(shù)。IEC組態(tài)軟件的實(shí)現(xiàn)原理之一是將前端用各種組態(tài)語言(ST,LD,F(xiàn)BD,SFC,IL)編寫的程序轉(zhuǎn)化成中間結(jié)構(gòu),再由組態(tài)軟件編譯后端根據(jù)不同的硬件平臺(tái)信息將中間結(jié)構(gòu)編譯成在該平臺(tái)上可執(zhí)行的目標(biāo)文件。組態(tài)軟件編譯部分的中間結(jié)構(gòu)是組態(tài)軟件IEC語言前端與組態(tài)軟件編譯后端的主要接口。好的中間結(jié)構(gòu)可使IEC語言前端做到與目標(biāo)機(jī)器無關(guān),而不依賴于目標(biāo)機(jī)器平臺(tái),同時(shí)可節(jié)省IEC語言前端的翻譯工作?,F(xiàn)今編譯程序使用的中間結(jié)構(gòu)有很多種形式,常見的有逆波蘭式、三元式、四元式和樹形結(jié)構(gòu),本文介紹一種基于三叉樹鏈表的中間結(jié)構(gòu)。

1 、總體設(shè)計(jì)思想

基于樹形結(jié)構(gòu)的中間結(jié)構(gòu)是現(xiàn)今大多數(shù)編譯器中間結(jié)構(gòu)的主流設(shè)計(jì)方案,比如GCC、LCC、TCC等均使用二叉樹或者多又樹作為其中間結(jié)構(gòu)。本文介紹的是一種三叉樹的設(shè)計(jì)方案。該方案中,以中間結(jié)構(gòu)表示的高級(jí)語言程序單元就是三叉語法樹節(jié)點(diǎn)組成的多層森林,每一層森林都是一個(gè)一維雙向鏈表,鏈表中的每個(gè)“節(jié)點(diǎn)”稱之為語法樹(一棵三叉樹),而每棵語法樹的節(jié)點(diǎn)則稱之為樹節(jié)點(diǎn)。其中,程序單元以POU(程序組織單元)為翻譯單位。

每個(gè)三叉樹節(jié)點(diǎn)包括的信息主要有語法樹的操作、節(jié)點(diǎn)類型、指向三個(gè)子樹的指針、鏈表前項(xiàng)與后項(xiàng)指針、關(guān)聯(lián)符號(hào)指針等。樹節(jié)點(diǎn)結(jié)構(gòu)體的數(shù)據(jù)結(jié)構(gòu)表示如下:

基于三叉樹鏈表的編譯器中間結(jié)構(gòu)的設(shè)計(jì)方案研究

其中,語法操作表示該節(jié)點(diǎn)可以完成什么樣的“運(yùn)算”。語法分析樹的語法操作符可以分為分別是POU節(jié)點(diǎn)操作符、語句操作符和表達(dá)式操作符三種類型,這三種類型的語法操作符將在下一節(jié)詳細(xì)介紹,通??梢哉Z法分析樹的語法操作來區(qū)分不同的語法分析樹。

類型是指當(dāng)前語法分析樹所代表的語法操作的類型。

符號(hào)指針是指向該節(jié)點(diǎn)關(guān)聯(lián)的符號(hào)表項(xiàng),并非所有節(jié)點(diǎn)的此項(xiàng)都有內(nèi)容,具體那些節(jié)點(diǎn)中可以關(guān)聯(lián)符號(hào)也將在下一節(jié)介紹。

圖1所示是一個(gè)POU程序單元以三叉樹鏈表的中間結(jié)構(gòu)總體表示的總體形式。

采用三叉樹森林的方法能夠充分的表示正常的高級(jí)語言,同時(shí),與其他編譯器不同,該方法還引入了POU節(jié)點(diǎn)操作符和語句操作符,而省去了前端大量語法翻譯的工作,符合IEC工業(yè)語言編譯器多前端的特征。

2、 中間結(jié)構(gòu)說明

語法分析樹的語法操作符可分為POU節(jié)點(diǎn)操作符、語句操作符和表達(dá)式操作符三種類型。下面來詳細(xì)介紹這三種語法樹節(jié)點(diǎn)的各種屬性。

2.1 POU節(jié)點(diǎn)操作符

POU節(jié)點(diǎn)操作符可用于表示POU的開始、結(jié)束、作用域和變量定義。各節(jié)點(diǎn)屬性如表l所列。

其中,語法操作以宏定義的形式聲明。符號(hào)是該節(jié)點(diǎn)關(guān)聯(lián)的符號(hào)表項(xiàng)。符號(hào)可分為POU符號(hào)和變量符號(hào)。POU符號(hào)包括POU名、參數(shù)個(gè)數(shù)及類型、返回值類型、POU地址等信息;變量符號(hào)則包括變量名、類型、作用域和地址等信息。

表l中的唯一節(jié)點(diǎn)指整個(gè)森林第一層鏈表中的節(jié)點(diǎn);葉節(jié)點(diǎn)指鏈表中一棵三叉樹的葉節(jié)點(diǎn)。

2.2 語句操作符

語句操作符分為分支選擇操作符、循環(huán)操作符、跳出、返回、調(diào)用和無條件跳轉(zhuǎn)等。各節(jié)點(diǎn)屬性如表2所列。

表2中的根節(jié)點(diǎn)指森林中一棵三叉樹的根節(jié)點(diǎn);中間節(jié)點(diǎn)指某三叉樹中的中間節(jié)點(diǎn),它既非根節(jié)點(diǎn),也非葉節(jié)點(diǎn)。CH00SE的左子節(jié)點(diǎn)是條件判定,中子節(jié)點(diǎn)是條件為真的內(nèi)容,右子節(jié)點(diǎn)是條件為假的內(nèi)容。同樣,LOOP的左子節(jié)點(diǎn)是條件判定,中子節(jié)點(diǎn)是循環(huán)體,右子節(jié)點(diǎn)是循環(huán)計(jì)數(shù)。對(duì)于WHILE語句,右子節(jié)點(diǎn)可以為空。RETURN的左子節(jié)點(diǎn)是返回表達(dá)式子樹。CALL的左子節(jié)點(diǎn)是參數(shù)子樹,中子節(jié)點(diǎn)是調(diào)用子樹。

2.3 表達(dá)式操作符

表達(dá)式操作符包括所有的高級(jí)語言運(yùn)算符,如賦值、算術(shù)、關(guān)系、邏輯運(yùn)算符等,以賦值、取地址和加法運(yùn)算符為例,其表達(dá)式操作符號(hào)主要屬性如表3所列。

3 、ST語言代碼對(duì)應(yīng)的中間結(jié)構(gòu)表示

本節(jié)以一段ST的POU程序?yàn)槔?,將其轉(zhuǎn)化為中間結(jié)構(gòu),以證明中間結(jié)構(gòu)的可行性。假設(shè)此POU中所定義的整型變量為a,b,那么,其POU程序如下:

對(duì)應(yīng)的中間結(jié)構(gòu)如圖2所示。其中,EQUAL是等值運(yùn)算符的宏定義。

4、結(jié)束語

本文介紹了一種三叉樹的中間結(jié)構(gòu)設(shè)計(jì)方案。該方案充分考慮了IEC61131—3組態(tài)軟件的多前端特性,并能夠做到不依賴于后端,同時(shí)為各語言翻譯前端的設(shè)計(jì)提供了很大的便利。這種中間結(jié)構(gòu)設(shè)計(jì)在HCC(Hollysys C Compiler)編譯器的開發(fā)中已經(jīng)實(shí)現(xiàn),其可行性也得到了驗(yàn)證,并已應(yīng)用在實(shí)際的組態(tài)軟件開發(fā)項(xiàng)目中。

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • plc
    plc
    +關(guān)注

    關(guān)注

    5037

    文章

    13921

    瀏覽量

    474654
  • 組態(tài)軟件
    +關(guān)注

    關(guān)注

    4

    文章

    233

    瀏覽量

    27549
  • 編譯器
    +關(guān)注

    關(guān)注

    1

    文章

    1662

    瀏覽量

    50228
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    自制Voron三叉戟裙燈

    描述Voron三叉戟裙燈PCB
    發(fā)表于 09-01 06:58

    基于CoSy的編譯器開發(fā)的研究

    CoSy是ACE公司開發(fā)的編譯器構(gòu)造框架[1]。它提供共享工具和引擎來構(gòu)造編譯器編譯器開發(fā)者只專注于目標(biāo)機(jī)相關(guān)代碼的開發(fā)。CoSy框架生成的編譯器具有可擴(kuò)展性和可移植性。可以根據(jù)目
    發(fā)表于 08-19 17:49 ?0次下載
    基于CoSy的<b class='flag-5'>編譯器</b>開發(fā)的<b class='flag-5'>研究</b>

    基于八維地質(zhì)建模系統(tǒng)設(shè)計(jì)研究李燦輝

    基于八維地質(zhì)建模系統(tǒng)設(shè)計(jì)研究_李燦輝
    發(fā)表于 03-16 08:00 ?0次下載

    基于三叉的OFT組密鑰管理協(xié)議

    針對(duì)集中式組播密鑰管理協(xié)議具有前向安全、后向安全、同謀破解等問題,本文提出了一種基于三叉(Ternary Tree)的OFT組密鑰管理協(xié)議(T-OFT)。使用三叉的邏輯密鑰
    發(fā)表于 12-13 16:07 ?0次下載
    基于<b class='flag-5'>三叉</b><b class='flag-5'>樹</b>的OFT組密鑰管理協(xié)議

    AVL 和普通的二查找的詳細(xì)區(qū)別分析

    那 AVL 和普通的二查找有何區(qū)別呢?如圖,如果我們插入的是一組有序上升或下降的數(shù)據(jù),則一棵普通的二查找必然會(huì)退化成一個(gè)單
    的頭像 發(fā)表于 01-15 14:36 ?6182次閱讀
     AVL <b class='flag-5'>樹</b>和普通的二<b class='flag-5'>叉</b>查找<b class='flag-5'>樹</b>的詳細(xì)區(qū)別分析

    三叉式萬向聯(lián)軸器輸出軸的運(yùn)動(dòng)規(guī)律分析

    針對(duì)三叉式萬向聯(lián)軸器傳動(dòng)時(shí)輸出軸的運(yùn)動(dòng)規(guī)律問題,建立三叉式萬向聯(lián)軸器系統(tǒng)的坐標(biāo)系,應(yīng)用坐標(biāo)變換技術(shù)建立了三叉式萬向聯(lián)軸器輸入軸和輸出軸的運(yùn)動(dòng)方程,推導(dǎo)出了三叉式萬向聯(lián)軸器采用雙徑向軸承
    發(fā)表于 02-26 10:46 ?0次下載
    <b class='flag-5'>三叉</b>式萬向聯(lián)軸器輸出軸的運(yùn)動(dòng)規(guī)律分析

    三叉桿-球籠式萬向聯(lián)軸器傳動(dòng)軸的運(yùn)動(dòng)仿真

    針對(duì)三叉桿一球籠式萬向聯(lián)軸器傳動(dòng)軸結(jié)構(gòu)復(fù)雜,難以采用傳統(tǒng)的圖解法、解析法獲得其運(yùn)動(dòng)規(guī)律的問題,采用Pro/E軟件,在充分考慮各構(gòu)件之間的相互約束關(guān)系的基礎(chǔ)上,對(duì)三叉桿一球籠式萬向聯(lián)軸器傳動(dòng)軸整體
    發(fā)表于 03-12 11:39 ?0次下載
    <b class='flag-5'>三叉</b>桿-球籠式萬向聯(lián)軸器傳動(dòng)軸的運(yùn)動(dòng)仿真

    詳解電源二叉樹到底是什么

    作為數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ),分很多種,像 AVL 、紅黑、二搜索....今天我想分享的是關(guān)于二
    的頭像 發(fā)表于 06-06 15:05 ?1.1w次閱讀
    詳解電源二<b class='flag-5'>叉樹</b>到底是什么

    CompCert編譯器目標(biāo)代碼生成機(jī)制研究綜述

    CompCert是著名的C語言可信編譯器,是經(jīng)過形式化驗(yàn)證的編譯器的杰出代表,近年來被廣泛應(yīng)用于學(xué)術(shù)界和工業(yè)界的許多研發(fā)工作中。 Compcert編譯器的當(dāng)前版本支持多種目標(biāo)機(jī)結(jié)構(gòu)。文
    發(fā)表于 05-07 10:17 ?7次下載

    叉排序樹AVL如何實(shí)現(xiàn)動(dòng)態(tài)平衡

    熟悉的二樹種類有二搜索(排序、查找)、二平衡、伸展、紅黑
    的頭像 發(fā)表于 10-28 17:02 ?2093次閱讀
    二<b class='flag-5'>叉排序樹</b>AVL如何實(shí)現(xiàn)動(dòng)態(tài)平衡

    直線模組3D打印幫助解決三叉

    直線模組3D打印幫助解決三叉痛。三叉痛是非常痛苦的事情。就在近日,神經(jīng)外科在3D打印導(dǎo)板引導(dǎo)下完成1例球囊壓迫術(shù)診治復(fù)發(fā)三叉痛的患者,標(biāo)志著我院神經(jīng)外科在三叉痛準(zhǔn)確微創(chuàng)診治方面又邁向了
    發(fā)表于 11-16 16:27 ?450次閱讀

    C語言數(shù)據(jù)結(jié)構(gòu):什么是二叉樹?

    完全二叉樹:完全二叉樹是效率很高的數(shù)據(jù)結(jié)構(gòu)。對(duì)于深度為K,有n個(gè)節(jié)點(diǎn)的二叉樹,當(dāng)且僅當(dāng)每一個(gè)節(jié)點(diǎn)都與深度為K的滿二叉樹中編號(hào)從1至n的節(jié)點(diǎn)一
    的頭像 發(fā)表于 04-21 16:20 ?3708次閱讀

    PCB設(shè)計(jì)的Voron三叉戟裙燈

    電子發(fā)燒友網(wǎng)站提供《PCB設(shè)計(jì)的Voron三叉戟裙燈.zip》資料免費(fèi)下載
    發(fā)表于 08-12 10:48 ?0次下載
    PCB設(shè)計(jì)的Voron<b class='flag-5'>三叉</b>戟裙燈

    HPC、AI與云計(jì)算:當(dāng)智能時(shí)代三叉戟在亞馬遜云科技完美融合

    希臘神話中,海神與豐收之神波塞冬手持三叉戟,為航船保駕護(hù)航,為農(nóng)人帶來清泉。從此之后,三叉戟經(jīng)常用來比喻種事物緊密結(jié)合,形成合力,比如足球世界很多球隊(duì)都有經(jīng)典的鋒線三叉戟。 在企業(yè)上
    的頭像 發(fā)表于 08-18 09:19 ?2563次閱讀

    Triton編譯器的優(yōu)化技巧

    (Instruction Selection) Triton 編譯器在指令選擇階段采用了先進(jìn)的算法來生成針對(duì)特定硬件架構(gòu)優(yōu)化的指令。這一階段的目標(biāo)是將高級(jí)中間表示(IR)轉(zhuǎn)換為低級(jí)機(jī)器代碼,同時(shí)盡可能地利用硬件
    的頭像 發(fā)表于 12-25 09:09 ?997次閱讀