Działanie sterowników S7-200 - podstawy cz.2.pdf

(105 KB) Pobierz
Działanie sterowników S7-200 - podstawy, część 2
A U T O  M A  T Y K A
Dzia³anie sterowników S7-200 - podstawy,
czêœæ 2
W†tej czÍúci artyku³u przedstawiamy informacje istotne dla
pocz¹tkuj¹cych projektantÛw systemÛw sterowania, ktÛrzy buduj¹ je na
bazie urz¹dzeÒ z†rodziny S7-200. Zaczynamy od alokacji i†funkcji
najpopularniejszych zmiennych systemowych. Dog³Íbne poznanie ich
moøliwoúci pozwoli tworzyÊ funkcjonalne i†niezawodne programy.
W†programach tworzonych za pomoc¹
Step7MicroWinV3.2 wykorzystuje siÍ nastÍ-
puj¹ce typy zmiennych:
- zmienne typu BOOL informuj¹ce o†stanie
logicznym pojedynczego bitu,
- zmienne typu BYTE odnosz¹ce siÍ do baj-
tu danych (8 bitÛw),
- zmienne typu WORD odnosz¹ce siÍ do
s³owa danych (16 bitÛw),
- zmienne typu DWORD odnosz¹ce siÍ do
podwÛjnego s³owa (32 bity),
- zmienne typu REAL odnosz¹ce siÍ do
wartoúci zmiennoprzecinkowych, okreúlo-
nych jako wartoúÊ i†mantysa (32 bity).
Uøytkownik ma moøliwoúÊ wybrania
wersji jÍzykowej menu edytora. DostÍpne s¹
menu edytora w†jÍzykach: angielskim, nie-
mieckim, francuskim i†w³oskim. Prze³¹czenie
wersji jÍzykowej nastÍpuje po wybraniu op-
cji Tool->Options->Language . W†opcji Tool-
>Options->Mnemonic Set istnieje moøliwoúÊ
wyboru postaci mnemonicznej zmiennych.
Wybieraj¹c International decydujemy, øe†wej-
úcia binarne oznaczone zostan¹ jako ìIî (wej-
úcia), zaú wyjúcia binarne jako ìQî (wyjúcia).
Ustawienie w† Mnemonic Set na SIMATIC po-
woduje odpowiednio oznaczanie wejúÊ jako
ìEî ( Eingang ) a†wyjúÊ ìAî ( Ausgang ).
W†przypadku pomy³ki edytor samodziel-
nie zamieni mnemonik na zgodny z†ustawio-
nym standardem. Waøna cech¹ oprogramowa-
nia Step7MicroWin 32 jest moøliwoúÊ wybo-
ru konwencji programowania. Uøytkownik na
pocz¹tku pisania programu decyduje czy bÍ-
dzie korzysta³ z†funkcji zgodnych ze standar-
dem SIMATIC, czy teø wszystkie instrukcje,
ktÛre bÍd¹ uøywane w†programie, bÍd¹ zgod-
ne z†norma IEC 1131-3. Ustawienia standar-
du programowania dokonuje siÍ w† Tools-
>Options->Programing Mode .
resowany bitowo V0.0, jako bajt VB0, s³o-
wo VW0, lub podwÛjne s³owo VD0.
- Obszar oznaczony jako ìIî lub ìEî. Jest
to obszar wejúÊ procesu. Sterownik na
pocz¹tku cyklu czyta stany sygna³Ûw na
wszystkich wejúciach i†wartoúci tych sta-
nÛw odk³ada w†obszarze wejúÊ procesu.
Moøliwy jest odczyt sygna³Ûw wejúcio-
wych jako pojedynczy bit I0.0, bajt
IB0,s³owo IW0, podwÛjne s³owo ID0.
- Obszar oznaczony jako ìQî lub ìAî. Jest
to obszar wyjúÊ procesu. Sterownik na
koÒcu cyklu przepisuje stany sygna³Ûw
z†obszaru wyjúÊ procesu na fizyczne wyj-
úcia sterownika. Moøliwy jest zapis sta-
nÛw z†obrazu wyjúÊ procesu na pojedyn-
cze wyjúcia Q0.0(bit), grupÍ bajt QB0,
s³owo QW0, lub podwÛjne s³owo QD0.
- Obszar oznaczony jako ìLî. Jest to tzw.
lokalny stos danych czyli pamiÍÊ progra-
mu przydzielona tylko dla bloku progra-
mowego np. SBRx, w†ktÛrym s¹ wywo³y-
wane zadeklarowane zmienne L. W†obsza-
rze ìLî moøliwy jest dostÍp do zmien-
nych typu bit L0.0, bajt L0, s³owo LW0
lub podwÛjne s³owo LD0.
- Obszar oznaczony jako ìSMî. Jest to pa-
miÍÊ znacznikÛw systemowych zapisanych
w†BIOS-ie sterownika S7-200. Zadaniem
tych znacznikÛw jest analiza pracy syste-
mu. Wszelkie odchy³ki od prawid³owej pra-
cy systemu sygnalizowane bÍd¹ w†znaczni-
kach systemowych SM. Uøytkownik ma
rÛwnieø moøliwoúÊ modyfikacji tych znacz-
nikÛw, np. w†celu zmiany prÍdkoúci prze-
sy³u danych przez zintegrowane z³¹cze ko-
munikacyjne sterownika S7-200.
czoúÊ - np. T0 ma rozdzielczoúÊ 1†ms, zaú T1
rozdzielczoúÊ 10 ms. Zegary rÛøni¹ siÍ rÛw-
nieø ze wzglÍdu na funkcjonalnoúÊ. W†biblio-
tece Step7MicroWin znajduj¹ siÍ trzy typy ze-
garÛw: z†opÛünieniem na za³¹czenie, z†opÛü-
nieniem na wy³¹czenie oraz z†opÛünieniem na
za³¹czenie i†podtrzymaniem. Liczba dostÍp-
nych zegarÛw uzaleøniona jest od typu CPU.
Liczniki
OprÛcz zegarÛw wykorzystywane s¹ rÛw-
nie czÍsto liczniki oznaczone jako ìCî ( Coun-
ter ). Ich zadaniem jest zliczanie impulsÛw po-
dawanych na wejúcia binarne sterownika lub
zliczanie zmian stanÛw wewnÍtrznych znacz-
nikÛw ìMî. Liczniki s¹ 16-bitowymi rejestra-
mi przechowuj¹cymi aktualnie zliczon¹ iloúÊ
impulsÛw. Dziel¹ siÍ na: zliczaj¹ce w†gÛrÍ
CTU, w†dÛ³ CTD, oraz uniwersalne zliczaj¹ce
gÛra/dÛ³ - CTUD. Liczniki aktywowane s¹ na-
rastaj¹cym zboczem sygna³u. Liczba dostÍp-
nych licznikÛw uzaleøniona jest od typu CPU.
Szybkie liczniki
Szybkie liczniki maj¹ rejestry 32-bitowe.
Ich zadaniem jest zliczanie impulsÛw poda-
wanych na okreúlone wejúcia CPU z†maksy-
maln¹ czÍstotliwoúci¹ do 30 kHz. Odczyt
impulsÛw odbywa siÍ poza cyklem pÍtli,
nie wystÍpuje wiÍc problem z†ìgubieniemî
poszczegÛlnych impulsÛw w†zaleønoúci od
czasu przetwarzania programu. Odczyt szyb-
kich licznikÛw dokonywany jest na ø¹danie
w†programie obs³ugi przerwania czasowego.
Szybkie liczniki oznaczane s¹ jako HSC.
Obszary alokacji zmiennych
W†obszarze pamiÍci wyrÛøniamy nastÍ-
puj¹ce obszary dla alokacji zmiennych:
- obszar adresowany bitowo oznaczony jako
ìMî ( Marker ). DostÍp do tego obszaru jest
moøliwy jako bitowy M0.0, bajtowy MB0,
s³owo MW0 lub podwÛjne s³owo DW0.
- Obszar oznaczony jako ìVî ( Variable ).
Jest to ca³y obszar bloku oznaczonego ja-
ko Data Block . Obszar ten moøe byÊ ad-
Wejúcia/wyjúcia analogowe
Odczyt sygna³Ûw analogowych dokony-
wany jest poprzez odwo³anie w†programie
do konkretnego kana³u analogowego. Odczy-
tywana jest aktualna wartoúÊ analogowa i†po
konwersji A/C. W†rejestrze modu³u analogo-
wego umieszczona zostaje wartoúʆliczbowa
z†zakresu -32000...+32000 lub 0...+32000.
Aby umieúciÊ przetworzon¹ wartoúÊ w†pa-
miÍci sterownika naleøy wykorzystaÊ z†bib-
lioteki programu Step7MicroWin - do tego
celu s³uøy funkcja MOV AIW0, VW10, gdzie
pierwszy kana³ analogowy oznaczony jest
jako AIW0, a†VW10 jest zmienn¹ umieszczo-
na w†pamiÍci sterownika w†obszarze îVî
o†adresie 10. WartoúÊ analogowa reprezen-
towana jest przez liczbÍ 16-bitow¹.
Zegary
W†systemach automatyki wystÍpuje ko-
niecznoúÊ precyzyjnego odmierzania czasu
z†zadan¹ dok³adnoúci¹. W†tym celu w†sterow-
niku S7-200 przygotowano komÛrki pamiÍci
oznaczone liter¹ ìTî (Timer). Timer jest 16-
bitowym rejestrem, w†ktÛrym znajduje siÍ ak-
tualna wartoúÊ odmierzonego czasu. Numery
zegarÛw s¹ powi¹zane z†rozdzielczoúci¹ cza-
su jaki odmierzaj¹. W†zaleønoúci od numeru
zegara przyporz¹dkowana jest rÛøna rozdziel-
Elektronika Praktyczna 12/2003
141
39647831.003.png 39647831.004.png 39647831.005.png 39647831.006.png
A U T O  M A  T Y K A
Tab. 1. Zestawienie wyposażenia jednostek centralnych S7−200
Opis
CPU221
CPU222
CPU224
CPU226
CPU226XM
Pamiêæ programu
4 kB
4 kB
8 kB
8 kB
16 kB
Pamiêæ danych
2 kB
2 kB
5 kB
5 kB
10 kB
Obraz wejϾ procesu
I0.0 do I15.7
I0.0 do I15.7
I0.0 do I15.7
I0.0 do I15.7
I0.0 do I15.7
Obraz wyjϾ procesu
Q0.0 do Q15.7
Q0.0 do Q15.7
Q0.0 do Q15.7
Q0.0 do Q15.7
Q0.0 do Q15.7
Liczba kana³ów
-
AIW0 do AIW30
AIW0 do AIW62
AIW0 do AIW62
AIW0 do AIW62
wejϾ analogowych
Liczba kana³ów
-
AQW0 do AQW30
AQW0 do AQW62
AQW0 do AQW62
AQW0 do AQW62
wyjϾ analogowych
Obszar pamiêci typu
VB0 do VB2047
VB0 do VB2047
VB0 do VB5119
VB0 do VB5119
VB0 do VB10239
“V” podany w bajtach
Obszar pamiêci typu
LB0 do LB63
LB0 do LB63
LB0 do LB63
LB0 do LB63
LB0 do LB63
“L” podany w bajtach
Obszar pamiêci typu
M0.0 do M31.7
M0.0 do M31.7
M0.0 do M31.7
M0.0 do M31.7
M0.0 do M31.7
“M” okreœlony bitowo
Obszar znaczników
SM0.0 do SM179.7
SM0.0 do SM 299.7
SM0.0 do SM 549.7
SM0.0 do SM 549.7
SM0.0 do SM 549.7
systemowych “SM”
Zagary “Timers”
256 (T0 do T255)
256 (T0 do T255)
256 (T0 do T255)
256 (T0 do T255)
256 (T0 do T255)
OpóŸnienie na za³¹cze-
nie z podtrzymaniem
1ms
T0,T64
T0,T64
T0,T64
T0,T64
T0,T64
10ms
T1 do T4 i T65 do T68
T1 do T4 i T65 do T68
T1 do T4 i T65 do T68
T1 do T4 i T65 do T68
T1 do T4 i T65 do T68
100ms
T5 do T31 i T69 do T95
T5 do T31 i T69 do T95
T5 do T31 i T69 do T95
T5 do T31 i T69 do T95
T5 do T31 i T69 do T95
OpóŸnienie na
za³¹czenie/wy³¹czenie
1 ms
T32, T96
T32, T96
T32, T96
T32, T96
T32, T96
10ms
T33 do T36 i T97 do T100
T33 do T36 i T97 do T100
T33 do T36 i T97 do T100
T33 do T36 i T97 do T100
T33 do T36 i T97 do T100
100ms
T37 do T63 i T101 do T255 T37 do T63 i T101 do T255 T37 do T63 i T101 do T255 T37 do T63 i T101 do T255 T37 do T63 i T101 do T255
Liczniki
C0 do C255
C0 do C255
C0 do C255
C0 do C255
C0 do C255
Szybkie liczniki HSC
HC0,HC3,HC4,HC5
HC0,HC3,HC4,HC5
HC0 do HC5
HC0 do HC5
HC0 do HC5
Akumulatory
AC0 do AC3
AC0 do AC3
AC0 do AC3
AC0 do AC3
AC0 do AC3
Skoki do etykiety
0 do 255
0 do 255
0 do 255
0 do 255
0 do 255
Liczba podprogramów
0 do 63
0 do 63
0 do 63
0 do 63
0 do 127
Liczba funkcji wykry-
256
256
256
256
256
wania zbocza narasta-
j¹cego/opadaj¹cego
Iloœæ pêtli regulacji PID
0 do 7
0 do 7
0 do 7
0 do 7
0 do 7
Porty komunikacyjne
Port0
Port0
Port0
Port0,Port1
Port0,Port1
Analogicznie sytuacja przedstawia siÍ
z†wyjúciami analogowymi, przy czym naleøy
wykonaÊ operacjÍ odwrotn¹, czyli przetworzo-
n¹ wartoúÊ z†zakresu -32000...+32000, przecho-
wywan¹ w†pamiÍci sterownika naleøy przes³aÊ
na konkretny kana³ analogowy za pomoc¹ in-
strukcji MOV VW10, AQW0, gdzie VW10 jest
zmienna w†sterowniku, a†AQW0 jest pierw-
szym kana³em wyjúciowym analogowym.
Sta³ Wiele operacji arytmetycznych wymaga
okreúlenia wartoúci sta³ych. Mog¹ byÊ one
okreúlone jako wartoúci typu: binarnego,
dziesiÍtnego, hexadecymalnego, ASCII,
zmiennoprzecinkowego. Przyk³adowe dekla-
racje wartoúci sta³ych:
Sta³a dziesiêtna
2022
zmienn¹ 32-bitow¹ typu podwÛjne s³owo. Ja-
ko wskaünik moøe byÊ uøyta zmienna z†ob-
szaru ìVî - np. VD200, akumulator - np.
AC1, zmienna lokalna ìLî - np. L6. Aby wy-
generowaÊ wskaünik naleøy skorzystaÊ z†fun-
kcji MOVD znajduj¹cej siÍ w†bibliotece fun-
kcji programu Step7MicroWin. Aby poinfor-
mowaÊ, øe chcemy zadeklarowaÊ wskaünik
do danej VW10 a†nie przes³aÊ wartoúÊ danej
do np. akumulatora, koniecznym jest poprze-
dzenie adresu, na ktÛry ma wskazywaÊ
wskaünik znakiem ì&î, np.:
MOV &VW10, AC1
MOV &MB4, VD5
MOV &C4, L6
Tak wytworzony wskaünik wskazuje obec-
nie na konkretna dan¹ czyli jak w†przyk³adach
powyøej na VW10, MB4, C4. Jeøeli chcemy
odczytaÊ wartoúÊ zawarta w†danej, wskazywa-
nej przez wskaünik naleøy wykonaÊ czynnoúci
jak w†przyk³adzie pokazanym na rys. 1 .
Micha³ Bereza, Siemens
Sta³a hexadecymalna
16#4AE3
Sta³a ASCII
‘ proba ‘
Akumulatory
Akumulatory s¹ 32-bitowymi rejestrami,
s³uø¹cymi do przechowywania wynikÛw po-
úrednich obliczeÒ oraz wykorzystywane s¹
przy adresowaniu za pomoc¹ wskaünikÛw.
Jednym z†zastosowaÒ akumulatorÛw†jest prze-
kazywanie parametrÛw do podprogramÛw
i†z†powrotem. W†CPU znajduj¹ siÍ 4†akumu-
latory oznaczone AC0, AC1, AC2, AC3.
Sta³a zmiennoprzecinkowa
+1.175495E-38
lub typu Real
Sta³a binarna
2#1000_1001_1010_0100
Adresowanie poúrednie
Adresowanie poúrednie jest wykorzysty-
wane jako jeden z†najefektywniejszych spo-
sobÛw dostÍpu do danych znajduj¹cych siÍ
w†pamiÍci sterownika. DziÍki adresowaniu
poúredniemu istnieje
moøliwoúÊ adresowa-
nia tabel danych i†³at-
wego zarz¹dzania ni-
mi. Aby uzyskaÊ do-
stÍp do danej w†spo-
sÛb poúredni najpierw
naleøy utworzyÊ
wskaünik adresowy,
ktÛry wskazuje na t¹
dan¹. Wskaünik jest
Dodatkowe informacje
Rys. 1
Pe³na dokumentacja w jêzyku angielskim do ste-
rownika S7-200 oraz oprogramowanie STEP7MicroWin
znajduje siê na p³ycie CD-EP12/2003B oraz w Internecie
pod adresem: www.siemens.pl/simatic w podkatalogu
Katalogi>Instrukcje .
142
Elektronika Praktyczna 12/2003
39647831.001.png 39647831.002.png
Zgłoś jeśli naruszono regulamin