完整一條指令,應該包含指令符+操作數(當然不包括那些單指令,比如NOT等)。其中操作數是指令要執行目標,也就是指令要進行操作址。
我們知道,PLC中劃有各種用途存儲區,比如物理輸入輸出區P、映像輸入區I、映像輸出區Q、位存儲區M、定時器T、計數器C、數據區DB和L等,同時我們還知道,每個區域可以用位(BIT)、字節(BYTE)、字(WORD)、雙字(DWORD)來衡量,說來指定確切大小。當然定時器T、計數器C不存這種衡量體制,它們僅用位來衡量。由此我們可以到,要描述一個址,至少應該包含兩個要素:
1、存儲區域
2、這個區域中具體位置
比如:A Q2.0
其中A是指令符,Q2.0是A操作數,也就是址。這個址由兩部分組成:
Q:指是映像輸出區
2.0:就是這個映像輸出區第二個字節第0位。
由此,我們出, 一個確切址組成應該是:
〖存儲區符〗〖存儲區尺寸符〗〖尺寸數值〗.〖位數值〗,例如:DBX200.0。
DB X 200 . 0
其中,我們又把〖存儲區符〗〖存儲區尺寸符〗這兩個部分合稱為:址標識符。這樣,一個確切址組成,又可以寫成:
址標識符 + 確切數值單元
【間接尋址概念】
尋址,就是指定指令要進行操作址。給定指令操作址方法,就是尋址方法。
談間接尋址之前,我們簡單了解一下直接尋址。所謂直接尋址,簡單說,就是直接給出指令確切操作數,象上面所說,A Q2.0,就是直接尋址,A這個指令來說,Q2.0就是它要進行操作址。
這樣看來,間接尋址就是間接給出指令確切操作數。對,就是這個概念。
比如:A Q[MD100] ,A T[DBW100]。程序語句中用方刮號 [ ] 標明內容,間接指明了指令要進行址,這兩個語句中MD100和DBW100稱為指針Pointer,它指向它們其中包含數值,才是指令真正要執行址區域確切位置。間接由此名。
西門子間接尋址方式計有兩大類型:存儲器間接尋址和寄存器間接尋址。
【存儲器間接尋址】
存儲器間接尋址址給定格式是:址標識符+指針。指針所指示存儲單元中所包含數值,就是址確切數值單元。
存儲器間接尋址具有兩個指針格式:單字和雙字。
單字指針是一個16bit結構,從0-15bit,指示一個從0-65535數值,這個數值就是被尋址存儲區域編號。
雙字指針是一個32bit結構,從0-2bit,共三位,8進制指示被尋址位編號,也就是0-7;而從3-18bit,共16位,指示一個從0-65535數值,這個數值就是被尋址字節編號。
指針可以存放M、DI、DB和L區域中,也就是說,可以用這些區域內容來做指針。
單字指針和雙字指針使用上有很大區別。
下面舉例說明:
L DW#16#35 //將32位16進制數35存入ACC1
T MD2 //這個值再存入MD2,這是個32位位存儲區域
L +10 //將16位整數10存入ACC1,32位16進制數35自動移動到ACC2
T MW100 //這個值再存入MW100,這是個16位位存儲區域
OPN DB[MW100] //打開DB10。這里[MW100]就是個單字指針,存放指針區域是M區,
MW100中值10,就是指針間接指定址,它是個16位值!
L L#+10 //以32位形式,把10放入ACC1,此時,ACC2中內容為:16位整數10
T MD104 //這個值再存入MD104,這是個32位位存儲區域
A I[MD104] //對I1.2進行與邏輯操作!
=DIX[MD2] //賦值背景數據位DIX6.5!
A DB[MW100].DBX[MD2] //讀入DB10.DBX6.5數據位狀態
=Q[MD2] //賦值給Q6.5
A DB[MW100].DBX[MD2] //讀入DB10.DBX6.5數據位狀態
=Q[MW100] //錯誤!!沒有Q10這個元件
從上面系列舉例我們至少看出來一點:
單字指針只應用址標識符是非位情況下。確,單字指針前面描述過,它確定數值是0-65535,而byte.bit這種具體位結構來說,只能用雙字指針。這是它們第一個區別,單字指針另外一個限制就是,它只能對T、C、DB、FC和FB進行尋址,通俗說,單字指針只可以用來指代這些存儲區域編號。
相單字指針,雙字指針就沒有這樣限制,它可以對位址進行尋址,還可以對BYTE、WORD、DWORD尋址,沒有區域限制。,有必有失,對非位區域進行尋址時,必須確保其0-2bit為全0!
總結一下:
單字指針存儲器間接尋址只能用址標識符是非位場合;雙字指針有位格式存,對址標識符沒有限制。也正是雙字指針是一個具有位指針,,當對字節、字雙字存儲區址進行尋址時,必須確保雙字指針內容是8倍數。
現,我們來分析一下上述例子中A I[MD104] 為什么最后是對I1.2進行與邏輯操作。
L L#+10 ,我們知道存放MD104中值應該是:
MD104:0000 0000 0000 0000 0000 0000 0000 1010
當作為雙字指針時,就應該3-18bit指定byte,0-2bit指定bit來確定最終指令要操作址,:
0000 0000 0000 0000 0000 0000 0000 1010 = 1.2
詳解西門子間接尋址(二)
【址寄存器間接尋址】
先前所說存儲器間接尋址中,間接指針用M、DB、DI和L直接指定,就是說,指針指向存儲區內容就是指令要執行確切址數值單元。但寄存器間接尋址中,指令要執行確切址數值單元,并非寄存器指向存儲區內容,也就是說,寄存器本身也是間接指向真正址數值單元。從寄存器到出真正址數值單元,西門子提供了兩種途徑:
1、區域內寄存器間接尋址
2、區域間寄存器間接尋址
址寄存器間接尋址一般格式是:
〖址標識符〗〖寄存器,P#byte.bit〗,比如:DIX[AR1,P#1.5] 或 M[AR1,P#0.0] 。
〖寄存器,P#byte.bit〗統稱為:寄存器尋址指針,而〖址標識符〗上帖中談過,它包含〖存儲區符〗+〖存儲區尺寸符〗。但這里,情況有所變化。比較一下剛才例子:
DIX [AR1,P#1.5]
X [AR1,P#1.5]
DIX可以認為是我們通常定義址標識符,DI是背景數據塊存儲區域,X是這個存儲區域尺寸符,指是背景數據塊中位。但下面一個示例中M呢?X指定了存儲區域尺寸符,那么存儲區域符哪里呢?毫無疑問,AR1中!
DIX [AR1,P#1.5] 這個例子,要尋址址區域事先已經確定,AR1可以改變這個區域內確切址數值單元,我們稱之為:區域內寄存器間接尋址方式,相應,這里[AR1,P#1.5] 就叫做區域內尋址指針。
X [AR1,P#1.5] 這個例子,要尋址址區域和確切址數值單元,都未事先確定,確定了存儲大小,這就是意味著我們可以不同區域間不同址數值單元以給定區域大小進行尋址,稱之為:區域間寄存器間接尋址方式,相應,這里[AR1,P#1.5] 就叫做區域間尋址指針。
既然有著區域內和區域間尋址之分,那么,同樣AR1中,就存有不同內容,它們代表著不同含義。
【AR格式】
址寄存器是專門用于尋址一個特殊指針區域,西門子址寄存器共有兩個:AR1和AR2,每個32位
當使用區域內寄存器間接尋址中時,我們知道這時AR中內容指明數值單元,,區域內寄存器間接尋址時,寄存器中內容等同于上帖中提及存儲器間接尋址中雙字指針,也就是:
其0-2bit,指定bit位,3-18bit指定byte字節。其第31bit固定為0。
AR:
0000 0000 0000 0BBB BBBB BBBB BBBB BXXX
這樣規定,就意味著AR取值只能是:0.0 ——65535.7
例如:當AR=D4(hex)=0000 0000 0000 0000 0000 0000 1101 0100(b),實際上就是等于26.4。
而區域間寄存器間接尋址中,要尋址區域也要AR中指定,顯然這時AR中內容肯定于寄存器區域內間接尋址時,對AR內容要求,說規定不同。
AR:
1000 0YYY 0000 0BBB BBBB BBBB BBBB BXXX
比較一下兩種格式不同,我們發現,這里第31bit被固定為1,同時,第24、25、26位有了可以取值范圍。聰明你,肯定可以聯想到,這是用于指定存儲區域。對,bit24-26取值確定了要尋址區域,它取值是這樣定義:
區域標識符
26、25、24位
P(外部輸入輸出)
000
I(輸入映像區)
001
Q(輸出映像區)
010
M(位存儲區)
011
DB(數據塊)
100
DI(背景數據塊)
101
L(暫存數據區,也叫局域數據)
111
我們把這樣AR內容,用HEX表示話,那么就有:
當是對P區域尋址時,AR=800xxxxx
當是對I區域尋址時,AR=810xxxxx
當是對Q區域尋址時,AR=820xxxxx
當是對M區域尋址時,AR=830xxxxx
當是對DB區域尋址時,AR=840xxxxx
當是對DI區域尋址時,AR=850xxxxx
當是對L區域尋址時,AR=870xxxxx
列舉,我們有了初步結論:AR中內容是8開頭,那么就一定是區域間尋址;要DB區中進行尋址,只需8后面跟上一個40。84000000-840FFFFF指明了要尋址范圍是:
DB區0.0——65535.7。
例如:當AR=840000D4(hex)=1000 0100 0000 0000 0000 0000 1101 0100(b),實際上就是等于DBX26.4。
我們看到,寄存器尋址指針 [AR1/2,P#byte.bit] 這種結構中,P#byte.bit又是什么呢?
【P#指針】
P#中P是Pointer,是個32位直接指針。所謂直接,是指P#中#后面所跟數值存儲單元,是P直接給定。這樣P#XXX這種指針,就可以被用來指令尋址中,作為一個“常數”來對待,這個“常數”可以包含或不包含存儲區域。例如:
● L P#Q1.0 //把Q1.0這個指針存入ACC1,此時ACC1內容=82000008(hex)=Q1.0
★ L P#1.0 //把1.0這個指針存入ACC1,此時ACC1內容=00000008(hex)=1.0
● L P#MB100 //錯誤!必須byte.bit結構給定指針。
● L P#M100.0 //把M100.0這個指針存入ACC1,此時ACC1內容=83000320(hex)=M100.0
● L P#DB100.DBX26.4 //錯誤!DBX已經提供了存儲區域,不能重復指定。
● L P#DBX26.4 //把DBX26.4這個指針存入ACC1,此時ACC1內容=840000D4(hex)=DBX26.4
我們發現,當對P#指定數值時,累加器中值和區域內尋址指針規定格式相同(也和存儲器間接尋址雙字指針格式相同);而當對P#指定帶有存儲區域時,累加器中內容和區域間尋址指針內容完全相同。事實上,把什么樣值傳給AR,就決定了是以什么樣方式來進行寄存器間接尋址。實際應用中,我們正是利用P#這種特點,不同需要,指定P#指針,然后,再傳遞給AR,以確定最終尋址方式。
寄存器尋址中,P#XXX作為寄存器AR指針偏移量,用來和AR指針進行相加運算,運算結果,才是指令真正要操作確切址數值單元!
是區域內區域間尋址,址所存儲區域都有了指定,,這里P#XXX只能指定純粹數值,如上面例子中★。
【指針偏移運算法則】
寄存器尋址指針 [AR1/2,P#byte.bit] 這種結構中,P#byte.bit如何參與運算,出最終址呢?
運算法則是:AR1和P#中數值,BYTE位和BIT位分類相加。BIT位相加按八進制規則運算,而BYTE位相加,則十進制規則運算。
例如:寄存器尋址指針是:[AR1,P#2.6],我們分AR1=26.4和DBX26.4兩種情況來分析。
當AR1等于26.4,
AR1:26.2
P#:2.6
= 29.7 這是區域內寄存器間接尋址最終確切址數值單元
當AR1等于DBX26.4,
AR1:DBX26.2
P#:2.6
= DBX29.7 這是區域間寄存器間接尋址最終確切址數值單元
【AR址數據賦值】
前面介紹,我們知道,要正確運用寄存器尋址,最重要是對寄存器AR賦值。同樣,區分是區域內區域間尋址,也是看AR中賦值。
對AR賦值通常有下面幾個方法:
1、直接賦值法
例如:
L DW#16#83000320
LAR1
可以用16進制、整數二進制直接給值,但必須確保是32位數據。賦值AR1中既存儲了址數值,也指定了存儲區域,這時寄存器尋址方式肯定是區域間尋址。
2、間接賦值法
例如:
L [MD100]
LAR1
可以用存儲器間接尋址指針給定AR1內容。具體內容存儲MD100中。
3、指針賦值法
例如:
LAR1 P#26.2
使用P#這個32位“常數”指針賦值AR。
總之,使用哪種賦值方式,AR存儲數據格式有明確規定,,都要賦值前,確認所賦值是否符合尋址規范。
詳解西門子間接尋址(三)
使用間接尋址主要目,是使指令執行結果有動態變化,簡化程序是第一目,某些情況下,這樣尋址方式是必須,比如對某存儲區域數據遍歷。此外,間接尋址,還可以使程序更具柔性,換句話說,可以標準化。
下面實例應用來分析如何靈活運用這些尋址方式,實例分析過程中,將對前面帖子中筆誤、錯誤和遺漏做糾正和補充。
【存儲器間接尋址應用實例】
我們先看一段示例程序:
L 100
T MW 100 // 將16位整數100傳入MW100
L DW#16#8 // 加載雙字16進制數8,當把它用作雙字指針時,BYTE.BIT結構,
結果演變過程就是:8H=1000B=1.0
T MD 2 // MD2=8H
OPN DB [MW 100] // OPN DB100
L DBW [MD 2] // L DB100.DBW1
T MW[MD2] // T MW1
A DBX [MD 2] // A DBX1.0
= M [MD 2] // =M1.0
這個例子中,我們中心思想其實就是:將DB100.DBW1中內容傳送到MW1中。這里我們使用了存儲器間接尋址兩個指針——單字指針MW100用于指定DB塊編號,雙字指針MD2用于指定DBW和MW存儲區字址。
事實上,從這個例子中心思想來看,根本沒有必要如此復雜。但為什么要用間接尋址呢?
要澄清使用間接尋址優勢,就讓我們從比較中,找答案吧。
例子告訴我們,它最終執行是把DB某個具體字數據傳送到位存儲區某個具體字中。這是針對數據塊1001數據字傳送到位存儲區第1字中具體操作。我們現需要對同樣數據塊多個字(連續不連續)進行傳送呢?直接方法,就是一句一句寫這樣具體操作。有多少個字傳送,就寫多少這樣語句。毫無疑問,不知道間接尋址道理,也應該明白,這樣編程方法是不合理。而使用間接尋址方法,語句就簡單多了。
【示例程序結構分析】
我將示例程序從結構上做個區分,重新輸入如下:
=========================== 輸入1:指定數據塊編號變量
|| L 100
|| T MW 100
===========================輸入2:指定字址變量
|| L DW#16#8
|| T MD 2
===========================操作主體程序
OPN DB [MW 100]
L DBW [MD 2]
T MW[MD2]
顯然,我們根本不需要對主體程序(紅色部分)進行簡單而重復復寫,而只需改變MW100和MD2賦值(綠色部分),就可以完成應用要求。
結論:對間接尋址指針內容修改,就完成了主體程序執行結果變更,這種修改是可以是動態和靜態。
正是對真正目標程序(主體程序)不做任何變動,而尋址指針是這個程序中唯一要修改方,可以認為,尋址指針是主體程序入口參數,就好比功能塊輸入參數。可使程序標準化,具有移植性、通用性。
那么又如何動態改寫指針賦值呢?不會是另一種簡單而重復復寫吧。
讓我們以一個具體應用,來完善這段示例程序吧:
將DB100中1-11數據字,傳送到MW1-11中
設計完成這個任務程序之前,我們先了解一些背景知識。
【數據對象尺寸劃分規則】
數據對象尺寸分為:位(BOOL)、字節(BYTE)、字(WORD)、雙字(DWORD)。這似乎是個簡單概念,但,MW10=MB10+MB11,那么是說,MW11=MB12+MB13?你回答是肯定,我建議你繼續看下去,不要跳過,這里疏忽,會導致最終程序錯誤。
按位和字節來劃分數據對象大小時,是以數據對象bit來偏移。這句話就是說,0bit后就是1bit,1bit后肯定是2bit,以此類推直到7bit,完成一個字節大小指定,再有一個bit偏移,就進入下一個字節0bit。
而按字和雙字來劃分數據對象大小時,是以數據對象BYTE來偏移!這就是說,MW10=MB10+MB11,并說,MW11=MB12+MB13,正確是MW11=MB11+MB12,然后才是MW12=MB12+MB13!
這個概念重要性,你程序中使用了MW10,那么,就不能對MW11進行任何操作,,MB11是MW10和MW11交集。
也就是說,“將DB100中1-11數據字,傳送到MW1-11中”這個具體任務而言,我們只需要對DBW1、DBW3、DBW5、DBW7、DBW9、DBW11這6個字進行6次傳送操作即可。這就是單獨分出一節,說明數據對象尺寸劃分規則這個看似簡單概念目所。
【循環結構】
要“將DB100中1-11數據字,傳送到MW1-11中”,我們需要將指針內容順序逐一指向相應數據字,這種對指針內容動態修改,其實就是遍歷。遍歷,最簡單莫過于循環。
一個循環包括以下幾個要素:
1、初始循環指針
2、循環指針自加減
2、繼續退出循環體條件判斷
被循環程序主體必須位于初始循環指針之后,和循環指針自加減之前。
比如:
初始循環指針:X=0
循環開始點M
被循環程序主體:-------
循環指針自加減:X+1=X
循環條件判斷:X≤10 ,False:GO TO M;True:GO TO N
循環退出點N
把X作為間接尋址指針內容,對循環指針操作,就等于對尋址指針內容動態而循環修改了。
【將DB100中1-11數據字,傳送到MW1-11中】
L L#1 //初始化循環指針。這里循環指針就是我們要修改尋址指針
T MD 102
M2: L MD 102
T #COUNTER_D
OPN DB100
L DBW [MD 102]
T MW [MD 102]
L #COUNTER_D
L L#2 // +2,是數據字偏移基準是字節。
+D
T MD 102 //自加減循環指針,這是動態修改了尋址指針關鍵
L L#11 //循環次數=n-1。n=6。這是,首次進入循環是無條件,
但已事實上執行了一次操作。
<=D
JC M2
有T MD102 ,L L#11, <=D詳細分析,請前面內容推導。
【將DB1-10中1-11數據字,傳送到MW1-11中】
這里增加了對DB數據塊尋址,使用單字指針MW100存儲尋址址,同樣使用了循環,嵌套數據字傳送循環外,這樣,要完成“將DB1-10中1-11數據字,傳送到MW1-11中”這個任務 ,共需要M1循環10次 ×M2循環6次 =60次。
L 1
T MW 100
L L#1
T MD 102
M1: L MW 100
T #COUNTER_W
M2: 對數據字循環傳送程序,同上例
L #COUNTER_W
L 1 //這里數據字偏移,編號簡單遞增,+1
+I
T MW 100
L 9 //循環次數=n-1,n=10
<=I
JC M1
示例分析,程序是讓尋址指針對要操作數據對象范圍內進行遍歷來編程,完成這個任務。我們看到,這種對存儲器間接尋址指針遍歷是基于字節和字,如何對位進行遍歷呢?這就是下一個要分析寄存器間接尋址實例內容了。
詳解西門子間接尋址(四)
L [MD100]
LAR1
與
L MD100
LAR1有什么區別?
當將MD100以這種 [MD100] 形式表示時,你既要對MD100賦值時考慮到所賦值是否符合存儲器間接尋址雙字指針規范,又要使用這個尋址格式作為語句一部分時,是否符合語法規范。
你給出第一個例程第一句:L [MD100]上,我們看出它犯了后一個錯誤。
存儲器間接尋址指針,是作為指定存儲區域確切數值單元來運用。也就是說,指針不包含區域標識,它指明了一個數值。,要 [MD100]前加上區域標識如:M、DB、I、Q、L等,還要加上存儲區尺寸大小如:X、B、W、D等。加存儲區域和大小標識時,要考慮累加器加載指令L不能對位址操作,,只能指定非位址。
對比下面寄存器尋址方式,我們這里,修改為:L MD[MD100]。并假定MD100=8Hex,同時我們也假定MD1=85000018Hex。
當把MD100這個雙字作為一個雙字指針運用時,其存儲值0-18bit將會雙字指針結構Byte.bit來重新“翻譯”,“翻譯”結果才是指針指向址,MD100中8Hex=1000B=1.0,下面語句:
L MD[MD100]
LAR1
“翻譯”就是:
L MD1
LAR1
前面我們已經假定了MD1=85000018,同樣道理,MD1作為指針使用時,對0-18bit應該Byte.bit結構“翻譯”,是傳送給AR址寄存器,還要對24-31bit進行區域尋址“翻譯”。這樣,我們出LAR1中最終值=DIX3.0。就是說,我們址寄存器AR1中存儲了一個指針,它指向DIX3.0。
L MD100
LAR1
這段語句,是直接把MD100值傳送給AR,當然也要“翻譯”,結果AR1=1.0。就是說,我們址寄存器AR1中存儲了一個指針,它指向1.0,這是由MD100直接賦值。
似乎,兩段語句,賦值給AR1結果不同而已,其實不然。我們事先假定值是考慮到對比關系,特意指定。MD100=CHex呢?
前一段,CHex=1100,其0-3bit為非0,程序將立即出錯,無法執行。(沒有MD1.4這種址!!)后一段AR1值翻譯以后,等于1.4,程序能正常執行。
90%以上的工程師,對PLC指針類型與間接尋址無從下手
下面看看西門子POINTER類型的結構:
參數類型POINTER存儲下列信息:
· DB編號(或0,如果數據沒有存儲在DB中)
· CPU中的存儲區域(下表給出了參數類型POINTER存儲器區的十六進制代碼)
數據的地址(格式為字節.位)
STEP 7提供指針格式:p#memory_area byte.bit_address. (如果形式參數被聲明為參數類型POINTER,只需要指出存儲區域和地址。STEP 7將自動地重定輸入指針的格式。) 下面的實例說明如何為以M50.0開始的數據輸入參數類型POINTER:P#M50.0
存儲器間接尋址:
使用存儲器間接尋址的程序語句包含一條指令,后面跟有[地址]標識符,最后是一個(地址必須括在方括號內)。根據所用的地址標識符,該指令會將存儲于指定地址的數據解釋為字或雙字指針。完整的數據地址由地址標識符和指針構成,如下例所示。間接尋址的優點是能在程序執行期間動態修改指令的數據地址。
存儲器間接尋址使用以下兩部分地址:
地址標識符
對于由位邏輯運算尋址的位,可分配地址標識符I、Q、M、L、DIX或DBX。
對于由裝載指令尋址的字節、字和雙字,可使用存儲區I、Q、M、L、D和PI,分配IB、IW、ID、DBB、DBW、DBD、DIB、DIW、DID、PIB、PIW、PID等形式的地址標識符。
對于由傳送指令尋址的字節、字和雙字,可使用存儲區I、Q、M、L、DB、DI和PQ,分配IB、IW、ID、DBB、DBW、DBD、DIB、DIW、DID、PQB、PQW、PQD等形式的地址標識符。
要尋址定時器、計數器或塊,可使用T、C、DB、DI、FB、FC形式的區域標識符。
括在方括號"[ ]"內的字或雙字指針的地址
字指針 - 含有定時器(T)、計數器(C)、數據塊(DB、DI)或邏輯塊(FC、FB)的標識號的字。字指針是十進制整數。
雙字指針 - 指含有位、字節、字或雙字的確切位置的雙字。雙字指針的格式為:P#字節.位。指針必須存儲在下列區域之一,才能進行存儲器間接尋址:
M - 位存儲器
L - 本地數據
D - 數據塊(DB或DI)
STAT 靜態數據(不是用于具有多重實例能力的塊的靜態數據)
注意如果要尋址使用存儲器間接尋址的字節、字或雙字,請確保指針的位號為雙字格式0。
字指針實例:
L 5 //將指針值載入ACCU 1。T MW2 //將指針傳送到MW2中。L T[MW2] //將5號定時器的當前時間值載入ACCU 1。
L C[MW2] //將5號計數器的當前計數值載入ACCU 1。
OPN DB[MW2] //將數據塊DB5作為共享數據塊打開。
OPN DI[MW2] //將數據塊DB5作為背景數據塊打開。
雙字指針實例:
L P#8.7 //將指針值載入ACCU 1。T MD2 //將指針傳送到MD2中。A I [MD2] //掃描輸入位8.7的狀態,并將其= Q [MD2] //信號狀態分配給輸出位Q 8.7。
區域內寄存器間接尋址:
使用區域內寄存器間接尋址的程序語句包含一條指令和以下組成部分:地址標識符[地址寄存器標識符,地址]。區域內寄存器間接尋址使用以下兩部分地址:
地址標識符
對于由位邏輯運算尋址的位,可以分配地址標識符I、Q、M、L、DIX或DBX。
對于由裝載指令尋址的字節、字和雙字,可使用存儲區I、Q、M、L、D和PI,分配IB、IW、ID、DBB、DBW、DBD、DIB、DIW、DID、PIB、PIW、PID等形式的地址標識符。
對于由傳送指令尋址的字節、字和雙字,可使用存儲區I、Q、M、L、DB、DI和PQ,分配IB、IW、ID、DBB、DBW、DBD、DIB、DIW、DID、PQB、PQW、PQD等形式的地址標識符。
方括號"[ ]"中的內容包括地址寄存器引用(AR1或AR2)、逗號分隔符","以及雙字指針。
雙字指針 - 指包含位、字節、字或雙字的部分地址的雙字。雙字指針的格式為:P#字節.位。
注意請記住您現在使用的是兩個格式為"P#字節.位"的指針。一個指針已被精確表示出來。另一個指針通過對地址寄存器AR1或AR2的引用來確定。如果要尋址字節、字或雙字,請確保指針的位號為0。使用寄存器間接尋址的語句不更改地址寄存器的內容。
指針實例:
L P#8.7 //將指針值載入ACCU 1。LAR1 //用ACCU 1中的指針裝載AR1。A I [AR1, P#0.0] //檢查輸入位I 8.7并將有符號的狀態分配給Q 10.0。= Q [AR1, P#1.1] //確切地址8.7在AR1中。偏移量不對其產生影響。確切位置10.0由8.7 (AR1)加上1.1 (偏移量)得出,結果是10.0而不是9.8。
區域內寄存器間接尋址實例:
A I [AR1,P#4.3] 對其位置是由AR1中的內容加上4個字節,再加上3個位計算得出的輸入位,執行邏輯與運算。= DIX [AR2, P#0.0] 將RLO位狀態分配給位于AR2中的實例數據位。L IB [AR1, P#10.0] 將輸入字節載入ACCU 1中。地址由AR1的內容加上十個字節計算得出。T LD [AR2,P#53.0] 將ACCU 1中的內容傳送到本地雙字中(該雙字的位置由AR2的內容加上53個字節計算得出)。
區域內寄存器間接尋址的特點是:地址標示符在方括號前確定,方括號中的指針均為不含存儲區信息(如[AR1,P#4.3]中AR1=P#8.7,兩個指針都不含有存儲區信息),否則將會與方括號前的地址標示符表示的存儲區沖突。
跨區域寄存器間接尋址:
使用跨區域寄存器間接尋址的程序語句包含一條指令和以下組成部分:地址標識符[地址寄存器標識符,地址]。
跨區域寄存器間接尋址使用以下兩部分地址:
對已尋址的數據對象(地址標識符)大小的規定數據對象大小規定 位(無規定表示是一個位)B 字節W 字D 雙字
方括號"[ ]"中的內容包括地址寄存器引用(AR1或AR2)、逗號分隔符","以及雙字指針。雙字指針 - 指包含位、字節、字或雙字的部分地址的雙字。指針具有以下區域內格式:P#字節.位。
注意事先必須已將跨區域雙字指針載入到由寄存器間接地址引用的地址寄存器中。跨區域雙字指針 - 包含位的部分地址(對于位邏輯指令)或字節、字或雙字的部分地址(對于裝載和傳送指令)的雙字。地址前面的區域標識符位于用來指定字節和位。跨區域雙字指針格式為:P#區域標識符字節.位。
對于由位邏輯指令尋址的位,可以分配跨區域指針區域標識符I、Q、M、DIX或DBX。
對于由裝載或傳送指令尋址的字節、字和雙字,可以分配跨區域指針區域標識符I、Q、M、DIX、DBX或P。注意要在指針中指定外設輸入或PI區域,請以P#Px.y形式輸入指針。區域被指定為P。在跨區域指針中不能使用外設輸出PQ區域。請記住您正使用兩個指針:
作為偏移量,直接在地址中表示的區域內雙字指針,例如P#4.0。
存儲在地址寄存器(AR1或AR2)中的跨區域雙字指針,例如P#Q4.0。
如果要訪問通過直接尋址方式進行尋址的字節、字或雙字,請確保這兩個指針的位號均為0。使用寄存器間接尋址的語句不更改地址寄存器的內容。
跨區域寄存器間接尋址的第一個實例:
L P# I8.7 //將指針值和區域標識符載入ACCU 1。LAR1 //將存儲區I和地址8.7存入AR1。L P# Q8.7 //將指針偏移量和區域標識符載入ACCU 1。LAR2 //將存儲區Q和地址8.7存入AR2。A [AR1, P#0.0] //檢查輸入位I 8.7并將其信號狀態分配給輸出位Q 10.0。= [AR2, P#1.1] //偏移量0.0沒有任何作用。輸出位10.0由8.7 (AR2)加上1.1 (偏移量)得出,結果是10.0而不是9.8。跨區域寄存器間接尋址的第二個實例:
A I 0.0 JC M002 L P#M10.0 //將指針值和區域標識符載入ACCU 1。LAR1 //將存儲區M和地址10存入ACCU 1。JU M001 M002: L P#Q0.3 //將指針值和區域標識符載入ACCU 1。LAR1 //將存儲區Q和地址0.3存入ACCU 1。M001:A I 0.4 = [AR1, P#0.1] //I 0.0用于控制哪個指針用于此語句。將I 0.4的信號狀態分配給存儲器位M 10.1,或者分配給輸出Q 0.4。
跨區域寄存器間接尋址實例A [AR1,P#4.3] 對于其位置是由AR1中的內容加上4個字節,再加上3個位計算得出的位,執行邏輯與運算。位的存儲區在AR1的位24、25和26中指出。= [AR2, P#0.0] 將RLO位信號狀態分配給位于AR2中的位。位的存儲區在AR1的位24、25和26中指出。L B [AR1, P#10.0] 將字節(其位置由AR1的內容加上10個字節計算得出)載入ACCU 1。位的存儲區在AR1的位24、25和26中指出。T D [AR2,P#53.0] 將ACCU 1的內容傳送到雙字(該字的精確位置由AR2的內容加上53個字節計算得出)。位的存儲區在AR1的位24、25和26中指出。
跨區域寄存器間接尋址的特點是:地址標示符在方括號前確定,方括號中的地址寄存器中包含存儲區信息(如[AR1,P#4.3]中AR1=P#Q0.3)。
區域內寄存器間接尋址和跨區域寄存器間接尋址的使用相當靈活,可以根據需要選擇。由上面的說明可知,區域內寄存器間接尋址是針對存儲區固定的間接尋址方式,尋址的存儲區是確定的。而跨區域寄存器間接尋址則在指令中不確定存儲區,存儲區由地址寄存器中存儲的指針中的信息確定,因而尋址的存儲區是可變的。
-
plc
+關注
關注
5016文章
13388瀏覽量
465438 -
西門子
+關注
關注
95文章
3062瀏覽量
116454 -
計數器
+關注
關注
32文章
2261瀏覽量
94999 -
定時器
+關注
關注
23文章
3255瀏覽量
115391 -
間接尋址
+關注
關注
0文章
19瀏覽量
8073
原文標題:高手都在用的西門子PLC間接尋址
文章出處:【微信號:電子技術控,微信公眾號:電子技術控】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
S7-200西門子PLC視頻教程大全
西門子plc的型號選擇_西門子plc型號說明
西門子plc數據類型_西門子plc通訊方式
![<b class='flag-5'>西門子</b><b class='flag-5'>plc</b>數據類型_<b class='flag-5'>西門子</b><b class='flag-5'>plc</b>通訊方式](https://file.elecfans.com/web1/M00/9E/49/o4YBAF05G46ARZwyAAAyrP5yWaE148.jpg)
評論