-
Data: 2014-06-02 00:47:26
Temat: Re: stara pamięć nie rdzewieje
Od: Mario <m...@...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2014-06-02 00:18, Piotrne pisze:
> W dniu 2014-05-31 16:00, Sebastian Biały pisze:
>> najprostszy przykład to nie dawno koleś który w logice
>> drabinkowej wydziargał w miesiąc układ (skomplikowany)
>> który na oko w dowolnym imperatywnym języku programowania
>> zajął by może z 2 godzinki z unit testami. Dlaczego więc
>> dziargał? "Bo logika drabinowa jest najprostsza!".
>
> Pisałem w ubiegłym roku "drabinkowy" program na sterownik
> Kinco K3. Zadanie było proste: wykonać w określonej kolejności
> kilka ruchów silnikiem krokowym z ustalonymi parametrami
> (prędkość, odległość). Parametry ustawiane na module HMI
> z ekranem dotykowym. Sekwencja ruchów silnika bardzo prosta:
> szukanie położenia końcowego (z czujnikiem krańcowym),
> przejazd o wartość D1, pauza, N przejazdów o wartość D2, powrót.
> Pisanie (poprzedzone studiowaniem języka drabinkowego)
> zajęło trochę czasu, a powstały program w zasadzie był
> emulatorem interpretera języka sekwencyjnego...
>
> Czyli zamiast napisać:
>
> 1) włącz silnik aż do znalezienia położenia krańcowego
> 2) włącz D1 impulsów silnika
> 3) for i:=1 to n { włącz D2 impulsów silnika }
> 4) wróć do położenia krańcowego
> 5) idź do 1
>
> napisałem (w uproszczeniu!) mniej więcej coś takiego:
>
> 1) jeśli (pierwszy_cykl == TRUE) to { nr_stanu = 1 }
>
> 2) jeśli (nr_stanu == 1 lub nr_stanu == 4) to włącz
> szukanie położenia krańcowego
>
> 3) jeśli (nr_stanu == 1 oraz znaleziono_stan_krańcowy)
> to { nr_stanu = 2 }
>
> 4) jeśli (nr_stanu == 4 oraz znaleziono_stan_krańcowy)
> to { nr_stanu = 5 }
>
> 5) jeśli (nr_stanu == 2) to włącz D1 impulsów silnika
>
> 6) jeśli (nr_stanu == 2 ORAZ wykryto_koniec_ruchu_silnika)
> to { nr_stanu = 3; licznik = n }
>
> 7) jeśli (nr_stanu == 3) to flaga1 = (licznik>0)
>
> 8) jeśli (nr_stanu == 3 ORAZ flaga1 == TRUE )
> to włącz D2 impulsów silnika
>
> 9) jeśli (nr_stanu == 3 ORAZ flaga1 == FALSE )
> to { nr_stanu = 4 }
>
> 10) jeśli (nr_stanu == 3 ORAZ wykryto_koniec_ruchu_silnika}
> to { nr_stanu = 3a }
>
> 11) jeśli (nr_stanu == 3a) to { zmniejsz licznik o 1 }
>
> 12) jeśli (nr_stanu == 3a) to { nr_stanu = 3 }
>
> 13) jeśli (nr_stanu == 4 ORAZ znaleziono_stan_krańcowy)
> to { nr_stanu = 1 }
>
> To oczywiście takie proste nie było, bo trzeba jeszcze czytać
> parametry z HMI i przenosić do "modułu" obsługującego silnik.
> A moduł mógł wystąpić tylko jeden raz w całym programie
> drabinkowym. Czyli zależnie od numeru_stanu trzeba było
> kopiować do niego różne parametry, a potem badać sumę logiczną
> wszystkich warunków, przy których silnik powinien się włączyć
> i takim sygnałem do aktywować.
Możesz to ominąć stosując cewki -(S)- i -(R)-
W dodatku nie rozumiem po co po kroku 4 wprowadzasz krok 5 będący
przejściem na kroku 1 - szukania pozycji krańcowej skoro w kroku 4
dojechał do pozycji krańcowej.
> Może ta drabinkowa koncepcja nadaje się do sterowania światłem
> na korytarzu, ale pisanie takiego kodu jest bardzo męczące.
Męczące dla kogoś przyzwyczajonego do C czy Pascala.
Duża część poważnej przemysłowej automatyki jest na drabince, co by
znaczyło, że ci co to robią uważają LD za wygodne narzędzie.
--
pozdrawiam
MD
Następne wpisy z tego wątku
- 02.06.14 00:55 AlexY
- 02.06.14 01:38 Mario
- 02.06.14 13:21 Piotrne
- 02.06.14 14:27 sundayman
- 02.06.14 19:49 Irokez
- 02.06.14 20:35 Mario
- 03.06.14 01:41 Piotrne
- 03.06.14 15:37 Mario
- 03.06.14 16:22 Tomasz Wójtowicz
Najnowsze wątki z tej grupy
- pozew za naprawę sprzętu na youtube
- gasik
- Zbieranie danych przez www
- reverse engineering i dodawanie elementów do istniejących zamkniętych produktów- legalne?
- Problem z odczytem karty CF
- 74F vs 74HCT
- Newag ciąg dalszy
- Digikey, SN74CBT3253CD, FST3253, ktoś ma?
- Szukam: czujnik ruchu z możliwością zaączenia na stałe
- kabelek - kynar ?
- Podnieść masę o 0.6V
- Moduł BT BLE 5.0
- Pomiar amplitudy w zegarku mechanicznym
- ale zawziętość i cierpliwość
- Chiński elektrolizer tester wody
Najnowsze wątki
- 2025-01-06 Jeździ, skręca, hamuje
- 2025-01-06 Białystok => System Architect (Java background) <=
- 2025-01-06 Gliwice => Specjalista ds. public relations <=
- 2025-01-06 Białystok => Solution Architect (Java background) <=
- 2025-01-06 Zielona GĂłra => Konsultant WdroĹźeniowy Comarch XL/Optima (KsiÄgowoĹ
- 2025-01-06 Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- 2025-01-06 Ostrów Wielkopolski => Area Sales Manager OZE <=
- 2025-01-06 Do IO i innych elektrooszolomow, tu macie prawdziwe smrody
- 2025-01-06 Białystok => Full Stack .Net Engineer <=
- 2025-01-06 Kraków => Business Development Manager - Network and Network Security
- 2025-01-06 Katowice => Regionalny Kierownik Sprzedaży (OZE) <=
- 2025-01-06 Warszawa => Spedytor Międzynarodowy <=
- 2025-01-06 Lublin => Programista Delphi <=
- 2025-01-06 Gdańsk => Specjalista ds. Sprzedaży <=
- 2025-01-06 śnieg