Projekt

Obecné

Profil

AMMI v3 » Historie » Verze 7

Jednatel J.H., 2017-12-07 15:54

1 1 Jednatel J.H.
{{>toc}}
2
3
h1(#top). Advance Machine Machine Interface ([[AMMI_v3|AMMI]]) ver.3.x
4
5
Pokročilé rozhraní zařízení-zařízení ve zkratce ([[AMMI_v3|AMMI]]) poskytuje komunikační protokol jednotlivých [[DKE#diagram|komponent DKE]]. [[AMMI_v3|AMMI]] je součástí libovolného [[PAC|DKE-PAC]]. Označení MMI představuje komunikaci mezi zařízeními, jako jsou například počítače, kontroléry, mobilní telefony, chytré senzory... a písmeno A (Advance) informuje o pokročilosti a komplexnosti této komunikace. Cílem AMMI je inteligentní kybernetické řízení. [[AMMI_v3|AMMI]] protokol je určený spíše pro zařízení, než pro uživatele a je optimalizovaný pro rychlost a spolehlivost. Pro přímou komunikaci uživatele a [[PAC-AT90|DKE-PAC]] je vhodné instalovat [[AHMI]] software. Aktuální vývojová verze [[AMMI_v3]] podporuje [[PAC-AT90_v3]] a má implementovány protokoly:
6
* [[MMI#usb|DKE-MMI-USB]] je převodník, dekodér nebo kodér komunikačního rozhraní. Označení USB představuje metalický komunikační standard Universal Serial Bus 2.0.
7
* [[MMI#wifi|DKE-MMI-WIFI]] je převodník, dekodér nebo kodér komunikačního rozhraní. Označení WIFI představuje bezdrátový komunikační standard IEEE 802.11.
8
* [[MMI#uart|DKE-MMI-UART]] je převodník, dekodér nebo kodér komunikačního rozhraní. Označení UART představuje metalický komunikační standard ANSI EIA/TIA-232.
9
10
-------------------------------------------------------------
11
12 7 Jednatel J.H.
h2(#spec). 1. Specifikace komunikačního protokolu [[AMMI_v3|AMMI]]
13 1 Jednatel J.H.
14
Fyzická, linková, síťová a transportní vrstvy vychází z níže uvedených protokolů. Uvádíme zde pouze konkrétní odlišnosti a informace potřebné pro snadnou implementaci. Sledy vodičů, napěťové úrovně, napájení a vodiče jsou specifikovány v [[PAC-AT90]].
15
16
## USART
17
*** TTL (5 V, 3,3 V)
18
*** RS232
19
*** USB 2.0
20
## IEEE 802.11 (Wi-Fi)
21
*** 2,4 GHz
22
*** TCP/UDP
23
*** client/server
24
25
Relační, prezentační a aplikační vrstvy společně zajišťují přenos informací mezi zařízeními. Převážně se jedná o sériový přenos dat a je optimalizovaný pro minimální datový tok. Dále uvádíme pouze tělo rámce (rámec definován užitou linkou). Tělo rámce [[AMMI_v3|AMMI]] je v podobě sekvence bajtů:
26 7 Jednatel J.H.
* *0.B* je počet následujících B těla rámce;
27
* *1.B* je adresa [[PAC-AT90|DKE-PAC]];
28
* *2.B* je příkaz/sdělení;
29
* *3.B* až *N.B* jsou určeny pro data zařízení, data příkazu nebo data sdělení.
30 1 Jednatel J.H.
31 7 Jednatel J.H.
Zařízení, sdělení, příkazy a jejich možné hodnoty jsou uvedeny v kapitole [[AMMI_v3#ammi_syntaxe|2. Syntaxe]].
32
33
Komunikace reaguje po přerušení na lince a to tak, že AMMI přijme nultý bajt v kterém je uvedeno kolik následujících bajtů bude posláno. Toto číslo nesmí být menší nebo větší než jsou minima a maxima definovaná použitým slovníkem. Pro aktuální platnou verzi je minimální délka přijaté sekvence 2 B a maximální délka této sekvence je 9 B. Do této délky se nepočítá nultý bajt. Doba mezi přijatými bajty nesmí být delší než nastavená maximální hodnota prodlevy. Tato hodnota je pro aktuální platnou verzi ve výchozím nastavení cca 900 ms. 
34
35
36 1 Jednatel J.H.
37 6 Jednatel J.H.
-------------------------------------------------------------
38 1 Jednatel J.H.
39 6 Jednatel J.H.
h3(#tx). 1.1 Struktura odchozího těla rámce (aplikace posílá do [[PAC-AT90]] bajty skrze předchozí vrstvy)
40
41 1 Jednatel J.H.
|=. *B0*              |=.     *B1*              |=. *B2*               |=.   *B3 až B9*                    |
42
|suma posílaných bajtů|adresa volaného zařízení |sdělení nebo příkaz   |data patřící sdělení nebo příkazu  |
43
44 6 Jednatel J.H.
Jednotlivé příkazy a sdělení jsou uvedeny v kapitole [[AMMI_v3#ammi_syntaxe|Syntaxe]].
45 1 Jednatel J.H.
46 6 Jednatel J.H.
-------------------------------------------------------------
47 1 Jednatel J.H.
48 6 Jednatel J.H.
h3. 1.2 Struktura příchozího těla rámce ([[PAC-AT90]] posílá do aplikace bajty skrze předchozí vrstvy)
49 1 Jednatel J.H.
50 6 Jednatel J.H.
|=. *B0*              |=.     *B1*                |=. *B2*               |=.   *B3 až B9*                    |
51
|suma příchozích bajtů|adresa volajícího zařízení |sdělení nebo příkaz   |data patřící sdělení nebo příkazu  |
52 1 Jednatel J.H.
53 6 Jednatel J.H.
Jednotlivé příkazy a sdělení jsou uvedeny v kapitole [[AMMI_v3#ammi_syntaxe|Syntaxe]].
54 1 Jednatel J.H.
55 6 Jednatel J.H.
-------------------------------------------------------------
56
57
h3. 1.3 Příklad komunikace a)
58
59 1 Jednatel J.H.
# aplikace otevře TCP port
60
# aplikace pošle |0x03|0x01|0xC3|0x03|
61
# aplikace zavře TCP port
62
63
Aplikace přikázala skrze Wi-Fi aby [[PAC-AT90]] na adrese 1 náhodně nastavil výstupy [[IOPE]] na 1 a 0. 
64
65 6 Jednatel J.H.
-------------------------------------------------------------
66 1 Jednatel J.H.
67 6 Jednatel J.H.
h3. 1.4 Příklad komunikace b)
68
69 1 Jednatel J.H.
# aplikace otevře TCP port
70
# aplikace pošle |0x03|0x01|0x01|0x0E|
71
# [[PAC-AT90]] pošle |0x03|0x01|0x01|0x0E|
72
# aplikace pošle |0x04|0x01|0xC3|0x32E6|
73
# [[PAC-AT90]] pošle |0x04|0x01|0xC3|0x32E6|
74
# aplikace zavře TCP port
75
76
Aplikace skrze Wi-Fi zapnula echo na [[PAC-AT90]] a přikázala [[PAC-AT90]] zapnout a vypnout výstupy [[IOPE]] dle schématu 0011 0010 1110 0110.
77
78
-------------------------------------------------------------
79 3 Jednatel J.H.
80 6 Jednatel J.H.
h2(#ammi_syntaxe). 2 Syntaxe a sémantika komunikačního protokolu [[AMMI_v3|AMMI]]
81 3 Jednatel J.H.
82 1 Jednatel J.H.
Následující kapitoly se věnují jednotlivým zařízením, modulům, funkčním celkům které lze skrze [[AMMI_v3|AMMI]] ovládat. Podrobné popisy chování a vlastností naleznete v dokumentaci jednotlivých modulů.
83 3 Jednatel J.H.
84 1 Jednatel J.H.
-------------------------------------------------------------
85 4 Jednatel J.H.
86 6 Jednatel J.H.
h3(#ammi_kernel). 2.1 Jádro ([[AMMI_v3#ammi_kernel|AMMI-KERNEL]])
87 4 Jednatel J.H.
88
Jádro AMMI představuje hlavní proces, který řídí, ovládá a plánuje činnost celého PAC. Jádro má načteny všechny HW prostředky, všechna rozšiřující zařízení a ví co kdy a jak provede. Chování jádra AMMI se dá pomocí následujících příkazů upravit. Příkaz vrátí aktuální nastavení, pokud bude délka příkazu 2 B, nebo pokud změníte nastavení.
89
90
|=. B0   |=.     B1      |\2=.   B2                                            |=. B3                       |
91
|*ΣB*    |*adresa*       |*sdělení*     |hex|popis                             |*data B 1*                  |
92
|/8^.2:3 |/8^.00:FF      |^.AMMI_SILENT |00 |tichý režim bez sdělení           | ENABLE(0x01)/DISABLE(0x00) |
93
                         |^.AMMI_ASCII  |01 |pro komunikaci používat ASCII     | ENABLE(0x01)/DISABLE(0x00) |
94
                         |^.AMMI_REPEAT |02 |rezervováno                       | ENABLE(0x01)/DISABLE(0x00) |
95
                         |^.AMMI_PING   |03 |posílat zpět přijaté B            | ENABLE(0x01)/DISABLE(0x00) |
96
                         |^.AMMI_LINE   |04 |každé sdělení má svůj řádek       | ENABLE(0x01)/DISABLE(0x00) |
97
                         |^.AMMI_HMI    |05 |rezervováno                       | ENABLE(0x01)/DISABLE(0x00) |
98
                         |^.AMMI_BACK   |06 |posílat sdělení procesů na pozadí | ENABLE(0x01)/DISABLE(0x00) |
99
                         |^.AMMI_ISR    |07 |zakázat nebo povolit přerušení    | ENABLE(0x01)/DISABLE(0x00) |
100
101
-------------------------------------------------------------
102
103 6 Jednatel J.H.
h3(#ammi_translator). 2.2. Překladač ([[AMMI_v3#ammi_translator|AMMI-TRANSLATOR]])
104 4 Jednatel J.H.
105
Překladač vytváří formu pro veškerou komunikaci jak mezi moduly DKE tak i mezi AHMI a PAC. Správné nastavení překladače je důležité pro veškeré komunikační funkce. Překladač umožňuje různé úrovně diagnostiky, volání, hlášení.
106
107
Nastavení překladače
108
|=. B0   |=.     B1      |\2=.   B2                                        |=. B3                 |
109
|*ΣB*    |*adresa*       |*sdělení*      |hex|popis                        |*data B 1*            |
110
|/10^.2:3|/10^.00:FF     |^.TRNSL_DISABLE|F0 |překladač vypnut             |                      |
111
                         |^.TRNSL_ENABLE |F1 |překladač zapnut             |                      |
112
                         |^.TRNSL_ERROR  |F8 |neznámá chyba překladače     |                      |
113
                         |^.TRNSL_TEXP   |F9 |vypršel čas příjmu dalšího B | pozice nepřijatého B |
114
                         |^.TRNSL_SHRT   |FA |přijato málo B               |                      |
115
                         |^.TRNSL_LONG   |FB |přijato mnoho B              |                      |
116
                         |^.TRNSL_UCOM   |FC |neznámý příkaz               |                      |
117
                         |^.TRNSL_UVAL   |FD |neznámá nebo chybná hodnota  |                      |
118
                         |^.TRNSL_UDEV   |FE |neznámé zařízení             |                      |
119
                         |^.TRNSL_NOTME  |FF |příkaz není pro mne          |                      |
120
121
-------------------------------------------------------------
122
123 6 Jednatel J.H.
h3(#ammi_sequences). 2.3. Sekvenční řízení ([[AMMI_v3#ammi_sequences|AMMI-SEQUENCES]])
124 1 Jednatel J.H.
125
[[AMMI_v3#ammi_sequences|AMMI-SEQUENCES]] představuje třídu s metodami a proměnnými pro odložené, opakované a cyklické řízení [[AMMI_v3|AMMI]]. Každý uložený příkaz má následující vlastnosti:
126
# SEKVENCE, sled bajtů konkrétního příkazu viz [[AMMI_v3#tx|tabulka Struktura odchozího těla rámce]]
127
# STATUS, zapnuto, vypnuto
128
# LOOP, počet opakování příkazu
129
# TIMER, kdy bude příkaz poprvé volán
130
# PERIODE, doba mezi jednotlivými volání příkazu.
131
132
Příkazy pro práci s metodami [[AMMI_v3#ammi_sequences|AMMI-SEQUENCES]] jsou v [[AMMI_v3#tx|tabulce Struktura odchozího těla rámce]] a jsou to:
133 4 Jednatel J.H.
134
|=. B0   |=.     B1 |\3=.   B2                                                      |=. B3                                                                 |
135
|*ΣB*    |*adresa*  |*příkaz*           |hex|popis                              |*Vstupní a výstupní parametr*                                         |
136
|/9^.2:3 |/9^.00:FF | SEQUENCES_SET     |40| Nastaví sled bajtů konkrétního volání. | Sled bajtů, viz [[AMMI_v3#tx|tabulka Struktura odchozího těla rámce]]|
137
                    | SEQUENCES_SET_TIME|41| Nastaví čas prvního volání.            | 0 až 65536 jednotek, viz [[AMMI_v3#tc|Hodiny]]                       |
138
                    | SEQUENCES_SET_LOPS|42| Nastaví počet volání.                  | 0 až 255                                                             |
139
                    | SEQUENCES_SET_PERD|43| Nastaví prodlevu mezi voláními.        | 0 až 255 jednotek, viz [[AMMI_v3#tc|Hodiny]]                         |
140
                    | SEQUENCES_SET_STAT|44| Nastaví status volání.                 | Zap, Vyp, Zámek                                                      |
141
                    | SEQUENCES_GET     |45| Vrátí všechny vlastnosti sekvence.     | Sled bajtů v posloupnosti seznamu z předchozího odstavce.            |
142
                    | SEQUENCES_INIT    |46| Uvolní všechna nastavení sekvencí.     |                                                                      |
143
                    | SEQUENCES_RUN     |47| Spustí konkrétní volání.               | 0 až maximální počet volání                                          |
144 3 Jednatel J.H.
                    | SEQUENCES_AUTORUN |48| Spustí automatický běh volání.         |                                                                      |
145
146
-------------------------------------------------------------
147
148 6 Jednatel J.H.
h3(#ammi_iope). 2.4 [[IOPE_v3|IOPE]] modul ([[AMMI_v3#ammi_iope|AMMI-IOPE]])
149 3 Jednatel J.H.
150
[[AMMI_v3#ammi_iope|AMMI-IOPE]] je třída s metodami a proměnnými pro komunikaci, ovládání a nastevaení rozšiřujícího modulu [[IOPE_v3|IOPE]].
151
152
Příkazy pro práci s metodami [[AMMI_v3#ammi_iope|AMMI-IOPE]] jsou v [[AMMI_v3#tx|tabulce Struktura odchozího těla rámce]] a jsou to:
153
154
|=. B0 |=.     B1 |=. B2               |\2=.   B3                                                |=. B4                            |=. B5            |=. B6     |
155
|*ΣB*  |*adredsa* |*zařízení*          |*sdělení/příkaz*    |popis                               |*data B 1*                       |*data B 2*       |*data B 3*|*data B 4*|
156
|/28^.4|/28^.1:255|/28^.IOPE(0x01:0xFF)|/6^.COLLECTORS(0xC3)|/6^.nastaví všechny výstupy [[IOPE]]|                                 |                 |          |          |
157
                                                                                                 | 0x00 = vše vypnout              |                 |          |          |
158
                                                                                                 | 0x01 = vše zapnout              |                 |          |          |
159
                                                                                                 | 0x02 = vše invertovat           |                 |          |          |
160
                                                                                                 | 0x03 = náhodná kombinace        |                 |          |          |
161
                                                                                                 | 0xF0 = vrať stavy výstupů       |                 |          |          |
162
                                       |COFF(0xC0)     |vypne výstup [[IOPE]] (vysoká impedance) | 0x00:0x0F = číslo kolektoru     |                 |          |          |
163
                                       |CON(0xC1)      |sepne výstup [[IOPE]] (otevřený kolektor)| 0x00:0x0F = číslo kolektoru     |                 |          |          |
164
                                       |CTGL(0xC2)     |invertuje výstup [[IOPE]]                | 0x00:0x0F = číslo kolektoru     |                 |          |          |
165
                                       |/6^.PWM(0xD0:0xDF)  |/6^.správa PWM pro jednotlivé výst. | 0x00 = PWM vypnout              |                 |          |          |
166 1 Jednatel J.H.
                                                                                                 | 0x01 = PWM zapnout              |                 |          |          |
167 3 Jednatel J.H.
                                                                                                 | 0x02 = PWM perioda              |                 |          |          |
168
                                                                                                 | 0x03 = PWM střída               |                 |          |          |
169 1 Jednatel J.H.
                                                                                                 | 0x04 = efekt1                   |                 |          |          |
170 3 Jednatel J.H.
                                                                                                 | 0xF0 = vrať aktuální nastavení  |                 |          |          |
171
                                       |/4^.ADC(0xA0:0xAF)  |/4^.správa kanálů ADC               | 0x00 = ADC vypnout              |                 |          |          |
172
                                                                                                 | 0x01 = ADC zapnout              |                 |          |          |
173
                                                                                                 | 0x02 = vrať hodnotu ADC kanálu  |                 |          |          |
174 1 Jednatel J.H.
                                                                                                 | 0xF0 = vrať aktuální nastavení  |                 |          |          |
175 3 Jednatel J.H.
                                       |/9^.ENCODER(0x60)   |/9^.příkazy inkrementálního enkodéru| 0x01 = kontrola délky cyklů     |                 |          |          |
176
                                                                                                 | 0x02 = vrátí délka cyklů        |                 |          |          |
177
                                                                                                 | 0x03 = kontrola počtu cyklů     |                 |          |          |
178
                                                                                                 | 0x04 = vrátí počet cyklů        |                 |          |          |
179
                                                                                                 | 0x05 = vrátí směr rotace        |                 |          |          |
180
                                                                                                 | 0x06 = nastaví minimální délu   | DELKA           |          |          |
181
                                                                                                 | 0x07 = nastaví maximální délu   | DELKA(MSB)      |DELKA(LSB)|          |
182
                                                                                                 | 0x08 = vyčistí čítače a hodnoty |                 |          |          |
183 1 Jednatel J.H.
                                                                                                 | 0x09 = nastaví rozlišení čítače | ROZLISENI(0:255)|          |          |
184
185
186
-------------------------------------------------------------
187
188 6 Jednatel J.H.
h2(#dev). 3 Vývojové informace
189 1 Jednatel J.H.
190
Vývojové informace mohou procházet uživatelé s bezpečnostní prověrkou reportér a vyšší.
191
192 6 Jednatel J.H.
# Aktuální vývojová verze: [[versions|3.x]]
193 1 Jednatel J.H.
# Developments Issues: #485
194
# "Components List":https://www.tme.eu/cz/Profile/Parking/740721.html
195
196
-------------------------------------------------------------
197
198 6 Jednatel J.H.
h2(#atch). 4 Přílohy