PAR P O M I A RY • A U T O M AT Y K A • R O B O T Y K A
1/2020 ISSN 1427-9126 Indeks 339512
Cena 25,00 zł w tym 5% VAT
Technical Sciences Quarterly | Measurements Automation Robotics
W numerze:
3 5 21
Od Redakcji Mariusz Olszewski
Modern Industrial Robotics ! " !
29
35
41
# $ "
! " # $ %&
'(
) * + * * + + , -
# +
# % Informacje dla Autorów – 89 | 93 | ! 96 | """ # $ ! 97 | % 98 | &'( ) * # ) '+'+ 100
Rada Naukowa Rok 24 (2020) Nr 1(235) ISSN 1427-9126, Indeks 339512
Redaktor naczelny & '* + !
. "
.* / $ 8 !
. #
.* ! !: & '* ; < = > : ! & '* 8 ! ' .* / $ 8 ! > : ! ! !? ! ! ! & '* / > : & '* + ! > !
Korekta .* /
) / * @ /
Druk $ ! = A ! &* * * B $ CDD *
Wydawca
01 2 3 8 : ! : < / < # < FJ 01 ( X Y ! ' Z [ $ \ 01 4 5 G ! @ < G ' : ! # < ] 01 61 ' 0 B < X Y ! ' < [= \ 7 X Y ! ' : [B : !\ 01 ) 8 E F > # :! $ ! G ! : ! # : J #G # ; 01 $ 31 8 * B ! X ! " 8 Y [X \ 01 1 8 # ;!. $ ^_ ` : 01 21 4 ( * # ! < G ' # [# \ 01 2 (
" X Y ! [ \ 01 3 ( B : E 8 :& ; 6 1 ( X Y ! ' # [= \ 01 2 9 ;! $ ] # < $
E F > # :! $ ! G ! : ! H# : J #G # * : KDK DKLPQT ;
Kontakt
01 31 9 G ' + / [ \ 01 ) * * b"Y Y # ! < c B X Y ! [X \
L < # : ! : ! ! * : KDK DKLPQT ; * KK QUP DV PT W& *& *& *&
01 : ;! $ G .! ] ;!. $ @ ] ;
Pomiary Automatyka Robotyka & : : L < !: L !: ! VhhU * # VQ ! $ ` : ` * ! ! ! $! & ] ! ! H& ! & ! < & L ! < : : ! ! : *
01 : ) * + f X Y ! [; ! \
8 L < ! # : ! : ! ! ! H < @+g = < GB @j +^#@ BG+X [G+m KDVQ% Up Th\ H . H ! < . ! < & < & : ! < G B * # !$] ] ` ^ B `& :! &$ ! ! $! & H L < !: # : ! : ! ! * ; ] & ] [ ' ! ]\ & & *
)
> G ' && ! : < ! : =: g [B : !\
# /B ; & # : ! : !
! ! KD & * [ ! & : ! < ! < : $J ' : ` ! ! < pV & KDVh * & * KUhDK\* # !& ! !& ! L : ! < *
01 =
Y :! ' [ $ \
;! # : ! : ! ! > A H : < : ! hDU?#L XB?KDVh _ J / B ;!. & ! < $ _E & < ] ] `*
01 2 )+ + X Y ! [8 \
01 ; ) ;! $ G .! # " ! # < ^&
01 < , ;! $ / < ! < ! # < ]
01 8 0 4 * , G ! G ' : ! : ! ! # < ; $ 01 ; * ;
/G X Y ! / [ \ 01 41 6 b8! Y # ! < c B X Y ! [X \
# : ! : ! ! G B VPKULhVKT * KP B V?KDKD
3
Od Redakcji
5
Mariusz Olszewski Modern Industrial Robotics ; &J$ ! & :! $
21
! " !
G:& : ' @ @ Y : > + !% +# Y #
29
! " # $ %& = &< @ ' " q " +# Y #
35
'( # ' : G:& Y : ' #"+ > g/G + :: +# Y @ @ Y :
41
# $ " ) * + * * + + , - # + / + < : Lm ! < g!& ' > ' Y !
49
' $ ^.J / =$` . ! / 0 ( $ * ( % * Simulations X.! ! < & : J ! < !: ! & :
61
! = '' 1
+ " #2 G ' : ! + L+ / Y Y X & ! / Y ^
67
;$ ! $ G !
, 2 , + , 0 G ' ' < < / t / ' < ' ; ! ' G Y
75
! : " < ; # <
# * # * # * @ : ' < @t X ! ' # ' < +< ' : + / :
83
8 : ! & 8 / < $ $ ;$ ! # 2 2 + :& ' / # / < ^''L +
89
! 4 #
1
#G @ +G
93
;! Nagrody, # 0 2 8
96
8
97
8 ' v & x III 8 0 5# 8
98
;! v & x L
100 8 ' v & x 52. ( " 8 0 ( # STST
K
P
O
M
I
A
R
Y
â&#x20AC;¢
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;¢
R
O
B
O
T
Y
K
A
NR 1 / 20 20
^ @ 8+ G
Drodzy Czytelnicy, : & `E ! naukowo-technicznego Pomiary Automatyka Robotyka w nowej $ * ; J `& :! # ! ! : ] ` ]* _:! . ! : !& _E ` ! ] ! $J & & _E : ] * .! # > & :! ! < ! $J ` ! ! * ; & : :! ` & +^#X ; ' > A ! & / B ;!. & b; & & : ! <c J !: :! $ . _ : _E & ! ] $ * <` :! & ` : &J$ ! * ; & ] !: ! :! & ! ] & ! ! ] & ` & : &J & ! $ & : ! < ! < & ! ! <* / ` ! !: & :! ! ! ! $J : ! ] _ : .! : +# Y* ; : ! ! J ] : ! _ : & ! ! < & < > : ! ] z lotnictwem. ; .] !: : & :! . _ ' > /8/ KDKD ] . ! ` ' & _ ` J : : * ; : ;! ! > F > # :! $ G ! : ! # : J #G # ; > ] & : ! numeru.
Redaktor naczelny kwartalnika Pomiary Automatyka Robotyka & '* < * .* + !
3
4
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 5â&#x20AC;&#x201C;20, DOI: 10.14313/PAR_235/5
" % - % . / Mariusz Olszewski 0 6 7 ( $ 8 6 " $ - 6 ; % . / $ ; % < / =$ !)>?)? 0
Abstract: In the past decade, robots have become the basic tools for the automatization and robotization of industrial production, as they used to be in the 70s programmable controllers, in the 80s processor drive controllers, in the 90s of the twentieth century frequency controlled AC motors and in the first years of the 21st century digitization, expressed in the significant advancement and dissemination of computerization, telecommunications and internetization. This role is evidenced by further, beyond conventional robotics, extension of its application and the emergence of new hardware and software solutions oriented towards joint, by robots and human, undertaking of hitherto not rationalized production tasks. This essay is devoted to these transformations in contemporary robotics. 8 U / $ $ $ $ ( ($ % $ - % & !
1. Introduction The International Federation of Robotics (IFR) reported that globally, in 2018, the value of sales of robots increased to USD 16.5 billion, which corresponds to the use of 422,000 robots and an annual increase of 6%. In just 5 years, from 2013, the number of machines installed annually increased by as much as 135%. These values, despite the currently visible economic recession, are also to remain in 2019 and then increase until Fig. 1. Global deliveries of industrial robots (in thousands of machines, *) forecast) â&#x20AC;&#x201C; IFR, 2019 2022 even at double-digit rate. At the Rys. 1. SprzedaĹź robotĂłw przemysĹ&#x201A;owych w skali Ĺ&#x203A;wiata (w tysiÄ&#x2026;cach maszyn, *) prognoza) â&#x20AC;&#x201C; IFR, 2019 [33, 46] same time, it should be noted that in 2018 as much as 74% of new robot applications were made in the industries of only five countries: of production processes carried in enterprises and industries China, Japan, South Korea, the USA and Germany. In this imposing the same product area, or even in regions and coungroup, however, Chinaâ&#x20AC;&#x2122;s industry is by far the largest recipient tries, expressed in the number of installed machines per 10,000 of robots â&#x20AC;&#x201C; in 2018, 154,000 were installed in it new machines, employees. In this competition, from the five leading countries it is also the largest user in the world â&#x20AC;&#x201C; it has completed as in robotics investments, Singapore comes first with 831 machimuch as 36% of all global robotization installations in prones per 10,000 employees, ahead of South Korea, Germany and duction processes. All this confirms the aforementioned thesis Japan â&#x20AC;&#x201C; the United States came in 8th place, and China only about the global importance of robotics and its place as curin 20th place. Relationship of this index with demographics rently the main tool for rationalizing production processes on and population size obvious here [46]. Polish economy with 36 a global scale [33, 46, 54]. robots per 10,000 employees are unfortunately out of this comIn the last few year the density of robotization has been petition â&#x20AC;&#x201C; although companiesâ&#x20AC;&#x2122; problems related to the lack of adopted as a modern indicator of just technical rationalization hands to work in a similar demographic situation as Poland is today and thanks to intensive robotics investments came to the fore of economically leading countries on a regional scale and then, in terms of product quality, on a global scale [20]. 3 + U
Apart from the product and state of robotization division " # $ % & !'( and focusing on the modern state of industrial robotics, six subclasses of robot class manipulation machines can be distin3 guished [19]: % )& *! )!*+ $ % % ** !) )!)! â&#x2C6;&#x2019; conventional robots that perform standard programming, control and use tasks in countless industrial applications
! since the late 1960s. It is worth recalling here that in 1968,
5
Modern Industrial Robotics Fig. 2. Density of robot applications in industrial production worldwide (the number of machines per 10,000 employees) â&#x20AC;&#x201C; IFR â&#x20AC;&#x201C; World Robotics, 2019 Rys. 2. IntensywnoĹ&#x203A;Ä&#x2021; robotyzacji produkcji przemysĹ&#x201A;owej w skali Ĺ&#x203A;wiata (liczba maszyn na 10.000 pracownikĂłw) â&#x20AC;&#x201C; IFR â&#x20AC;&#x201C; World Robotics, 2019 [46]
the pioneering company for the development of robotics, Unimation managed to use as much as 48 robots for the first time across the world, but by assigning this date a breakthrough, symbolic beginning of the robotization era, â&#x2C6;&#x2019; cooperating robots, cobots, performing tasks referred to as MRK (Men-Robots-Collaboration), â&#x2C6;&#x2019; hybrid robots, for both conventional and collaborative robotics tasks, â&#x2C6;&#x2019; service robots, including cobots, â&#x2C6;&#x2019; multi-chain robots, with a twinarms or parallel kinematic structure, including cobots, â&#x2C6;&#x2019; mobile robots performing locomotion and manipulation tasks in the area of production and intralogistics of the Industry 4.0 character.
telecommunications techniques, machine tools and tools, metallurgy, plastics and rubber processing, also packaging, beverage and food, pharmaceutical, cosmetics and medical products, wood processing, chemical, paper and printing, construction, also construction of renewable energy equipment and machinery [1, 6, 12, 16, 22, 26]. A characteristic structural solution of the mechanisms of modern industrial robots is a series structure (also called a chain) of kinematic members, performing mutually rotational movements, divided into two groups: three regional members with the structure {CR, BR1, BR2}, ensuring that the effector reaches the set position in the manipulative space machine and one, two or three local members ensuring orientation of the machine effector. This provides a total of four, five or six degrees of mobility of the mechanism and an appropriate number of degrees of freedom of the effector, so in the case of a mechanism with six members virtually any free arrangement of the effector in the working space of the machine mechanism. Restrictions on the number of mechanismsâ&#x20AC;&#x2122; mobility are a consequence of the machineâ&#x20AC;&#x2122;s application areas proposed by the manufacturer and the desire to reduce its cost. In principle, only two kinematic solutions of the local group are used - in the case of three members they are structures: {AL1, BL, AL2} and {CL, BL, AL}, in the situation of limited
S1 : L Conventional industrial robots nowadays the most commonly used subclass of robots, which ensures robotization of machines, workstations and production processes in industries â&#x20AC;&#x201C; only reminding in turn about their application importance: automotive and working machines, mechatronic and electromechanical, including household appliances, information and
a)
b)
Fig. 3. A typical mechanism of a modern industrial robot with six levels of mobility and kinematic structure {CR, BR1, BR2, AL1, BL, AL2}: a) sketch of construction, b) ABB Automation GmbH robot mechanism on a stand demonstrating cooperation with the turntable mechanism, increasing the degree mobility of a set of two handling machines Rys. 3. Typowy mechanizm wspĂłĹ&#x201A;czesnego robota przemysĹ&#x201A;owego o szeĹ&#x203A;ciu stopniach ruchliwoĹ&#x203A;ci i strukturze kinematycznej {CR, BR1, BR2, AL1, BL, AL2}: a) szkic budowy; b) mechanizm robota firmy ABB Automatic GmbH na stanowisku demonstrujÄ&#x2026;cym wspĂłĹ&#x201A;pracÄ&#x2122; z mechanizmem obrotnicy powiÄ&#x2122;kszajÄ&#x2026;cym liczbÄ&#x2122; ruchliwoĹ&#x203A;ci zestawu dwĂłch maszyn manipulacyjnych [12, 35]
6
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Mariusz Olszewski Fig. 5. M-2000A / 2300L robot with a load capacity of 2300 kg and an unladen weight of 11,000 kg of Fanuc Deutschland GmbH, based on global linear motion guides (7. mobility level) of the Swiss company Güdel Group AG Rys. 5. Robot M-2000A/2300L o obciążalności 2300 kg i masie własnej 11 tys. kg firmy Fanuc Deutschland GmbH, osadzony na prowadnicach globalnego ruchu liniowego (7. stopień ruchliwości) szwajcarskiej firmy Güdel Group AG [42, 45]
mobility of the mechanism, the last element before the effector is the AL member rule, ensuring rotation of the effector on the structural axis of this member and most often on the structural axis also of the third, last before the local group, regional member, i.e. BR2. This makes it easier for the machine operator to program the effector’s trajectory, more precisely the current location of the tool’s central point, i.e. TCP (Tool Center Point) and the effector’s approach vector to the object of manipulation or machining. Since the end of the 1990s, the use of AC electric servo motors has been popularizing in the construction of industrial robot mechanisms – thanks to the introduction of new neodymium magnetic materials – hence the absolute advantage of rotational motion and given kinematic structures. Electric but
Fig. 4. Modern version of the SCARA robot mechanism, manufactured by Epson Europe B.V., used in the process of checking the implementation and selection of spring Rys, 4. Współczesna wersja mechanizmu robota SCARA, produkcji firmy Epson Europe B.V., zastosowanego w procesie kontroli wykonania i selekcji sprężyn [12, 41]
direct-current (DC) servo drives were used in robotics for the first time in 1974 by the Swedish company ASEA, earlier exclusively and still later, above 60 kg load capacity, electrohydraulic servo and motor servo drives were used. Their advantage was very high, especially hydraulic motors, energy efficiency in relation to the mass and volume of the engine, hence it was possible to attach to each component of the mechanism its own drive. Despite the indisputable utility and energy advantages of AC servo motors, their lower energy efficiency and corresponding higher mass and volume are forcing manufacturers to a different way of driving local members. They are placed on the last regional member (BR2) in front of the local group, and the transfer of movement through the length of this member and other local members, e.g. to the AL member, must be provided by shaft and toothed belt gears [26, 34]. We should also mention the drive of the first member (CR) of the described kinematic structure – in classic solutions it was a drive located in the foundation of the machine mechanism, and thus requiring the hollow of the ground or raising the mechanism above the needs of its actions, which sometimes caused problems with placing the mechanism e.g. on walls or posts of the production hall. Therefore, some modern manufacturers suggest reversing this design: the drive is mounted on this element, which facilitates applications, but by increasing the load on the element, it forces the machine to use more energy. Linear motion drives have practically ceased to be used in the construction of conventional industrial robot mechanisms – a certain exception is the use of various types of global motion drives along the lines of supported production machines. The only regional mechanism, but used only for the tasks of operating machine tools as well as injection and foundry machines, is the SCARA (Selective Compliance Assembly Robot Arm or Selective Compliance Articulated Robot Arm) robot mechanism known since 1981 [18], with three or less often four degrees of mobility and structures {CR1, CR2, ZL} or {CR1, CR2, ZR, AL} or also {ZR, CR1, CR2, AL} – here a single, local or regional linear movement along the Z axis is needed providing such just the effect of the effector serving these production machines. A clear trend of recent years is the extension of the load capacity and geometric extent of industrial robot mechanisms. While in classic solutions of the previous decades,
7
Modern Industrial Robotics
Fig. 6. Non-contact, but graphically supported and based on the operator’s hand movements, programming and control of the mechanism of a robot with a parallel, open structure, IBG Automation GmbH, equipped with a gripper Co-act, holding Schunk GmbH & Co. KG Rys. 6. Bezdotykowe, ale wspomagane graficznie i oparte na ruchach dłoni operatorki, programowanie i sterowanie mechanizmu robota o strukturze równoległej, otwartej, firmy IBG Automation GmbH, wyposażonego w chwytak linii Co-act holdingu Schunk GmbH & Co. KG [19, 50]
the permissible mass loads were – on average – in the area from 6 kg to 60 kg, now the upper load capacity is already 100 kg, and the largest load capacity, 2300 kg, has the Fanuc-M-2000A/2300L robot Deutschland GmbH weighing 11 tons, 6 degrees of mobility, repeatability of the TCP point position ±0.18 mm and a range of movement over 3.7 m. Even greater range, over 4.6 m, with a slightly lower load capacity, 1700 kg, has its neighbor in the Fanuc heavy machinery family: the M-2000A/1700L robot [42]. Contrary to popular belief, this tendency favors the needs of a number of industries relevant to the economy. Examples of application fields are the automotive industry, including service and repair of cars without the need for hydraulic ducts and lifts, metallurgy (foundries) and machinery (rail, ship, air transport, machining machinery, service and coupling of the stamping press and forge) without the need for time-consuming use of gantries, tire industry, mining industry (quarries), etc. At the other end of the scale of permissible loads are miniature robots with very low load capacity – it is assumed for this class of machines as a limitation of 1 kg capacity. An example of such a compact machine with a miniature mechanism is the MotoMINI robot from YASKAWA Europe GmbH [56] with a load capacity of 500 g, 6 degrees of mobility, repeatability of the TCP position ±0.03 mm and a range of motion not exceeding 350 mm. The robot is equipped with the Motoman YRC1000micro controller, developed especially for such small machines. Just a few kilograms weight and the compact dimensions of MotoMINI make it easy to set up the robot in different, changing places in the production line. Conventional industrial robots are programmed by teaching the desired machine effector motions by the machine operator – two modes, used yet in the 1960s, are used [16, 18]: − point programming (multi-point teach-in programming, MP), also called simple programming. An indispensable device for teaching a simple manipulation machine is a controller or a programming or teaching panel (teach panel), which serves the machine operator to induce the desired movement of individual members by manually controlled servo drives of the mechanism and as a result of this change of shape and location of the TCP point effector and then, in the memory of the robot controller, the machine coordinate values determining the mutual relations of the mechanism members measured by rotary position transducers, e.g. encoders, − follow-up programming (play-back programming or on-line programming), also called programming by predicting the
8
P
O
M
I
A
R
Y
•
A
U
T
O
M
planned motion trajectory. This concept, given in 1968, was derived from the observation of two facts: manual performance of certain technological activities by an experienced employee who can successfully meet the technological requirements of the robotized process and the possibility of using this experience to program the movement of the robot mechanism by manual effector/embedded tool on the mechanism, by the same employee, directly by hand or using a 3D joystick or control stick, allowing for remote forcing the spatial movement of a TCP point and also a corresponding change in the shape of the robot mechanism along with the current storage of current values of mutual positions (machine coordinates) of the mechanism members, − and the third mode – given at the end of the 1980s and gradually spreading since the turn of the century, during a period of rapid digitization and computerization, i.e. − computer-aided programming (off-line programming) implemented as: • graphic programming (called virtual reality-programming or VR-Programming), based on a computer simulation image of a production station with embedded robot mechanism and a variant application of one of the above-mentioned programming methods, • reverse or computer programming (computer aided design-programming or CAD-programming), using the well-known CAD documentation for the produced object of the robot tool trajectory path or its manipulation and computer path calculating the values of machine coordinates on this basis using the extent and geometric shape of the mechanism members and equations describing the dependence of machine coordinates on the location of the TCP point in the common base system of the real and virtually existing in the CAD space of the robot mechanism. It is a reversal of simple programming – in it manually setting machine coordinate values of the real or virtual machine mechanism in the manner described - calculation by the computer program of these values, and thus a reversal of simple programming, hence the good name in Polish. Manufacturers of modern industrial robots have adopted, as a dominant principle, to provide the user with the use of two programming modes: the basic is computer-aided programming, currently most often in reverse and complementary – as simple programming. It mainly serves the robot operator during the start-up phase of the robotic station or production machine, allowing for correction and supplementing of missing effector transitions in computer implementation [1, 27, 28, 40, 54]. A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Mariusz Olszewski
Fig. 7. Cooperation between the cobot from Fanuc Deutschland GmbH company and employees at the control and demonstration assembly stand Rys. 7. WspĂłĹ&#x201A;praca kobota firmy Fanuc Fanuc Deutschland GmbH i pracownicy na demonstracyjnym stanowisku kontrolnym i montaĹźowym [42]
V1 : L Cobots â&#x20AC;&#x201C; cooperative or collaborative robots (hence the word cluster), are constructed for direct cooperation with the human-operator and human-worker (hence the very good Polish name: â&#x20AC;&#x17E;roboty wspĂłĹ&#x201A;pracujÄ&#x2026;ceâ&#x20AC;? â&#x2020;&#x2019; cooperating robots), supporting robotic stations, devices, machines and production lines [23, 31]. The first machines of this subclass of robots were created in 1996 at the University of Northwestern in Illnois for Intelligent Assist Devices for moving heavy loads in spaces requiring human presence and directing their movement. The essence of the application of cobots is the removal from the production space of both devices protecting against accidents caused by human collisions with conventional handling machines, as well as the removal of closed areas, intended only for the use of these machines, completely separated from the presence of man. The increase in interest in cobots, seen in the last few years, is due to two reasons. The first is the conventional robotization of industry that accelerates equally dynamically, in these years, and the investorsâ&#x20AC;&#x2122; willingness to reduce costs resulting from unused space for production purposes and from the introduction of additional safety devices unnecessary in production. The second, even more important, proved to be proven in industrial practice necessary presence of employees in most robotized production processes and not only for the maintenance (operational and service) of the handling machines themselves, but primarily for technological reasons. Nowadays, there is already the hypothetical possibility of robotizing any, even low-series production process, but the cost of such investment and the time of its amortization are incomparably large, simply unacceptable nowadays, in relation to the implementation of the same process involving manual work. This may apply only to some of the executive positions, but also in this case the presence of cobots or conventional robots and with cobotic behavior throughout the entire production process is desirable, for reasons of work safety of people employed therein even at other conventionally robotic positions. The above-mentioned verbal interest in cobots does not yet translate into equally clear use of these machines in practice. In 2018, according to IFR, among 422,000 global machines installed, cobots are only 11,000 machines, i.e. in percentage terms 3.2% of all installed handling machines [46, 54]. Nevertheless, a clear increase in the number of these machines is expected in the near future, not only in industry, but in areas such as surgery and the service of people with this kind of care [24].
 The essence of the construction of cobots is to bring the structure, drives, sensors and control of the machine mechanism closer to the limited movement possibilities of the arm/ arms of the man and his specifically bionic sensoric and current capabilities, both kinematic and kinetic. Unlike conventional robots, usually made of extruded or metallurgical profiles, with measuring elements and drive assemblies mounted outside, the elements of the cobot mechanism are made of shell, plastic or metallic fittings hiding all necessary elements and load-bearing assemblies (if there is a need to stiffen the outer shells) and executive motion, from sensors, through motors, gears, connection axis construction to power, signal and network cables. In this new, anthropomorphic or bionic way, the desired geometry, structure and rigidity of the cobotâ&#x20AC;&#x2122;s kinematic chain are provided. At the same time, the smooth, round, often soft (through the outer material or plastic lining) chain of the machine mechanism meets most of the desirable human requirements for contact of his body and arms with a â&#x20AC;&#x153;foreignâ&#x20AC;? object. Hence the almost indistinguishable similarities in the appearance of cobots in the catalogs of manufacturing companies.
Fig. 8. Programming the trajectory of the cobot effector motion by teaching, consisting in forcing the movement (as the author does with your hand) of one of the mechanism members and through this movement changing the shape of the mechanism and the location of the TCP point Rys. 8. Programowanie trajektorii ruchu efektora kobota przez nauczanie, polegajÄ&#x2026;ce na wymuszeniu ruchu (jak czyni to autor dĹ&#x201A;oniÄ&#x2026;) jednego z czĹ&#x201A;onĂłw mechanizmu i przez ten ruch zmiany ksztaĹ&#x201A;tu mechanizmu i poĹ&#x201A;oĹźenia punktu TCP [19]
9
Modern Industrial Robotics In the area of motion and control parameters, cobots differ significantly from conventional robots – the main differences relate to the fulfillment of the mentioned requirements for safe, ergonomically consistent cooperation with humans – of course, and to the values of motion parameters, mechanism weight, its lifting capacity and positioning repeatability, also for machine prices. Averaging – this is expressed in the reception: − limited linear motion speed of mechanism and effector members, maximum values in non-collaborative mode do not exceed 1 m/s, in collaborative mode they are several times lower and depend on the speed of movement of the operator’s arm and hand, − equally limited speed of the effector rotation, maximum values in non-collaborative mode do not exceed 135–400°/s, in collaborative mode they depend – as above – only on the operator, − very small, compared to conventional machines, unit masses and load capacity (kinematic chain load capacity) machines, taking into account ergonomically acceptable loads for a person, which depend on the applications adopted and the type of work expended by a man – these are values or definitely less than 10 kg (e.g. 4 kg capacity), or with a slightly increased range of 10–20 kg (e.g. 14 kg), − allowing displacement by the operator of the entire, nonfunded mechanism in relation not only to a given position, but also to several positions of the production line – hence the mass of the mechanism must take into account the ergonomics of the load imposed on the movement of people moving or moving this mechanism – this mass usually does not exceed 30 kg, − the effective range of the effector’s movement to the ergonomically recommended spaces for human movement, sitting or standing at the stand, i.e. from 400 mm to 800 mm, − repeatability of positioning of movements programmed by the movement of a human hand - this value can be even within ±0.15 mm, however, it is usually higher, even by an order of magnitude, − programming the effector trajectory by teaching, consisting in manually guiding and setting selected members or the effector and thus changing the shape of the mechanism and the position of the TCP point with it – this is the most cobotic way of programming these machines, − prices of cobots, currently higher than conventional machines with similar performance parameters, from 40,000 USD up to 70,000 USD – weighs here extensive sensor and specifically “soft” mechanism construction. It is assumed that when considering using the offer of cobots on the Polish market, you need to prepare for an expenditure of 100,000 PLN. Requirements for safe human cooperation with the Men-Robots-Collaboration machine are specified in the ISO/TS 15066 standard (Robots and Robotic Devices – Collaborative Robots) – these are four permitted situations of mutual contact, i.e. cooperation or collaboration [12, 34, 40, 54]: − situation 1: some detention; the cobot (or hybrid robot) mechanism stops when a person enters (even slipping a hand) into the machine’s working space, − situation 2: handling with the hand; after activating the safe operation switch (otherwise the mechanism is stopped), it is possible to operate the mechanism with a human hand after determining the appropriate force (moment) measured with the sensor, affecting the mechanism, − situation 3: speed and distance control, the machine’s working space is divided into several zones, detected overrun (e.g. by a laser scanner), the first, outer zone reduces the speed of movement, exceeding subsequent zones – further reduction of its value, exceeding the proper working space of the machine – complete stop of the movement of the mechanism,
10
P
O
M
I
A
R
Y
•
A
U
T
O
M
Fig. 9. BionicCobot of Festo AG & KG holding with pneumotronic vane servo motors: three control buttons (programming, stopping, starting the program) and a virtual display of the behavior and programming of the cobot mechanism are visible Rys. 9. BionicCobot holdingu Festo AG & KG z pneumotronicznymi serwosilnikami łopatkowymi: widoczne trzy przyciski sterowania (programowania, zatrzymania, startu programu) oraz ekran wirtualnej prezentacji zachowań i programowania mechanizmu kobota [19, 43]
− situation 4: reduction of strength and energy expenditure; given in the Technical Specification (TS) description of this situation: the maximum values of forces (moments) or energy expended by the mechanism, after their initiation, are impassable values. A particularly interesting solution belonging to this group of robots is BionicCobot (Festo Vertrieb GmbH & Co. KG) [29, 30, 43]. A solution already known in 2017, but still awe-inspiring with a huge number of problems that have been successfully solved. The robot mechanism and its geometrical expanses perfectly meet the ergonomic requirements of the human figure, including its speed, acceleration and load parameters. It is possible to program its movements with all three of the aforementioned methods used in conventional, onand off-line robotics, it is especially convenient to program by teaching that meets the requirements of collaboration by operating the mechanism by hand (Method 2). This was achieved by the consistent application of a pneumotronic servo drive using vane rotary actuators. Thanks to this, the mechanism is “soft”, it is carried out smoothly by hand, position and trajectory setting is very easy, when parked, it does not consume energy, the forces implemented correspond to those known from drive pneumatics (supply pressure 6 bar). However, this is definitely the most difficult, referring to the solutions of robots with electric drives, type of positioning drive (in the margins A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Mariusz Olszewski of the pneumotronics problem: it was solved for the Festo company at the Institute of Automatic Control and Robotics of the Warsaw University of Technology in the turn of the 20th and 21st centuries [13]). The perfect complement to the mechanisms of cobots is proposed by the holding Schunk GmbH & Co. KG, Co-act effectors family. It consists of four gripper effectors, the most advanced Co-act JL1 has [50]: − capacitive proximity sensors for collision situations, − cown touch screen enabling communication of the effector with the employee-partner of the cobot, teaching the effector involves showing the effector the object being captured and switching the effector modes of operation, − a video camera placed between the fingers of the gripper to identify the object being captured, − two types of gripping: scissor and vise (parallel), − the ability to set the desired gripping force, − tactile sensors distinguishing between the object being captured and the human-partner’s hand, − optical notification of the “human” partner about the effector’s work status and identification of the object being captured. The basic ways of programming cobots are basically identical to the programming modes of conventional robots. As a good example, you can take the rules adopted by the undoubted leader in the market of cobotics, the Danish company Universal Robots A/S. Namely, the company has set the mechanisms ease of use and programming of their movements. The software uses the Linux system, simplifying programming and, above all, reducing the training time of operators and employees, which works great in the case of point motion path design programs, worse in the case of cooperation with external devices and systems, based on data exchange. Understanding these difficulties, the company established close cooperation with manufacturers of external devices, i.e. effectors, sensors and actuators, as well as cooperation with software producers. Therefore, the UR+ platform has been built into the company’s system, allowing the integration of its own UR system with third-party devices and software.
As the tab-windows of the UR cobot program were adopted [52]: − startup screen, split into two windows: the program allows you to select various functions and modes of programming and dialog programming commands the position of the TCP trajectory, − Move tab used to change the shape of the mechanism and change the resulting location of its TCP point – three modes are implemented here: • Move Tool – used to perform the basic task of the bookmark, i.e. setting the TCP in the machine workspace by moving selected members, • Move Joints – used to cause the movement of only one member of the mechanism, taking into account its limitations of geometric extent, • Freedrive – used for cobotic programming of the shape of the mechanism using the hand/hand of the operator or employee. This programming method is permitted for robots with a load capacity of 3 kg and 5 kg, for a robot with a load capacity of 10 kg (UR10), this movement should be allowed by pressing the motion enable button on the back of the programming panel (analogous to conventional robot programming panels), − Graphics tab – visualizing the programmed trajectory of the mechanism’s movement, − Structure tab – allowing you to modify the designed program and add other functionalities to it by copying, cutting, pasting and disabling currently unnecessary parts of the program, − Installation tab – implementing program settings, including input/output interfaces, security, and network protocols Profinet, − The tab I/O – preview of inputs and outputs of the robot controller. In addition to the fourth collaborative situation approved by the manufacturer and compliant with the ISO/TS 15066 standard, the application of cobots from Univeral Robots also meets the requirements of the TÜV (German,
Fig. 10. UR10 cobots company Universal Robots A/S (mechanism with six degrees of mobility, load capacity of 10 kg, 30 kg curb weight, range 1300 mm and repeatability of TCP positions ±0.1 mm) at a demonstration stand for box-assembly containing ordered products in shape cavities Rys. 10. Koboty UR10 firmy Universal Robots A/S (mechanizm o sześciu stopniach ruchliwości, udźwigu 10 kg, masie własnej 30 kg, zasięgu 1300 mm i powtarzalności pozycji TCP ±0,1 mm) na demonstracyjnym stanowisku kompletacji pudełek-skrzynek mieszczących uporządkowane produkty w zagłębieniach kształtowych [52]
11
Modern Industrial Robotics
Technischer Ă&#x153;berwachungsverein) certificate confirming the compliance of generally understood safe work of man and machine with the EN ISO 13849-1: 2008 standard, later replaced by the EN ISO 13849-1: 2016-02 standard and its Polish equivalent (Machine Safety â&#x20AC;&#x201C; Elements of the Safety Related Control System â&#x20AC;&#x201C; Part 1: General Design Principles) [54].
according to the 4th situation of MRK. The robot was equipped with sensory supervision of forces and moments in all six degrees of mobility of the mechanism. It is also possible to use a cobotic gripper effector or a specialized tool effector with MRK properties. MRK hybrid modification requirements may also apply to cobots - e.g. to use, in addition to a company-equipped cobot with its specific sensory, processor and actuator accessories, in addition to a safety scanner that allows the cobot to work at speeds greater than collaborative in a situation where itâ&#x20AC;&#x2122;s the scanned environment does not contain any unexpected object during programming. In practice, this should be understood as the division of the work space of the cobot, resulting from its kinematic structure and geometrical extent of its members, into two zones: â&#x2C6;&#x2019; an operating zone in which a cobot can behave like a conventional robot and â&#x2C6;&#x2019; to the collaboration zone where the employee may be and the cobot must meet the mentioned specific requirements of the adopted, for example 4th collaboration situation. Therefore, when preparing a cobotic or hybrid application, the following threats should be identified, in accordance with the requirements of ISO 10218-2: 2011 (Robots and Robotic Devices â&#x20AC;&#x201C; Safety Requirements for Industrial Robots â&#x20AC;&#x201C; Part 2: Robot Systems and Integration) [40, 54]: â&#x2C6;&#x2019; threats related to the robotic mechanism: â&#x20AC;˘ functional parameters of the mechanism: kinematic structure, geometrical mass and extensions, velocities and accelerations of motion of members and effector, generated by force drives and moments, affecting the emergence of human hazards, â&#x20AC;˘ the possibility of quasi-static contact with the human body, â&#x20AC;˘ mutual arrangement of workplaces: man and robot, â&#x2C6;&#x2019; threats related to the equipment of the robot mechanism: â&#x20AC;˘ effectors, non-ergonomic construction solutions of grippers and tools, e.g. the possibility of dropping the transferred element, sharp edges of this element, etc., â&#x20AC;˘ the possibility of pressing the human body during the program, â&#x20AC;˘ construction and location of programming and control panels, e.g. the possibility of accidentally starting or stopping the robot mechanism, â&#x20AC;˘ construction and placement of other machines in the immediate vicinity of the robotic human and robot workplace, â&#x2C6;&#x2019; threats resulting from a given robot application: â&#x20AC;˘ the surroundings of the human and robot workplace, e.g. temperature, noise, dustiness, â&#x20AC;˘ availability of special human protective equipment, â&#x20AC;˘ non-ergonomically designed trajectory of the robot effector motion. In addition, it is appropriate to determine the risk of hazards caused by the presence of human-operator or human-employee in the operational and collaborative zone of the robot: â&#x2C6;&#x2019; the frequency and duration of human stay in the collaborative zone, â&#x2C6;&#x2019; frequency and duration of direct contact between man and robot, â&#x2C6;&#x2019; the nature of the transitions between the operational and collaboration zone, â&#x2C6;&#x2019; the nature of resetting the robotâ&#x20AC;&#x2122;s work system: automatic or manual, â&#x2C6;&#x2019; the necessary number of employees in the collaboration zone: one or more employees and in what capacity, â&#x2C6;&#x2019; non-collaborative tasks forcing people to enter this zone.
X1 ' L : L Already from the requirements set out in the previous point for the cobots it follows that from the point of view of the industrial robotics user there should be such a variety of robots or cobots that meets the double application requirements associated with the already mentioned problem of their presence throughout the production line. Namely, the relatively high cost of cobots, reduced movement speeds, reduced parameters of the working space and reduced load capacity, tend to make robotization applicants use non-robotized robots with conventional properties, higher movement speeds and lower prices. This is how a variety of manipulative machines called hybrid robots was created, combining (almost) conventional prices and performance with the requirements of MRK. These properties are limited, however, usually only to one selected collaborative situation according to ISO/TS 15066. A good example of such a hybrid robot is Motoman HC10 from YASKAWA Europe GmbH with a motion distance of 1.2 m and a load capacity of 10 kg (HC is of course Human Collaborative) [56]. This robot is designed for both standard, conventional and collaborative applications, which provides it with a slightly modified implementation of cobotic security
Fig. 11. Motoman HC10 hybrid robot from YASKAWA Europe GmbH with an application-adapted, specialized effector-tool, construction from StĂśger Automation GmbH Rys. 11. Robot hybrydowy Motoman HC10 firmy YASKAWA Europe GmbH z dostosowanym do aplikacji, specjalizowanym efektorem-narzÄ&#x2122;dziem konstrukcji firmy StĂśger Automation GmbH [56]
12
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Mariusz Olszewski
Y1 ) : L Another large group of modern robots characterized not so much by servicing and servicing machines, stations, lines, systems and industrial processes, but above all by supporting and servicing us, people in specific life situations, from servicing the apartment and performing everyday activities, to servicing patients hospital departments, including surgical, rehabilitation and laboratory rooms, to support chronically ill, crippled or infirm people as well as medical and nursing staff who look after these people in nursing homes, retirement homes, and retirement homes, especially in hospices. Service robots also in the mentioned industrial applications have quite specific tasks of supporting employees performing these tasks manually, without any machine support. A good example are reports from the Korean holding company Doosan Robotics Inc. on the application of service robots at car preparation stations provided by the manufacturer to the developer for further shipment or direct pickup by the customer [39]. In this case, of course, they must be hybrid service robots with
clearly assigned cobotic behaviors. These service works are programmed cobotically by the employee servicing the service station and in relation to a series of several or a dozen serviced car bodies moved and set manually by the employee servicing the employee in specific places around the car body, started â&#x20AC;&#x201C; by performing already previously programmed tasks such as setting the customerâ&#x20AC;&#x2122;s choice wheels and tires, recognizing the location of their mounting bolts and checking their tightening torque, checking the correct mounting of the side mirrors and their operation, installing the correct license plates, cleaning and polishing the paint, etc. In the second, even more interesting to us, people, service area, a very interesting solution in the group of service robots is the Lio mobile cobot proposed by the Swiss company F&P Robotics AG to serve us as a partner, as the other person, in all of the above-mentioned activities and tasks, in which we require direct contact with the other person: a doctor, a nurse, a physiotherapist, and thus serve as a personal service robot or more properly personal, serviceable [44]. Lio is a mobile machine with the P-Rob cobot mechanism moun-
Fig. 12. Service works of the Korean Doosan Robotics Inc. holding: robotized car preparation stand for pickup by the customer: wheel replacement, number setting, paint cleaning and polishing, windows, headlights, mirrors and other body parts Rys. 12. Roboty serwisowe koreaĹ&#x201E;skiej holdingu Doosan Robotics Inc.: zrobotyzowane stanowisko przygotowania samochodu do odbioru przez klienta: wymiana kĂłĹ&#x201A;, zaĹ&#x201A;oĹźenie numerĂłw, czyszczenie i polerowanie lakieru, szyb, reflektorĂłw, lusterek i innych elementĂłw karoserii [19, 39]
Fig. 13. Service works on the cobotic properties of the Swiss company F&P Robotics AG: a) Lio mobile personal cobot, b) Industrial service robots P-Rob, cobot in the foreground with the gripper of the Schunk GmbH & Co. KG Rys. 13. Roboty serwisowe o wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ciach kobotycznych szwajcarskiej firmy F&P Robotics AG: a) mobilny kobot osobisty Lio, b) przemysĹ&#x201A;owe roboty serwisowe P-Rob, kobot na pierwszym planie z chwytakiem holdingu Schunk GmbH & Co. KG [12, 44]
a)
b)
13
Modern Industrial Robotics
Fig. 14. The cobotic service robot LBR-iiwa of the KUKA AG holding used in the architectural design DIANA (Dynamic Interactive Robotic Assistant for Novel Applications) for the assembly of irregularly positioned wooden architectural elements in the workspace Rys. 14. Kobotyczny robot serwisowy LBR-iiwa holdingu KUKA AG wykorzystany w projekcie architektonicznym DIANA (Dynamic Interactive Robotic Assistant for Novel Applications) do montaĹźu nieregularnie ustawionych w przestrzeni roboczej drewnianych elementĂłw architektronicznych [21, 49]
Z1 ( [ * : L
ted on a mobile platform. This integrated chassis and handling mechanism, protected by a soft lining, is designed to encourage direct contact with it. It can be programmed by teaching various, even complex activities necessary to perform in our, how strongly changing environment. A two-arm version with two parallel open chains of P-Rob mechanisms, already with clear humanoid features, is also being prepared at F&P Robotics. Another project of the F&P Robotics company is cobot Lio as a partner of nursing staff during blood sampling, performing injections as Robot Assistant for Nurses [34, 44]. And one more example, at the opposite end of the area of service applications discussed so far. The DIANA project (Dynamic Interactive Robotic Assistant for Novel Applications) assumed the use of a cobotic service robot for assembling irregularly positioned wooden elements. The assumed geometry and this building material required the use of assembly technique enabling dynamic detection and response of the tool to numerous deviations from the assumed dimension [21]. In the process of project implementation, a KUKA production robot â&#x20AC;&#x201C; LBR-iiwa, with seven levels of mobility of the kinematic mechanism was used, which is distinguished by the fact that for each axis of movement during its operation, the torque generated by it is measured. Torque sensors were introduced in order to enable safe cooperation of the robot with a human and giving way to the robot mechanism in front of the encountered obstacle after reaching the set, safe moment and programming the mechanism movement by teaching, using the manual method of the robot effector by the employee. In the DIANA project, these sensors were also used during assembly to detect inaccuracies in the execution of the elements and the process of their joining so as to compensate for the large inaccuracies of architectural designs on construction sites [2, 3, 7]. The DIANA project has become an important step to implement the assumptions of Industrial Transformation 4.0 into the assembly processes of architectronical elements on construction sites [3].
14
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
Apart from the attempts at industrial humanoid solutions, multi-chain robotics in modern versions uses mechanisms with parallel kinematic structures that can be divided into two groups of solutions [9, 10, 32]: â&#x2C6;&#x2019; robots with mechanisms with two parallel, open kinematic chains, with clear anthropomorphic features, which is why they are most often called two-armed or twinarms robots, â&#x2C6;&#x2019; robots with mechanisms of two (dipods), three (tripods), generally several, e.g. six (hexapods), closed so-called Stewart platform, kinematic chains, often referred to as parallel robots. Two-armed robots are still treated as innovative, effective, but also effective due to the possibility of introducing and checking the advanced control of the arm and/or hand movement of the operator or employee, using augmented reality (AR) and intelligent sensory gloves or smart work gloves. These solutions are already present in the commercial programs of several manufacturing companies, including those with selected cobotic properties (MRK). The application of this subclass of handling machines is primarily assembly, usually involving both hands of the employee, replaced by two parallel kinematic chains of identical construction. For this reason, the geometrical parameters of these robots are, as described in the cobots, ergonomically adapted to the figure, mutual position and extent of human arms, as well as their kinematic parameters: speed and acceleration and load parameters. In the construction of two-armed robots and cobots, manufacturers use their machines with one serial kinematic chain, duplicating this chain in two copies connected by a kind of platform, also known for the construction of manipulation machines with parallel structures such as dipods and tripods, but with an inverted mounting position. This can vary in performance even within products of one manufacturer, as well as proprietary designs but combined with third-party effectors. Especially scientific and research centers and institutions dealing with model performances A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Mariusz Olszewski related to new effector solutions usually use machines from other companies, attaching their own studies to them. A great example of such a solution, well made and already having the first applications behind it, is the Yumi cobot from ABB Automation GmbH [35]. The machine weighs 38 kg and can handle an object weighing up to 500 g loading each of the arms. It was used in a company producing furniture hinges. It consists of two elements, which must be properly superimposed and then put together, without changing their mutual position, under two automatic screwdrivers. The assembly process ends with quality control. Here, the two-armed Yumi cobot with a video camera used in the gripper, analogously used as in the case of the already described Co-act JL1 gripper from Schunk [50], identifying the mutual position of the connected elements and checking the correctness of their connection by comparing the made hinge with the stored reference image of a well-made element. The advantage of the Yumi cobot is the possibility of using this two-arm robotization in other positions (low curb weight) and intuitive programming, through teaching, which does not require long training of the employees of the department of the applying company. The construction of closed kinematic chains was initiated in 1947 by E.V. Gough, initially building a research stand and carrying it out professionally in 1955. It was an extremely interesting period of time when technical solutions emerged,
Fig. 16. The use of augmented reality and at the same time anthropomorphic, sensory glove (on the right hand) for intelligent programming of a two-armed cobot with a ten-finger gripper, Deutsches Zentrum für Luft- und Raumfahrt e.V. (DLR) Rys. 16. Zastosowanie rozszerzonej rzeczywistości i równocześnie antropomorficznej, sensorycznej rękawicy (na prawej dłoni) do inteligentnego programowania dwuramiennego kobota z dziesięciopalcowym chwytakiem, Deutsches Zentrum für Luft- und Raumfahrt e.V. (DLR) [19, 38]
a)
b)
Fig. 15. Two-armed robots of the ABB Automation GmbH company with various structures and execution of platforms connecting kinematic chains of “arms”: a) with the cobotic effector of the Schunk GmbH & Co. KG, b) with ABB effector–gripper Rys. 15. Roboty dwuramienne firmy ABB Automation GmbH o różnej strukturze i wykonaniu platform łączących łańcuchy kinematyczne „ramion”: a) z efektorem kobotycznym holdingu Schunk GmbH & Co. KG, b) z efektorem–chwytakiem ABB [12, 35, 50]
which were crucial for the future development of the machine industry. In 1948, Bill Moog builds the first electrohydraulic servo valve, thanks to which the production of numerically controlled (NC) machine tools could be started from 1954, and in the same year the first, patented, programmable industrial robot designed by G. Devol is created, and the aforementioned year appears Gough hexapod design with electrohydraulic servo drive [11, 26. 27]. However, interest in the idea of Gough’s parallel mechanism is suppressed in the 1960s by the first successes of industrial applications of serial robot mechanisms, already performed by J. Engelberger. Interest in Gough’s idea sustains D. Stewart’s analogous study, also hexapod, and also with hydraulic drive, described in 1966. And again it shifts to the margin of robotics by introducing electric drive and processor control in industrial robots in 1974 by the Swedish group ASEA [18, 20]. It wasn’t until the late 1980s and the 1990s that the twentieth century was ending that there was interest in parallel mechanisms. This time in a dipod or more often tripod design, with three kinematic chains articulated (class III connections) with a connector, called Stewart’s platform in robotics slang. An effector was mounted in series to this platform and two or more kinematic members were mounted on it, increasing the total mobility to four or five degrees of mobility. Initially, pneumatic, piston rod and rodless cylinders servo-controlled were used as drives, since the first decade of the 21st century electric servo drives have been gradually becoming more common. At this point it is worth mentioning and this applies to all of the described robotics, about technological changes, also affecting the area of machine and robot propulsion and causing in the last several years evolutionary, but now a very clear departure from propulsion solutions related to pneumatics [13]. The 50s, 60s and 70s of the last century, when pneumatics became the basic, practically the only means of automating production processes, were the period of uniquely intensive development of control and drive pneumatics. However, as early as the 1980s and 1990s, pneumatic information acquisition and processing devices, both continuous and discrete, were replaced by electronic and processor devices. Pneumatic applications have remained and remain the actuator drives of
15
Modern Industrial Robotics
Fig. 17. Multi-chain closed kinematic works with electropneumatic actuator drive: a) with a double-chain mechanism (dipod), piston rod drive, Bosch Rexroth AG, b) with a three-chain mechanism (tripod), rodless drive, Festo Vertrieb GmbH und Co. KG Rys. 17. Roboty wielołańcuchowe o zamkniętej strukturze kinematycznej z elektropneumatycznym napędem siłownikowym: a) z mechanizmem dwułańcuchowym (dipod), napęd tłoczyskowy, Bosch Rexroth AG, b) z mechanizmem trójłańcuchowym (tripod), napęd beztłoczyskowy, Festo Vertrieb GmbH und Co. KG [37, 43] a)
b)
automated and robotic production processes, but the relative area of their applications is clearly accelerating reduction in favor of electric drive, even after the design of throttled controlled pneumatic actuators has been transformed into servopneumatic and pneumotronic actuators [13–15]. Three factors influenced the development of new, competitive to drive pneumatics, solutions and applications of electric drives and servo drives in industrial robotics: − the aforementioned introduction in the 1990s of new magnetic materials, primarily neodymium, increasing the energy efficiency of electric motors with their significantly reduced mass and volume, − indisputably easier direct supply of electricity to the actuators of machines and robots than it is the case with the supply of pressure energy and compressed flow of air, by means of this electricity, − the need to save energy, both due to the rising costs of obtaining and using it, as well as the rapidly spreading awareness of the negative environmental impact of obtaining energy from conventional sources and materials. In the case of pneumatics, it is particularly unfavorable to generate energy supplying the actuator controls twice, drastically deteriorating the energy efficiency of these devices. Examples showing definitely better effects and technical and energetic solutions of electrical compared to pneumatic ones have been given for several years now, initially with some dis-
a)
16
belief, now with full conviction that the choice of electrical solutions is right. The investment cost of the electric actuator with all necessary components, in this example, was still in 2018 about 260% of the investment cost of the pneumatic actuator, including all necessary components for its use. However, this cost was depreciated after 5 months of using the actuator. However, at the moment (2019), the actuator manufacturers ensure that the investment costs of both solutions are equal! [19]. The fact of carbon dioxide emissions is also not without significance. In the case of approx. 24,000 kWh of energy needed additionally to maintain the operation of the exemplary pneumatic cylinder in relation to the electric cylinder, it is also an additional emission of approx. 12,000 kg of CO2 after adoption, e.g. for Germany, the equivalent of carbon dioxide emissions at the level of approx. 500 g CO2/kWh called the “carbon footprint” [19]. Returning to multi-chain robots – the advantages of the most commonly developed electric drive tripods include: − a much more “rigid” mechanism construction compared to series mechanisms, which undoubtedly has a beneficial effect on improving the quality of the effector positioning (repeatability of the effector position in the range of hundredths of a millimeter), which in turn predisposes multi-chain robots for the production of devices built on a micro scale and nanotechnology, − to the disadvantages:
Fig. 18. Multi-chain robots with a closed kinematic structure and various drives: a) with a three-chain mechanism (tripod), with an electric motor drive, with four levels of mobility, b) with a six-chain mechanism (hexapod), with six levels of mobility, with an electrohydraulic actuator, a Japanese company AKA Rys. 18. Roboty wielołańcuchowe o zamkniętej strukturze kinematycznej i różnych napędach: a) z mechanizmem trójłańcuchowym (tripod), z elektrycznym napędem silnikowym, o czterech stopniach ruchliwości, b) z mechanizmem sześciołańcuchowym (heksapod), o sześciu stopniach ruchliwości, z elektrohydraulicznym napędem siłownikowym, japońska firmy AKA [19]
b)
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Mariusz Olszewski
Fig. 19. Robotino, a mobile robot from Festo AG & KG for research and training in Industry 4.0: a) a traveling platform with a column and one of three platforms supporting production modules by its own effectors, b) mechanism with 3 levels of local mobility of the robot effector Rys. 19. Robotino, robot mobilny firmy Festo AG & KG dla prac badawczych i szkoleniowych w obszarze PrzemysĹ&#x201A;u 4.0: a) platforma jezdna wraz z kolumnÄ&#x2026; i jednÄ&#x2026; z trzech platform obsĹ&#x201A;ugujÄ&#x2026;cych moduĹ&#x201A;y produkcyjne przez wĹ&#x201A;asne efektory, b) mechanizm o trzech stopniach ruchliwoĹ&#x203A;ci lokalnej efektora robota [19, 43] a)
â&#x2C6;&#x2019; definitely smaller workspace, which in production applications carried out on a micro and nanotechnology scale is not of great importance, â&#x2C6;&#x2019; higher cost and price of these machines compared to conventional design robots, â&#x2C6;&#x2019; collaborative versions are more difficult than in the case of cobots with serial mechanisms â&#x20AC;&#x201C; hence, at least in the solutions encountered, multi-chain mechanisms are protected in closed application processes.
\1 ( L : L The first machines belonging to the subclass of industrial, autonomous mobile robots (mobile robots, Automated Guided Vehicles â&#x20AC;&#x201C; AGVs or Autonomous Intelligent Vehicles â&#x20AC;&#x201C; AIVs) appeared at the beginning of the last decade. Taking into account only machines with a currently noticeable practical significance, they can be divided into two clearly different groups of solutions: â&#x2C6;&#x2019; mobile robots supporting modules and production departments of Industry 4.0. These machines are still used in the research, development and implementation phases of the manufacturing process transformations, ultimately in line with the assumptions of Industrial Transformation 4.0 [17, 25], â&#x2C6;&#x2019; autonomous mobile robots designed for intralogistic-house transport of products, materials and tools, i.e. automation and robotization of the production area, also intralogistics, logistics, palletizing and storage [4, 5]. An example of a mobile robot solution of the first group of machines intended for the areas of Industry 4.0 is Robotino, a locomotion and handling machine, available in two versions: Basic Edition and Premium Edition. They differ in the intensity of computer processing, the volume of internal memory and the details of the platform and column, e.g. in the Premium version, you can use three column platforms that support different production modules [19, 43]. Robotino is equipped with three servo electrically driven modules, providing the possibility of moving the platform in three directions of motion and omnidirectional regional rotation at the stop, and identically driven three elements of local motion embedded on them effector â&#x20AC;&#x201C; thus a total of seven degrees of mobility of the final effector. The position of the mechanism is controlled by nine infrared sensors, with the additional option of retrofitting the machine with two optical and one inductive motion tracking sensor. The power supply is
b)
provided by 12 V batteries with a controlled level of charge and a power station. Computer control with COM Express specification, using an Intel Core i5, 2.4 GHz or Intel Atom, 1.8 GHz processor. The operation of the operating and utility systems is protected by a 32 GB SSD drive or 64 GB optional. The work of four DC motors of the mobile platform movement is directly controlled by a 32 bit processor, generating PWM signals using the FPGA interface and receiving signals from encoders coupled with four motors driving the mobile platform. The movement of the robot column and its local parts are programmed by computer-assisted learning, implemented as graphic programming, based on a computer simulation image of the production department with a robot embedded in it. Teaching itself can be implemented by one of the previously selected methods used in modern conventional robotics. Computer â&#x20AC;&#x201C; machine communication is provided via wireless LAN. For system startup and simulation, the interface (API) supports the use of various systems and languages, including Windows XP, Vista, Windows 7/8/10, C/C ++, JAVA Net, LabVIEW and MATLAB/Simulink, Robot Operating System (ROS SmartSoft) and Microsoft Robotics Developer Studio. Robotino performance parameters [43]: â&#x2C6;&#x2019; traffic maps in the area of 20â&#x20AC;&#x201C;5600 mm, traffic speed up to 10 km/h, â&#x2C6;&#x2019; load capacity 30 kg, curb weight 20 kg, â&#x2C6;&#x2019; platform diameter 450 mm, â&#x2C6;&#x2019; tactile contact zone of the platform sensory supported, â&#x2C6;&#x2019; HD 1080 px video camera with USB interface. Moving to internal transport machines, their first solutions appeared almost parallel to the first industrial robots, i.e. in the 1950sâ&#x20AC;&#x201C;60s. of the 20th century. These machines have gone, along with the development of industrial robotics, a long way to introduce new, innovative solutions, associated primarily with the implementation of autonomous traffic and in the area of maximum speeds of several meters per second and safe behavior for workers encountered on the roads of this movement. The presence of these employees in typical applications of internal transport machines cannot be simply excluded in industrial practice. A good, proven example of such a solution is the VersaBot 500/700 mobile robot, a young company created in 2013, the Polish company VersaBox [5, 55]. The robot can navigate the colored line, use the laser mapping system of the traffic environment, implementing in it autonomous, intelligent, safe behaviors, checking in the company of other dozen mobile robots and special versions, designed for so-called clean production
17
Modern Industrial Robotics
a)
b)
Fig. 20. Autonomous mobile robots (AGV) for intralogistic transport: a) VersaBot 500/700 by VersaBox Sp. z o.o., b) LD from Omron Rys. 20. Autonomiczne roboty mobilne (AGV) transportu wewnętrznego: a) VersaBot 500/700 firmy VersaBox Sp. z o.o., b) LD firmy Omron [47, 55]
rooms, including in the food industry. It can work as a towing vehicle, is equipped with a pallet jack, ensures assembly of roller feeders and adapters for the mounting of manipulative mechanisms. The company cooperates with system integrators, also supports leasing solutions. In recent years, interesting solutions have emerged for automated and robotic mobile stations carrying out selected tasks related to further technical rationalization of logistics and intralogistics, especially palletization. This applies not only to manufacturing companies, but above all to logistics companies that provide co-packing services, i.e. packaging and repackaging of products or their sets within contract logistics. It encourages the development and application of these solutions of modern universality, including the Internet of these processes and their special time-consuming nature, especially in confrontation with the lack of employees. An interesting implementation of this concept is the diploma, master’s project, carried out by Piotr Kwiatkowski in 2019 [8], conducted at the Institute of Automatic Control and Robotics of the Warsaw University of Technology, in cooperation with
the international company Kuehne + Nagel [48], offering dedicated solutions in the field of international and domestic air and sea forwarding, road, rail, as well as contract and integrated logistics as well as integrator of station execution, Biuro Inżynierskie Sp. z o.o. The project was implemented within 4 months, the cost – about 250 thousand PLN. The work was honored in the ‘Young Innovative’ Competition, PIAP, in 2019 and the Siemens and Rector Award of the Warsaw University of Technology in 2019. Important for the successful implementation of the project was the use of a Universal Robots A/S [52] cobot station in the construction of a robotic program for palletizing products and for coordinating the station’s overriding work – the Siemens Simatic S-7 1200 controller [51]. The most important station parameters [8]: − number of pallet places – 2, − supported pallets: 800 mm × 1200 mm – EUR1, − maximum palletizing height – 2000 mm, − maximum number of cycles per minute – 8, − number of scanners for safe cobot operation – 3.
a)
b)
Fig. 21. A robotized, mobile palletizing station with a cooperating robot: a) sketch of the project solution, b) made palletizing station Rys. 21. Zrobotyzowana, mobilna stacja paletyzująca z robotem współpracującym: a) szkic rozwiązania projektu, b) wykonana stacja paletyzująca [8, 48]
18
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Mariusz Olszewski
]1 And ending the essay on modern intelligent robotics: the tasks of cobotics, hybrid, service, autonomous mobile and multi-chain robotics, require extremely wide, multidisciplinary, well-established knowledge and practical experience in the field of work ergonomics, basics of mechatronics, sensorics, processors and actuatorics, including in particular the basics of the construction and properties of the listed robotic solutions, in their modern generation and shape â&#x20AC;&#x201C; should not be surprising to the statements of practitioners â&#x20AC;&#x201C; professionals (ASTOR, May 2019 [33]) that: â&#x2C6;&#x2019; I do not think, in order to soon cobots can replace the classic robots... â&#x20AC;&#x201C; Zbigniew Proch (Company RENEX), and also â&#x2C6;&#x2019; In Polish industry, the introduction of traditional robots is much more profitable than cobots... â&#x20AC;&#x201C; Stefan Ĺťyczkowski (Chairman of the Board of Directors of ASTOR). In order to change this state of affairs in Poland, it is necessary here to formulate new content and forms of vocational education and new specializations, with a simultaneous emphasis on increasing the importance and number of mechatronics engineers and mechatronics engineering professions: production, automation, robotics, actuatorics, sensorics, computer science, industrial informatics industrial engineer, also industry 4.0 engineer and cyberinformatics, also engineers for Industry 4.0 [6, 25, 28]. This change is required by the need to shape and support the career paths of technical and engineering staff whose knowledge and experience will be absolutely crucial in Industry 4.0 for the market success of a given enterprise. Post-graduate studies are also indispensable here, in June 2019 the Rector of Warsaw University of Technology has just established new Post-graduate Studies in Industrial Transformation 4.0 at the Faculty of Mechatronics of Warsaw University of Technology â&#x20AC;&#x201C; it is planned to launch them already in this academic year (2019/2020) or in next year in October 2020/2021 [19].
9. 10.
11.
12. 13. 14. 15. 16.
17. 18.
19.
20.
: 0 21. 1. Bord of Management, Messe MĂźnchen GmbH: automatica, Optimize your Production. Face the Future of Manufacturing. Final Edition (2018), [www.automatica-munich.com]. 2. Bock Th., Construction Robotics Enabling Innovative Disruption and Social Supportability. [in:] Proceedings of the International Symposium on Automation and Robotics in Construction (ISARC), 2015. Vilnius Gediminas Technical University, Department of Construction Economics & Property, Vilnius, 1â&#x20AC;&#x201C;11. 3. BrĂźninghaus J., Stum S., Nelles J., Mertens A., Schlick Ch., Brell-Cockan S., Arbeitsorganisatorische und ergonomische Anforderungen an die Mensch-Roboter-Interaktion auf der Baustelle der Zukunft. Kongress der Gesellschaft fĂźr Arbeitswissenschaft e.v., RWTH Aachen, 2016. 4. ChoĹ&#x201A;odowicz E., Figurowski D., Mobile Robot Path Planning with Obstacle Avoidance Using Particle Swarm Optimization, â&#x20AC;&#x153;Pomiary Automatyka Robotykaâ&#x20AC;?, Vol. 21, No. 3, 2017, 59â&#x20AC;&#x201C;67, DOI: 10.14313/PAR_225/59. 5. Chojecki R., Olszewski M., A Mobile Robot for Laboratory Purposes and its Applications. â&#x20AC;&#x153;Pomiary Automatyka Kontrolaâ&#x20AC;?, Vol. 55, No. 3, 2009, 190â&#x20AC;&#x201C;193. 6. KaliczyĹ&#x201E;ska M., Kluczowe technologie PrzemysĹ&#x201A;u 4.0 (Key Technologies of Industry 4.0). â&#x20AC;&#x17E;Automatykaâ&#x20AC;?, Vol. 4, No. 1â&#x20AC;&#x201C;2, 2018, 95â&#x20AC;&#x201C;96. 7. Kohler M., Gramazio F., Willmann J., The Robotic Touch: How Robots Change Architecture, ETH Zurich, Zurich Park Books, 2014. 8. Kwiatkowski P.K., Zrobotyzowana mobilna stacja paletyzujÄ&#x2026;ca z robotem wspĂłĹ&#x201A;pracujÄ&#x2026;cym (Robotized, mobile palletiza-
22.
23.
24.
25. 26.
27. 28. 29. 30. 31.
tion station based on collaborative robot). Praca dyplomowa magisterska (promoter M. Olszewski, work awarded in the Competition â&#x20AC;&#x153;Young Innovationsâ&#x20AC;?, PIAP, in 2019 and by Siemens and the Rector of Warsaw University of Technology, in 2019), Warsaw University of Technology (2019). Ĺ aski P.A., Kinematic Analysis of Parallel Manipulators. Publisher Politechnika Ĺ&#x161;wiÄ&#x2122;tokrzyska, M121, Kielce 2019. Ĺ aski P.A., Takosoglu J.E., BĹ&#x201A;asiak S., Design of a 3-DOF tripod Electro-pneumatic Parallel Manipulator. â&#x20AC;&#x153;Robotics and Autonomous Systemsâ&#x20AC;?, Vol. 72, 2015, 56â&#x20AC;&#x201C;70, DOI: 10.1016/j.robot.2015.04.009. Merlet J.-P., Solving the Forward Kinematics of a Goughtype Parallel Manipulator with Interval Analysis. â&#x20AC;&#x153;International Journal of Robotics Researchâ&#x20AC;?, Vol. 23, No. 3, 2004, 221â&#x20AC;&#x201C;235, DOI: 10.1177/0278364904039806. Olszewski M., automatica 2018. Optimize your Production. â&#x20AC;&#x153;Automatykaâ&#x20AC;?, Vol. 4, No. 10, 2018, 107â&#x20AC;&#x201C;122. Olszewski M., Basics of Servopneumatics. VDI Verlag, DĂźsseldorf 2007. Olszewski M., Bionika (Bionics). â&#x20AC;&#x153;Automatykaâ&#x20AC;?, Vol. 4, No. 6, 2018, 111â&#x20AC;&#x201C;116. Olszewski M., Mechatronika (Mechatronics). â&#x20AC;&#x17E;Automatykaâ&#x20AC;?, Vol. 4, No. 1â&#x20AC;&#x201C;2, 2018, 97â&#x20AC;&#x201C;99. Olszewski M., Mechatronizacja produktu i produkcji â&#x20AC;&#x201C; PrzemysĹ&#x201A; 4.0 (Mechatronization of the Product and the Production â&#x20AC;&#x201C; Industry 4.0), â&#x20AC;&#x17E;Pomiary Automatyka Robotykaâ&#x20AC;?, Vol. 20, No. 3/2016, 13-28, DOI: 10.14313/PAR_221/13. Olszewski M., PrzemysĹ&#x201A; 4.0 (Industry 4.0). â&#x20AC;&#x17E;Automatykaâ&#x20AC;?, Vol. 4, No. 1â&#x20AC;&#x201C;2, 2018, 99â&#x20AC;&#x201C;104. Olszewski M., RozwĂłj robotyki (Development of Robotics), Part I, Essay Robotics. â&#x20AC;&#x17E;Automatykaâ&#x20AC;?, Vol. 5, No. 3, 2019, 159â&#x20AC;&#x201C;168. Olszewski M., WspĂłĹ&#x201A;czesna robotyka (Modern Robotics), Part III, Essay Robotics. â&#x20AC;&#x17E;Automatykaâ&#x20AC;?, Vol. 5, No. 9, 2019, 89â&#x20AC;&#x201C;107. Olszewski M., Robotyka w Polsce (Robotics in Poland), Part II, Essay Robotics. â&#x20AC;&#x17E;Automatykaâ&#x20AC;?, Vol. 5, No. 3, 2019, 169â&#x20AC;&#x201C;182. Olszewski M., Wojtowicz J., Wrona S., DÄ&#x2026;browska-ŝóĹ&#x201A;tak K., Mechatronika w architekturze â&#x20AC;&#x201C; architektronika (Architecture with Mechatronics â&#x20AC;&#x201C; Architectronics). â&#x20AC;&#x17E;Pomiary Automatyka Robotykaâ&#x20AC;?, Vol. 21, No. 3/2017, 11-25, DOI: 10.14313/PAR_225/11. Panasiuk J., Kaczmarek W.: Robotyzacja procesĂłw produkcyjnych (Robotization of Production Processes). PWN, Warszawa 2017. PiÄ&#x2026;tek Z., Collaborative and Mobile Robots. AGV Report from the Market. APA â&#x20AC;&#x201C; Automatyka PodzespoĹ&#x201A;y Aplikacje, Reports 2019. Pilz T., Neue Wege in der Robotik beschreiten. Robotik und Produktion. Integration, Anwendung, Losungen, No. 3, 2018, 8â&#x20AC;&#x201C;10. Poreda R., Gracel J., The Introduction of Robotics. Six Common Mistakes. Automatyka, 3(3), pp. 40-42 (2019) Robotik und Production, Integration, Anwendung, LĂśsungen. (in) Highlights der automatica, Vol. 3, No. 3, TeDo Verlag GmbH, Marburg 2018. Industry Robotics. The Domestic Market in 2018. APA â&#x20AC;&#x201C; Automatyka PodzespoĹ&#x201A;y Aplikacje, Reports 2018. Staniszewska A., Zrobotyzowany przemysĹ&#x201A; (The Robotised Industry). Automatyka, Vol. 5, No. 3, 2019, 30â&#x20AC;&#x201C;36. Stoll W., Bionik. Lernen von der Natur â&#x20AC;&#x201C; Impulse fĂźr Innovation. Edition Festo, Esslingen 2018. Stoll W., Bionics. Inspiring Technology. Verlag Hermann Schmidt, Mainz 2012. Stumm S., Braumann J., von Hilchen M., Brell-Cokcan S., On-site Robotic Construction Assistance for Assembly Using a-priori Knowledge and Human-Robot Collaboration.
19
Modern Industrial Robotics
32. 33. 34. 35. 36. 37. 38. 39. 40. 41.
[in:] RodiÄ&#x2021; A., Boranglu T. (eds), Advances in robot design and intelligent control, Vol. 540, Springer 2017. Zhang D., Parallel Robotic Machine Tools. Springer, New York, Heidelberg 2010. www.astor.com.pl â&#x20AC;&#x201C; ASTOR Publications, www.automatica-munich.com â&#x20AC;&#x201C; Bord of Management, Messe MĂźnchen GmbH, www.abb.de/robotics â&#x20AC;&#x201C; ABB Automation GmbH, www.beckhoff.de â&#x20AC;&#x201C; Beckhoff Automation GmbH & Co. KG, www.boschrexroth.de â&#x20AC;&#x201C; Bosch Rexroth AG, www.dlr.de/m â&#x20AC;&#x201C; Deutsches Zentrum fĂźr Luft- und Raumfahrt e.V. (DLR), Institut fĂźr Robotik und Mechatronik, www.doosanrobotics.com â&#x20AC;&#x201C; Doosan Robotics Inc, www.eu-nited.net/robotics â&#x20AC;&#x201C; EUnited Robotics â&#x20AC;&#x201C; The European Robotics Association, www.epson.eu â&#x20AC;&#x201C; Epson Europe B.V.,
42. 43. 44. 45. 46. 47. 48. 49. 50. 51. 52. 53.
www.fanuc.eu â&#x20AC;&#x201C; Fanuc Deutschland GmbH, www.festo.de â&#x20AC;&#x201C; Festo Vertrieb GmbH und Co. KG, www.fp-robotics.com â&#x20AC;&#x201C; F&P Robotics AG, www.gudel.com â&#x20AC;&#x201C; GĂźdel Group AG, www.ifr.org â&#x20AC;&#x201C; International Federation of Robotics, industrial.omron.pl â&#x20AC;&#x201C; Omron Electronics Sp. z o.o., www.kuehne-nagel.pl â&#x20AC;&#x201C; Kuehne+Nagel Sp. z o.o. www.kuka.com â&#x20AC;&#x201C; KUKA AG, www.schunk.com â&#x20AC;&#x201C; Schunk GmbH & Co. KG, www.siemens.com â&#x20AC;&#x201C; Siemens AG, www.universal-robots.com â&#x20AC;&#x201C; Universal Robots A/S, www.cit-ec.de â&#x20AC;&#x201C; Universität Bielefeld, Cluster of Excellence Cognitive Interaction Technology (CITEC), 54. www.vdma.org/r+a â&#x20AC;&#x201C; VDMA Robotik + Automation, 55. pl-pl.facebook.com/versabox.pl â&#x20AC;&#x201C; VersaboX Sp. z o.o., 56. www.yaskawa.eu.com â&#x20AC;&#x201C; YASKAWA Europe GmbH.
0 A / Streszczenie: Roboty staĹ&#x201A;y siÄ&#x2122; w mijajÄ&#x2026;cym dziesiÄ&#x2122;cioleciu podstawowymi narzÄ&#x2122;dziami automatyzacji i robotyzacji produkcji przemysĹ&#x201A;owej, tak jak kiedyĹ&#x203A;, w latach 70. sterowniki programowalne, w latach 80. procesorowe regulatory napÄ&#x2122;dĂłw, w latach 90. XX wieku nastawniki czÄ&#x2122;stotliwoĹ&#x203A;ciowe silnikĂłw prÄ&#x2026;du przemiennego i w pierwszych latach XXI wieku cyfryzacja, wyraĹźajÄ&#x2026;ca siÄ&#x2122; istotnym zaawansowaniem i upowszechnieniem informatyzacji, telekomunikacji i internetyzacji. Ĺ&#x161;wiadectwem tej roli jest dalsze, poza obszary konwencjonalnej robotyki, rozszerzanie jej aplikacji i pojawienie siÄ&#x2122; nowych rozwiÄ&#x2026;zaĹ&#x201E; sprzÄ&#x2122;towych i programowych ukierunkowanych na wspĂłlne, przez roboty i czĹ&#x201A;owieka, podejmowanie dotychczas nie racjonalizowanych zadaĹ&#x201E; produkcyjnych. Tym wĹ&#x201A;aĹ&#x203A;nie przemianom we wspĂłĹ&#x201A;czesnej robotyce poĹ&#x203A;wiÄ&#x2122;cony jest ten esej. ) U / $ $ $ $ ( $ $ @ & !
Prof. Mariusz Olszewski, PhD, DSc % & !'( ORCID: 0000-0003-3516-2942 ; 6 0 6 7 ( *+B?$ % 6 ; E % F / % 8 % *+G! $ % H % > *+=! - *+G= ( I I 6 % > / @ %$ *+=? 0J7 / I @ ( % % ( % $ % % .K; / ( / % I @ E / % L M" > N O)!!)P$ M8 % 6 " N O)!!BP % > M" > Q % N O)!!+P ; I % 6 % % 6 % % / Q 6 - 6 ; % . / " 8 6 0 6 7 > ( *++&R)!*)S / 6 I 6 - % - 6 ; % " O@-;@P )!! R)!*GS > 6 7 >K% > @ >H ;FT 0 )!*! 7 6 % 6 I % ( - % > & ! 6 $ $ / $ > % 6 % % R - % & !$ 6 )!*B
20
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 21â&#x20AC;&#x201C;28, DOI: 10.14313/PAR_235/21
- % V ( % @Q - / 0 1 2 # 1 3% 4 5 6 % 7 6 % @ . $ T % - 6 ; $ 0 @ )$ ?>+?+ . A
1 8 Norma IEC 61131-3 definiuje piÄ&#x2122;Ä&#x2021; jÄ&#x2122;zykĂłw programowania sterownikĂłw przemysĹ&#x201A;owych. Norma ta jest powszechnie stosowana, wiele Ĺ&#x203A;rodowisk inĹźynierskich jest z niÄ&#x2026; caĹ&#x201A;kowicie, bÄ&#x2026;dĹş czÄ&#x2122;Ĺ&#x203A;ciowo zgodnych. W literaturze opisano kilka akademickich rozwiÄ&#x2026;zaĹ&#x201E;, jednak zazwyczaj implementujÄ&#x2026; one jedynie wybrane elementy normy (np. tylko jeden lub dwa jÄ&#x2122;zyki). Komercyjne Ĺ&#x203A;rodowiska inĹźynierskie zwykle obsĹ&#x201A;ugujÄ&#x2026; wszystkie jÄ&#x2122;zyki, ale ich dokumentacja skupia siÄ&#x2122; na korzystaniu ze Ĺ&#x203A;rodowiska, natomiast rzadko ujawniane sÄ&#x2026; szczegĂłĹ&#x201A;y dotyczÄ&#x2026;ce wewnÄ&#x2122;trznej architektury i implementacji. W artykule przedstawiono takie rozwiÄ&#x2026;zania dla pakietu inĹźynierskiego CPDev. Architektura bazujÄ&#x2026;ca na maszynie wirtualnej sprawia, Ĺźe Ĺ&#x203A;rodowisko jest przenoĹ&#x203A;ne, co uĹ&#x201A;atwia wdroĹźenie na róşnych platformach sprzÄ&#x2122;towych. W artykule przedstawiono kilka wdroĹźeĹ&#x201E; przemysĹ&#x201A;owych Ĺ&#x203A;rodowiska CPDev ) U
% V $ -K B** *> $ % $ $ $ F"-$ $
1. Wprowadzenie Ĺ&#x161;rodowiska inĹźynierskie implementujÄ&#x2026;ce jÄ&#x2122;zyki normy IEC 61131-3 (przyjÄ&#x2122;tej w Polsce jako PN-EN 61131-3) sÄ&#x2026; obecnie powszechnie stosowane w przemyĹ&#x203A;le do tworzenia programĂłw sterowania [1, 2]. Standard IEC 61131-3 [3] definiuje piÄ&#x2122;Ä&#x2021; jÄ&#x2122;zykĂłw programowania: dwa tekstowe IL, ST, dwa graficzne LD, FBD i mieszany jÄ&#x2122;zyk SFC. JÄ&#x2122;zyki IL, LD i SFC sÄ&#x2026; przeznaczone zwĹ&#x201A;aszcza do zastosowaĹ&#x201E; w procesach produkcyjnych opartych na sterownikach PLC [4], natomiast ST, FBD, jak teĹź SFC, sÄ&#x2026; stosowane w obszarach wykorzystujÄ&#x2026;cych sterowniki PAC i systemy DCS. Kompilatory jÄ&#x2122;zykĂłw IEC 61131-3 sÄ&#x2026; podstawowymi skĹ&#x201A;adnikami Ĺ&#x203A;rodowisk inĹźynierskich. Kompilator, na podstawie kodu ĹşrĂłdĹ&#x201A;owego programu, generuje kod wykonywalny. Zwykle stosowane sÄ&#x2026; trzy podejĹ&#x203A;cia do kompilacji programĂłw sterowania. Pierwsze polega na bezpoĹ&#x203A;rednim tĹ&#x201A;umaczeniu programu sterowania z jÄ&#x2122;zykĂłw IEC 61131-3 do wykonywalnego kodu maszynowego procesora. PoniewaĹź zmiana procesora (CPU) wymaga nowego kompilatora, takie rozwiÄ&#x2026;zanie jest zasadniczo dedykowane dla konkretnej platformy sprzÄ&#x2122;towej. Kolejne podejĹ&#x203A;cie jest dwuetapowe. W pierwszym kroku programy sterowania sÄ&#x2026; tĹ&#x201A;umaczone z jÄ&#x2122;zykĂłw IEC 61131-3 na kod ĹşrĂłdĹ&#x201A;owy w jÄ&#x2122;zyku poĹ&#x203A;rednim C lub C++, ktĂłry nastÄ&#x2122;pnie,
3 + U
Q . U $ % ' > 3 % *B *! )!*+ $ % % )G ** )!*+
!
kolejnym narzÄ&#x2122;dziem, jest kompilowany do wykonywalnego kodu maszynowego. RozwiÄ&#x2026;zanie to moĹźe byÄ&#x2021; przeniesione na róşne platformy sprzÄ&#x2122;towe, jeĹ&#x203A;li tylko posiadamy dla nich kompilator jÄ&#x2122;zyka C/C++. Trzecie z podejĹ&#x203A;Ä&#x2021; wymaga opracowania maszyny wirtualnej (VM) interpretujÄ&#x2026;cej pewien poĹ&#x203A;redni jÄ&#x2122;zyk, do ktĂłrego kompilowane sÄ&#x2026; programy sterowania. Takie podejĹ&#x203A;cie zostaĹ&#x201A;o wprowadzone na przykĹ&#x201A;ad w Ĺ&#x203A;rodowisku ISaGRAF [5] z jÄ&#x2122;zykiem poĹ&#x203A;rednim TIC (ang. Target Independent Code). Obecnie STRATON [6] (niezaleĹźny dostawca) rĂłwnieĹź bazuje na takiej metodzie, jak rĂłwnieĹź wiele z prototypowych rozwiÄ&#x2026;zaĹ&#x201E; akademickich takĹźe bazuje na maszynach wirtualnych. Jednak maszyna wirtualna wprowadza dodatkowy narzut czasowy, co powoduje, Ĺźe tego typu podeĹ&#x203A;cie jest zwykle mniej wydajne. Prace nad Ĺ&#x203A;rodowiskiem inĹźynierskim zgodnym z normÄ&#x2026; IEC 61131-3 autorzy tego artykuĹ&#x201A;u rozpoczÄ&#x2122;li ponad 10 lat temu [7], po rozmowach z producentami automatyki przemysĹ&#x201A;owej. W pewnym stopniu byĹ&#x201A;a to kontynuacja wczeĹ&#x203A;niejszych prac nad sterownikami wielofunkcyjnymi [8]. Opracowane Ĺ&#x203A;rodowisko, nazwane CPDev (ang. Control Program Developer) kompilowaĹ&#x201A;o programy z jÄ&#x2122;zyka ST do kodu VMASM (ang. Virtual Machine Assembler) interpretowanego przez maszynÄ&#x2122; wirtualnÄ&#x2026;, poczÄ&#x2026;tkowo na oĹ&#x203A;miobitowych mikrokontrolerach MCS 51 i AVR. Z zaĹ&#x201A;oĹźenia Ĺ&#x203A;rodowisko wspieraĹ&#x201A;o samodzielnÄ&#x2026; adaptacjÄ&#x2122; maszyny wirtualnej dla docelowego sprzÄ&#x2122;tu przez inĹźynierĂłw i studentĂłw, zarĂłwno dla zastosowaĹ&#x201E; w przemyĹ&#x203A;le, jak i w dydaktyce. W kolejnych latach w pakiecie wprowadzono rozszerzenia dla 32- i 64-bitowych procesorĂłw, uzupeĹ&#x201A;niono je o translatory jÄ&#x2122;zykĂłw graficznych, narzÄ&#x2122;dzie do projektowania interfejsĂłw HMI i wieloprojektowe Ĺ&#x203A;rodowisko uruchomieniowe (poczÄ&#x2026;tkowo zaimplementowane w FPGA [9]). Dwa rozszerzenia wsparĹ&#x201A;y badania nad podejĹ&#x203A;ciem MDD (ang. Model Driven Development) [10] i testami jednostkowymi [11]. Do tej pory Ĺ&#x203A;rodowisko zostaĹ&#x201A;o wdroĹźone przez kilku producentĂłw urzÄ&#x2026;dzeĹ&#x201E; automatyki w kraju i za granicÄ&#x2026;.
21
G:& : _ .! & ! $ & +# Y
V1 <
W artykule przedstawiono rozwiÄ&#x2026;zania podstawowych problemĂłw, ktĂłre moĹźna napotkaÄ&#x2021; podczas rozwoju oprogramowania zgodnego z normÄ&#x2026; IEC 61131-3, w tym zarĂłwno pakietu inĹźynierskiego, jak teĹź Ĺ&#x203A;rodowiska uruchomieniowego. W szczegĂłlnoĹ&#x203A;ci pokazano rozwiÄ&#x2026;zania zapewniajÄ&#x2026;ce: â&#x2C6;&#x2019; przenoĹ&#x203A;noĹ&#x203A;Ä&#x2021; kompilatora i Ĺ&#x203A;rodowiska uruchomieniowego dla róşnych procesorĂłw i zastosowaĹ&#x201E; wymagajÄ&#x2026;cych dedykowanych sterownikĂłw PLC, â&#x2C6;&#x2019; integracjÄ&#x2122; elementĂłw sprzÄ&#x2122;towych ze Ĺ&#x203A;rodowiskiem uruchomieniowym, â&#x2C6;&#x2019; mechanizm projektowania bibliotek HMI obejmujÄ&#x2026;cych obiekty graficzne wyĹ&#x203A;wietlane na róşnych urzÄ&#x2026;dzeniach, â&#x2C6;&#x2019; wsparcie dla wymiany danych za pomocÄ&#x2026; wielu protokoĹ&#x201A;Ăłw komunikacyjnych. ArtykuĹ&#x201A; ma nastÄ&#x2122;pujÄ&#x2026;cÄ&#x2026; strukturÄ&#x2122;. W kolejnym rozdziale przedstawiono przeglÄ&#x2026;d literatury dotyczÄ&#x2026;cy podstawowych aspektĂłw zwiÄ&#x2026;zanych ze Ĺ&#x203A;rodowiskami inĹźynierskimi. RozdziaĹ&#x201A; 3 prezentuje moĹźliwoĹ&#x203A;ci CPDev. JÄ&#x2122;zyk poĹ&#x203A;redni VMASM, parametryzowany kompilator i przykĹ&#x201A;adowy program sterowania opisano w rozdziale 4. Kolejny rozdziaĹ&#x201A; wyjaĹ&#x203A;nia architekturÄ&#x2122; maszyny wirtualnej oraz powiÄ&#x2026;zanie z funkcjami niskopoziomowymi. RozdziaĹ&#x201A; 6 opisuje translatory jÄ&#x2122;zykĂłw graficznych i przedstawia dwuwarstwowÄ&#x2026; strukturÄ&#x2122; obsĹ&#x201A;ugi HMI. RozdziaĹ&#x201A; 7 pokazuje dane niezbÄ&#x2122;dne do powiÄ&#x2026;zania zmiennych z interfejsami komunikacyjnymi i przedstawia typowe wdroĹźenia.
Pierwotna wersja CPDev, wspierajÄ&#x2026;ca poczÄ&#x2026;tkowo jedynie jÄ&#x2122;zyk ST [7], zostaĹ&#x201A;a rozbudowana o obsĹ&#x201A;ugÄ&#x2122; pozostaĹ&#x201A;ych jÄ&#x2122;zykĂłw normy IEC 61131-3, projektowanie interfejsĂłw HMI, generator dokumentacji oraz moduĹ&#x201A;y o zastosowaniu badawczym. Na rysunku 1 przedstawiono kolejne etapy przetwarzania programĂłw sterowania. Programy tekstowe (jÄ&#x2122;zyki ST, IL) sÄ&#x2026; kompilowane do mnemonikĂłw poĹ&#x203A;redniego jÄ&#x2122;zyka VMASM. Diagramy LD, FBD i SFC sÄ&#x2026; tĹ&#x201A;umaczone na ST, a nastÄ&#x2122;pnie kompilowane. JÄ&#x2122;zyk ST jest wiÄ&#x2122;c bazowym jÄ&#x2122;zykiem Ĺ&#x203A;rodowiska. Wykonywalny kod binarny jest generowany przez asembler z mnemonikĂłw VMASM i Ĺ&#x201A;adowany do maszyny wirtualnej. ĹšrĂłdĹ&#x201A;a maszyny wirtualnej napisano w jÄ&#x2122;zyku C, co uĹ&#x201A;atwia przenoĹ&#x203A;noĹ&#x203A;Ä&#x2021; na róşne platformy sprzÄ&#x2122;towe.
S1 + Koncepcja maszyny wirtualnej, jako abstrakcyjnego procesora dedykowanego jÄ&#x2122;zyka, pierwotnie zostaĹ&#x201A;a wdroĹźona jako p-maszyna dla jÄ&#x2122;zyka programowania Pascal. WspĂłĹ&#x201A;czeĹ&#x203A;nie zastosowano jÄ&#x2026; w jÄ&#x2122;zyku Java jako JVM (ang. Java Virtual Machine) [12] i na platformie .NET jako CLR (ang. Common Language Runtime) [13]. DostÄ&#x2122;pna jest takĹźe otwarta implementacja JVM w jÄ&#x2122;zyku Verilog, przeznaczona dla FPGA [14]. W odniesieniu do systemĂłw sterowania pierwsze rozwiÄ&#x2026;zania bazujÄ&#x2026;ce na maszynach wirtualnych (poza komercyjnym ISaGRAF) opisano w [15, 16], stosujÄ&#x2026;c IL jako jÄ&#x2122;zyk poĹ&#x203A;redni. Stosunkowo prosta architektura [15] umoĹźliwiĹ&#x201A;a implementacjÄ&#x2122; na oĹ&#x203A;miobitowym mikroprocesorze C8051. Ostatnio takĹźe CLR, a wiÄ&#x2122;c maszyna wirtualna .NET, zostaĹ&#x201A;a przystosowana do aplikacji IEC 61131-3 [17]. PowstaĹ&#x201A;y rĂłwnieĹź narzÄ&#x2122;dzia o przeznaczeniu dydaktycznym, ograniczone do wybranych elementĂłw normy IEC 61131-3, np. UniSim [18] lub Whimori CDU [19]. Z nowszych przykĹ&#x201A;adĂłw WEB PLC Simulator [20] pozwala na implementacjÄ&#x2122; modelu fabryki i sterowania w jÄ&#x2122;zyku ST. HT-PLC [21] bazujÄ&#x2026;cy na Arduino z moduĹ&#x201A;em Ethernet jest programowalny w LD. Mimo licznych aplikacji, szczegĂłĹ&#x201A;y dotyczÄ&#x2026;ce kompilatorĂłw jÄ&#x2122;zykĂłw IEC 61131-3 sÄ&#x2026; ujawniane jedynie sporadycznie. MoĹźliwoĹ&#x203A;ci standardowej skĹ&#x201A;adni SSA (ang. Static Single Assignment â&#x20AC;&#x201C; jednokrotne statyczne przypisanie) i zasady stosowanej tu translacji kierowanej skĹ&#x201A;adniÄ&#x2026; opisano m.in. w [22]. Translatory diagramĂłw LD na jÄ&#x2122;zyki IL lub ST zazwyczaj bazujÄ&#x2026; na grafach AOV (ang. Activity on Vertex) [23, 24]. Translator wbudowany w CPDev rĂłwnieĹź korzysta z grafu AOV, z ktĂłrego generowany jest program w jÄ&#x2122;zyku ST. Grafy EDFG (ang. Enhanced Data Flow Graphs) [25] pozwalajÄ&#x2026; na implementowanie programĂłw napisanych w IL, LD i SFC w FPGA. RozwaĹźajÄ&#x2026;c interfejsy HMI naleĹźy wspomnieÄ&#x2021; o zasadach graficznego projektowania aplikacji sterowania [26]. IstniejÄ&#x2026; takĹźe przemysĹ&#x201A;owe standardy w tym obszarze, jak na przykĹ&#x201A;ad niemiecki standard VDI/VDE 3699 [27].
22
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
Rys. 1. Przetwarzanie programĂłw sterowania w Ĺ&#x203A;rodowisku CPDev Fig. 1. Processing of control programs in the CPDev environment
Z punktu widzenia uĹźytkownika podstawowe funkcjonalnoĹ&#x203A;ci CPDev sÄ&#x2026; podobne do innych Ĺ&#x203A;rodowisk inĹźynierskich. Pewnym wyróşnikiem jest tu mechanizm automatycznego wyznaczania poĹ&#x201A;Ä&#x2026;czeĹ&#x201E; miÄ&#x2122;dzy blokami w edytorach FBD i LD [28], ktĂłry bazuje na algorytmie A* [29]. RĂłwnieĹź edytor ekranĂłw HMI korzysta z niezaleĹźnych od sprzÄ&#x2122;tu komponentĂłw zapisanych w bibliotekach. Kompilator generuje dodatkowo plik XML z zestawem danych o rozmieszczeniu zmiennych globalnych, co jest wymagane dla interfejsĂłw komunikacyjnych i moduĹ&#x201A;Ăłw wejĹ&#x203A;Ä&#x2021;/wyjĹ&#x203A;Ä&#x2021;. Na podstawie modeli w diagramach SysML [30] moĹźliwe jest generowanie szablonĂłw programĂłw i zadaĹ&#x201E; komunikacyjnych [10]. Testy jednostkowe i tablicowe mogÄ&#x2026; korzystaÄ&#x2021; z IEC 61131-3 lub dedykowanego jÄ&#x2122;zyka [11]. ModuĹ&#x201A;y CPDev majÄ&#x2026; wbudowane interfejsy XML, co pozwala na zwinne i wahadĹ&#x201A;owe podeĹ&#x203A;cie inĹźynierii oprogramowania [31]. Poza maszynÄ&#x2026; wirtualnÄ&#x2026; wykonujÄ&#x2026;cÄ&#x2026; zadania sterowania, Ĺ&#x203A;rodowisko uruchomieniowe moĹźe zawieraÄ&#x2021; moduĹ&#x201A; wykonawczy HMI obsĹ&#x201A;ugujÄ&#x2026;cy interfejs graficzny. Maszyna wirtualna i moduĹ&#x201A; HMI dziaĹ&#x201A;ajÄ&#x2026; rĂłwnolegle i niezaleĹźnie, wymieniajÄ&#x2026;c dane przez zmienne globalne.
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
! " !
X1 2" Definicja jÄ&#x2122;zyka poĹ&#x203A;redniego VMASM obejmuje wszystkie typy danych, instrukcje i skĹ&#x201A;adnie. Wieloplatformowe implementacje wymagajÄ&#x2026; jednak parametryzowanego kompilatora.
okreĹ&#x203A;lajÄ&#x2026;cego zasoby sprzÄ&#x2122;towe, typy danych, instrukcje i konwersje. Tak wiÄ&#x2122;c róşne wersje, przeznaczone na docelowe platformy sprzÄ&#x2122;towe lub do okreĹ&#x203A;lonych zastosowaĹ&#x201E;, mogÄ&#x2026; byÄ&#x2021; tworzone z jednego ogĂłlnego kompilatora i powiÄ&#x2026;zanej z nim ogĂłlnej maszyny wirtualnej.
X1^1
X1S1
VMASM obsĹ&#x201A;uguje wszystkie typy danych zdefiniowane w normie IEC 61131-3 poza typem WSTRING. Z uwagi na wystÄ&#x2122;powanie problemĂłw podczas mieszania typĂłw Ĺ&#x201A;aĹ&#x201E;cuchowych jednobajtowych z dwubajtowymi zdecydowano pozostawiÄ&#x2021; w implementacji tylko jeden z nich (tablice konwersji oparte na jÄ&#x2122;zyku i stronie kodowej, w ktĂłrych majÄ&#x2026; byÄ&#x2021; te teksty umieszczone, ponadto wystÄ&#x2122;powanie znakĂłw modyfikujÄ&#x2026;cych litery znacznie utrudnia implementacjÄ&#x2122; takich konwersji). Z uwagi na maĹ&#x201A;Ä&#x2026; przestrzeĹ&#x201E; adresowÄ&#x2026; w 16-bitowej wersji maszyny wirtualnej zdecydowano pozostaÄ&#x2021; tylko przy typie STRING. W niektĂłrych wdroĹźeniach CPDev, gdzie znaki miÄ&#x2122;dzynarodowe sÄ&#x2026; niezbÄ&#x2122;dne, typ STRING jest interpretowany jako wielobajtowy i jest rĂłwnowaĹźny typowi WSTRING. Typ BOOL zajmuje 1 bajt, INT â&#x20AC;&#x201C; 2 bajty, REAL â&#x20AC;&#x201C; 4 bajty, DATE_AND_TIME â&#x20AC;&#x201C; 8 bajtĂłw (struktura z polami); podobnie dla pozostaĹ&#x201A;ych typĂłw. Przez parametryzacjÄ&#x2122; kompilatora liczba typĂłw wymagana w konkretnym zastosowaniu moĹźe byÄ&#x2021; ograniczona. Instrukcje VMASM skĹ&#x201A;adajÄ&#x2026; siÄ&#x2122; z funkcji i procedur. Procedury kontrolujÄ&#x2026; przepĹ&#x201A;yw realizacji programu, wywoĹ&#x201A;ujÄ&#x2026; podprogramy, obsĹ&#x201A;ugujÄ&#x2026; kopiowanie obszarĂłw pamiÄ&#x2122;ci itd. Instrukcje VMASM majÄ&#x2026; nastÄ&#x2122;pujÄ&#x2026;cÄ&#x2026; skĹ&#x201A;adniÄ&#x2122;:
Plik XML z kodem ĹşrĂłdĹ&#x201A;owym programu jest kompilowany przez skaner i parser do pliku z mnemonikami VMASM. Za pomocÄ&#x2026; osobnego zestawu sĹ&#x201A;Ăłw kluczowych skaner ST przetwarza takĹźe jÄ&#x2122;zyk IL, zastÄ&#x2122;pujÄ&#x2026;c rejestr CR tworzonymi ad hoc tymczasowymi zmiennymi [32]. Parser wyprowadza drzewo skĹ&#x201A;adni abstrakcyjnej wedĹ&#x201A;ug schematu z gĂłry na dĂłĹ&#x201A;, stosujÄ&#x2026;c translacjÄ&#x2122; kierowanÄ&#x2026; skĹ&#x201A;adniÄ&#x2026; [22]. Podstawowe komponenty skanera i parsera sÄ&#x2026; deklarowane jako klasy w jÄ&#x2122;zyku C#. Listy stosowane sÄ&#x2026; we wszystkich fazach kompilacji. PrzykĹ&#x201A;ad fragmentu programu w jÄ&#x2122;zyku ST i odpowiadajÄ&#x2026;cego mu tĹ&#x201A;umaczenia VMASM dla generatora pojedynczego impulsu na wyjĹ&#x203A;ciu OUT po czasie T#5s od aktywacji zboczem narastajÄ&#x2026;cym na wejĹ&#x203A;ciu IN pokazano na rysunku 2. Blok R_TRIG1 wykrywa zbocze narastajÄ&#x2026;ce, natomiast przerzutnik RS1 i timer TON1 ze sprzÄ&#x2122;Ĺźeniem zwrotnym generujÄ&#x2026; impuls. Parser poczÄ&#x2026;tkowo zapisuje rezultat do zmiennych tymczasowych (SSA zapisuje do wirtualnych rejestrĂłw). NastÄ&#x2122;pnie, aby ograniczyÄ&#x2021; liczbÄ&#x2122; takich zmiennych, kompilator przechodzi przez fazÄ&#x2122; optymalizacji, w ktĂłrej zastÄ&#x2122;puje nadmiarowe zmienne tymczasowe zmiennymi uĹźytkownika (globalnymi lub lokalnymi) oraz nakĹ&#x201A;ada na siebie adresy tych zmiennych tymczasowych, ktĂłre nie sÄ&#x2026; uĹźywane do obliczeĹ&#x201E; w tym samym czasie.
[:etykieta] instrukcja [operand1] [,operand2] [,operand3] ...
Y1 (
Etykieta jest opcjonalna, instrukcja okreĹ&#x203A;la jednoczeĹ&#x203A;nie liczbÄ&#x2122; operandĂłw. Operandami mogÄ&#x2026; byÄ&#x2021; zmienne, etykiety i bezpoĹ&#x203A;rednie wartoĹ&#x203A;ci. Symbol specjalny ? (znak zapytania) oznacza etykietÄ&#x2122; lub zmiennÄ&#x2026; tymczasowÄ&#x2026; z prefiksem ?LR?. Elementy struktur sÄ&#x2026; wybierane operatorem kropka (.). W przypadku jÄ&#x2122;zyka IL, wynik wykonywania rozkazu przechowywany jest w rejestrze CR (ang. Current Result), a nastÄ&#x2122;pnie zawartoĹ&#x203A;Ä&#x2021; CR jest zapisywana w zmiennej. VMASM Ĺ&#x201A;Ä&#x2026;czy te dwa kroki w jednÄ&#x2026; instrukcjÄ&#x2122;, gdzie operand1 wskazuje lokalizacjÄ&#x2122; wyniku (operacja pamiÄ&#x2122;Ä&#x2021;-pamiÄ&#x2122;Ä&#x2021;). Kompilator i maszyna wirtualna, zaprojektowane dla wieloplatformowych implementacji, muszÄ&#x2026; braÄ&#x2021; pod uwagÄ&#x2122; rozmiar adresĂłw docelowego procesora, bÄ&#x2026;dĹş teĹź nie wymagajÄ&#x2026; wszystkich typĂłw danych zdefiniowanych w normie IEC 61131-3. By to uwzglÄ&#x2122;dniÄ&#x2021;, kompilator ST na VMASM jest parametryzowany za pomocÄ&#x2026; pliku XML LCF (ang. Library Configuration File)
Mnemoniki generowane przez kompilator podlegajÄ&#x2026; konwersji do kodu binarnego dla maszyny wirtualnej. Maszyna jest zaprojektowana w architekturze harwardzkiej (rozdzielone przestrzenie adresowe pamiÄ&#x2122;ci programu i danych). W pierwszej fazie implementacji tworzony jest jej interfejs dla docelowej platformy sprzÄ&#x2122;towej.
Y1^1 3 * Podstawowe skĹ&#x201A;adniki maszyny wirtualnej, takie jak pamiÄ&#x2122;ci programu i danych, stosy programu i danych, moduĹ&#x201A; wykonywania instrukcji i interfejs dla docelowej platformy, pokazano na rysunku 3. ModuĹ&#x201A; wykonywania instrukcji pobiera rozkazy z pamiÄ&#x2122;ci programu, przetwarza je, pobiera operandy z pamiÄ&#x2122;ci danych lub programu (zmienne lub staĹ&#x201A;e) i zapisuje wyniki w pamiÄ&#x2122;ci danych.
! " # ! $ ! " # ! $ $ % && # ! " # ! $
Rys. 2. Program w ST i translacja na VMASM dla generatora impulsu Fig. 2. ST program and VMASM translation for the pulse generator
23
G:& : _ .! & ! $ & +# Y
Stos programu
Stos danych
programu
Interfejs dla platformy docelowej
danych
Prototypy funkcji niskopoziomowych
Rys. 3. OgĂłlna architektura maszyny wirtualnej Fig. 3. General architecture of the virtual machine
Z1^1 4 " # %& $
Interfejs dla docelowej platformy skĹ&#x201A;ada siÄ&#x2122; z niskopoziomowych funkcji zaleĹźnych od sprzÄ&#x2122;tu i systemu operacyjnego, jak aktualizacja wejĹ&#x203A;Ä&#x2021; i wyjĹ&#x203A;Ä&#x2021;, zarzÄ&#x2026;dzanie czasem cyklu, alokacja pamiÄ&#x2122;ci itp. OgĂłlna czÄ&#x2122;Ĺ&#x203A;Ä&#x2021; maszyny wirtualnej jest napisana w standardowym jÄ&#x2122;zyku C, podobnie jak wiÄ&#x2122;kszoĹ&#x203A;Ä&#x2021; tego typu maszyn wirtualnych i moĹźe byÄ&#x2021; bezpoĹ&#x203A;rednio kompilowana na typowe procesory. Maszyna wirtualna dziaĹ&#x201A;a wiÄ&#x2122;c jak interpreter wykonujÄ&#x2026;c kolejne linie kodu. Pojedyncza instrukcja programu pobiera operandy w zaleĹźnoĹ&#x203A;ci od specyfikacji zdefiniowanej w pliku LCF i wykonuje stosowne obliczenia. W przypadku funkcji rezultat umieszczany jest pod odpowiednim adresem.
WspĂłlnÄ&#x2026; cechÄ&#x2026; edytorĂłw diagramĂłw LD i FBD jest mechanizm automatycznego wyznaczania poĹ&#x201A;Ä&#x2026;czeĹ&#x201E; za pomocÄ&#x2026; algorytmu A* [29]. Translatory zastÄ&#x2122;pujÄ&#x2026; wewnÄ&#x2122;trzne poĹ&#x201A;Ä&#x2026;czenia pomocniczymi zmiennymi lokalnymi niezbÄ&#x2122;dnymi, by wyĹ&#x203A;wietliÄ&#x2021; bieĹźÄ&#x2026;cÄ&#x2026; wartoĹ&#x203A;Ä&#x2021; na poĹ&#x201A;Ä&#x2026;czeniu w trybie on-line. Wersja FBD przykĹ&#x201A;adowego fragmentu programu, wraz z jego translacjÄ&#x2026; na ST, jest pokazana na rysunku 4a. Pomocnicza zmienna out_R_TRIG1_Q i dalsze z przedrostkiem out_ sÄ&#x2026; tworzone automatycznie. Poza tymi zmiennymi tĹ&#x201A;umaczenie nie róşni siÄ&#x2122; zbytnio od oryginalnego kodu ST (rys. 2). Rysunek 4b przedstawia diagram LD odpowiadajÄ&#x2026;cy FBD. SygnaĹ&#x201A; OUT na wejĹ&#x203A;ciu RS1 zapewnia sprzÄ&#x2122;Ĺźenie zwrotne. Nie ma ograniczeĹ&#x201E; dla zĹ&#x201A;oĹźonoĹ&#x203A;ci szczebla, o ile tylko zachowano reguĹ&#x201A;y jÄ&#x2122;zyka LD. Zmodyfikowany algorytm A* stosowany w edytorach Ĺ&#x201A;Ä&#x2026;czy podejĹ&#x203A;cie konwencjonalne z heurystycznym. Podczas wyzna-
Y1S1 0 0 OgĂłlna czÄ&#x2122;Ĺ&#x203A;Ä&#x2021; maszyny wirtualnej zawiera zestaw funkcji do obsĹ&#x201A;ugi komponentĂłw procesora w kolejnych fazach dziaĹ&#x201A;ania maszyny, rozpoczynajÄ&#x2026;c od zaĹ&#x201A;adowania programu z danego projektu. SÄ&#x2026; to prototypy niskopoziomowych funkcji (poczÄ&#x2026;tkowo puste), niezaleĹźne od CPU i zastosowanych rozwiÄ&#x2026;zaĹ&#x201E; sprzÄ&#x2122;towych. Cztery przykĹ&#x201A;ady takich prototypĂłw pokazano poniĹźej. â&#x2C6;&#x2019;
â&#x20AC;&#x201C; inicjalizacja sprzÄ&#x2122;tu, zapis poczÄ&#x2026;tkowego stanu (czas, parametry), â&#x2C6;&#x2019; VMP_PreCycle â&#x20AC;&#x201C; aktualizacja zmiennych z zewnÄ&#x2122;trznych wejĹ&#x203A;Ä&#x2021; przed rozpoczÄ&#x2122;ciem obliczeĹ&#x201E;, zapis poczÄ&#x2026;tkowego stanu zegara systemowego, â&#x2C6;&#x2019; VMP_PostCycle â&#x20AC;&#x201C; aktualizacja zewnÄ&#x2122;trznych wyjĹ&#x203A;Ä&#x2021; rezultatem obliczeĹ&#x201E; z bieĹźÄ&#x2026;cego cyklu, wykonanie procedur testowych lub komunikacyjnych, â&#x2C6;&#x2019; VMP_CurrentTime â&#x20AC;&#x201C; zwraca bieĹźÄ&#x2026;cÄ&#x2026; wartoĹ&#x203A;Ä&#x2021; zegara systemowego do zmiennej typu TIME. Kod niskopoziomowych funkcji jest przygotowywany w C/C++ podczas wdroĹźenia na docelowÄ&#x2026; platformÄ&#x2122; i konsolidowany z ogĂłlnÄ&#x2026; czÄ&#x2122;Ĺ&#x203A;ciÄ&#x2026; maszyny wirtualnej. Po tej fazie implementacja maszyny wirtualnej dla docelowej platformy sprzÄ&#x2122;towej jest gotowa do uruchomienia.
(a)
(b)
Z1 4 '( Jak wspomniano w rozdziale 3, programy utworzone w jÄ&#x2122;zykach graficznych sÄ&#x2026; poczÄ&#x2026;tkowo tĹ&#x201A;umaczone do ST, a nastÄ&#x2122;pnie kompilowane. DziÄ&#x2122;ki dwuwarstwowej strukturze oprogramowania dla paneli HMI, narzÄ&#x2122;dzie do projektowania interfejsĂłw graficznych moĹźe wspĂłĹ&#x201A;pracowaÄ&#x2021; z róşnymi urzÄ&#x2026;dzeniami.
24
P
O
M
I
A
R
Y
â&#x20AC;˘
Rys. 4. Diagramy i translacja generatora impulsu: (a) FBD, (b) LD Fig. 4. Diagrams and translation of the pulse generator: (a) FBD, (b) LD
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
! " !
czania poĹ&#x201A;Ä&#x2026;czenia obliczany jest jego koszt, biorÄ&#x2026;cy pod uwagÄ&#x2122; liczbÄ&#x2122; przeciÄ&#x2122;Ä&#x2021; z innymi poĹ&#x201A;Ä&#x2026;czeniami i liczbÄ&#x2122; zmian kierunkĂłw [28], aby moĹźliwie zmniejszyÄ&#x2021; dĹ&#x201A;ugoĹ&#x203A;Ä&#x2021; poĹ&#x201A;Ä&#x2026;czeĹ&#x201E;, zachowujÄ&#x2026;c jednoczeĹ&#x203A;nie przejrzystoĹ&#x203A;Ä&#x2021; schematu.
Z1S1 4 " )% Diagramy SFC przechowywane sÄ&#x2026; w pamiÄ&#x2122;ci jako drzewa. Drzewo moĹźe skĹ&#x201A;adaÄ&#x2021; siÄ&#x2122; z krokĂłw, tranzycji, skokĂłw, wyboru sekwencji i sekwencji wspĂłĹ&#x201A;bieĹźnych. Pierwsze trzy elementy sÄ&#x2026; podstawowe i tworzÄ&#x2026; dwa dalsze. Akcje przywiÄ&#x2026;zane sÄ&#x2026; do krokĂłw, a typy akcji okreĹ&#x203A;lane sÄ&#x2026; kwalifikatorem zgodnie z normÄ&#x2026; IEC 61131-3 [3]. Translacja z SFC na ST korzysta z dwĂłch blokĂłw funkcjonalnych z biblioteki systemowej, SFC_STEP oraz SFC_ACTION_CONTROL. Blok SFC_STEP wyznacza aktywnoĹ&#x203A;Ä&#x2021; poszczegĂłlnych krokĂłw na podstawie flagi next-step-flag powiÄ&#x2026;zanej z wejĹ&#x203A;ciem. Blok ma dwa wyjĹ&#x203A;cia, X i T, oznaczajÄ&#x2026;ce aktywnoĹ&#x203A;Ä&#x2021; i czas, ktĂłry minÄ&#x2026;Ĺ&#x201A; od aktywacji (dla tranzycji i akcji). Blok STEP_ACTION_CONTROL aktywuje akcjÄ&#x2122; powiÄ&#x2026;zanÄ&#x2026; z krokiem w zaleĹźnoĹ&#x203A;ci od kwalifikatora. Translator Ĺ&#x201A;Ä&#x2026;czy wyjĹ&#x203A;cie X z SFC_STEP z wejĹ&#x203A;ciem SFC_ACTION_CONTROL odpowiadajÄ&#x2026;cym uĹźytemu kwalifikatorowi. Wykonywanie kodu akcji uruchamiane jest wyjĹ&#x203A;ciem A.
Z1V1 0 '( Graficzne panele operatorskie, zazwyczaj z ekranem dotykowym, stosowane sÄ&#x2026; w systemach wykorzystujÄ&#x2026;cych sterowniki PLC i PAC. Panele takie niekiedy zintegrowane sÄ&#x2026; ze sterownikami, jak np. w przypadku urzÄ&#x2026;dzeĹ&#x201E; pochodzÄ&#x2026;cych z firm Beckhoff, Unitronix czy Horner. ObsĹ&#x201A;uga paneli HMI zostaĹ&#x201A;a zaimplementowana w Ĺ&#x203A;rodowisku CPDev w ramach narzÄ&#x2122;dzia CPVis obejmujÄ&#x2026;cego edytor graficzny dedykowany do tworzenia ekranĂłw z predefiniowanych komponentĂłw. Zmienne globalne, bÄ&#x2026;dĹş staĹ&#x201A;e, przypisywane sÄ&#x2026; jako atrybuty komponentĂłw. Dane projektu zapisywane sÄ&#x2026; w pliku XML i eksportowane do kodu binarnego wykorzystywanego w uruchomieniowym docelowego sterownika. Aby zaimplementowaÄ&#x2021; oprogramowanie HMI na docelowym urzÄ&#x2026;dzeniu, inĹźynier powinien przygotowaÄ&#x2021; zestaw procedur rysujÄ&#x2026;cych podstawowe elementy graficzne (np. linia, koĹ&#x201A;o, tekst), wykorzystujÄ&#x2026;c mechanizmy i biblioteki specyficzne dla urzÄ&#x2026;dzenia, jak np. RamTex, GLCD, GDI+ lub inne. Na podstawowych elementach bazuje domyĹ&#x203A;lna biblioteka CPVis ze zĹ&#x201A;oĹźonymi obiektami graficznymi jak BarGraph, ProcessValue, TouchableBox, Gauge itp. DziÄ&#x2122;ki temu utworzone obiekty sÄ&#x2026; niezaleĹźne od sprzÄ&#x2122;tu i mogÄ&#x2026; byÄ&#x2021; wyĹ&#x203A;wietlone na róşnych urzÄ&#x2026;dzeniach.
\1 + Podczas wdraĹźania Ĺ&#x203A;rodowiska na docelowej platformie naleĹźy takĹźe opracowaÄ&#x2021; mechanizmy komunikacji i konfiguracji wejĹ&#x203A;Ä&#x2021;/ wyjĹ&#x203A;Ä&#x2021;. Aby to umoĹźliwiÄ&#x2021;, kompilator, poza kodem binarnym, tworzy plik XML (rozszerzenie DCP) z mnemonikami VMASM (dla debugowania) i podstawowymi danymi na temat zmiennych globalnych. Na podstawie tych danych moĹźliwe jest powiÄ&#x2026;zanie zmiennych z zewnÄ&#x2122;trznymi interfejsami.
\1^1 " 0 Konfigurator zapewnia trzy funkcjonalnoĹ&#x203A;ci: â&#x2C6;&#x2019; ustalenie parametrĂłw interfejsu komunikacyjnego, â&#x2C6;&#x2019; powiÄ&#x2026;zanie zmiennych globalnych z interfejsami, â&#x2C6;&#x2019; przesĹ&#x201A;anie kodu binarnego, parametrĂłw komunikacyjnych i tablicy powiÄ&#x2026;zaĹ&#x201E; do sterownika.
Typowe parametry interfejsu komunikacyjnego to prÄ&#x2122;dkoĹ&#x203A;Ä&#x2021; transmisji, numer urzÄ&#x2026;dzenia itd. (dla Ĺ&#x201A;Ä&#x2026;cza szeregowego) czy adres IP (dla Ĺ&#x201A;Ä&#x2026;cza Ethernet). Aby wyjaĹ&#x203A;niÄ&#x2021;, jak moĹźe wyglÄ&#x2026;daÄ&#x2021; prosty konfigurator, rozwaĹźmy system, gdzie sterownik komunikuje siÄ&#x2122; z trzema zdal-
Rys. 5. Konfigurator komunikacji Fig. 5. Communication configurer
nymi moduĹ&#x201A;ami wejĹ&#x203A;cia/wyjĹ&#x203A;cia [33] w protokole Modbus RTU (pierwsze przemysĹ&#x201A;owe wdroĹźenie CPDev [7]). ZaĹ&#x201A;óşmy, Ĺźe zmienna IN z przykĹ&#x201A;adu jest ustawiana pierwszym wejĹ&#x203A;ciem z moduĹ&#x201A;u wejĹ&#x203A;Ä&#x2021; binarnych (urzÄ&#x2026;dzenie podrzÄ&#x2122;dne nr 1, adres Modbus 4003). Podobnie zmienna OUT jest zapisywana do moduĹ&#x201A;u wyjĹ&#x203A;Ä&#x2021; binarnych (urzÄ&#x2026;dzenie podrzÄ&#x2122;dne 2, adres Modbus 4205). Zasadnicza czÄ&#x2122;Ĺ&#x203A;Ä&#x2021; okna konfiguracyjnego zawierajÄ&#x2026;ca definicje zadaĹ&#x201E; komunikacyjnych pokazana jest na rysunku 5. Pierwszy wiersz z funkcjÄ&#x2026; FC3 Modbus odczytuje jeden rejestr z urzÄ&#x2026;dzenia nr 1 spod adresu 4003 i zapisuje wartoĹ&#x203A;Ä&#x2021; do zmiennej IN. Drugi wiersz z funkcjÄ&#x2026; FC16 zapisuje zmiennÄ&#x2026; OUT pod adres 4205 urzÄ&#x2026;dzenia nr 2. PoniewaĹź zmienna typu BOOL zajmuje jeden bajt, wykonywane sÄ&#x2026; konwersje 8- 16-bit. Obecna implementacja maszyny wirtualnej na komputer PC (softcontroller) zawiera wbudowany podstawowy serwer opracowany na podstawie publicznie dostÄ&#x2122;pnego LightOPC [34].
\1S1 Jak wspomniano, Ĺ&#x203A;rodowisko inĹźynierskie moĹźe byÄ&#x2021; przeniesione na docelowÄ&#x2026; platformÄ&#x2122; po opracowaniu: â&#x2C6;&#x2019; interfejsu dla platformy docelowej, â&#x2C6;&#x2019; narzÄ&#x2122;dzia konfigurujÄ&#x2026;cego komunikacjÄ&#x2122; i wejĹ&#x203A;cia/wyjĹ&#x203A;cia, â&#x2C6;&#x2019; moduĹ&#x201A;u uruchomieniowego umoĹźliwiajÄ&#x2026;cego przesĹ&#x201A;anie kodu binarnego i danych konfiguracyjnych do sterownika. Podsystemy automatyki okrÄ&#x2122;towej, jak sterowanie napÄ&#x2122;dami, kursem, zarzÄ&#x2026;dzanie poborem energii i inne, naleĹźÄ&#x2026;ce do systemu Mega-Guard z firmy Praxis [35] sÄ&#x2026; najistotniejszym wdroĹźeniem CPDev. KaĹźdy podsystem skĹ&#x201A;ada siÄ&#x2122; z procesora sterujÄ&#x2026;cego, jednostki bÄ&#x2026;dĹş jednostek wejĹ&#x203A;cia/wyjĹ&#x203A;cia i panelu dotykowego TFT, bazujÄ&#x2026;cych na CPU ARM. Procesor komunikuje siÄ&#x2122; z moduĹ&#x201A;ami I/O przez CAN, a z TFT przez Ethernet. WartoĹ&#x203A;ci zmiennych procesowych pokazywane sÄ&#x2026; na ekranie TFT. Sterownik StTr-PLC, skĹ&#x201A;adnik zintegrowanej platformy komunikacyjnej GSM/GPRS z firmy Nauka i Technika [36], nadzoruje i steruje rozproszonymi instalacjami. Sterownik zawiera procesor ARM-Cortex CPU, dotykowy panel TFT, wejĹ&#x203A;cia/wyjĹ&#x203A;cia i moduĹ&#x201A; komunikacyjny. Poza komunikacjÄ&#x2026; GSM/GPRS, sterownik StTr-PLC implementuje Wi-Fi oraz ZigBee. DziÄ&#x2122;ki komunikacji bezprzewodowej urzÄ&#x2026;dzenia z serii StTr sÄ&#x2026; takĹźe uĹźywane w zastosowaniach mobilnych, jak monitoring miejskiej komunikacji autobusowej. Inne przykĹ&#x201A;adowe wdroĹźenia obejmujÄ&#x2026; jednostki RTU z firmy iGrid [37] do automatyki podstacji energetycznych (protokoĹ&#x201A;y IEC 60870 i 61850) oraz sterownik PLC1 z firmy Bart-Com [38] ze zdalnymi moduĹ&#x201A;ami wejĹ&#x203A;cia/wyjĹ&#x203A;cia (Profibus DP, Modbus RTU) dedykowany do inteligentnych domĂłw.
25
G:& : _ .! & ! $ & +# Y
]1
10. Jamro M., RzoĹ&#x201E;ca D., RzÄ&#x2026;sa W., Testing communication tasks in distributed control systems with SysML and Timed Colored Petri Nets model, â&#x20AC;&#x153;Computers in Industryâ&#x20AC;?, Vol. 71, 2015, 77â&#x20AC;&#x201C;87, DOI: 10.1016/j.compind.2015.03.007. 11. Jamro M., POU-Oriented Unit Testing of IEC 61131-3 Control Software, â&#x20AC;&#x153;IEEE Transactions on Industrial Informaticsâ&#x20AC;?, Vol. 11, No. 5, 2015, 1119â&#x20AC;&#x201C;1129, DOI: 10.1109/TII.2015.2469257. 12. B. Venners, Inside the Java Virtual Machine. New York: McGraw-Hill Inc., 1997. 13. Richter J., Richter A., CLR via C#. Microsoft Press, 2006. 14. Schoeberl M., A Java Processor Architecture for Embedded Real-time Systems, â&#x20AC;&#x153;Journal of Systems Architectureâ&#x20AC;?, Vol. 54, No. 1â&#x20AC;&#x201C;2, 2008, 265â&#x20AC;&#x201C;286, DOI: 10.1016/j.sysarc.2007.06.001. 15. Zhou C., Chen H., Development of a PLC Virtual Machine Orienting IEC 61131-3 Standard, [in:] 2009 International Conference on Measuring Technology and Mechatronics Automation, Vol. 3, 2009, 374â&#x20AC;&#x201C;379, DOI: 10.1109/ICMTMA.2009.422. 16. Zhang M., Lu Y., Xia T., The Design and Implementation of Virtual Machine System in Embedded SoftPLC System, [in:] 2013 International Conference on Computer Sciences and Applications, 775â&#x20AC;&#x201C;778, DOI: 10.1109/CSA.2013.185. 17. Cavalieri S., Puglisi G., Scroppo M.S., Galvagno L., Moving IEC 61131-3 applications to a computing framework based on CLR Virtual Machine, [in:] 2016 IEEE 21st International Conference on Emerging Technologies and Factory Automation (ETFA), 1â&#x20AC;&#x201C;8, DOI: 10.1109/ETFA.2016.7733632. 18. De Tommasi G., Pironti A., An educational open-source tool for the design of IEC 61131-3 compliant automation software, [in:] 2008 International Symposium on Power Electronics, Electrical Drives, Automation and Motion, 486â&#x20AC;&#x201C;491, DOI: 10.1109/SPEEDHAM.2008.4581144. 19. Shin S., Kwon M., Rho S., Whimori CDK: A Control Program Development Kit, [in:] 2009 International Conference on Computing, Engineering and Information, 115â&#x20AC;&#x201C;118, DOI: 10.1109/ICC.2009.33. 20. Palma L.B., Brito V., Rosas J., Gil P., WEB PLC simulator for ST programming, [in:] 2017 4th Experiment@International Conference (exp.atâ&#x20AC;&#x2122;17), 303â&#x20AC;&#x201C;308, DOI: 10.1109/EXPAT.2017.7984410. 21. Inzunza VillagĂłmez H.I., PĂŠrez Arce B., HernĂĄndez Ruiz S.I., LĂłpez Corella J.A., Design and implementation of a development environment on ladder diagram (HT-PLC) for Arduino with Ethernet connection, [in:] 2018 IEEE International Conference on Automation/XXIII Congress of the Chilean Association of Automatic Control (ICAACCA), 1â&#x20AC;&#x201C;6, DOI: 10.1109/ICA-ACCA.2018.8609850. 22. Cooper K.D., Torczon L., Engineering a Compiler (Second Edition). Morgan Kaufmann, Boston 2012. 23. Fen G., Ning W., A Transformation Algorithm of Ladder Diagram into Instruction List Based on AOV Digraph and Binary Tree, [in:] TENCON 2006 â&#x20AC;&#x201C; 2006 IEEE Region 10 Conference, 1â&#x20AC;&#x201C;4, DOI: 10.1109/TENCON.2006.343937. 24. Huang L., Liu W., Liu Z., Algorithm of transformation from PLC ladder diagram to structured text, [in:] 2009 9th International Conference on Electronic Measurement Instruments, 4-778â&#x20AC;&#x201C;4-782, DOI: 10.1109/ICEMI.2009.5274701. 25. Milik A., Hrynkiewicz E., Distributed PLC Based on Multicore CPUs â&#x20AC;&#x201C; Architecture and Programming, â&#x20AC;&#x153;IFAC-PapersOnLineâ&#x20AC;?, Vol. 49, No. 25, 2016, 1â&#x20AC;&#x201C;7, DOI: 10.1016/j.ifacol.2016.12.001. 26. Fiset J.-Y., Human-Machine Interface Design for Process Control Applications. Instrumentation, Systems and Automation Society, 2009.
W artykule zaprezentowano przenoĹ&#x203A;ne Ĺ&#x203A;rodowisko inĹźynierskie, przeznaczone do implementacji w sterownikach przemysĹ&#x201A;owych z 8-, 16- lub 32-bitowymi procesorami. Ĺ&#x161;rodowisko oparte jest na maszynie wirtualnej wykonujÄ&#x2026;cej kod poĹ&#x203A;redni VMASM, do ktĂłrego kompilowane sÄ&#x2026; programy z jÄ&#x2122;zykĂłw ST lub IL. JÄ&#x2122;zyki graficzne sÄ&#x2026; najpierw tĹ&#x201A;umaczone do ST. Kompilator i maszyna wirtualna sÄ&#x2026; parametryzowane za pomocÄ&#x2026; plikĂłw konfiguracyjnych XML. Prototypy niskopoziomowych funkcji wbudowane w maszynÄ&#x2122; wirtualnÄ&#x2026; umoĹźliwiajÄ&#x2026; jej wdroĹźenie na róşnych platformach sprzÄ&#x2122;towych. DziÄ&#x2122;ki rozdzieleniu oprogramowania HMI na warstwy zaleĹźne i niezaleĹźne od sprzÄ&#x2122;tu, projekty HMI mogÄ&#x2026; byÄ&#x2021; wyĹ&#x203A;wietlane na róşnych urzÄ&#x2026;dzeniach. Generowany przez kompilator plik XML z danymi o zmiennych globalnych umoĹźliwia ich powiÄ&#x2026;zanie z interfejsami komunikacyjnymi i I/O. Zazwyczaj producenci urzÄ&#x2026;dzeĹ&#x201E; automatyki mogÄ&#x2026; samodzielnie zaimplementowaÄ&#x2021; opisane Ĺ&#x203A;rodowisko inĹźynierskie. Rozszerzenia Ĺ&#x203A;rodowiska o programowanie zorientowane obiektowo, wykonywanie zadaĹ&#x201E; wyzwalane zdarzeniowo i przeniesienie wieloprojektowego Ĺ&#x203A;rodowiska na wielordzeniowe procesory, ze wspĂłĹ&#x201A;bieĹźnym uruchamianiem projektĂłw na poszczegĂłlnych rdzeniach, sÄ&#x2026; obecnie opracowywane.
" Autorzy dziÄ&#x2122;kujÄ&#x2026; Marcinowi Jamro za pomoc przy rozwoju Ĺ&#x203A;rodowiska kilka lat temu. Projekt finansowany w ramach programu Ministra Nauki i Szkolnictwa WyĹźszego pod nazwÄ&#x2026; â&#x20AC;&#x17E;Regionalna Inicjatywa DoskonaĹ&#x201A;oĹ&#x203A;ciâ&#x20AC;? w latach 2019â&#x20AC;&#x201C;2022 nr projektu 027/RID/2018/19 caĹ&#x201A;kowita kwota finansowania 11 999 900 zĹ&#x201A;.
& L 0 1. Vogel-Heuser B., SchĂźtz D., Frank T., Legat C., Model-driven engineering of Manufacturing Automation Software Projects â&#x20AC;&#x201C; A SysMLbased approach, â&#x20AC;&#x153;Mechatronicsâ&#x20AC;?, Vol. 24, No. 7, 2014, 883â&#x20AC;&#x201C;897, DOI: 10.1016/j.mechatronics.2014.05.003. 2. Thramboulidis K., A cyberâ&#x20AC;&#x201C;physical system-based approach for industrial automation systems, â&#x20AC;&#x153;Computers in Industryâ&#x20AC;?, Vol. 72, 2015, 92â&#x20AC;&#x201C;102, DOI: 10.1016/j.compind.2015.04.006. 3. IEC 61131-3 - Programmable controllers - Part 3: Programming languages, 2003, 2013. 4. Hsieh S.-J., Cheng Y.-T., Algorithm and intel ligent tutoring system design for programmable controller programming, â&#x20AC;&#x153;The International Journal of Advanced Manufacturing Technologyâ&#x20AC;?, Vol. 71, No. 5â&#x20AC;&#x201C;8, 2014, 1099â&#x20AC;&#x201C;1115, DOI: 10.1007/s00170-013-5539-z. 5. ISaGRAF Technology, [www.isagraf.com]. 6. COPA-DATA France, Software components for industrial control, [www.straton-plc.com]. 7. RzoĹ&#x201E;ca D., Sadolewski J., Stec A., Ĺ&#x161;wider Z., Trybus B., Trybus L., Mini-DCS system programming in IEC 61131-3 Structured Text, â&#x20AC;&#x153;Journal of Automation, Mobile Robotics and Intelligent Systemsâ&#x20AC;?, Vol. 2, No. 3, 2008, 48â&#x20AC;&#x201C;54. 8. Cisek J., Mikluszka W., Ĺ&#x161;wider Z., Trybus L., A LowCost DCS with Multifunction Instruments and CAN Bus, â&#x20AC;&#x153;IFAC Proceedings Volumesâ&#x20AC;?, Vol. 34, No. 29, 2001, 64â&#x20AC;&#x201C;69, DOI: 10.1016/S1474-6670(17)32794-5. 9. Hajduk Z., Trybus B., Sadolewski J., Architecture of FPGA Embedded Multiprocessor Programmable Controller, â&#x20AC;&#x153;IEEE Transactions on Industrial Electronicsâ&#x20AC;?, Vol. 62, No. 5, 2015, 2952â&#x20AC;&#x201C;2961, DOI: 10.1109/TIE.2014.2362888.
26
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
! " !
27. VDI/VDE 3699 Process control using display screens, 2015. 28. Jamro M., RzoĹ&#x201E;ca D., Automatic connections in IEC 61131-3 Function Block Diagrams, [in:] 2013 Federated Conference on Computer Science and Information Systems, 463â&#x20AC;&#x201C;469. 29. Hart P.E., Nilsson N.J., Raphael B., A Formal Basis for the Heuristic Determination of Minimum Cost Paths, â&#x20AC;&#x153;IEEE Transactions on Systems Science and Cyberneticsâ&#x20AC;?, Vol. 4, No. 2, 1968, 100â&#x20AC;&#x201C;107, DOI: 10.1109/TSSC.1968.300136. 30. OMG, â&#x20AC;&#x153;OMG Systems Modeling Language, V1.3,â&#x20AC;? 2012. 31. Jamro M., RzoĹ&#x201E;ca D., Agile and hierarchical round-trip engineering of IEC 61131-3 control software, â&#x20AC;&#x153;Computers in Industryâ&#x20AC;?, Vol. 96, 2018, 1â&#x20AC;&#x201C;9, DOI: 10.1016/j.compind.2018.01.004. 32. Sadolewski J., Szmyd E., Polski kompilator oraz sterowniki programowane za pomocÄ&#x2026; jÄ&#x2122;zyka IL normy IEC 61131-3, â&#x20AC;&#x17E;Pomiary Automatyka Robotykaâ&#x20AC;?, R. 13, Nr 2, 2009, 615â&#x20AC;&#x201C;622. 33. Lumel S.A. [www.lumel.com.pl/en]. 34. Light OPC Server. [www.ipi.ac.ru]. 35. Praxis Automation Technology B.V. [www.praxis-automation.nl].
36. Nauka i Technika. [www.nit.pl]. 37. iGrid T&D. [www.igrid-td.com]. 38. Bart-Com. [www.bart-com.pl].
- 6 K ( ( K R % L @Q @ ( 2% 8 The IEC 61131-3 standard defines five languages, dedicated for programming industrial controllers. The standard is commonly used, there are numerous engineering environments fully or partially compatible with it. Several academic solutions have been described in the literature, but they typically implement only selected parts of the IEC 61131-3 standard (e.g. only one or two languages). On the other hand, commercial engineering environments usually implement all languages, but their documentation focuses on the application of the environment, whereas details about internal architecture and implementation are rarely disclosed. The paper describes such internal details of the CPDev engineering environment. The architecture based on the virtual machine makes the environment portable, thus facilitate implementation on diverse hardware platforms. Several industrial implementations of CPDev are also mentioned. KeywordsU -K B** *> $ ( ( $ % ( ( $ $ $ F"-$ $ %
( - / 0
( 1
% ' % ORCID: 0000-0001-5724-0978
' % ORCID: 0000-0001-7370-9027
X O . )!!)P$ ( V 6 O@ . )!!&P$ % % > 6 $ Y > 6 O@ Z [ )!*)P #% )!!& $ % )!* % T % - 6 > ; @ . \ ( [ @ ( ( % [ [
;/ 0 % K - 6 > @ . O)!!BP 0 )!*) U % > % 6 0 % ; > $ K - 6 @ Z [> H \ ( [ A A ( $ A %
27
G:& : _ .! & ! $ & +# Y
( 2 # 1
9 %( ( 3% 4
' % ORCID: 0000-0002-5615-3626
% /' % ORCID: 0000-0003-3504-5340
;/ 0 % K - 6 > @ . O*++ P > U % )!!& #/ % % % T > % - 6 ; @ . > ( % % [> A / % A
;/ 0 % K - 6 > @ . O*+=&P J 0 % ; $ K - 6 > @ Z [ H U % O*++)P % / ( > O)!!&P #% [ % $ % % ( A $ % > V % ( %A
( 5 6 %
( 9 %( ( 7 6 %
/ / ' % ORCID: 0000-0002-4588-3973
/ ' > ORCID: 0000-0002-1415-3679
;% T % - 6 ; @ . U % 0 % K $ ; $ - 6 > K ;HF T Q 6 )!!& \ ( ( A / % % [ A > ( % ( > [ (
U ;HF T A O*+G!P$ (% A V % $ / #% U> % A @ . > ; % )!! / 0 > T ; . / @;J ( > $
28
P
O
M
I
A
R
Y
â&#x20AC;¢
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;¢
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 29â&#x20AC;&#x201C;34, DOI: 10.14313/PAR_235/29
K% ( I A XQ 8<Q @Q 3% 4 @ . $ T % - 6 ; $ 0 @ )$ ?>+?+ . A
1 8 W artykule opisano edytory graficzne jÄ&#x2122;zykĂłw LD i FBD wykorzystywane w autorskim Ĺ&#x203A;rodowisku inĹźynierskim CPDev. Schematy stworzone za pomocÄ&#x2026; tych edytorĂłw sÄ&#x2026; wstÄ&#x2122;pnie konwertowane do kodu ĹşrĂłdĹ&#x201A;owego w ST, a nastÄ&#x2122;pnie tĹ&#x201A;umaczone do autorskiego kodu poĹ&#x203A;redniego. UnikalnÄ&#x2026; cechÄ&#x2026; edytorĂłw jest mechanizm automatycznego wyznaczania poĹ&#x201A;Ä&#x2026;czeĹ&#x201E; miÄ&#x2122;dzy elementami schematu, wykorzystujÄ&#x2026;cy algorytm A*. PoszczegĂłlne elementy schematu nie majÄ&#x2026; sztywno okreĹ&#x203A;lonego poĹ&#x201A;oĹźenia w polu roboczym, co wpĹ&#x201A;ywa na przejrzystoĹ&#x203A;Ä&#x2021; schematu. W trybie Ĺ&#x203A;ledzenia on-line, bezpoĹ&#x203A;rednio na schemacie graficznym wyĹ&#x203A;wietlane sÄ&#x2026; wartoĹ&#x203A;ci wyjĹ&#x203A;Ä&#x2021; poszczegĂłlnych elementĂłw. W tym celu schemat graficzny jest konwertowany do postaci grafu AOV, a nastÄ&#x2122;pnie upraszczany i bezpoĹ&#x203A;rednio z niego generowany jest kod ĹşrĂłdĹ&#x201A;owy w jÄ&#x2122;zyku ST. Opracowane edytory graficzne umoĹźliwiajÄ&#x2026; tworzenie zarĂłwno prostych jak i zĹ&#x201A;oĹźonych programĂłw sterowania, jak rĂłwnieĹź zapewniajÄ&#x2026; Ĺ&#x201A;atwÄ&#x2026; edycjÄ&#x2122;, klonowanie fragmentĂłw schematu, zapis, odczyt oraz drukowanie stworzonego diagramu. ) U
% V $ -K B** *> $ $ A XQ 8<Q$ % ( I $ ( 6 ;#]
1. Wprowadzenie
3 + U
/ ( Z % $ % /' %
przez inĹźynierĂłw w przemyĹ&#x203A;le, jak i studentĂłw. W kolejnych latach do pakietu dodano rozszerzenia dla 32- i 64-bitowych procesorĂłw, uzupeĹ&#x201A;niono je o translatory jÄ&#x2122;zykĂłw graficznych LD, FBD, SFC, narzÄ&#x2122;dzie do projektowania interfejsĂłw HMI i wieloprojektowe Ĺ&#x203A;rodowisko uruchomieniowe. Dwa kolejne rozszerzenia wsparĹ&#x201A;y badania nad podejĹ&#x203A;ciem MDD (ang. Model Driven Development) [3] i testami jednostkowymi [4]. Do tej pory Ĺ&#x203A;rodowisko CPDev zostaĹ&#x201A;o wdroĹźone przez kilku znaczÄ&#x2026;cych producentĂłw urzÄ&#x2026;dzeĹ&#x201E; automatyki w kraju i za granicÄ&#x2026;. Translatory jÄ&#x2122;zykĂłw graficznych (LD, FBD) na jÄ&#x2122;zyk ST, wbudowane w pakiety inĹźynierskie, czÄ&#x2122;sto bazujÄ&#x2026; na grafach AOV (ang. Activity on Vertex) [5, 6]. W pakiecie CPDev moduĹ&#x201A; translatora rĂłwnieĹź korzysta z grafu AOV, z ktĂłrego to bezpoĹ&#x203A;rednio (po optymalizacji) generowany jest program w jÄ&#x2122;zyku ST. SzczegĂłĹ&#x201A;y zostanÄ&#x2026; przedstawione w rozdziale 5. W artykule zaprezentowano dwa elementy Ĺ&#x203A;rodowiska inĹźynierskiego CPDev â&#x20AC;&#x201C; edytory graficzne jÄ&#x2122;zykĂłw LD i FBD, zgodnych z normÄ&#x2026; IEC 61131-3. W kolejnym rozdziale przedstawiono budowÄ&#x2122; Ĺ&#x203A;rodowiska, gĹ&#x201A;Ăłwne okno programu oraz interfejs uĹźytkownika. W rozdziale 3 opisano moĹźliwoĹ&#x203A;ci edytorĂłw LD i FBD, a w rozdziale 4 translator schematĂłw graficznych na kod ĹşrĂłdĹ&#x201A;owy w jÄ&#x2122;zyku ST (wraz z przykĹ&#x201A;adami konwersji). W podsumowaniu przedstawiono wybrane wdroĹźenia przemysĹ&#x201A;owe pakietu CPDev.
3 % *) !+ )!*+ $ % % !? *) )!*+
S1 <
Ĺ&#x161;rodowiska inĹźynierskie implementujÄ&#x2026;ce jÄ&#x2122;zyki normy IEC 61131-3 [1] (przyjÄ&#x2122;tej w Polsce jako PN-EN 61131-3) sÄ&#x2026; powszechnie stosowane w przemyĹ&#x203A;le do tworzenia programĂłw sterowania. Standard ten definiuje piÄ&#x2122;Ä&#x2021; jÄ&#x2122;zykĂłw programowania, w tym dwa tekstowe IL, ST, dwa graficzne LD, FBD oraz mieszany jÄ&#x2122;zyk SFC. JÄ&#x2122;zyki IL, LD i SFC sÄ&#x2026; przeznaczone gĹ&#x201A;Ăłwnie do zastosowaĹ&#x201E; w procesach produkcyjnych opartych na sterownikach PLC, natomiast jÄ&#x2122;zyki ST, FBD sÄ&#x2026; stosowane w obszarach wykorzystujÄ&#x2026;cych sterowniki PAC. Prace nad Ĺ&#x203A;rodowiskiem inĹźynierskim zgodnym z normÄ&#x2026; IEC 61131-3 rozpoczÄ&#x2122;Ĺ&#x201A;y siÄ&#x2122; juĹź ponad 10 lat temu [2]. Opracowane wtedy Ĺ&#x203A;rodowisko nazwane zostaĹ&#x201A;o CPDev (ang. Control Program Developer) i kompilowaĹ&#x201A;o jedynie programy z jÄ&#x2122;zyka ST do autorskiego kodu VMASM (ang. Virtual Machine Assembler) interpretowanego nastÄ&#x2122;pnie przez stworzonÄ&#x2026; maszynÄ&#x2122; wirtualnÄ&#x2026;, zaimplementowanÄ&#x2026; poczÄ&#x2026;tkowo na oĹ&#x203A;miobitowych mikrokontrolerach MCS 51 i AVR. Od poczÄ&#x2026;tku Ĺ&#x203A;rodowisko wspieraĹ&#x201A;o moĹźliwoĹ&#x203A;Ä&#x2021; samodzielnej implementacji maszyny wirtualnej na docelowym sprzÄ&#x2122;cie, zarĂłwno
!
Ĺ&#x161;rodowisko inĹźynierskie, takie jak przedstawiany tu pakiet CPDev, moĹźna uznaÄ&#x2021; za: (1) uniwersalne, jeĹ&#x203A;li umoĹźliwia gene-
29
@ ! ! A ` ! J " q & +# Y rowanie kodu wykonywalnego na różne Platforma 1 platformy sprzętowe, (2) otwarte pod Maszyna Interfejs Kod Program Program względem programowym i sprzętowym, wirtualna we/wy progr. Program w ST VMASM jeżeli dostępne są dla użytkownika końT w LD r Platforma 2 cowego narzędzia do tworzenia własnych a n bloków funkcjonalnych oraz specyfikaInterfejs Maszyna Kod Program s Kompilator wirtualna we/wy progr. l w FBD cje interfejsów wejścia/wyjścia, (3) elaa t styczne, jeżeli spośród wszystkich typów o Platforma 3 Program r danych zdefiniowanych w normie IEC Program w SFC Interfejs Kod Maszyna można swobodnie wybrać te, które najzasobów w IL we/wy progr. wirtualna lepiej odpowiadają danej aplikacji. Pierwsza wersja CPDev, wspierająca Rys. 1. Etapy tworzenia oprogramowania dla różnych platform sprzętowych Fig. 1. Stages of software development for various hardware platforms początkowo jedynie język ST, została w kolejnych latach rozszerzona o obsługę pozostałych języków normy IEC 611313, graficzne projektowanie interfejsów HMI, automatyczny generator dokumentacji oraz dodatkowe moduły o zastosowaniu badawczym. Na rysunku 1 przedstawiono kolejne etapy przetwarzania programów sterowania napisanych w różnych językach normy. Języki tekstowe (ST, IL) są tu bezpośrednio kompilowane do mnemoników opracowanego na potrzeby środowiska specjalizowanego języka VMASM. Diagramy graficzne LD, FBD i SFC są najpierw konwertowane na język ST, a następnie kompilowane do VMASM. Język ST jest więc bazowym językiem środowiska CPDev. Wykonywalny kod binarny programu jest generowany z mnemoników VMASM i ładowany do maszyny wirtualnej. Źródła maszyny wirtualnej napisano w całości w języku C, co znacząco ułatwia przenośność na różne platformy sprzętowe. Rys. 2. Główne okno programu i interfejs użytkownika w systemie CPDev Fig. 2. The main program window and the user interface in the CPDev system Podstawowe funkcjonalności CPDev są podobne do innych tego typu środowisk inżynierskich [7, 8]. Nowością jest autorski mechanizm komunikacyjnym potrzebne dane za pomocą zmiennych gloautomatycznego wyznaczania połączeń między elementami balnych. graficznymi na schematach FBD i LD [9] bazujący na algoNa rysunku 2 pokazano główne okno interfejsu CPDev, rytmie A* [10]. Również tworzony przez użytkownika schemat zawierające: − (po lewej stronie) drzewa struktury projektu, zmiennych graficzny jest konwertowany do postaci grafu AOV [5], który następnie jest upraszczany (eliminowane są nadmiarowe węzły) globalnych, wykonywanych zadań, zastosowanych bibliotek i dostępnych zasobów programowych, i bezpośrednio z niego generowany jest program w języku ST. − (na górze) menu główne i paski narzędziowe (ikony do szybKompilator wykorzystuje zbiór reguł języka ST, biblioteki bloków funkcjonalnych oraz wykaz instrukcji elementarkiego wyboru), − (na dole) okno komunikatów, raportów oraz informacji stanych realizowanych przez maszynę wirtualną. Oprócz kodu tusowych, wykonywalnego tworzone są informacje służące do śledze− (centralnie) obszar roboczy z oknami zawierającymi pronia, uruchamiania i symulacji programu. Konfiguracja zasobów sprzętowych dotyczy pamięci, interfejsu wejścia/wyjścia gramy użytkownika w językach normy IEC 61131-3 (ST, oraz interfejsu komunikacyjnego, a specyfikacja obejmuje typy IL, LD, FBD, SFC). W obszarze roboczym (rys. 2) otwarte są dwa okna: jedno i obszary pamięci, liczby oraz typy wejść i wyjść oraz kanały komunikacyjne. programu (prog_1) w języku FBD oraz drugie funkcji użytkowPodstawowe składniki maszyny wirtualnej to: pamięci pronika (fn_1) w języku LD – funkcja ta użyta jest w programie gramu i danych, osobne stosy programu i danych, moduł prog_1. Interfejsy obu edytorów graficznych (FBD i LD) są wykonywania instrukcji oraz interfejs dla docelowej platformy. identyczne, co znacząco ułatwia ich obsługę przez użytkownika Maszyna wirtualna działa jako interpreter wykonując kolejne końcowego tworzącego programy sterowania. W programie są linie kodu programu. Interfejs dla docelowej platformy składa to jednak dwie osobne klasy FBDEditor oraz LDEditor dziedziczące od wspólnej klasy bazowej GraphicEditor. się z niskopoziomowych funkcji zależnych od sprzętu i systemu Poszczególne programy lub funkcje (napisane w dowolnych operacyjnego, jak aktualizacja wejść i wyjść czy też zarządzajęzykach normy) mogą także wymieniać dane przez zmienne nie czasem cyklu. globalne. Do dyspozycji użytkownika są też gotowe biblioteki Poza maszyną wirtualną wykonującą główne zadania sterowania, środowisko uruchomieniowe może zawierać również funkcji i bloków funkcjonalnych zgodnych z normą IEC 61131-3, moduły HMI obsługujące poszczególne interfejsy graficzne do zarówno z wejściem EN jak i bez niego. Na bieżąco dołączane komunikacji z operatorem. Maszyna wirtualna i moduł HMI są także własne biblioteki. działają wtedy równolegle i niezależnie, wymieniając kanałem
30
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
V1 0 " # %& $
UĹźytkownik moĹźe rĂłwnieĹź tworzyÄ&#x2021; wĹ&#x201A;asne funkcje i bloki funkcjonalne gromadzÄ&#x2026;c je w swoich bibliotekach â&#x20AC;&#x201C; moĹźna tu korzystaÄ&#x2021; ze wszystkich doĹ&#x201A;Ä&#x2026;czonych bibliotek i dostÄ&#x2122;pnych jÄ&#x2122;zykĂłw (ST, IL, LD, FBD, SFC). Na rys. 5 pokazano przykĹ&#x201A;ad funkcji uĹźytkownika (o nazwie fn_1) opracowanej w jÄ&#x2122;zyku LD. Funkcja ma dwa wejĹ&#x203A;cia (in1, in2) oraz wyjĹ&#x203A;cie (o takiej samej nazwie jak nazwa funkcji). W oknie wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci elementu moĹźna modyfikowaÄ&#x2021; jego nazwÄ&#x2122;, typ, dziaĹ&#x201A;anie oraz okreĹ&#x203A;liÄ&#x2021;, czy jest to wejĹ&#x203A;cie lub wyjĹ&#x203A;cie funkcji czy teĹź zmienna lokalna (pomocnicza) lub globalna.
WspĂłlnÄ&#x2026; cechÄ&#x2026; zaimplementowanych w pakiecie CPDev edytorĂłw diagramĂłw FBD i LD jest mechanizm automatycznego wyznaczania poĹ&#x201A;Ä&#x2026;czeĹ&#x201E; miÄ&#x2122;dzy elementami za pomocÄ&#x2026; zmodyfikowanego algorytmu A* [10], Ĺ&#x201A;Ä&#x2026;czÄ&#x2026;cego podejĹ&#x203A;cie konwencjonalne z heurystycznym. Modyfikacja ta polega na dodaniu wspĂłĹ&#x201A;czynnikĂłw wagowych [9], ktĂłrych odpowiedni dobĂłr wpĹ&#x201A;ywa znaczÄ&#x2026;co na liczbÄ&#x2122; przeciÄ&#x2122;Ä&#x2021; z innymi poĹ&#x201A;Ä&#x2026;czeniami, jak teĹź na liczbÄ&#x2122; zmian kierunkĂłw (w gĂłrÄ&#x2122;, w dĂłĹ&#x201A;, w lewo, w prawo), aby moĹźliwie zmniejszyÄ&#x2021; dĹ&#x201A;ugoĹ&#x203A;Ä&#x2021; poĹ&#x201A;Ä&#x2026;czeĹ&#x201E;. DziÄ&#x2122;ki temu elementy schematu, takie jak bloki, funkcje, styki czy cewki, nie majÄ&#x2026; Ĺ&#x203A;ciĹ&#x203A;le przywiÄ&#x2026;zanego poĹ&#x201A;oĹźenia w polu roboczym (np. poziomo w drabince LD) i mogÄ&#x2026; byÄ&#x2021; rozmieszczone dowolnie w polu roboczym. WpĹ&#x201A;ywa to znaczÄ&#x2026;co na przejrzystoĹ&#x203A;Ä&#x2021; schematu i pozwala w Ĺ&#x201A;atwy sposĂłb go modyfikowaÄ&#x2021; i dodawaÄ&#x2021; nowe elementy w razie potrzeby. PrzykĹ&#x201A;adowy program (diagram) Rys. 3. Program w FBD utworzony w edytorze graficznym pakietu CPDev w jÄ&#x2122;zyku FBD jest pokazany na rys. Fig. 3. The program in FBD created in the graphic editor of the CPDev package 3. UĹźyto tu instancji bloku bibliotecznego (TOF) oraz bramek AND i OR. ZwrĂłÄ&#x2021;my uwagÄ&#x2122;, Ĺźe w odróşnieniu od innych tego typu pakietĂłw inĹźynierskich (np. [7, 8]), poĹ&#x201A;oĹźenie elementĂłw schematu (blokĂłw, funkcji itp.) jest tu dowolne, a kolejnoĹ&#x203A;Ä&#x2021; ich przetwarzania jest zdefiniowana przez uĹźytkownika (okreĹ&#x203A;la to liczba w dolnej czÄ&#x2122;Ĺ&#x203A;ci prostokÄ&#x2026;ta, np. bramka AND bÄ&#x2122;dzie przetwarzana jako pierwsza). OczywiĹ&#x203A;cie uĹźytkownik moĹźe w kaĹźdej chwili zmieniÄ&#x2021; tÄ&#x2122; kolejnoĹ&#x203A;Ä&#x2021;, wstawiÄ&#x2021; lub usunÄ&#x2026;Ä&#x2021; jakiĹ&#x203A; element, czy teĹź sklonowaÄ&#x2021; fragment schematu (kolejnoĹ&#x203A;Ä&#x2021; elementĂłw zostanie wtedy automatycznie przenumerowana). Tak utworzone schematy sÄ&#x2026; przeksztaĹ&#x201A;cane do programĂłw ĹşrĂłdĹ&#x201A;owych w jÄ&#x2122;zyku ST, gdzie mogÄ&#x2026; byÄ&#x2021; dowolnie modyfikowane. Podobnie bloki funkcjonalne lub funkcje, napisane przez uĹźytkownika w innych jÄ&#x2122;zykach normy, sÄ&#x2026; Rys. 4. Program w LD utworzony w edytorze graficznym pakietu CPDev automatycznie obrazowane w edytorze Fig. 4. The program in LD created in the graphic editor of the CPDev package graficznym i mogÄ&#x2026; byÄ&#x2021; tam uĹźyte do tworzenia kolejnych schematĂłw. PrzykĹ&#x201A;adowy schemat w jÄ&#x2122;zyku drabinkowym (LD) pokazano na rys. 4. SkĹ&#x201A;ada siÄ&#x2122; on z trzech szczebli, gdzie w pierwszym zastosowano zestyki a na wyjĹ&#x203A;ciu cewkÄ&#x2122; (out1). Tutaj rĂłwnieĹź, w zaleĹźnoĹ&#x203A;ci od preferencji uĹźytkownika, moĹźna trzymaÄ&#x2021; siÄ&#x2122; â&#x20AC;&#x17E;klasycznegoâ&#x20AC;? sposobu tworzenia schematu LD (elementy w jednej linii) lub zastosowaÄ&#x2021; format â&#x20AC;&#x17E;swobodnyâ&#x20AC;? (np. wysuniÄ&#x2122;ty w gĂłrÄ&#x2122; zestyk in2). W drugim szczeblu uĹźyto funkcji bibliotecznej AND z wejĹ&#x203A;ciem EN oraz celowo wysuniÄ&#x2122;tÄ&#x2026; w gĂłrÄ&#x2122; zmiennÄ&#x2026; wejĹ&#x203A;ciowÄ&#x2026; in3. W trzecim szczeblu zastosowano instancjÄ&#x2122; bloku funkcjonalnego TON (takĹźe z wejRys. 5. PrzykĹ&#x201A;ad tworzenia funkcji uĹźytkownika w edytorze LD Fig. 5. An example of creating a user function in the LD editor Ĺ&#x203A;ciem EN).
31
@ ! ! A ` ! J " q & +# Y
X1 4 " # $ %&
linii programu w ST oraz wprowadzane sÄ&#x2026; dodatkowe zmienne lokalne reprezentujÄ&#x2026;ce wyjĹ&#x203A;cia elementĂłw schematu (z prefiksem, np. out_contact_ czy teĹź out_bp_, oraz postfiksem, np. _80_80 oznaczajÄ&#x2026;cym wspĂłĹ&#x201A;rzÄ&#x2122;dne elementu na schemacie). Zatem zmienna out_contact_input1_80_80 oznacza wyjĹ&#x203A;cie elementu input1 (zestyku) o wspĂłĹ&#x201A;rzÄ&#x2122;dnych (80, 80) â&#x20AC;&#x201C; na grafie AOV odpowiada jej wÄ&#x2122;zeĹ&#x201A; wirtualny vn1 (virtiual node). Podobnie, wyjĹ&#x203A;ciu elementu input3 odpowiada wÄ&#x2122;zeĹ&#x201A; vn2. PoĹ&#x201A;Ä&#x2026;czenie szeregowe wÄ&#x2122;zĹ&#x201A;a wirtualnego i rzeczywistego tĹ&#x201A;umaczone jest jako operacja AND (np. vn4 := vn3 AND input2), natomiast rĂłwnolegĹ&#x201A;e dwĂłch wÄ&#x2122;zĹ&#x201A;Ăłw wirtualnych jako OR (np. vn3 := vn1 OR vn2). W podobny sposĂłb konwertowane sÄ&#x2026; zĹ&#x201A;oĹźone schematy LD. Ze wzglÄ&#x2122;du na swobodny format diagramu LD (elementy szczebla nie muszÄ&#x2026; leĹźeÄ&#x2021; w jednej linii), kolejnoĹ&#x203A;Ä&#x2021; przetwarzania elementĂłw na schemacie wyznaczana jest na podstawie grafu AOV, a nie ich fizycznego poĹ&#x201A;oĹźenia (wspĂłĹ&#x201A;rzÄ&#x2122;dnych) na diagramie. Dlatego teĹź wysuniÄ&#x2122;cie zestykĂłw in2 oraz out2 na schemacie (rys. 8) nie ma Ĺźadnego wpĹ&#x201A;ywu na generowany kod (analizowany jest graf AOV, a nie poĹ&#x201A;oĹźenie elementĂłw na diagramie). Funkcje i bloki funkcjonalne w jÄ&#x2122;zyku LD mogÄ&#x2026; mieÄ&#x2021; dodatkowe wejĹ&#x203A;cie EN (enable). Norma IEC 61131-3 nie traktuje go jako zwykĹ&#x201A;ego wejĹ&#x203A;cia, dlatego teĹź programy uĹźywajÄ&#x2026;ce funkcji lub blokĂłw z EN naleĹźy w sposĂłb specjalny przekonwertowaÄ&#x2021; na ST (rys. 9). Konwertowanie programĂłw w FBD jest prostsze (rys. 10), gdyĹź kolejnoĹ&#x203A;Ä&#x2021; przetwarzania elementĂłw schematu jest definiowana przez uĹźytkownika (w oknie wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci).
Jednym z zaĹ&#x201A;oĹźeĹ&#x201E; przy tworzeniu pakietu CPDev byĹ&#x201A;o to, aby w trybie debugowania moĹźliwe byĹ&#x201A;o wyĹ&#x203A;wietlanie bezpoĹ&#x203A;rednio na schemacie (diagramie) wartoĹ&#x203A;ci wyjĹ&#x203A;Ä&#x2021; wszystkich uĹźytych elementĂłw (stykĂłw, cewek, blokĂłw funkcjonalnych i funkcji). Przedstawiono to na rys. 6. Z lewej strony okna, w miejscu drzewa projektu, prezentowane sÄ&#x2026; wtedy wartoĹ&#x203A;ci wybranych zmiennych (globalnych i lokalnych) oraz wejĹ&#x203A;Ä&#x2021; i wyjĹ&#x203A;Ä&#x2021; uĹźytych blokĂłw i funkcji. Dodatkowo na schemacie w oknie roboczym w trybie on-line, po najechaniu kursorem na poĹ&#x201A;Ä&#x2026;czenie, wyĹ&#x203A;wietlane sÄ&#x2026; aktualne wartoĹ&#x203A;ci zmiennych (np. FALSE na wyjĹ&#x203A;ciu zestyku ALARM) oraz poszczegĂłlne poĹ&#x201A;Ä&#x2026;czenia miÄ&#x2122;dzy elementami schematu zmieniajÄ&#x2026; kolor lub atrybut (np. TRUE â&#x20AC;&#x201C; linia ciÄ&#x2026;gĹ&#x201A;a niebieska, FALSE â&#x20AC;&#x201C; linia przerywana czarna). Dlatego teĹź stworzony przez uĹźytkownika schemat w jÄ&#x2122;zyku LD jest najpierw konwertowany do postaci grafu AOV, ktĂłrego to wierzchoĹ&#x201A;kami (vertices) sÄ&#x2026; te wĹ&#x201A;aĹ&#x203A;nie elementy schematu (reprezentujÄ&#x2026;ce zmienne, zadania lub czynnoĹ&#x203A;ci), a krawÄ&#x2122;dzie grafu (edges) definiujÄ&#x2026; poĹ&#x201A;Ä&#x2026;czenia (relacje) miÄ&#x2122;dzy nimi (rys. 7). Tak stworzony graf AOV jest kolejno upraszczany (eliminowane sÄ&#x2026; nadmiarowe wÄ&#x2122;zĹ&#x201A;y), a nastÄ&#x2122;pnie bezpoĹ&#x203A;rednio z niego generowany jest program w jÄ&#x2122;zyku ST. W przeciwieĹ&#x201E;stwie do translatorĂłw opisywanych m.in. w pracach [5, 6], tutaj graf AOV nie jest przeksztaĹ&#x201A;cany do drzewa binarnego, gdyĹź (zgodnie z pierwotnym zaĹ&#x201A;oĹźeniem) potrzebne sÄ&#x2026; wartoĹ&#x203A;ci na wyjĹ&#x203A;ciach kaĹźdego elementu. MoĹźna to zaobserwowaÄ&#x2021; we fragmencie programu LD (rys. 7), gdzie jeden wiersz diagramu tĹ&#x201A;umaczony jest na kilka
Rys. 6. WyglÄ&#x2026;d okienek pakietu CPDev w trybie debugowania on-line Fig. 6. The appearance of CPDev package windows in on-line debug mode
vn0
input1
vn1
input3
vn3
input2
vn4
output1
vn5
vn2
vn1: vn2: vn3: vn4: vn5: Rys. 7. Program w LD, odpowiadajÄ&#x2026;cy mu graf AOV oraz tĹ&#x201A;umaczenie na jÄ&#x2122;zyk ST Fig. 7. The LD program, the corresponding AOV graph and translation into ST
32
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Rys. 8. PrzykĹ&#x201A;ad tĹ&#x201A;umaczenia szczebla drabinki w LD na jÄ&#x2122;zyk ST Fig. 8. Example of ladder rung translation into ST language
Rys. 9. Program z blokiem z wejĹ&#x203A;ciem EN i jego tĹ&#x201A;umaczenie na jÄ&#x2122;zyk ST Fig. 9. Program with a block with EN input and its translation into ST
(1) (2) (3)
Rys. 10. Program w jÄ&#x2122;zyku FBD i jego tĹ&#x201A;umaczenie na jÄ&#x2122;zyk ST Fig. 10. The program in FBD and its translation into ST
Z1 W artykule zaprezentowano edytory jÄ&#x2122;zykĂłw LD i FBD stosowane w Ĺ&#x203A;rodowisku inĹźynierskim CPDev. Programy w jÄ&#x2122;zykach graficznych normy IEC 61131-3, jak LD, FBD i SFC, sÄ&#x2026; wstÄ&#x2122;pnie konwertowane do kodu ĹşrĂłdĹ&#x201A;owego w ST, natomiast programy w jÄ&#x2122;zykach tekstowych ST i IL sÄ&#x2026; juĹź bezpoĹ&#x203A;rednio tĹ&#x201A;umaczone do kodu poĹ&#x203A;redniego VMASM. UnikalnÄ&#x2026; cechÄ&#x2026; opracowanych edytorĂłw graficznych diagramĂłw FBD i LD jest mechanizm automatycznego wyznaczania poĹ&#x201A;Ä&#x2026;czeĹ&#x201E; miÄ&#x2122;dzy elementami schematu z wykorzystaniem zmodyfikowanego algorytmu A*. DziÄ&#x2122;ki temu poszczegĂłlne elementy schematu nie majÄ&#x2026; z gĂłry narzuconego poĹ&#x201A;oĹźenia w polu roboczym (np. w drabince LD), a wiÄ&#x2122;c mogÄ&#x2026; byÄ&#x2021; rozmieszczone dowolnie, co znaczÄ&#x2026;co wpĹ&#x201A;ywa na przejrzystoĹ&#x203A;Ä&#x2021; schematu i jednoczeĹ&#x203A;nie pozwala w Ĺ&#x201A;atwy sposĂłb go modyfikowaÄ&#x2021;. Przy projektowaniu pakietu CPDev przyjÄ&#x2122;to, Ĺźe w trybie debugowania moĹźliwe bÄ&#x2122;dzie wyĹ&#x203A;wietlanie bezpoĹ&#x203A;rednio na schemacie graficznym (diagramie) wartoĹ&#x203A;ci wyjĹ&#x203A;Ä&#x2021; jego poszczegĂłlnych elementĂłw. Dlatego schemat w jÄ&#x2122;zyku LD jest najpierw konwertowany do postaci grafu AOV, ktĂłry to jest kolejno upraszczany (eliminowane sÄ&#x2026; nadmiarowe wÄ&#x2122;zĹ&#x201A;y), a bezpoĹ&#x203A;rednio z niego generowany jest kod ĹşrĂłdĹ&#x201A;owy w jÄ&#x2122;zyku ST (przykĹ&#x201A;ady zamieszczono w rozdziale 4). Sterowniki podsystemĂłw automatyki okrÄ&#x2122;towej, naleĹźÄ&#x2026;ce do systemu Mega-Guard z firmy Praxis [11], sÄ&#x2026; najistotniejszym wdroĹźeniem pakietu CPDev. KaĹźdy moduĹ&#x201A; skĹ&#x201A;ada siÄ&#x2122; z procesora sterujÄ&#x2026;cego, jednostek wejĹ&#x203A;cia/wyjĹ&#x203A;cia i panelu dotykowego TFT, komunikujÄ&#x2026;cych siÄ&#x2122; przez CAN lub Ethernet. Natomiast wdroĹźenia firmy Nauka i Technika [12] bazujÄ&#x2026; na sterowniku StTr-PLC, bÄ&#x2122;dÄ&#x2026;cym skĹ&#x201A;adnikiem zintegrowanej platformy wykorzystujÄ&#x2026;cej moduĹ&#x201A;y komunikacyjne GSM, Wi-Fi oraz ZigBee.
" Autor dziÄ&#x2122;kuje wspĂłĹ&#x201A;twĂłrcom Ĺ&#x203A;rodowiska CPDev, w szczegĂłlnoĹ&#x203A;ci Leszkowi Trybusowi, Bartoszowi Trybusowi, Janowi Sadolewskiemu, Dariuszowi RzoĹ&#x201E;ca oraz Marcinowi Jamro, za wszelkÄ&#x2026; pomoc przy tworzeniu i modyfikacjach opisywanych tu edytorĂłw graficznych.
& L 0 1. IEC 61131-3 â&#x20AC;&#x201C; Programmable controllers â&#x20AC;&#x201C; Part 3: Programming languages, 2003, 2013. 2. RzoĹ&#x201E;ca D., Sadolewski J., Stec A., Ĺ&#x161;wider Z., Trybus B., Trybus L., Mini-DCS system programming in IEC 61131-3 Structured Text, â&#x20AC;&#x153;Journal of Automation, Mobile Robotics and Intelligent Systemsâ&#x20AC;?, Vol. 2, No. 3, 2008, 48â&#x20AC;&#x201C;54. 3. Jamro M., RzoĹ&#x201E;ca D., RzÄ&#x2026;sa W., Testing communication tasks in distributed control systems with SysML and Timed Colored Petri Nets model, â&#x20AC;&#x153;Computers in Industryâ&#x20AC;?, Vol. 71, 2015, 77â&#x20AC;&#x201C;87, DOI: 10.1016/j.compind.2015.03.007. 4. Jamro M., POU-Oriented Unit Testing of IEC 61131-3 Control Software, â&#x20AC;&#x153;IEEE Transactions on Industrial Informaticsâ&#x20AC;?, Vol. 11, No. 5, 2015, 1119â&#x20AC;&#x201C;1129, DOI: 10.1109/TII.2015.2469257. 5. Fen G., Ning W., A Transformation Algorithm of Ladder Diagram into Instruction List Based on AOV Digraph and Binary Tree [in:] TENCON â&#x20AC;&#x201C; IEEE Region 10 Conference, 2006, DOI: 10.1109/TENCON.2006.343937. 6. Huang L., Liu W., Liu Z., Algorithm of transformation from PLC ladder diagram to structured text [in:] 9th International Conference on Electronic Measurement Instruments, 2009, 4-778â&#x20AC;&#x201C;4-782, DOI: 10.1109/ICEMI.2009.5274701. 7. 3S-Smart Software Solutions GmbH, CODESYS, [www. codesys.com].
33
@ ! ! A ` ! J " q & +# Y
H K% 6 XQ % 8<Q X ( ( @Q @ ( 2% 8 The article describes graphic editors of LD and FBD languages used in the CPDev proprietary engineering community. The diagrams created with the help of these editors are pre-converted to source code in ST, and then translated into the authorâ&#x20AC;&#x2122;s intermediate code. A unique feature of these editors is the mechanism of automatically determining connections between diagram elements using the A* algorithm. Individual elements of the diagram do not have a rigid position in the working field (e.g. LD ladder), which significantly affects the transparency of the diagram. In on-line tracking mode, the output values of its individual elements are displayed directly on the graphic scheme. To ensure this, the graphic schema is first converted to an AOV graph, and then simplified and the ST source code is directly generated from it. Developed graphic editors allow creating both simple and complex control programs, as well as ensure easy editing, cloning of fragments of the scheme, saving, loading and printing of the created diagram. KeywordsU ( ( $ -K B** *> $ $ XQ % 8<Q ( ( $ ( % $ ;#] (
9 %( ( 3% 4 % /' % ORCID: 0000-0003-3504-5340 ;/ 0 % K - 6 > @ . O*+=&P J 0 % ; $ K - 6 > @ Z [ H U % O*++)P % / ( > O)!!&P #% [ % $ % % ( A $ % > V % ( %A
34
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 35â&#x20AC;&#x201C;40, DOI: 10.14313/PAR_235/35
@ % ( F"- % V @Q - / 0 @ . $ T % - 6 ; $ 0 @ )$ ?>+?+ . A
1 8 Panele operatorskie HMI sÄ&#x2026; powszechnie stosowane w systemach automatyki przemysĹ&#x201A;owej. PozwalajÄ&#x2026; na wizualizacjÄ&#x2122; sterowania procesem przemysĹ&#x201A;owym, jak rĂłwnieĹź na zmianÄ&#x2122; parametrĂłw. WartoĹ&#x203A;ci prezentowane operatorowi na ekranie procesowym pochodzÄ&#x2026; ze sterownika, bÄ&#x2026;dĹş sterownikĂłw, poĹ&#x201A;Ä&#x2026;czonych Ĺ&#x201A;Ä&#x2026;czem komunikacyjnym. Wydajna komunikacja miÄ&#x2122;dzy HMI a sterownikiem jest niezbÄ&#x2122;dna dla prawidĹ&#x201A;owego dziaĹ&#x201A;ania systemu automatyki. W artykule przeanalizowano kilka aspektĂłw takiej komunikacji i zaproponowano rozwiÄ&#x2026;zania pozwalajÄ&#x2026;ce na skrĂłcenie czasu cyklu komunikacyjnego. Opisane metody zostaĹ&#x201A;y zaimplementowane w pakiecie inĹźynierskim CPDev. ) U $ @X $ $ F"-$
1. Wprowadzenie Ĺ&#x161;rodowisko inĹźynierskie CPDev [1, 2] jest opracowanym w Katedrze Informatyki i Automatyki Politechniki Rzeszowskiej zestawem narzÄ&#x2122;dzi pozwalajÄ&#x2026;cym na programowanie sterownikĂłw PLC (ang. Programmable Logic Controller) i PAC (ang. Programmable Automation Controller) w jÄ&#x2122;zykach normy IEC 61131-3, przyjÄ&#x2122;tej w Polsce jako PN-EN 61131-3 [3]. Norma ta definiuje piÄ&#x2122;Ä&#x2021; jÄ&#x2122;zykĂłw programowania, dwa tekstowe: ST (ang. Structured Text) i IL (ang. Instruction List), dwa graficzne: FBD (ang. Function Block Diagram) i LD (ang. Ladder Diagram) oraz mieszany jÄ&#x2122;zyk SFC (ang. Sequential Function Chart). Ĺ&#x161;rodowisko CPDev pozwala na programowanie w kaĹźdym z wymienionych jÄ&#x2122;zykĂłw. Pakiet CPDev zostaĹ&#x201A; wdroĹźony w kilku rozwiÄ&#x2026;zaniach technicznych, przygotowanych przez polskich i zagranicznych producentĂłw urzÄ&#x2026;dzeĹ&#x201E; automatyki przemysĹ&#x201A;owej. Pakiet CPDev zawiera narzÄ&#x2122;dzie CPVis pozwalajÄ&#x2026;ce na przygotowanie ekranĂłw procesowych dla panelu operatorskiego HMI (ang. Human-Machine Interface). Wizualizacja przebiegu procesu sterowania na panelu HMI jest rozwiÄ&#x2026;zaniem czÄ&#x2122;sto stosowanym w systemach automatyki. CharakterystycznÄ&#x2026; cechÄ&#x2026; CPDev jest przygotowywanie wizualizacji w powiÄ&#x2026;zaniu z programem sterowania. Wysokopoziomowe mechanizmy wizualiza-
3 + U
Q . U $ % ' > 3 % *B *! )!*+ $ % % )G ** )!*+
!
cyjne sÄ&#x2026; niezaleĹźne od sprzÄ&#x2122;tu, mogÄ&#x2026; byÄ&#x2021; wdroĹźone na docelowej platformie sprzÄ&#x2122;towej, po opracowaniu zestawu niskopoziomowych funkcji graficznych. WÄ&#x2026;skim gardĹ&#x201A;em moĹźe byÄ&#x2021; jednak interfejs komunikacyjny. Wymagania wydajnoĹ&#x203A;ciowe byĹ&#x201A;y motywacjÄ&#x2026; do przeprowadzenia opisanych w artykule badaĹ&#x201E; i przetestowania proponowanych rozwiÄ&#x2026;zaĹ&#x201E; w praktyce. W kolejnym rozdziale przedstawiono krĂłtki przeglÄ&#x2026;d literatury powiÄ&#x2026;zanej z tematykÄ&#x2026; artykuĹ&#x201A;u. Trzeci rozdziaĹ&#x201A; zwiÄ&#x2122;Ĺşle przedstawia Ĺ&#x203A;rodowisko inĹźynierskie CPDev, zwĹ&#x201A;aszcza w kontekĹ&#x203A;cie przygotowywania wizualizacji dla paneli HMI. Kolejny z rozdziaĹ&#x201A;Ăłw poĹ&#x203A;wiÄ&#x2122;cony jest problematyce wymiany danych miÄ&#x2122;dzy sterownikiem a HMI i moĹźliwym optymalizacjom. Ostatni z rozdziaĹ&#x201A;Ăłw podsumowuje artykuĹ&#x201A;.
S1 + WymianÄ&#x2122; danych miÄ&#x2122;dzy sterownikiem a pozostaĹ&#x201A;ymi urzÄ&#x2026;dzeniami automatyki, w tym panelami HMI, zazwyczaj zapewnia dedykowana przemysĹ&#x201A;owa sieÄ&#x2021; komunikacyjna [4]. Typowo bazuje ona na magistrali polowej [5] i jednym z przemysĹ&#x201A;owych protokoĹ&#x201A;Ăłw komunikacyjnych zdefiniowanych w normie IEC 61158 [6]. W literaturze opisywano takĹźe inne, niestandardowe rozwiÄ&#x2026;zania, na przykĹ&#x201A;ad korzystajÄ&#x2026;ce z protokoĹ&#x201A;u HTTP (ang. Hypertext Transfer Protocol ) zamiast specjalizowanego protokoĹ&#x201A;u przemysĹ&#x201A;owego [7, 8], ale nie sÄ&#x2026; one zazwyczaj stosowane w praktyce. Komunikacja w systemach automatyki przemysĹ&#x201A;owej moĹźe korzystaÄ&#x2021; z róşnych paradygmatĂłw dostÄ&#x2122;pu do Ĺ&#x201A;Ä&#x2026;cza komunikacyjnego, takich jak na przykĹ&#x201A;ad producent-dystrybutor-konsument, przekazywanie znacznika (ang. token passing), czy najczÄ&#x2122;Ĺ&#x203A;ciej stosowany paradygmat master-slave [9]. KaĹźdy z nich bazuje na multipleksowaniu z podziaĹ&#x201A;em czasu TDM (ang. Time Division Multiplexing) definiujÄ&#x2026;c szczeliny czasowe, gdy poszczegĂłlne urzÄ&#x2026;dzenia majÄ&#x2026; dostÄ&#x2122;p do Ĺ&#x201A;Ä&#x2026;cza. PrzykĹ&#x201A;a-
35
# & ! _ : & :! $ & : & : g/G _ .! : +# Y dowo w paradygmacie master-slave jedno z urzÄ&#x2026;dzeĹ&#x201E; podĹ&#x201A;Ä&#x2026;czonych do wspĂłlnej magistrali jest urzÄ&#x2026;dzeniem nadrzÄ&#x2122;dnym, inicjujÄ&#x2026;cym transmisjÄ&#x2122;, a pozostaĹ&#x201A;e urzÄ&#x2026;dzeniami podrzÄ&#x2122;dnymi, mogÄ&#x2026;cymi przesĹ&#x201A;aÄ&#x2021; komunikat jedynie w odpowiedzi na polecenie mastera. Alternatywne podejĹ&#x203A;cie, korzystajÄ&#x2026;ce z multipleksowania z podziaĹ&#x201A;em czÄ&#x2122;stotliwoĹ&#x203A;ci FDM (ang. Frequency Division Multiplexing) jest rozwaĹźane w literaturze [10], ale nie zostaĹ&#x201A;o przyjÄ&#x2122;te w praktyce. Zasady graficznego projektowania aplikacji sterowania, do ktĂłrych naleĹźÄ&#x2026; takĹźe ekrany procesowe HMI, przedstawiono w pracach [11, 12]. Obszaru tego dotyczy takĹźe standard VDI/ VDE 3699 [13]. Sposoby uwzglÄ&#x2122;dnienia czynnika ludzkiego podczas projektowania HMI przedstawiono w pracach [14, 15]. Pierwsze wersje rozszerzeĹ&#x201E; pakietu inĹźynierskiego CPDev o moĹźliwoĹ&#x203A;Ä&#x2021; projektowania interfejsĂłw graficznych opisano w [16, 17]. AktualnÄ&#x2026; funkcjonalnoĹ&#x203A;Ä&#x2021; w tym zakresie pokazano w [18].
teĹź zĹ&#x201A;oĹźone (np. bargraf, wykres). Parametry poszczegĂłlnych obiektĂłw (rozmiar, kolor itp.) mogÄ&#x2026; byÄ&#x2021; ustalone jako staĹ&#x201A;e, bÄ&#x2026;dĹş powiÄ&#x2026;zane ze zmiennymi z programu sterowania, wizualizujÄ&#x2026;c stan procesu. Takie powiÄ&#x2026;zanie moĹźe dotyczyÄ&#x2021; zmiennej wejĹ&#x203A;ciowej, bezpoĹ&#x203A;rednio odczytywanej z sensora (np. stan zaworu otwarty/zamkniÄ&#x2122;ty), bÄ&#x2026;dĹş dodatkowej zmiennej, obliczanej wyĹ&#x201A;Ä&#x2026;cznie na potrzeby wizualizacji (np. kolor obiektu zmienny przedziaĹ&#x201A;ami, uzaleĹźniony od temperatury). W drugim przypadku jest konieczne przygotowanie wraz z wizualizacjÄ&#x2026; dodatkowych, prostych programĂłw w jednym z jÄ&#x2122;zykĂłw IEC 61131-3 (typowo w ST), obliczajÄ&#x2026;cych wartoĹ&#x203A;ci wizualizowanych zmiennych. Proces ten szerzej opisano w [18]. NaleĹźy podkreĹ&#x203A;liÄ&#x2021;, Ĺźe takie programy wizualizacyjne mogÄ&#x2026; byÄ&#x2021; przygotowane w innym jÄ&#x2122;zyku niĹź gĹ&#x201A;Ăłwny program sterowania. PrzykĹ&#x201A;adowy wyglÄ&#x2026;d edytora graficznego CPVis pokazano na rys. 1. Druga czÄ&#x2122;Ĺ&#x203A;Ä&#x2021; â&#x20AC;&#x201C; Ĺ&#x203A;rodowisko wykonawcze â&#x20AC;&#x201C; jest uruchamiana na panelu HMI. Wizualizacja zaprojektowana na komputerze PC w programie CPVis jest kompilowana do kodu poĹ&#x203A;redniego, ktĂłry jest interpretowany przez Ĺ&#x203A;rodowisko wykonawcze uruchomione na panelu HMI. Kod poĹ&#x203A;redni zawiera informacje o obiektach z biblioteki uĹźytych na poszczegĂłlnych ekranach, ich lokalizacji, wielkoĹ&#x203A;ci, powiÄ&#x2026;zaniu ze zmiennymi itd. Interpretacja tego kodu pozwala na obliczenie bieĹźÄ&#x2026;cego wyglÄ&#x2026;du ekranu procesowego i wyĹ&#x203A;wietlenie go operatorowi. Proces ten ponawiany jest cyklicznie, z zadanym interwaĹ&#x201A;em. Biblioteka obiektĂłw graficznych bazuje na podstawowych elementach, jak na przykĹ&#x201A;ad linia, koĹ&#x201A;o czy tekst. Podczas implementacji Ĺ&#x203A;rodowiska wykonawczego CPVis na docelowym panelu HMI jest konieczne przygotowanie procedur graficznych rysujÄ&#x2026;cych te podstawowe elementy, w sposĂłb zaleĹźny od sprzÄ&#x2122;tu. PozostaĹ&#x201A;a czÄ&#x2122;Ĺ&#x203A;Ä&#x2021; Ĺ&#x203A;rodowiska wykonawczego jest niezaleĹźna od sprzÄ&#x2122;tu, co uĹ&#x201A;atwia wdroĹźenie. Jedno z takich wdroĹźeĹ&#x201E;, dla autopilota okrÄ&#x2122;towego, przedstawiono w [19].
V1 4 '(
Jak wspomniano w poprzednich rozdziaĹ&#x201A;ach Ĺ&#x203A;rodowisko inĹźynierskie CPDev pozwala na programowanie sterownikĂłw przemysĹ&#x201A;owych w jÄ&#x2122;zykach normy IEC 61131-3. Jednym z moduĹ&#x201A;Ăłw wbudowanych w pakiet CPDev jest CPVis, narzÄ&#x2122;dzie dedykowane do przygotowywania wizualizacji w powiÄ&#x2026;zaniu z implementacjÄ&#x2026; programĂłw sterowania. CPVis skĹ&#x201A;ada siÄ&#x2122; z dwĂłch czÄ&#x2122;Ĺ&#x203A;ci â&#x20AC;&#x201C; edytora graficznego uruchamianego na komputerze PC i Ĺ&#x203A;rodowiska wykonawczego implementowanego na docelowym panelu operatorskim HMI [17]. Edytor graficzny pozwala na projektowanie wizualizacji korzystajÄ&#x2026;cej z biblioteki obiektĂłw graficznych. Standardowa biblioteka zawiera zarĂłwno proste obiekty (np. prostokÄ&#x2026;t), jak
Rys. 1. Edytor graficzny CPVis Fig. 1. CPVis graphical editor
36
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
X1 ; * "
'( Panele HMI wyĹ&#x203A;wietlajÄ&#x2026; operatorowi ekrany procesowe, przedstawiajÄ&#x2026;ce stan obiektu, bieĹźÄ&#x2026;ce wartoĹ&#x203A;ci sygnaĹ&#x201A;Ăłw, sterowania, wartoĹ&#x203A;Ä&#x2021; zadanÄ&#x2026; itp. Wiele z elementĂłw graficznych, z ktĂłrych zbudowane sÄ&#x2026; ekrany procesowe, to elementy dynamiczne, a nie statyczne, co oznacza, Ĺźe ich aktualny wyglÄ&#x2026;d zaleĹźy od wartoĹ&#x203A;ci poszczegĂłlnych zmiennych. Dynamika moĹźe wprowadzaÄ&#x2021; zmianÄ&#x2122; elementu graficznego w zaleĹźnoĹ&#x203A;ci od stanu sygnaĹ&#x201A;u (np. odmienne grafiki przedstawiajÄ&#x2026;ce zawĂłr otwarty lub zamkniÄ&#x2122;ty), jak teĹź zmianÄ&#x2122; jego parametrĂłw (np. wysokoĹ&#x203A;Ä&#x2021; prostokÄ&#x2026;ta ilustrujÄ&#x2026;cego poziom cieczy w zbiorniku, czy jego kolor odzwierciedlajÄ&#x2026;cy temperaturÄ&#x2122; pĹ&#x201A;ynu). By to osiÄ&#x2026;gnÄ&#x2026;Ä&#x2021; niezbÄ&#x2122;dne jest cykliczne przekazywanie do panelu HMI bieĹźÄ&#x2026;cych wartoĹ&#x203A;ci zmiennych, powiÄ&#x2026;zanych z elementami graficznymi. Taka wymiana danych prowadzona jest zazwyczaj w jednym z przemysĹ&#x201A;owych protokoĹ&#x201A;Ăłw komunikacyjnych. Na potrzeby dalszej analizy przyjmijmy, Ĺźe zastosowano protokĂłĹ&#x201A; Modbus RTU. Nie zawÄ&#x2122;Ĺźa to jednak ogĂłlnoĹ&#x203A;ci rozwaĹźaĹ&#x201E;, wiele dalszych kwestii moĹźna analogicznie rozpatrywaÄ&#x2021; takĹźe dla innych protokoĹ&#x201A;Ăłw. ProtokĂłĹ&#x201A; Modbus RTU bazuje na paradygmacie dostÄ&#x2122;pu do Ĺ&#x201A;Ä&#x2026;cza typu master-slave. Oznacza to, Ĺźe jedno z urzÄ&#x2026;dzeĹ&#x201E; jest urzÄ&#x2026;dzeniem nadrzÄ&#x2122;dnym, inicjujÄ&#x2026;cym transmisjÄ&#x2122;, a pozostaĹ&#x201A;e sÄ&#x2026; urzÄ&#x2026;dzeniami podrzÄ&#x2122;dnymi. W przypadku komunikacji panelu HMI ze sterownikiem moĹźliwa jest zarĂłwno konfiguracja, gdzie panel HMI jest urzÄ&#x2026;dzeniem typu master (nadrzÄ&#x2122;dnym), a sterownik â&#x20AC;&#x201C; slave (urzÄ&#x2026;dzeniem podrzÄ&#x2122;dnym) jak teĹź sytuacja odwrotna (sterownik â&#x20AC;&#x201C; master, HMI â&#x20AC;&#x201C; slave). WybĂłr odpowiedniej konfiguracji dla danego systemu automatyki zaleĹźy od moĹźliwoĹ&#x203A;ci komunikacyjnych sterownika, panelu HMI, jak teĹź od liczby poĹ&#x201A;Ä&#x2026;czonych sterownikĂłw i paneli. JeĹźeli panel HMI ma wyĹ&#x203A;wietlaÄ&#x2021; obrazy procesowe wymagajÄ&#x2026;ce odczytu zmiennych z kilku sterownikĂłw, to zazwyczaj konfiguruje siÄ&#x2122; je jako slave, a panel jako master. JeĹźeli natomiast do jednego sterownika ma byÄ&#x2021; podĹ&#x201A;Ä&#x2026;czonych kilka paneli HMI, to czÄ&#x2122;sto konfiguracja jest odwrotna i to sterownik zapisuje wartoĹ&#x203A;ci do panelu HMI. ZakĹ&#x201A;adajÄ&#x2026;c ustalonÄ&#x2026; liczbÄ&#x2122; zmiennych, ktĂłrych wartoĹ&#x203A;ci naleĹźy przesĹ&#x201A;aÄ&#x2021;, konfiguracja ta nie ma wiÄ&#x2122;kszego wpĹ&#x201A;ywu na liczbÄ&#x2122; transmitowanych bajtĂłw, moĹźe natomiast poĹ&#x203A;rednio wpĹ&#x201A;ywaÄ&#x2021; na czas cyklu komunikacyjnego, w zaleĹźnoĹ&#x203A;ci od czasu odpowiedzi poszczegĂłlnych urzÄ&#x2026;dzeĹ&#x201E;. Dla uproszczenia przyjmijmy w dalszych rozwaĹźaniach, Ĺźe urzÄ&#x2026;dzeniem nadrzÄ&#x2122;dnym jest panel HMI. W protokole Modbus zdefiniowano polecenia (funkcje) pozwalajÄ&#x2026;ce na wymianÄ&#x2122; danych. NajczÄ&#x2122;Ĺ&#x203A;ciej uĹźywane wymieniono poniĹźej: â&#x2C6;&#x2019; FC1 â&#x20AC;&#x201C; odczyt zmiennych binarnych, â&#x2C6;&#x2019; FC2 â&#x20AC;&#x201C; odczyt wejĹ&#x203A;Ä&#x2021; binarnych, â&#x2C6;&#x2019; FC3 â&#x20AC;&#x201C; odczyt rejestrĂłw, â&#x2C6;&#x2019; FC4 â&#x20AC;&#x201C; odczyt rejestrĂłw wejĹ&#x203A;ciowych, â&#x2C6;&#x2019; FC5 â&#x20AC;&#x201C; zapis pojedynczej zmiennej binarnej, â&#x2C6;&#x2019; FC6 â&#x20AC;&#x201C; zapis pojedynczego rejestru, â&#x2C6;&#x2019; FC15 â&#x20AC;&#x201C; zapis wielu zmiennych binarnych, â&#x2C6;&#x2019; FC16 â&#x20AC;&#x201C; zapis wielu rejestrĂłw. Zmienne binarne i rejestry mogÄ&#x2026; byÄ&#x2021; zarĂłwno odczytywane i zapisywane, wejĹ&#x203A;cia binarne i rejestry wejĹ&#x203A;ciowe sÄ&#x2026; tylko do odczytu. Podczas korzystania z funkcji bitowych (FC1, FC2, FC5, FC15) stan zmiennej binarnej kodowany jest na pojedynczym bicie, co pozwala na przesĹ&#x201A;anie informacji o oĹ&#x203A;miu zmiennych w jednym bajcie. Rejestry sÄ&#x2026; szesnastobitowe. W praktyce zestaw zaimplementowanych funkcji spoĹ&#x203A;rĂłd wymienionych i adresacja wykorzystana w sterowniku zaleĹźy od producenta. Spotykane sÄ&#x2026; na przykĹ&#x201A;ad rozwiÄ&#x2026;zania implementujÄ&#x2026;ce jedynie funkcje dotyczÄ&#x2026;ce zmiennych binarnych i rejestrĂłw (bez wejĹ&#x203A;Ä&#x2021; binarnych i rejestrĂłw wejĹ&#x203A;ciowych) i mapujÄ&#x2026;ce wejĹ&#x203A;cia
pod odpowiednimi adresami pozostaĹ&#x201A;ych zmiennych. Niekiedy zmienne binarne mapowane sÄ&#x2026; w przestrzeni adresowej rejestrĂłw, co pozwala na odczyt zmiennych róşnego typu (takĹźe binarnych) jednym poleceniem, wraz z innymi rejestrami. RozwaĹźmy polecenie odczytujÄ&#x2026;ce rejestry (FC3). Jego ramkÄ&#x2122; przedstawiono na rysunku 2. W jednym poleceniu urzÄ&#x2026;dzenie nadrzÄ&#x2122;dne moĹźe zaĹźÄ&#x2026;daÄ&#x2021; od urzÄ&#x2026;dzenia podrzÄ&#x2122;dnego przesĹ&#x201A;ania wartoĹ&#x203A;ci wielu zmiennych (rejestrĂłw). Liczba rejestrĂłw odczytywanych pojedynczym poleceniem nie moĹźe przekroczyÄ&#x2021; 125, z uwagi na ograniczenie wielkoĹ&#x203A;ci pojedynczej wiadomoĹ&#x203A;ci (odpowiedzi) do 256 bajtĂłw. Oznacza to, Ĺźe starszy bajt w polu liczby rejestrĂłw bÄ&#x2122;dzie zawsze rĂłwny zero. Adres slave
Kod funkcji
Adres poczÄ&#x2026;tkowy
Liczba rejestrĂłw
Suma kontrolna
1B
1B (0x03)
2B
2B
2B
Rys. 2. Ramka polecenia FC3 Modbus RTU Fig. 2. Frame of Modbus RTU FC3 function
Adres slave
Kod funkcji
Liczba bajtĂłw
Dane
Suma kontrolna
1B
1B (0x03)
1B
n Ă&#x2014; 2B
2B
Rys. 3. Ramka odpowiedzi FC3 Modbus RTU Fig. 3. Frame of reply to Modbus RTU FC3 function
W odpowiedzi urzÄ&#x2026;dzenie podrzÄ&#x2122;dne przesyĹ&#x201A;a ramkÄ&#x2122; (rys. 3). Jej dĹ&#x201A;ugoĹ&#x203A;Ä&#x2021; jest zmienna i zaleĹźy od liczby odczytywanych rejestrĂłw. Ĺ atwo zauwaĹźyÄ&#x2021;, Ĺźe przesĹ&#x201A;anie w jednej transakcji komunikacyjnej (zapytanie-odpowiedĹş) wartoĹ&#x203A;ci wielu rejestrĂłw wymaga, by byĹ&#x201A;y to kolejne rejestry. Oznacza to, Ĺźe najkorzystniejsza jest sytuacja, gdy wszystkie zmienne wykorzystywane na danym ekranie sÄ&#x2026;siadujÄ&#x2026; ze sobÄ&#x2026; w pamiÄ&#x2122;ci sterownika. Aby zapewniÄ&#x2021; korzystnÄ&#x2026;, sÄ&#x2026;siedniÄ&#x2026; lokalizacjÄ&#x2122; zmiennych, najprostsze jest ich wĹ&#x201A;aĹ&#x203A;ciwe rozmieszczenie bezpoĹ&#x203A;rednio na etapie implementacji programu sterowania. W przypadku zmiennych globalnych i programu w jÄ&#x2122;zyku ST inĹźynier moĹźe wpĹ&#x201A;ywaÄ&#x2021; na lokalizacjÄ&#x2122; zmiennych za pomocÄ&#x2026; modyfikatora AT. Jest to jednak Ĺźmudne rozwiÄ&#x2026;zanie, moĹźe takĹźe prowadziÄ&#x2021; do komplikacji podczas dalszych modyfikacji programu. Zadanie to znacznie upraszcza siÄ&#x2122;, jeĹźeli pakiet inĹźynierski wspiera inĹźynieriÄ&#x2122; wahadĹ&#x201A;owÄ&#x2026; [20] lub przynajmniej udostÄ&#x2122;pnia szablony kodĂłw ĹşrĂłdĹ&#x201A;owych na podstawie tworzonych modeli, na przykĹ&#x201A;ad w jÄ&#x2122;zyku SysML [21]. Niestety, optymalne, z uwagi na wymagania komunikacyjne, rozmieszczenie wszystkich zmiennych niekiedy jest niemoĹźliwe, zwĹ&#x201A;aszcza dla zmiennych zĹ&#x201A;oĹźonych (tablic, struktur) lub wykorzystywanych na wielu ekranach procesowych. Innym rozwiÄ&#x2026;zaniem jest utworzenie kopii wszystkich transmitowanych zmiennych, sÄ&#x2026;siadujÄ&#x2026;co w kolejnych komĂłrkach pamiÄ&#x2122;ci. Pozwala to na odczytanie jednym poleceniem wielu zmiennych bÄ&#x2122;dÄ&#x2026;cych elementami róşnych struktur czy tablic, jak teĹź wykorzystywanych na wielu ekranach (wĂłwczas tworzonych jest wiele kopii, osobna dla kaĹźdego ekranu). Niestety podejĹ&#x203A;cie to wymaga kaĹźdorazowej synchronizacji wartoĹ&#x203A;ci oryginalnej zmiennej i kaĹźdej jej kopii, po dowolnej modyfikacji. Alternatywne podejĹ&#x203A;cie, proponowane w tym artykule, nie wymaga modyfikacji programu sterowania. ZauwaĹźmy, Ĺźe niekiedy korzystniejsze czasowo moĹźe byÄ&#x2021; odczytanie wiÄ&#x2122;kszego fragmentu pamiÄ&#x2122;ci, zawierajÄ&#x2026;cego oprĂłcz wymaganych zmiennych takĹźe inne rejestry i zignorowanie nadmiarowych informacji, tylko po to by wymiana danych bazowaĹ&#x201A;a na pojedynczej transakcji komunikacyjnej, a nie dwĂłch, bÄ&#x2026;dĹş nawet kilku, sukcesywnie odczytujÄ&#x2026;cych jedynie wymagane obszary. Nie zawsze jednak takie rozwiÄ&#x2026;zanie bÄ&#x2122;dzie prowadziÄ&#x2021; do poprawy para-
37
# & ! _ : & :! $ & : & : g/G _ .! : +# Y
metrĂłw czasowych. Przedstawiona dalej analiza teoretyczna pozwala na obliczenie czasu cyklu komunikacyjnego w róşnych przypadkach i wybranie korzystniejszego. RozwaĹźmy sytuacjÄ&#x2122;, gdy wymagany jest odczyt dwĂłch szesnastobitowych zmiennych (dwĂłch rejestrĂłw Modbus) tak rozmieszczonych w pamiÄ&#x2122;ci sterownika, Ĺźe miÄ&#x2122;dzy nimi leĹźÄ&#x2026; takĹźe inne rejestry. PrzykĹ&#x201A;ad takiej sytuacji pokazano na rysunku 4.
na Ĺ&#x201A;Ä&#x2026;cznÄ&#x2026; dĹ&#x201A;ugoĹ&#x203A;Ä&#x2021; pojedynczej ramki Modbus. W takim przypadku czas cyklu wynosi:
Róşnica tcycle1 â&#x2C6;&#x2019; tcycle2 okreĹ&#x203A;la, o ile krĂłtszy jest czas cyklu komunikacyjnego w drugim przypadku. WartoĹ&#x203A;ci dodatnie oznaczajÄ&#x2026;, Ĺźe drugi przypadek jest korzystniejszy; ujemne, Ĺźe korzystniejszy jest przypadek pierwszy.
PrzestrzeĹ&#x201E; adresowa sterownika
(
)
tcycle1 â&#x2C6;&#x2019; tcycle2 = 20 â&#x2C6;&#x2019; 2k tb + tm + ts Ĺ atwo zauwaĹźyÄ&#x2021;, Ĺźe dla k 10 istnieje korzyĹ&#x203A;Ä&#x2021; z zastosowania drugiego sposobu odczytu, niezaleĹźnie od czasĂłw tm, ts > 0. Dla k > 10, wybierajÄ&#x2026;c optymalny sposĂłb naleĹźy wziÄ&#x2026;Ä&#x2021; pod uwagÄ&#x2122; czasy tm i ts zaleĹźne od zastosowanych urzÄ&#x2026;dzeĹ&#x201E;. OczywiĹ&#x203A;cie analogiczne obliczenia moĹźna przeprowadziÄ&#x2021; dla wielu grup wizualizowanych zmiennych, rozdzielonych innymi zmiennymi w pamiÄ&#x2122;ci sterownika. Takie rozwiÄ&#x2026;zanie, dynamicznie wybierajÄ&#x2026;ce sposĂłb transmisji w zaleĹźnoĹ&#x203A;ci od poĹ&#x201A;oĹźenia zmiennych, zaimplementowano w pakiecie inĹźynierskim CPDev. Rys. 4. PrzykĹ&#x201A;adowe rozmieszczenie zmiennych w pamiÄ&#x2122;ci sterownika Fig. 4. Example location of variables in the controllerâ&#x20AC;&#x2122;s memory
Y1 W artykule przedstawiono wpĹ&#x201A;yw rozmieszczenia zmiennych globalnych, wizualizowanych na panelu HMI, na opóźnienia komunikacyjne. Zaproponowano metody poprawy parametrĂłw czasowych, w szczegĂłlnoĹ&#x203A;ci bazujÄ&#x2026;ce na koncepcji grupowania zmiennych i zbiorczego odczytu. Przedstawiono sposĂłb obliczania czasu cyklu komunikacyjnego w zaleĹźnoĹ&#x203A;ci od przyjÄ&#x2122;tej metody odczytu, pozwalajÄ&#x2026;cy na stwierdzenie czy automatyczne grupowanie poprawi parametry czasowe w konkretnym przypadku. Wspomniany mechanizm zostaĹ&#x201A; zaimplementowany w pakiecie inĹźynierskim CPDev.
Pokazane na rysunku 4 zmienne Valves[1] i Tank[2]. Temperature sÄ&#x2026; wizualizowane na jednym ekranie procesowym i ich wartoĹ&#x203A;ci muszÄ&#x2026; byÄ&#x2021; cyklicznie odczytywane przez panel HMI. Nie ma moĹźliwoĹ&#x203A;ci zmiany adresĂłw tych zmiennych, tak by leĹźaĹ&#x201A;y obok siebie, gdyĹź sÄ&#x2026; to elementy zĹ&#x201A;oĹźonych zmiennych (tablic i struktury). Zmienne te mogÄ&#x2026; byÄ&#x2021; odczytywane pojedynczo, w dwĂłch osobnych transakcjach komunikacyjnych, bÄ&#x2026;dĹş grupowo, w jednej transakcji, ale wraz z nadmiarowymi rejestrami leĹźÄ&#x2026;cymi miÄ&#x2122;dzy nimi. Przeanalizujmy te dwie moĹźliwoĹ&#x203A;ci pod kÄ&#x2026;tem wpĹ&#x201A;ywu na czas cyklu komunikacyjnego. Dla zachowania ogĂłlnoĹ&#x203A;ci zaĹ&#x201A;óşmy, Ĺźe interesujÄ&#x2026;ce nas zmienne sÄ&#x2026; odseparowane od siebie przez k innych rejestrĂłw. Przy pojedynczym odczycie zmiennych w ramach jednego cyklu komunikacyjnego przesyĹ&#x201A;ane sÄ&#x2026; dwie pary zapytanie/odpowiedĹş. KaĹźdorazowo zapytanie wymaga przesĹ&#x201A;ania 8 bajtĂłw, a odpowiedĹş 7 bajtĂłw (zgodnie z ramkami przedstawionymi na rysunkach 2 i 3). W cyklu komunikacyjnym przesyĹ&#x201A;ane jest wiÄ&#x2122;c 30 bajtĂłw. Dodatkowo konieczne jest speĹ&#x201A;nienie wymagaĹ&#x201E; czasowych protokoĹ&#x201A;u Modbus RTU. ProtokĂłĹ&#x201A; wymaga, by miÄ&#x2122;dzy ramkami przesyĹ&#x201A;anymi na magistralÄ&#x2122; wystÄ&#x2122;powaĹ&#x201A;y okresy ciszy na linii, o minimalnej dĹ&#x201A;ugoĹ&#x203A;ci rĂłwnej czasowi transmisji 3,5 znaku. Dalsze opóźnienia wprowadzane sÄ&#x2026; przez przetwarzanie danych po stronie obu urzÄ&#x2026;dzeĹ&#x201E;. Oznaczmy jako tb czas transmisji pojedynczego bajtu (zaleĹźny od ustalonej prÄ&#x2122;dkoĹ&#x203A;ci Ĺ&#x201A;Ä&#x2026;cza komunikacyjnego), tm â&#x20AC;&#x201C; czas potrzebny na przygotowanie zapytania przez urzÄ&#x2026;dzenie nadrzÄ&#x2122;dne (master), ts â&#x20AC;&#x201C; czas potrzebny na przygotowanie odpowiedzi przez urzÄ&#x2026;dzenie podrzÄ&#x2122;dne (slave), a tcycle1 â&#x20AC;&#x201C; Ĺ&#x201A;Ä&#x2026;czny czas cyklu komunikacyjnego w i-tym przypadku. BazujÄ&#x2026;c na poprzednio przedstawionych wyliczeniach uzyskujemy:
(
" Projekt finansowany w ramach programu Ministra Nauki i Szkolnictwa WyĹźszego pod nazwÄ&#x2026; â&#x20AC;&#x17E;Regionalna Inicjatywa DoskonaĹ&#x201A;oĹ&#x203A;ciâ&#x20AC;? w latach 2019â&#x20AC;&#x201C;2022 nr projektu 027/ RID/2018/19 caĹ&#x201A;kowita kwota finansowania 11 999 900 zĹ&#x201A;.
& L 0 1. RzoĹ&#x201E;ca D., Sadolewski J., Stec A., Ĺ&#x161;wider Z., Trybus B., Trybus L., CPDev engineering environment for control programming, [in:] Trends in Advanced Intelligent Control, Optimization and Automation (W. Mitkowski, J. Kacprzyk, K. OprzÄ&#x2122;dkiewicz, P. Skruch, eds.), (Cham), Vol. 577, 303â&#x20AC;&#x201C;314, Springer International Publishing, 2017, DOI: 10.1007/978-3-319-60699-6_29. 2. Jamro M., RzoĹ&#x201E;ca D., Sadolewski J., Stec A., Ĺ&#x161;wider Z., Trybus B., Trybus L., CPDev Engineering Environment for Modeling, Implementation, Testing, and Visualization of Control Software, [in:] Recent Advances in Automation, Robotics and Measuring Techniques (R. Szewczyk, C. ZieliĹ&#x201E;ski, and M. KaliczyĹ&#x201E;ska, eds.), (Cham), Vol. 267, 81â&#x20AC;&#x201C;90, Springer International Publishing, 2014, DOI: 10.1007/978-3-319-05353-0_9. 3. IEC 61131-3 - Programmable controllers â&#x20AC;&#x201C; Part 3: Programming languages, 2003, 2013. 4. Silva M., Pereira F., Soares F., LeĂŁo C.P., Machado J., Carvalho V., An Overview of Industrial Communication Networks, [in:] New Trends in Mechanism and Machine Science (P. Flores and F. Viadero, eds.), (Cham),
)
tcycle1 = 2 tm + 8tb + 3, 5tb + ts + 7tb + 3, 5tb = 44tb + 2tm + 2ts W drugim przypadku, jeĹźeli zmienne bÄ&#x2122;dÄ&#x2026; transmitowane w ramach jednej transakcji zapytanie/odpowiedĹş, zapytanie rĂłwnieĹź wymaga przesĹ&#x201A;ania 8 bajtĂłw, ale dĹ&#x201A;ugoĹ&#x203A;Ä&#x2021; odpowiedzi zaleĹźy od liczby k dodatkowych transmitowanych rejestrĂłw i wyraĹźa siÄ&#x2122; wzorem 9 + 2k. OczywiĹ&#x203A;cie k nie moĹźe przekroczyÄ&#x2021; wartoĹ&#x203A;ci 123, by speĹ&#x201A;niÄ&#x2021; wspomniane wczeĹ&#x203A;niej ograniczenie
38
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Vol. 24, 933â&#x20AC;&#x201C;940, Springer International Publishing, 2015, DOI: 10.1007/978-3-319-09411-3_97. 5. Thomesse J., Fieldbus Technology in Industrial Automation, â&#x20AC;&#x153;Proceedings of the IEEEâ&#x20AC;?, Vol. 93, No. 6, June 2005, 1073â&#x20AC;&#x201C;1101, DOI: 10.1109/JPROC.2005.849724. 6. IEC 61158 - Industrial Communication Networks â&#x20AC;&#x201C; Fieldbus Specifications, 2007. 7. Jestratjew A., KwiecieĹ&#x201E; A., Using HTTP as Field Network Transfer Protocol, [in:] Computer Networks (A. KwiecieĹ&#x201E;, P. Gaj, P. Stera, eds.), (Berlin, Heidelberg), Vol. 160, 2011, 306â&#x20AC;&#x201C;313, Springer Berlin Heidelberg, DOI: 10.1007/978-3-642-21771-5_33. 8. Jestratjew A., KwiecieĹ&#x201E; A., Performance of HTTP Protocol in Networked Control Systems, â&#x20AC;&#x153;IEEE Transactions on Industrial Informaticsâ&#x20AC;?, Vol. 9, No. 1, 2013, 271â&#x20AC;&#x201C;276, DOI: 10.1109/TII.2012.2183138. 9. Gaj P., Jasperneite J., Felser M., Computer Communication within Industrial Distributed Environment â&#x20AC;&#x201C; a Survey, â&#x20AC;&#x153;IEEE Transactions on Industrial Informaticsâ&#x20AC;?, Vol. 9, No. 1, 2013, 182â&#x20AC;&#x201C;189, DOI: 10.1109/TII.2012.2209668. 10. StĂłj J., Real-Time Communication Network Concept Based on Frequency Division Multiplexing, [in:] Computer Networks (A. KwiecieĹ&#x201E;, P. Gaj, P. Stera, eds.), (Berlin, Heidelberg), Vol. 291, 2012, 247â&#x20AC;&#x201C;260, Springer Berlin Heidelberg, DOI: 10.1007/978-3-642-31217-5_27. 11. Fiset J.-Y., Human-Machine Interface Design for Process Control Applications. Instrumentation, Systems and Automation Society, 2009. 12. Zhang P., Human-machine interfaces, [in:] Advanced Industrial Control Technology (Zhang P., ed.), 527â&#x20AC;&#x201C;555, Oxford: William Andrew Publishing, 2010. 13. VDI/VDE 3699 Process control using display screens, 2015. 14. Oshana R., Human Factors and User Interface Design for Embedded Systems, in Software Engineering for Embedded Systems (R. Oshana, M. Kraeling, eds.), 417â&#x20AC;&#x201C;440, Oxford: Newnes, 2013. 15. Nachreiner F., Nickel P., Meyer I., Human factors in process control systems: The design of humanâ&#x20AC;&#x201C;machine interfaces, â&#x20AC;&#x153;Safety Scienceâ&#x20AC;?, Vol. 44, No. 1, 2006, 5â&#x20AC;&#x201C;26. Safety and Design, DOI: 10.1016/j.ssci.2005.09.003. 16. Jamro M., Trybus B., Configurable Operator Interface for CPDev Environment, â&#x20AC;&#x153;Pomiary Automatyka Robotykaâ&#x20AC;?, R. 17, Nr 2, 2013, 426â&#x20AC;&#x201C;431.
17. Jamro M., Trybus B., IEC 61131-3 programmable human machine interfaces for control devices, [in:] 6th International Conference on Human System Interactions (HSI), 2013, 48â&#x20AC;&#x201C;55, DOI: 10.1109/HSI.2013.6577801. 18. RzoĹ&#x201E;ca D., Stec A., Trybus B., Control Program Development in CPDev Using SFC Language, HMI and Runtime Environment, [in:] Automation 2018 (R. Szewczyk, C. ZieliĹ&#x201E;ski, and M. KaliczyĹ&#x201E;ska, eds.), (Cham), 223â&#x20AC;&#x201C;232, Springer International Publishing, DOI: 10.1007/978-3-319-77179-3_21. 19. Jamro M., RzoĹ&#x201E;ca D., Sadolewski J., Stec A., Ĺ&#x161;wider Z., Trybus B., Trybus L., Structure and Functionalities of Ship Autopilot Simulator, [in:] Challenges in Automation, Robotics and Measurement Techniques (R. Szewczyk, C. ZieliĹ&#x201E;ski, and M. KaliczyĹ&#x201E;ska, eds.), (Cham), 2016, 223â&#x20AC;&#x201C;231, Springer International Publishing, DOI: 10.1007/978-3-319-29357-8_20. 20. Jamro M., RzoĹ&#x201E;ca D., Agile and hierarchical round-trip engineering of IEC 61131-3 control software, â&#x20AC;&#x153;Computers in Industryâ&#x20AC;?, Vol. 96, 2018, 1â&#x20AC;&#x201C;9, DOI: 10.1016/j.compind.2018.01.004. 21. Jamro M., RzoĹ&#x201E;ca D., SysML-based Optimisation of Global Variables Arrangement for Visualisation in Distributed Control Systems Oriented Towards Communication Performance, [in:] MATEC Web Conf., Vol. 252, 2019, DOI: 10.1051/matecconf/201925201005.
@ 6 - 6 @X R F"- @Q K ( ( K 2% 8 HMI (Human-Machine Interface) panels are commonly used in industrial automation systems. They facilitate the visualization of industrial process control as well as enable the change of parameters. The values displayed on a HMI are read from a controller or controllers connected by a communication link. Thus efficient PLC â&#x20AC;&#x201C; HMI communication is essential for proper functioning of the whole automation system. Several aspects of such communication are analyzed in the paper and some solutions proposed to reduce the communication cycle. The described methods have been implemented in the CPDev engineering environment. KeywordsU % $ @X $ $ F"-$
39
# & ! _ : & :! $ & : & : g/G _ .! : +# Y
( - / 0 % ' % ORCID: 0000-0001-5724-0978 X O . )!!)P$ ( V 6 O@ > . )!!&P$ % > % 6 $ Y > 6 O@ Z [ )!*)P ; T % ; - 6 > @ . % )!!& \ ( > [ @ ( ( % [ [
40
P
O
M
I
A
R
Y
â&#x20AC;¢
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;¢
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 41â&#x20AC;&#x201C;47, DOI: 10.14313/PAR_235/41
( ( ( [ [ [ U R A ( [% 7 0
@ ^A% $ 0 % K $ K $ - 6 ; $ - ; $ < 6 ( *=_))$ +!>+)& ^A%`
1 8 Strategie sterowania Ĺ&#x203A;lizgowego sÄ&#x2026; cenione za swojÄ&#x2026; caĹ&#x201A;kowitÄ&#x2026; niewraĹźliwoĹ&#x203A;Ä&#x2021; na klasÄ&#x2122; zakĹ&#x201A;ĂłceĹ&#x201E; i niepewnoĹ&#x203A;ci modelu. Uzyskanie tej wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci jest moĹźliwe przez sprowadzenie punktu opisujÄ&#x2026;cego dynamikÄ&#x2122; ukĹ&#x201A;adu na pewnÄ&#x2026; hiperpowierzchniÄ&#x2122; przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; zdefiniowanÄ&#x2026; w przestrzeni stanĂłw. W poczÄ&#x2026;tkowym etapie sterowania, w ktĂłrym punkt opisujÄ&#x2026;cy zbliĹźa siÄ&#x2122; do tej hiperpowierzchni, ukĹ&#x201A;ad pozostaje wraĹźliwy na zakĹ&#x201A;Ăłcenia, co utrudnia projektowanie skutecznych strategii sterowania Ĺ&#x203A;lizgowego. Aby zapewniÄ&#x2021; odpornoĹ&#x203A;Ä&#x2021; ukĹ&#x201A;adu na zakĹ&#x201A;Ăłcenia i niepewnoĹ&#x203A;ci modelu na wszystkich etapach procesu sterowania liczni autorzy zaproponowali zastosowanie ruchomych hiperpowierzchni przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E;. Celem niniejszego artykuĹ&#x201A;u przeglÄ&#x2026;dowego jest przedstawienie najwaĹźniejszych osiÄ&#x2026;gniÄ&#x2122;Ä&#x2021; z zakresu sterowania Ĺ&#x203A;lizgowego z wykorzystaniem takich hiperpowierzchni. OmĂłwione sÄ&#x2026; pionierskie prace proponujÄ&#x2026;ce zastosowanie ruchomych hiperpowierzchni przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; oraz przedstawione sÄ&#x2026; metody ich projektowania. NastÄ&#x2122;pnie podkreĹ&#x203A;lone sÄ&#x2026; najwaĹźniejsze osiÄ&#x2026;gniÄ&#x2122;cia z zakresu sterowania Ĺ&#x203A;lizgowego wykorzystujÄ&#x2026;cego ruchome hiperpowierzchnie przeĹ&#x201A;Ä&#x2026;czaĹ&#x201E; zarĂłwno dla ukĹ&#x201A;adĂłw ciÄ&#x2026;gĹ&#x201A;ych jak i dyskretnych. ) U $ ( $ [ U
1. Wprowadzenie NastÄ&#x2122;pnie stosowany jest sygnaĹ&#x201A; sterujÄ&#x2026;cy Strategie sterowania Ĺ&#x203A;lizgowego ukĹ&#x201A;adami ciÄ&#x2026;gĹ&#x201A;ymi zaistniaĹ&#x201A;y w literaturze rosyjskiej w poĹ&#x201A;owie XX wieku [1â&#x20AC;&#x201C;3]. IstotÄ&#x2026; ich dziaĹ&#x201A;ania jest sprowadzenie punktu opisujÄ&#x2026;cego dynamikÄ&#x2122; ukĹ&#x201A;adu na tak zwanÄ&#x2026; hiperpowierzchniÄ&#x2122; Ĺ&#x203A;lizgowÄ&#x2026; zdefiniowanÄ&#x2026; w przestrzeni stanĂłw oraz utrzymanie go na tej hiperpowierzchni. Zastosowanie tego rodzaju strategii skutkuje caĹ&#x201A;kowitÄ&#x2026; niewraĹźliwoĹ&#x203A;ciÄ&#x2026; ukĹ&#x201A;adu na klasÄ&#x2122; zakĹ&#x201A;ĂłceĹ&#x201E; oraz niepewnoĹ&#x203A;ci modelu [4] speĹ&#x201A;niajÄ&#x2026;cÄ&#x2026; tak zwane warunki dopasowania. Projektowanie regulatora Ĺ&#x203A;lizgowego dla ukĹ&#x201A;adĂłw ciÄ&#x2026;gĹ&#x201A;ych rozpoczyna siÄ&#x2122; od zdefiniowania zmiennej Ĺ&#x203A;lizgowej oraz odpowiadajÄ&#x2026;cej jej hiperpowierzchni przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; w nastÄ&#x2122;pujÄ&#x2026;cy sposĂłb
Ď&#x192; (t ) = c Te (t ) = c T â&#x17D;Ąâ&#x17D;Łxd â&#x2C6;&#x2019; x (t ) â&#x17D;¤â&#x17D;Ś = 0,
(1)
gdzie x jest wektorem stanu, xd â&#x20AC;&#x201C; wektorem zadanym, a przez e oznaczamy uchyb zmiennych stanu.
3 + U
@ X U $ ' % 3 % *& !* )!)! $ % % *+ !) )!)!
!
â&#x17D;§u + â&#x17D;Ş u t =â&#x17D;¨ â&#x17D;Şâ&#x17D;Šu â&#x2C6;&#x2019;
()
() Ď&#x192; (t ) < 0,
dla Ď&#x192; t â&#x2030;Ľ 0 dla
(2)
ktĂłry sprowadza punkt opisujÄ&#x2026;cy dynamikÄ&#x2122; ukĹ&#x201A;adu na hiperpowierzchniÄ&#x2122; Ĺ&#x203A;lizgowÄ&#x2026; dla dowolnych warunkĂłw poczÄ&#x2026;tkowych. Zmienna struktura sygnaĹ&#x201A;u (2) zapewnia, Ĺźe punkt opisujÄ&#x2026;cy jest utrzymywany na tej hiperpowierzchni, dziÄ&#x2122;ki czemu wpĹ&#x201A;yw zakĹ&#x201A;ĂłceĹ&#x201E; na dynamikÄ&#x2122; obiektu jest odrzucony. W podobny sposĂłb regulatory Ĺ&#x203A;lizgowe zostaĹ&#x201A;y zaprojektowane dla ukĹ&#x201A;adĂłw dyskretnych [5, 6]. W przypadku dyskretnym stan obiektu x(k) nie jest sprowadzany bezpoĹ&#x203A;rednio na hiperpowierzchniÄ&#x2122; Ĺ&#x203A;lizgowÄ&#x2026; (1), lecz do jej ustalonego otoczenia
{x : c e â&#x2030;¤ δ } T
(3)
zwanego warstwÄ&#x2026; Ĺ&#x203A;lizgowÄ&#x2026;, gdzie 2d > 0 jest szerokoĹ&#x203A;ciÄ&#x2026; tej warstwy. Mimo Ĺźe w przypadku dyskretnym niemoĹźliwe jest caĹ&#x201A;kowite odrzucenie wpĹ&#x201A;ywu zakĹ&#x201A;ĂłceĹ&#x201E; na ukĹ&#x201A;ad, dyskretne regulatory Ĺ&#x203A;lizgowe zapewniajÄ&#x2026; stopieĹ&#x201E; odpornoĹ&#x203A;ci na te zakĹ&#x201A;Ăłcenia proporcjonalny do szerokoĹ&#x203A;ci warstwy Ĺ&#x203A;lizgowej. OdpornoĹ&#x203A;Ä&#x2021; na zakĹ&#x201A;Ăłcenia i niepewnoĹ&#x203A;ci modelu jest ceniona wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ciÄ&#x2026; regulatorĂłw Ĺ&#x203A;lizgowych, zarĂłwno w przypadku ukĹ&#x201A;adĂłw ciÄ&#x2026;gĹ&#x201A;ych jak i dyskretnych. WĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;Ä&#x2021; ta jest jednak zapewniona jedynie w drugim etapie
41
_ < :] < & & < ] & $] > J & ]
sterowania, po sprowadzeniu punktu opisujÄ&#x2026;cego dynamikÄ&#x2122; ukĹ&#x201A;adu do otoczenia hiperpowierzchni Ĺ&#x203A;lizgowej. Zanim ta hiperpowierzchnia zostanie osiÄ&#x2026;gniÄ&#x2122;ta, ukĹ&#x201A;ad pozostaje natomiast wraĹźliwy na zakĹ&#x201A;Ăłcenia, co moĹźe mieÄ&#x2021; negatywny wpĹ&#x201A;yw na dynamiczne wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci obiektu. Faza osiÄ&#x2026;gania trybu Ĺ&#x203A;lizgowego moĹźe ponadto byÄ&#x2021; dĹ&#x201A;uga dla wzglÄ&#x2122;dnie duĹźych warunkĂłw poczÄ&#x2026;tkowych. Aby zapewniÄ&#x2021; odpornoĹ&#x203A;Ä&#x2021; ukĹ&#x201A;adu na zakĹ&#x201A;Ăłcenia i niepewnoĹ&#x203A;ci modelu na wszystkich etapach procesu sterowania, wielu autorĂłw zaproponowaĹ&#x201A;o wykorzystanie ruchomych hiperpowierzchni przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; w sterowaniu Ĺ&#x203A;lizgowym. Zastosowanie takich hiperpowierzchni sprawia, Ĺźe ruch Ĺ&#x203A;lizgowy rozpocznie siÄ&#x2122; natychmiast, dziÄ&#x2122;ki czemu wpĹ&#x201A;yw zakĹ&#x201A;ĂłceĹ&#x201E; na dynamikÄ&#x2122; obiektu bÄ&#x2122;dzie zawsze odrzucony. Niniejszy artykuĹ&#x201A; ma na celu przedstawienie najwaĹźniejszych osiÄ&#x2026;gniÄ&#x2122;Ä&#x2021; z zakresu sterowania Ĺ&#x203A;lizgowego z ruchomymi hiperpowierzchniami przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; i opisanie przykĹ&#x201A;adowych metod projektowania takich hiperpowierzchni. ArtykuĹ&#x201A; jest uporzÄ&#x2026;dkowany w nastÄ&#x2122;pujÄ&#x2026;cy sposĂłb. W rozdziale 2 omĂłwione sÄ&#x2026; najistotniejsze publikacje dotyczÄ&#x2026;ce ruchomych hiperpowierzchni przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; dla ukĹ&#x201A;adĂłw ciÄ&#x2026;gĹ&#x201A;ych. W tym samym rozdziale zaprezentowane sÄ&#x2026; przykĹ&#x201A;adowe ruchome hiperpowierzchnie majÄ&#x2026;ce na celu zlikwidowanie fazy osiÄ&#x2026;gania trybu Ĺ&#x203A;lizgowego. RozdziaĹ&#x201A; 3 poĹ&#x203A;wiÄ&#x2122;cony jest ruchomym hiperpowierzchniom przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; dla ukĹ&#x201A;adĂłw dyskretnych. W rozdziale 4 wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci ruchomych hiperpowierzchni przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; sÄ&#x2026; zilustrowane za pomocÄ&#x2026; przykĹ&#x201A;adu symulacyjnego. RozdziaĹ&#x201A; 5 zawiera krĂłtkie podsumowanie.
wraĹźliwoĹ&#x203A;ci ukĹ&#x201A;adu na zakĹ&#x201A;Ăłcenia w chwilach, w ktĂłrych skokowe funkcje cr(t) i a(t) zmieniajÄ&#x2026; wartoĹ&#x203A;Ä&#x2021;. W odpowiedzi na ten problem, autor artykuĹ&#x201A;u [10] zaproponowaĹ&#x201A; modyfikacjÄ&#x2122; hiperpowierzchni (4) i (5), w ktĂłrej skokowe cr(t) i a(t) zostaĹ&#x201A;y zastÄ&#x2026;pione liniowymi funkcjami czasu. Autorzy pracy [11] zaproponowali modyfikacje ruchomych hiperpowierzchni (4) oraz (5) z wykorzystaniem logiki rozmytej. OkreĹ&#x203A;lajÄ&#x2026;c stopieĹ&#x201E; przynaleĹźnoĹ&#x203A;ci punktu opisujÄ&#x2026;cego dynamikÄ&#x2122; ukĹ&#x201A;adu do zdefiniowanych zbiorĂłw rozmytych, autorzy uzyskujÄ&#x2026; ciÄ&#x2026;gĹ&#x201A;e funkcje obrotu lub przesuniÄ&#x2122;cia hiperpowierzchni Ĺ&#x203A;lizgowej. Zaproponowana strategia zostaĹ&#x201A;a wykorzystana do sterowania manipulatorem robota o dwĂłch stopniach swobody. W artykule [12] rĂłwnieĹź wykorzystano wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci logiki rozmytej do zaprojektowania ruchomej hiperpowierzchni Ĺ&#x203A;lizgowej. Funkcje przynaleĹźnoĹ&#x203A;ci stanu ukĹ&#x201A;adu do rozwaĹźanych zbiorĂłw rozmytych zaprojektowano tak, aby ograniczyÄ&#x2021; niepoĹźÄ&#x2026;dane oscylacje wokĂłĹ&#x201A; powierzchni Ĺ&#x203A;lizgowej (tzw. chattering). W pracy [13] zaproponowano trzy nowe metody projektowania ruchomych hiperpowierzchni przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; dla ukĹ&#x201A;adĂłw drugiego rzÄ&#x2122;du. W pierwszej metodzie rozwaĹźana jest liniowa powierzchnia
Strategie sterowania Ĺ&#x203A;lizgowego wykorzystujÄ&#x2026;ce ruchome hiperpowierzchnie przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; sÄ&#x2026; znacznie czÄ&#x2122;Ĺ&#x203A;ciej stosowane dla ukĹ&#x201A;adĂłw ciÄ&#x2026;gĹ&#x201A;ych niĹź dla dyskretnych. Wynika to z bardziej korzystnych wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci ciÄ&#x2026;gĹ&#x201A;ego ruchu Ĺ&#x203A;lizgowego, gdzie punkt opisujÄ&#x2026;cy dynamikÄ&#x2122; ukĹ&#x201A;adu moĹźe byÄ&#x2021; utrzymany na hiperpowierzchni przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E;, a nie tylko w jej otoczeniu, jak ma to miejsce w przypadku dyskretnym. W tym rozdziale zaprezentowane zostanÄ&#x2026; najwaĹźniejsze prace dotyczÄ&#x2026;ce zastosowania ruchomych hiperpowierzchni Ĺ&#x203A;lizgowych w sterowaniu ukĹ&#x201A;adami ciÄ&#x2026;gĹ&#x201A;ymi.
Ď&#x192; (t ) = cr (t ) e1 (t ) + e2 (t ) = 0,
(4)
gdzie cr(t) jest funkcjÄ&#x2026; skokowÄ&#x2026; powodujÄ&#x2026;cÄ&#x2026; kilkakrotny obrĂłt tej hiperpowierzchni wokĂłĹ&#x201A; poczÄ&#x2026;tku ukĹ&#x201A;adu wspĂłĹ&#x201A;rzÄ&#x2122;dnych o ustalony kÄ&#x2026;t. Druga z zaproponowanych hiperpowierzchni ma postaÄ&#x2021;
Ď&#x192; (t ) = c pe1 (t ) + e2 (t ) â&#x2C6;&#x2019; Îą (t ) ,
(5)
gdzie a(t) jest skokowÄ&#x2026; funkcjÄ&#x2026; odpowiadajÄ&#x2026;cÄ&#x2026; za jej liniowe przesuniÄ&#x2122;cie. Dla obydwu zaproponowanych hiperpowierzchni, funkcje cr(t) oraz a(t) sÄ&#x2026; wybrane tak, aby w chwili 0 hiperpowierzchnia zawieraĹ&#x201A;a punkt opisujÄ&#x2026;cy warunki poczÄ&#x2026;tkowe ukĹ&#x201A;adu. Ponadto w skoĹ&#x201E;czonym czasie t0 hiperpowierzchnia zostaje sprowadzona do postaci zapewniajÄ&#x2026;cej stabilnoĹ&#x203A;Ä&#x2021; ukĹ&#x201A;adu zamkniÄ&#x2122;tego. Zaproponowane podejĹ&#x203A;cie charakteryzuje siÄ&#x2122; prostotÄ&#x2026; implementacji, lecz nie zapewnia caĹ&#x201A;kowitej nie-
M
I
A
R
Y
dla
0
(6)
t â&#x2030;ĽT
â&#x20AC;˘
A
U
T
O
M
â&#x17D;§â&#x17D;ŞAt 2 + Bt + C
dla t < T
â&#x17D;Şâ&#x17D;Š
dla
0
t â&#x2030;ĽT
(7)
Trzecia hiperpowierzchnia jest opisana nieliniowÄ&#x2026; formuĹ&#x201A;Ä&#x2026; gwarantujÄ&#x2026;cÄ&#x2026; zniwelowanie uchybu regulacji w skoĹ&#x201E;czonym czasie. Wszystkie zaproponowane metody dÄ&#x2026;ĹźÄ&#x2026; do minimalizacji wskaĹşnika IAE przy ograniczeniach naĹ&#x201A;oĹźonych na sygnaĹ&#x201A; sterujÄ&#x2026;cy. W artykule [14] strategia Ĺ&#x203A;lizgowa z hiperpowierzchniÄ&#x2026; (6) zostaĹ&#x201A;a ponadto wykorzystana do sterowania ruchem przenoĹ&#x203A;nika podwieszonego. W pracy [15] wykorzystano trzy rodzaje ruchomych hiperpowierzchni zaproponowanych wczeĹ&#x203A;niej [13] do sterowania poĹ&#x201A;oĹźeniem statku kosmicznego. Parametry tych hiperpowierzchni zostaĹ&#x201A;y dobrane tak, aby zminimalizowaÄ&#x2021; wskaĹşnik optymalnoĹ&#x203A;ci ISE. Udowodniono, Ĺźe zastosowanie ruchomych hiperpowierzchni zapewnia stabilnoĹ&#x203A;Ä&#x2021; ukĹ&#x201A;adu i pozwala zrealizowaÄ&#x2021; Ĺ&#x203A;ledzenie trajektorii. Autor artykuĹ&#x201A;u [16] wykorzystaĹ&#x201A; ruchomÄ&#x2026; hiperpowierzchniÄ&#x2122; Ĺ&#x203A;lizgowÄ&#x2026; w sterowaniu stÄ&#x2122;Ĺźeniem substratĂłw w bioreaktorze. Mimo silnej nieliniowoĹ&#x203A;ci rozwaĹźanego reaktora i koniecznoĹ&#x203A;ci zaspokojenia istotnych fizycznych ograniczeĹ&#x201E; dotyczÄ&#x2026;cych stÄ&#x2122;Ĺźenia pierwiastkĂłw, autor udowodniĹ&#x201A;, Ĺźe zaproponowana metoda zapewnia wszystkie poĹźÄ&#x2026;dane wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci ukĹ&#x201A;adu. ArtykuĹ&#x201A; [17] opisuje alternatywne podejĹ&#x203A;cie do projektowania ruchomych hiperpowierzchni dla ukĹ&#x201A;adĂłw dynamicznych drugiego rzÄ&#x2122;du. Zaproponowano nowÄ&#x2026; metodÄ&#x2122; wyboru parametrĂłw ruchomej hiperpowierzchni Ĺ&#x203A;lizgowej (6) bazujÄ&#x2026;cÄ&#x2026; na minimalizacji wskaĹşnika ITAE. Ponadto rozwaĹźono problem ograniczenia sygnaĹ&#x201A;u sterujÄ&#x2026;cego oraz zmiennej stanu odpowiadajÄ&#x2026;cej za prÄ&#x2122;dkoĹ&#x203A;Ä&#x2021;.
W artykuĹ&#x201A;ach [7â&#x20AC;&#x201C;9] zaproponowano dwie metody projektowania ruchomych hiperpowierzchni przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; dla ukĹ&#x201A;adĂłw ciÄ&#x2026;gĹ&#x201A;ych drugiego rzÄ&#x2122;du. W pierwszej metodzie rozwaĹźana jest hiperpowierzchnia
O
â&#x17D;Şâ&#x17D;Š
Ď&#x192; (t ) = e1 (t ) + βe2 (t ) + â&#x17D;¨
S1^1 _ "
P
dla t < T
przesuwajÄ&#x2026;ca siÄ&#x2122; ze staĹ&#x201A;Ä&#x2026; prÄ&#x2122;dkoĹ&#x203A;ciÄ&#x2026; od punktu opisujÄ&#x2026;cego warunki poczÄ&#x2026;tkowe obiektu do poczÄ&#x2026;tku ukĹ&#x201A;adu wspĂłĹ&#x201A;rzÄ&#x2122;dnych. Druga z zaproponowanych hiperpowierzchni jest liniÄ&#x2026; przesuwajÄ&#x2026;cÄ&#x2026; siÄ&#x2122; ze staĹ&#x201A;ym przyspieszeniem
S1 +
42
â&#x17D;§â&#x17D;ŞAt + B
Ď&#x192; (t ) = e1 (t ) + βe2 (t ) + â&#x17D;¨
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
# $ "
S1S1 _ " W artykule [18] zaproponowano modyfikacjÄ&#x2122; liniowej hiperpowierzchni Ĺ&#x203A;lizgowej (6) dla ukĹ&#x201A;adĂłw trzeciego rzÄ&#x2122;du. W szczegĂłlnoĹ&#x203A;ci omĂłwiono wybĂłr parametrĂłw A i B tej hiperpowierzchni dla dwĂłch przypadkĂłw. Najpierw rozwaĹźono przypadek z ograniczeniami naĹ&#x201A;oĹźonymi na przyspieszenie, a nastÄ&#x2122;pnie przypadek ograniczenia zarĂłwno prÄ&#x2122;dkoĹ&#x203A;ci jak i przyspieszenia. W obydwu przypadkach parametry hiperpowierzchni zostaĹ&#x201A;y wybrane tak, aby zminimalizowaÄ&#x2021; wskaĹşnik jakoĹ&#x203A;ci IAE. Minimalizacja wspĂłĹ&#x201A;czynnika ITAE dla analogicznej strategii zostaĹ&#x201A;a dodatkowo rozwaĹźona w artykule [19]. W pracy [20] uwzglÄ&#x2122;dniono dodatkowe ograniczenie naĹ&#x201A;oĹźone na sygnaĹ&#x201A; sterujÄ&#x2026;cy. Pokazano, Ĺźe zaproponowana strategia z ruchomÄ&#x2026; hiperpowierzchniÄ&#x2026; Ĺ&#x203A;lizgowÄ&#x2026; moĹźe jednoczeĹ&#x203A;nie zapewniÄ&#x2021; ograniczenie prÄ&#x2122;dkoĹ&#x203A;ci, przyspieszenia i sygnaĹ&#x201A;u sterujÄ&#x2026;cego. Podobne ograniczenia rozwaĹźono w artykule [21], ale rozpatrzono dodatkowo problem minimalizacji wspĂłĹ&#x201A;czynnika jakoĹ&#x203A;ci ITAE. Zastosowanie ruchomych hiperpowierzchni do ograniczenia wartoĹ&#x203A;ci zmiennych stanu w ukĹ&#x201A;adach trzeciego rzÄ&#x2122;du zostaĹ&#x201A;o rĂłwnieĹź rozpatrzone w pracy [22]. Zbadano dwa typy ograniczeĹ&#x201E; prÄ&#x2122;dkoĹ&#x203A;ci w rozwaĹźanym ukĹ&#x201A;adzie â&#x20AC;&#x201C; konwencjonalne staĹ&#x201A;e ograniczenie tej wartoĹ&#x203A;ci oraz elastyczne ograniczenie zdefiniowane przy pomocy funkcji kosztu. SkutecznoĹ&#x203A;Ä&#x2021; zaproponowanej strategii zilustrowano na przykĹ&#x201A;adzie serwomechanizmu elektrohydraulicznego. Wyniki dotyczÄ&#x2026;ce optymalnego wykorzystania ruchomych hiperpowierzchni w sterowaniu ukĹ&#x201A;adami drugiego i trzeciego rzÄ&#x2122;du zostaĹ&#x201A;y zbiorczo opisane w publikacji [23].
S1V1 _ " W pracy [24] zaproponowano uogĂłlnienie hiperpowierzchni Ĺ&#x203A;lizgowych (4) oraz (5) na przypadek ukĹ&#x201A;adu dowolnego rzÄ&#x2122;du. Podobnie jak w artykuĹ&#x201A;ach [7â&#x20AC;&#x201C;9] zastosowano skokowÄ&#x2026; funkcjÄ&#x2122; zapewniajÄ&#x2026;cÄ&#x2026; obrĂłt lub przesuniÄ&#x2122;cie hiperpowierzchni w ustalonych odstÄ&#x2122;pach czasu. Autorzy wykorzystali normÄ&#x2122; wektora stanu do wyznaczenia poczÄ&#x2026;tkowego poĹ&#x201A;oĹźenia hiperpowierzchni Ĺ&#x203A;lizgowej i obliczyli n â&#x2C6;&#x2019; 1 parametrĂłw odpowiadajÄ&#x2026;cych za jej ruch w n-wymiarowej przestrzeni stanĂłw. Autorzy artykuĹ&#x201A;u [25] zaproponowali nowÄ&#x2026; metodÄ&#x2122; projektowania ruchomej hiperpĹ&#x201A;aszczyzny Ĺ&#x203A;lizgowej dla n-wymiarowego ukĹ&#x201A;adu. Metoda ta wykorzystuje ciÄ&#x2026;gĹ&#x201A;e funkcje l(t) oraz b(t) dobrane tak, aby zapewniÄ&#x2021; szybkie tempo zbieĹźnoĹ&#x203A;ci do stanu ustalonego jednoczeĹ&#x203A;nie gwarantujÄ&#x2026;c niewraĹźliwoĹ&#x203A;Ä&#x2021; ukĹ&#x201A;adu na zakĹ&#x201A;Ăłcenia w kaĹźdym etapie procesu sterowania. Nieliniowe funkcje wykorzystane przez autorĂłw zostaĹ&#x201A;y zaprojektowane z uĹźyciem modelu rozmytego Takagi i Sugeno [26]. Inna metoda projektowania ruchomych hiperpowierzchni z wykorzystaniem logiki rozmytej zostaĹ&#x201A;a zaproponowana w pracy [27]. Autorzy wykorzystali model rozmyty Jamshidi i wspĂłĹ&#x201A;autorĂłw [28] do zaprojektowania hiperpowierzchni o dynamicznie zmieniajÄ&#x2026;cej siÄ&#x2122; prÄ&#x2122;dkoĹ&#x203A;ci obrotu. ZaproponowanÄ&#x2026; strategiÄ&#x2122; wykorzystali do sterowania serwomechanizmem elektrohydraulicznym. W artykuĹ&#x201A;ach [29] oraz [30] zaproponowano strategiÄ&#x2122; sterowania Ĺ&#x203A;lizgowego ukĹ&#x201A;adami dowolnego rzÄ&#x2122;du. Strategia wykorzystuje zmodyfikowanÄ&#x2026; hiperpowierzchniÄ&#x2122; o parabolicznym ksztaĹ&#x201A;cie. IdeÄ&#x2026; tej strategii jest dopasowanie ksztaĹ&#x201A;tu hiperpowierzchni do naturalnej zmiany stanu ukĹ&#x201A;adu poddanego sterowaniu Ĺ&#x203A;lizgowemu. Parametry rozwaĹźanej paraboli sÄ&#x2026; zmienne w czasie, ale ograniczone z gĂłry i z doĹ&#x201A;u przez wybrane staĹ&#x201A;e. W przeciwieĹ&#x201E;stwie do klasycznych podejĹ&#x203A;Ä&#x2021;, nowa metoda zapobiega gwaĹ&#x201A;townym zmianom stanu ukĹ&#x201A;adu w przejĹ&#x203A;ciu miÄ&#x2122;dzy fazÄ&#x2026; osiÄ&#x2026;gania a fazÄ&#x2026; Ĺ&#x203A;lizgowÄ&#x2026;. W szczegĂłlnoĹ&#x203A;ci, w celu ograniczenia wartoĹ&#x203A;ci sygnaĹ&#x201A;u sterujÄ&#x2026;cego w poczÄ&#x2026;tkowych chwilach procesu sterowania, autorzy proponujÄ&#x2026; rozpoczÄ&#x2122;cie ruchu hiperpĹ&#x201A;aszczyzny Ĺ&#x203A;lizgowej z opóźnieniem.
W pracy [31] zaproponowano zastosowanie strategii sterowania Ĺ&#x203A;lizgowego z ruchomÄ&#x2026; hiperpowierzchniÄ&#x2026; przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; do sterowania manipulatorem elastycznym. Autorzy proponujÄ&#x2026; zastosowanie dwĂłch hiperpowierzchni Ĺ&#x203A;lizgowych. Pierwsza z nich, odpowiadajÄ&#x2026;ca za kÄ&#x2026;t nachylenia piasty, jest niezmienna w czasie. Druga hiperpowierzchnia jest ruchoma i odpowiada za kompensacjÄ&#x2122; drgaĹ&#x201E; elastycznego ramienia robota. W artykuĹ&#x201A;ach [32â&#x20AC;&#x201C;34] wykorzystano ruchome hiperpowierzchnie przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; w sterowaniu silnikami prÄ&#x2026;du staĹ&#x201A;ego oraz silnikami indukcyjnymi. Pokazano, Ĺźe zastosowanie takich hiperpowierzchni zapewnia odpornoĹ&#x203A;Ä&#x2021; na niepewnoĹ&#x203A;ci modelu na kaĹźdym etapie procesu sterowania oraz ogranicza niepoĹźÄ&#x2026;dane oscylacje wokĂłĹ&#x201A; hiperpowierzchni Ĺ&#x203A;lizgowej. W szczegĂłlnoĹ&#x203A;ci w artykule [32] eksperymentalnie wykazano odpornoĹ&#x203A;Ä&#x2021; ukĹ&#x201A;adu na niespodziewane zmiany parametrĂłw i zilustrowano wydajnoĹ&#x203A;Ä&#x2021; obliczeniowÄ&#x2026; zastosowanego algorytmu. Autorzy artykuĹ&#x201A;u [35] zaproponowali nowÄ&#x2026; strategiÄ&#x2122; sterowania Ĺ&#x203A;lizgowego dla ukĹ&#x201A;adĂłw o jednym wejĹ&#x203A;ciu, w ktĂłrych wartoĹ&#x203A;Ä&#x2021; bezwzglÄ&#x2122;dna sygnaĹ&#x201A;u sterujÄ&#x2026;cego jest ograniczona. Zaproponowana ruchoma hiperpowierzchnia zawiera dwa skĹ&#x201A;adniki: staĹ&#x201A;y oraz wykĹ&#x201A;adniczo zbieĹźny do zera. Wykazano, Ĺźe zastosowanie takiej hiperpowierzchni pozwala na ograniczenie wartoĹ&#x203A;ci sygnaĹ&#x201A;u sterujÄ&#x2026;cego na kaĹźdym etapie procesu sterowania, jeĹ&#x203A;li tylko zakĹ&#x201A;Ăłcenia wpĹ&#x201A;ywajÄ&#x2026;ce na ukĹ&#x201A;ad speĹ&#x201A;niajÄ&#x2026; warunki dopasowania. W pracy [36] zaproponowano nowÄ&#x2026; strategiÄ&#x2122; sterowania bazujÄ&#x2026;cÄ&#x2026; na podziale ukĹ&#x201A;adu czwartego rzÄ&#x2122;du na dwa podukĹ&#x201A;ady drugiego rzÄ&#x2122;du. Dla obydwu dwuwymiarowych podukĹ&#x201A;adĂłw zaproponowano zastosowanie obrotowej hiperpowierzchni Ĺ&#x203A;lizgowej wykorzystujÄ&#x2026;cej reguĹ&#x201A;y rozmyte do wyznaczenia kÄ&#x2026;ta obrotu. Zaproponowane podejĹ&#x203A;cie zapewnia stabilnoĹ&#x203A;Ä&#x2021; ukĹ&#x201A;adu i jednoczeĹ&#x203A;nie znacznie upraszcza jego strukturÄ&#x2122;.
V1 Strategie wykorzystujÄ&#x2026;ce ruchome hiperpowierzchnie Ĺ&#x203A;lizgowe w sterowaniu dyskretnymi obiektami dynamicznymi nie sÄ&#x2026; tak powszechne jak ich odpowiedniki dla ukĹ&#x201A;adĂłw ciÄ&#x2026;gĹ&#x201A;ych. Znacznie powszechniejszÄ&#x2026; metodÄ&#x2026; zapewnienia odpornoĹ&#x203A;ci ukĹ&#x201A;adu dyskretnego na zakĹ&#x201A;Ăłcenia i niepewnoĹ&#x203A;ci modelu sÄ&#x2026; tak zwane predefiniowane przebiegi zmiennej Ĺ&#x203A;lizgowej [37, 38]. Niemniej jednak, kilku autorĂłw zdecydowaĹ&#x201A;o siÄ&#x2122; wykorzystaÄ&#x2021; takie hiperpowierzchnie rĂłwnieĹź w sterowaniu ukĹ&#x201A;adami ciÄ&#x2026;gĹ&#x201A;ymi. W artykule [39] zaprojektowano ruchomÄ&#x2026; hiperpowierzchniÄ&#x2122; Ĺ&#x203A;lizgowÄ&#x2026; dla ukĹ&#x201A;adĂłw dyskretnych drugiego rzÄ&#x2122;du. Hiperpowierzchnia ta zawiera skĹ&#x201A;adnik â&#x20AC;&#x17E;zapominajÄ&#x2026;cyâ&#x20AC;?, dziÄ&#x2122;ki ktĂłremu punkt opisujÄ&#x2026;cy dynamikÄ&#x2122; obiektu znajduje siÄ&#x2122; na tej hiperpowierzchni juĹź w pierwszej chwili, a odpowiedĹş ukĹ&#x201A;adu upodabnia siÄ&#x2122; do dead-beatowej w skoĹ&#x201E;czonym czasie. Zaproponowana strategia zostaĹ&#x201A;a wykorzystana do sterowania serwomotorem synchronicznym. Nowe podejĹ&#x203A;cie do problemu projektowania ruchomych hiperpowierzchni Ĺ&#x203A;lizgowych zostaĹ&#x201A;o przedyskutowane w artykule [40]. Zaproponowana hiperpowierzchnia jest przesuwana tak, aby punkt opisujÄ&#x2026;cy dynamikÄ&#x2122; ukĹ&#x201A;adu znajdowaĹ&#x201A; siÄ&#x2122; na niej w kaĹźdym kroku. Hiperpowierzchnia ta jest jednak ograniczona do ustalonego obszaru przestrzeni stanĂłw. KrawÄ&#x2122;dĹş tego obszaru zastÄ&#x2122;puje hiperpowierzchniÄ&#x2122; Ĺ&#x203A;lizgowÄ&#x2026;, gdy punkt opisujÄ&#x2026;cy przyjmuje niedopuszczalne wartoĹ&#x203A;ci. Zaproponowana strategia zostaĹ&#x201A;a wykorzystana w sterowaniu ramieniem robota o jednym stopniu swobody. W pracy [41] zaproponowano strategiÄ&#x2122; sterowania Ĺ&#x203A;lizgowego dla twardych dyskĂłw. Zastosowano dyskretnÄ&#x2026; hiperpowierzchniÄ&#x2122; Ĺ&#x203A;lizgowÄ&#x2026;, ktĂłra jest obracana w kilku poczÄ&#x2026;tkowych chwilach procesu sterowania, podobnie do tej opisanej wzorem (4).
43
_ < :] < & & < ] & $] > J & ]
X1
PrÄ&#x2122;dkoĹ&#x203A;Ä&#x2021; obrotu tej hiperpowierzchni jest dobrana tak, aby uzyskaÄ&#x2021; najmniejszy moĹźliwy czas odczytu danych. Autorzy artykuĹ&#x201A;u [42] rozwaĹźali dyskretne ukĹ&#x201A;ady dynamiczne z opóźnionym sprzÄ&#x2122;Ĺźeniem zwrotnym. Zaproponowana przez nich nieliniowa hiperpowierzchnia Ĺ&#x203A;lizgowa zmienia siÄ&#x2122; w czasie w zaleĹźnoĹ&#x203A;ci od odczytanego wejĹ&#x203A;cia obiektu i ma na celu zapewnienie stabilnoĹ&#x203A;ci ukĹ&#x201A;adu w obecnoĹ&#x203A;ci opóźnieĹ&#x201E;. Autorzy wykorzystali sterowanie rĂłwnowaĹźne sprowadzajÄ&#x2026;ce stan obiektu na hiperpowierzchniÄ&#x2122; Ĺ&#x203A;lizgowÄ&#x2026; w kaĹźdej chwili i wykazali stabilnoĹ&#x203A;Ä&#x2021; ruchu Ĺ&#x203A;lizgowego przy uĹźyciu metody Lapunowa. Autorzy pracy [43] rozwaĹźyli problem ograniczenia sygnaĹ&#x201A;u sterujÄ&#x2026;cego w dyskretnym sterowaniu Ĺ&#x203A;lizgowym. Zastosowali oni hiperpowierzchniÄ&#x2122; z dodatkowym skĹ&#x201A;adnikiem zaleĹźnym od przeszĹ&#x201A;ego stanu ukĹ&#x201A;adu. Waga tego skĹ&#x201A;adnika zmienia siÄ&#x2122; w czasie i dÄ&#x2026;Ĺźy asymptotycznie do zera. Parametr reprezentujÄ&#x2026;cy tÄ&#x2122; wagÄ&#x2122; moĹźe byÄ&#x2021; dobrany tak, aby zmniejszyÄ&#x2021; wartoĹ&#x203A;ci sygnaĹ&#x201A;u sterujÄ&#x2026;cego w poczÄ&#x2026;tkowej fazie sterowania. Autorzy wykorzystali zaproponowanÄ&#x2026; strategiÄ&#x2122; do sterowania podwĂłjnym wirnikiem.
W tym rozdziale zasada dziaĹ&#x201A;ania strategii sterowania Ĺ&#x203A;lizgowego z ruchomymi hiperpowierzchniami przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; zostanie zilustrowana na przykĹ&#x201A;adzie ukĹ&#x201A;adu drugiego rzÄ&#x2122;du. RozwaĹźany ukĹ&#x201A;ad ciÄ&#x2026;gĹ&#x201A;y jest podobny do tego wykorzystanego w publikacji [13], a jego dynamika ma postaÄ&#x2021; (8) () () x (t ) = â&#x17D;Ąâ&#x17D;Ł1 + δ (t ) â&#x17D;¤â&#x17D;Ś f ( x , t ) + â&#x17D;Ąâ&#x17D;Ł1 + δ (t ) â&#x17D;¤â&#x17D;Ś f ( x , t ) + u (t ) + d (t ) ,
x 1 t = x 2 t , 2
1
1
2
2
δ1 (t ) = δ 2 (t ) = 0,1 sin (15t ) ,
( ) f ( x , t ) = â&#x2C6;&#x2019;0, 2 (1 â&#x2C6;&#x2019; x ) , d (t ) = 0,12 sin (10t ) . f1 x , t = â&#x2C6;&#x2019;0, 5x14 ,
gdzie
(9)
2 2
2
Rys. 1. Pierwsza zmienna stanu Fig. 1. The first state variable
Rys. 3. SygnaĹ&#x201A; sterujÄ&#x2026;cy dla hiperpowierzchni (6) Fig. 3. Control signal for hypersurface (6)
Rys. 2. SygnaĹ&#x201A; sterujÄ&#x2026;cy dla hiperpowierzchni niezmiennej w czasie Fig. 2. Control signal for the time-invariant hypersurface
Rys. 4. SygnaĹ&#x201A; sterujÄ&#x2026;cy dla hiperpowierzchni (7) Fig. 4. Control signal for hypersurface (7)
44
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
# $ "
W niniejszym przykĹ&#x201A;adzie trzy strategie sterowania Ĺ&#x203A;lizgowego zostanÄ&#x2026; zastosowane do sterowania tym ukĹ&#x201A;adem. Celem procesu sterowania jest sprowadzenie stanu obiektu z x(0) = [1 0]T do zera. RozwaĹźane strategie to: A) Konwencjonalne sterowanie Ĺ&#x203A;lizgowe z nieruchomÄ&#x2026; hiperpowierzchniÄ&#x2026; przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E; s(t) = x2(t) + 0,6x1(t) oraz sygnaĹ&#x201A;em sterujÄ&#x2026;cym
(10)
B) Strategia z ruchomÄ&#x2026; hiperpowierzchniÄ&#x2026; o staĹ&#x201A;ej prÄ&#x2122;dkoĹ&#x203A;ci (6) zaproponowana w [13]. Parametry hiperpowierzchni to T = 5, A = 0,12, B = â&#x2C6;&#x2019;0,6, a sygnaĹ&#x201A; sterujÄ&#x2026;cy
() ()
â&#x17D;§0, 6x 2 t + A dla t â&#x2030;¤ T â&#x17D;Ş u t = u0 t â&#x2C6;&#x2019; â&#x17D;¨ dla t > T . â&#x17D;Şâ&#x17D;Š 0, 6x 2 t
()
()
(11)
C) Strategia z ruchomÄ&#x2026; hiperpowierzchniÄ&#x2026; o staĹ&#x201A;ym przyspieszeniu (7) zaproponowana w [13]. Parametry hiperpowierzchni to T = 5, A = â&#x2C6;&#x2019;0,024, B = 0,12, C = â&#x2C6;&#x2019;0,6, a sygnaĹ&#x201A; sterujÄ&#x2026;cy
() ()
â&#x17D;§0, 6x 2 t + 2At + B dla t â&#x2030;¤ T â&#x17D;Ş u t = u0 t â&#x2C6;&#x2019; â&#x17D;¨ dla t > T . â&#x17D;Şâ&#x17D;Š 0, 6x 2 t
()
()
(12)
NastÄ&#x2122;pujÄ&#x2026;ce cztery rysunki ilustrujÄ&#x2026; wyniki porĂłwnania. Pierwszy rysunek ilustruje przebieg pierwszej zmiennej stanu, a pozostaĹ&#x201A;e trzy â&#x20AC;&#x201C; wartoĹ&#x203A;ci sygnaĹ&#x201A;Ăłw sterujÄ&#x2026;cych. Z rysunku 1 widaÄ&#x2021;, Ĺźe strategie wykorzystujÄ&#x2026;ce ruchome hiperpowierzchnie (6) oraz (7) zapewniajÄ&#x2026; szybsze tempo zbieĹźnoĹ&#x203A;ci pierwszej zmiennej do stanu ustalonego niĹź konwencjonalne podejĹ&#x203A;cie z nieruchomÄ&#x2026; hiperpowierzchniÄ&#x2026; Ĺ&#x203A;lizgowÄ&#x2026;. Rysunki 2â&#x20AC;&#x201C;4 ilustrujÄ&#x2026;, Ĺźe wszystkie strategie generujÄ&#x2026; podobne wartoĹ&#x203A;ci sygnaĹ&#x201A;u sterujÄ&#x2026;cego w fazie Ĺ&#x203A;lizgowej, natomiast strategie B i C zapewniajÄ&#x2026; rozpoczÄ&#x2122;cie oscylacji wokĂłĹ&#x201A; ruchomej hiperpowierzchni juĹź na poczÄ&#x2026;tku procesu sterowania, dziÄ&#x2122;ki czemu rozwaĹźany ukĹ&#x201A;ad jest zawsze niewraĹźliwy na zakĹ&#x201A;Ăłcenia i niepewnoĹ&#x203A;ci modelu.
Y1 W niniejszym artykule dokonano przeglÄ&#x2026;du strategii sterowania Ĺ&#x203A;lizgowego wykorzystujÄ&#x2026;cych ruchome hiperpowierzchnie przeĹ&#x201A;Ä&#x2026;czeĹ&#x201E;. IdeÄ&#x2026; takich strategii jest zapewnienie, Ĺźe punkt opisujÄ&#x2026;cy dynamikÄ&#x2122; ukĹ&#x201A;adu zawsze znajduje siÄ&#x2122; w bezpoĹ&#x203A;rednim otoczeniu hiperpowierzchni, dziÄ&#x2122;ki czemu korzystne wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci regulatorĂłw Ĺ&#x203A;lizgowych sÄ&#x2026; zapewnione na kaĹźdym etapie procesu sterowania. Zaprezentowano najwaĹźniejsze publikacje omawiajÄ&#x2026;ce wykorzystanie takich hiperpowierzchni, zarĂłwno dla ukĹ&#x201A;adĂłw ciÄ&#x2026;gĹ&#x201A;ych jak i dyskretnych. Zasada dziaĹ&#x201A;ania ruchomych hiperpowierzchni zostaĹ&#x201A;a rĂłwnieĹź zilustrowana na przykĹ&#x201A;adzie ciÄ&#x2026;gĹ&#x201A;ego ukĹ&#x201A;adu drugiego rzÄ&#x2122;du.
" Autor artykuĹ&#x201A;u dziÄ&#x2122;kuje Fundacji na rzecz Nauki Polskiej za wsparcie finansowe w ramach programu START 2019.
& L 0 1. Emelyanov S.V., Variable Structure Control Systems, Nauka, Moskwa 1967. 2. Itkis Y., Control Systems of Variable Structure, Nauka, Moskwa, 1976. 3. Utkin V., Variable structure systems with sliding modes, â&#x20AC;&#x153;IEEE Transactions on Automatic Controlâ&#x20AC;?, Vol. 22, No. 2, 1976, 212â&#x20AC;&#x201C;222, DOI: 10.1109/TAC.1977.1101446. 4. Drazenovic B., The invariance conditions in variable structure systems, â&#x20AC;&#x153;Automaticaâ&#x20AC;?, Vol. 5, No. 3, 1969, 287â&#x20AC;&#x201C;295, DOI: 10.1016/0005-1098(69)90071-5. 5. Milosavljevic C., General conditions for the existence of a quasi-sliding mode on the switching hyperplane in discrete variable structure systems, â&#x20AC;&#x153;Automation and Remote Controlâ&#x20AC;?, Vol. 46, No. 3, 1985, 307â&#x20AC;&#x201C;314. 6. Drakunov S. V., Utkin V., On discrete-time sliding modes, â&#x20AC;&#x153;IFAC Proceedings Volumesâ&#x20AC;?, Vol. 22, No. 3, 1989, 273â&#x20AC;&#x201C;278, DOI: 10.1016/S1474-6670(17)53647-2. 7. Choi S.B., Cheong C.C., Park D.W., Moving switching surfaces for robust control of second-order variable structure systems, â&#x20AC;&#x153;International Journal of Controlâ&#x20AC;?, Vol. 58, No. 1, 1993, 229â&#x20AC;&#x201C;245, DOI: 10.1080/00207179308922999. 8. Choi S.B., Park D.W., Jayasuriya S., A time-varying sliding surface for fast and robust tracking control of second-order uncertain systems, â&#x20AC;&#x153;Automaticaâ&#x20AC;?, Vol. 30, No. 5, 1994, 899â&#x20AC;&#x201C;904, DOI: 10.1016/0005-1098(94)90180-5. 9. Choi S.B., Park D.W., Moving sliding surfaces for fast tracking control of second-order dynamical systems, â&#x20AC;&#x153;Journal of Dynamic Systems, Measurement and Controlâ&#x20AC;?, Vol. 116, No. 1, 1994, 154â&#x20AC;&#x201C;158, DOI: 10.1115/1.2900671. 10. Bartoszewicz A., A comment on â&#x20AC;&#x2122;A time-carying sliding surface for fast and robust tracking control of second-order uncertain systemsâ&#x20AC;&#x2122;, â&#x20AC;&#x153;Automaticaâ&#x20AC;?, Vol. 31, No. 12, 1995, 1893â&#x20AC;&#x201C;1895, DOI: 10.1016/0005-1098(95)00122-1. 11. Ha Q., Rye D., Durrant-Whyte H., Fuzzy moving sliding mode control with application to robotic manipulators, â&#x20AC;&#x153;Automaticaâ&#x20AC;?, Vol. 35, No. 4, 1999, 607â&#x20AC;&#x201C;616, DOI: 10.1016/S0005-1098(98)00169-1. 12. Zhang J., Jiang K., Chen Z., Zhao Z., Global robust fuzzy sliding mode for a class of non-linear system, â&#x20AC;&#x153;Transactions of the Institute of Measurement and Controlâ&#x20AC;?, Vol. 28, No. 3, 2006, 219â&#x20AC;&#x201C;227, DOI: 10.1191/0142331206tim174oa. 13. Bartoszewicz A., Time-varying sliding modes for second-order systems, â&#x20AC;&#x153;IEE Proceedings â&#x20AC;&#x201C; Control Theory and Applicationsâ&#x20AC;?, Vol. 143, No. 5, 1996, 455â&#x20AC;&#x201C;462, DOI: 10.1049/ip-cta:19960535. 14. Nowacka-Leverton A., MichaĹ&#x201A;ek M., Pazderski D., Bartoszewicz A., Experimental verification of SMC with moving switching lines applied to hoisting crane vertical motion control, â&#x20AC;&#x153;ISA Transactionsâ&#x20AC;?, Vol. 51, No. 6, 2012, 682â&#x20AC;&#x201C;693, DOI: 10.1016/j.isatra.2012.05.003. 15. Yongqiang J., Xiangdong L., Wei Q., Chaozhen H., Time-varying sliding mode controls in rigid spacecraft attitude tracking, â&#x20AC;&#x153;Chinese Journal of Aeronauticsâ&#x20AC;?, Vol. 21, No. 4, 2008, 352â&#x20AC;&#x201C;360, DOI: 10.1016/S1000-9361(08)60046-1. 16. Tokat S., Sliding mode controlled bioreactor using a time-varying sliding surface, â&#x20AC;&#x153;Transactions of the Institute of Measurement and Controlâ&#x20AC;?, Vol. 31, No. 5, 2009, 435â&#x20AC;&#x201C;456, DOI: 10.1177/0142331208100893. 17. Nowacka-Leverton A., Bartoszewicz A., ITAE optimal variable structure control of second order system with input signal and velocity constraints, â&#x20AC;&#x153;Kybernetesâ&#x20AC;?, Vol. 38, No. 7â&#x20AC;&#x201C;8, 2009, 1093â&#x20AC;&#x201C;1105, DOI: 10.1108/03684920910976844.
45
_ < :] < & & < ] & $] > J & ]
18. Bartoszewicz A., Nowacka A., Reaching phase elimination in variable structure control of the third order system with state constraints, “Kybernetika”, Vol. 42, No. 1, 2006, 111–126, http://eudml.org/doc/33795. 19. Bartoszewicz A., Nowacka A., Optimal design of the shifted switching planes for VSC of a third-order system, “Transactions of the Institute of Measurement and Control”, Vol. 28, No. 4, 2006, 335–352, DOI: 10.1177/0142331206070366. 20. Bartoszewicz A., Nowacka A., Sliding mode control of the third-order system subject to velocity, acceleration and input signal constraints, “International Journal of Adaptive Control and Signal Processing”, Vol. 21, No. 8-9, 2007, 779-794, DOI: 10.1002/acs.970. 21. Bartoszewicz A., Nowacka-Leverton A., ITAE optimal sliding modes for third-order systems with input signal and state constraints, “IEEE Transactions on Automatic Control”, Vol. 55, No. 8, 2010, 1928–1932, DOI: 10.1109/TAC.2010.2049688. 22. Bartoszewicz A., Nowacka-Leverton A., SMC without the reaching phase – the switching plane design for the third order system, “IET Control Theory and Applications”, Vol. 1, No. 5, 2007, 1461–1470, DOI: 10.1049/ietcta:20060458. 23. Bartoszewicz A., Nowacka-Leverton A., Time-Varying Sliding Modes for Second and Third Order Systems, Springer-Verlag, Berlin, 2009. 24. Roy R. G., Olgac N., Robust nonlinear control via moving sliding surfaces – n-th order case, 36th Conference on Decision & Control, San Diego, USA, 1997, 943–948, DOI: 10.1109/CDC.1997.657564. 25. Lee H., Kim E., Kang H. J., Park M., Design of a sliding mode controller with fuzzy sliding surfaces, “IEEE Proceedings – Control Theory and Applications”, Vol. 145, No. 5, 1998, 411–418, DOI: 10.1049/ip-cta:19982242. 26. Takagi T., Sugeno M., Fuzzy identification of systems and its applications to modeling and control, “IEEE Transactions on Systems, Man, and Cybernetics”, Vol. SMC-15, No. 1, 1985, 116-132, DOI: 10.1109/TSMC.1985.6313399. 27. Park D. W., Choi S. B., Moving sliding surfaces for high-order variable structure systems, “International Journal of Control”, Vol. 72, No. 11, 1999, 960–970, DOI: 10.1080/002071799220506. 28. Jamshidi M., Vadiee N., Ross T. J., Fuzzy Logic and Control: Software and Hardware Applications, Prentice Hall, Eaglewood Cliffs, NJ, 1993. 29. Tokat S., Eksin I., Guzelkaya M., A new design method for sliding mode controllers using a linear time-varying sliding surface, “Proceedings of the Institution of Mechanical Engineers, Part I: Journal of Systems and Control Engineering”, Vol. 216, No. 1, 2002, 455–466, DOI: 10.1243/095965102321042218. 30. Eksin I., Tokat S., Guzelkaya M., Soylemez M. T., Design of a sliding mode controller with a nonlinear time-varying sliding surface, “Transactions of the Institute of Measurement and Control”, Vol. 25, No. 2, 2003, 145–162, DOI: 10.1191/0142331203tm079oa. 31. Fung E. H. K., Lee C. K. M., Variable structure tracking control of a single-link flexible arm using time-varying sliding surface, “Journal of Robotic Systems”, Vol. 16, No. 12, 1999, 715–726, DOI: 10.1002/(SICI)1097-4563 (199912)16:12<715::AID-ROB4>3.0.CO;2-6. 32. Betin F., Pinchon D., Capolino G., A time-varying sliding surface for robust position control of a DC motor drive, “IEEE Transaction on Industrial Electronics”, Vol. 49, No. 2, 2002, 462–473, DOI: 10.1109/41.993280. 33. Sivert A., Betin F., Faqir A., Capolino G. A., Robust control of an induction machine drive using a time-varying
46
P
O
M
I
A
R
Y
•
A
U
T
O
M
sliding surface, Proceedings of the IEEE International Symposium on Industrial Electronics, Ajaccio, Francja, 2004, 1369–1374, DOI: 10.1109/ISIE.2004.1572012. 34. Sivert A., Faqir A., Nahidmobarakeh B., Betin F., Capolino G. A., Moving switching surfaces for high precision position control of electrical drives, Proceedings of the IEEE International Conference on Industrial Technology, Hammamet, Tunezja, 2004, 175–180, DOI: 10.1109/ICIT.2004.1490278. 35. Corradini M. L., Orlando G., Linear unstable plants with saturating actuators: Robust stabilization with a time-varying sliding surface, “Automatica”, Vol. 43, No. 1, 2002, 88–94, DOI: 10.1016/j.automatica.2006.07.018. 36. Yorgancioglu F., Komurcugil H., Decoupled sliding-mode controller based on time-varying sliding surfaces for fourth-order systems, “Expert Systems with Applications”, Vol. 37, No. 10, 2010, 6764–6774, DOI: 10.1016/j.eswa.2010.03.049. 37. Gao W., Wang Y., Homaifa A., Discrete-time variable structure control systems, IEEE Transactions on Industrial Electronics, Vol. 42, No. 2, 1995, 117–122, DOI: 10.1109/41.370376. 38. Latosinski P., Sliding mode control based on the reaching law approach – a brief survey, 22nd International Conference on Methods and Models in Automation and Robotics, Międzyzdroje, Polska, 2017, 519–524, DOI: 10.1109/MMAR.2017.8046882. 39. Yu W. C., Wang G. J., Chang C. C., Discrete sliding mode control with forgetting dynamic sliding surface, “Mechatronics”, Vol. 14, No. 7, 2004, 737–755, DOI: 10.1016/j.mechatronics.2004.01.003. 40. Kanai Y., Mori Y., Discrete time sliding mode control with time varying switching hyper plane, SICE Annual Conference, Tokio, Japonia, 2008, 2349–2352, DOI: 10.1109/SICE.2008.4655058. 41. Hu Q., Du C., Xie L., Wang Y., Discrete-time sliding mode control with time-varying surface for hard disk drives, “IEEE Transactions on Control Systems Technology”, Vol. 17, No. 1, 2009, 175–183, DOI: 10.1109/TCST.2008.922505. 42. Yadav N. K., Singh R. K., Discrete-time nonlinear sliding mode controller, “International Journal of Engineering, Science and Technology”, Vol. 3, No. 3, 2011, 94–100. 43. Corradini M. L., Cristofano A., Orlando G., Stabilization of discrete-time linear systems with saturating actuators using sliding modes: application to a twin-rotor system, 50th Conference on Decision and Control and European Control Conference, Orlando, FL, USA, 2011, 1–6, DOI: 10.1109/CDC.2011.6160601.
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
# $ "
% ( " % ( 7 >] ( ( F 6 R < 6 2% 8 Sliding mode control strategies are valued for their total insensitivity to the class of disturbances and uncertainty of the model. Obtaining this property is possible by bringing a point describing the dynamics of the system to a certain switching hypersurface defined in the state space. At the initial stage of control, where the description point approaches this hypersurface, the system remains sensitive to interferences, which hinders the design of effective sliding mode control strategies. To ensure the systemâ&#x20AC;&#x2122;s resistance to interference and model uncertainty at all stages of the control process, many authors proposed the use of mobile switching hypersurfaces. The purpose of this review article is to present the most important achievements in the area of sliding mode control using such hypersurfaces. Discussed are pioneering works proposing the use of mobile switching hypersurfaces and methods of their design are presented. Next, the most important achievements in the area of sliding mode control using movable switching hypersurfaces for both continuous and discrete systems are highlighted. KeywordsU $ % ( % $ > ( % ( 6
7 0
' % ORCID: 0000-0001-5580-352X Q @ X U O *+=+P - ; @ > ^A% U % > )!*= V \ ( % / ( % / (A ( % > % ( ( ( 0 )!*+ V ( % 7;.7 6 % ( 8 % J @ O8J@P \ ( / A V AV > % % A
47
NR 3/2015
48
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 49â&#x20AC;&#x201C;60, DOI: 10.14313/PAR_235/49
6 0 % 7 " Q % X % " 8 ( / ; ) / % $ *%
0 6 7 ( $ 8 6 @ % ; K ( ($ - 6 ; % ; % " $ Q 6 " $ J )&$ !!>BB?$ 0 $ @ %
2% 8 This article presents the results of wind tunnel testing of a model of a missile intended for a vertical cold launch system. The objective of this work was to obtain nondimensional aerodynamic coefficients to build a lookup table database for a six-degree-of-freedom numerical simulation of the missile launch phase. The material model of the full-scale missile was designed in UG/NX Siemens software and manufactured. Low speed measurements were conducted at the Warsaw University of Technology and as a result, static forces and moments characteristics were obtained using six component internal balance for a wide range of angles of attack and sideslip with a 1° interval. Finally, 200 Monte-Carlo simulations in MATLAB/Simulink were evaluated to investigate the missile behavior in the launch phase with the measured results. It was observed that the rolling moment resulting, i.a. from fin cant angles misalignments in the initial roll rate of the missile significantly affects the trajectories. ) U % $ / $ $ % $ %
1. Introduction This article presents the results of low velocity wind tunnel testing of the vertically cold launched missile model and applies them to the numerical simulation. The missile is launched vertically (Fig. 1) with an external device (e.g., hot gas generator, spring, elastic rope) with the velocity order several meters per second. Next, a set of small, mostly solid propellant, lateral thrusters is used to change the attitude rapidly. The main missile motor firing takes place out of the launch platform when the object has the desired attitude. This approach has significant advantages over the classical hot vertical launching strategy, such as better firing coverage, lower acoustic, visual and thermal signatures [1]. It is worth mentioning that there are only a few missiles which have this launch capability, for example: 9M330, 9M96E, KM-SAM or CAMM. Moreover, aerodynamic data for existing cold launched missiles, especially at low speeds, are often classified and not widely available. At rough first approximation due to low dynamic pressure the aerodynamic loads acting on the object might be neglected [2]. On the other hand, there always exist some disturbances that might influence the missile trajectory. At the rapid turnover maneuver high angles of attacks might occur. In the literature
there are some examples of data for missiles at very low subsonic speeds [3. 4]. These characteristics must be known in advance in order to build an aerodynamic database for performing a six-degree-of-freedom (6 DoF) numerical simulation of the launch phase [5]. The abovementioned characteristics may be determined in different ways [6] using semi-empirical engineering level codes (e.g.: Missile DATCOM [7], AP97 [8], MISL3), Computational Fluid Dynamics, wind tunnel testing or identification from flight tests data. Wind tunnel experimental methodology was chosen in this work because it is one of the most reliable methods of obtaining aerodynamic characteristics. A serious disadvantage of this technique are relatively high costs. Therefore, it is important to plan a test program carefully in order to minimize the required number of test cases.
3 + U
" \ $ ' % 3 % *= ** )!*+ $ % % != !* )!)!
!
Fig. 1. Missile vertical cold launch Rys. 1. Zimny pionowy start rakiety
49
Use of Wind Tunnel Measurements Data in Cold Launched Missile Flight Simulations
S1 3
( It is quite a difficult task to maintain full geometric, kinematic and dynamic similarities between flow around a real object and its scaled model during experiments. For the considered case, gravity and unsteady effects were assumed to be negligible. For this reason, Reynolds number Re and Mach number Ma were chosen as main similarity criteria for static measurements. The Reynolds number is
Re =
Ď Vd Îź
Fig. 3. Shape of the nose section (dimensions in millimeters) Rys. 3. KsztaĹ&#x201A;t czÄ&#x2122;Ĺ&#x203A;ci nosowej (wymiary w milimetrach)
(1)
where r is air density, V â&#x20AC;&#x201C; characteristic flow velocity, d â&#x20AC;&#x201C; missile diameter and m is dynamic viscosity. The Mach number is
Ma =
V a
(2) Fig. 4. Material model of the missile Rys. 4. Model materialny rakiety
where a is the speed of sound. When these nondimensional numbers are the same for the real and scaled flow then both flows will be dynamically similar and as a result, the force and moment coefficients will be the same for the model and full-scale flows. Sometimes it might be impossible to match both numbers simultaneously. The required velocity for the flow in the experiment should be: Vm =
Ď l Îźm V Ď m lm Îź
(a)
(3)
(b)
(c)
Fig. 5. Components of the model (a) nose section (b) fins (c) mounting frame Rys. 5. Komponenty modelu (a) sekcja nosowa (b) stabilizatory (c) wrÄ&#x2122;ga mocujÄ&#x2026;ca
where lowercase index m refers to model parameters, and the quantities without the index refer to the full scale prototype. Using a downscaled model to keep the Reynolds numbers equal, either the airspeed or air density must be increased. On the other hand, increasing the airspeed will also bring the Mach number to a high range, while the area of interest is Ma << 1. In the considered low-speed flight region, Reynolds number effects predominate and matching of the Mach number is not so critical [6]. 3D CAD modeling methodology in UG/NX Siemens software was used to design the test object. The virtual assembly was used for model elements machining. The resulting material model was 52.5% in size with respect to the full scale missile
due to the limited volume of the wind tunnel test section. The shape of the model was presented in Fig. 2 and Fig. 3. A spherically blunted tangent ogive nose section was applied. Flat plate airfoil (1.2 mm thick) was used in four trapezoidal fins rigidly mounted in cruciform configuration. The material model (Fig. 4) was made of a wooden nose section, aluminum cylindrical body and steel fins. The surface of the model was polished to achieve the desired roughness. For the preliminary tests the model was mounted to the aerodynamic scale with the steel rear support. A visual marker in the form of chessboard was added to observe potential model vibrations at high inflow angles. The mass of the model (without support) was approximately 2.3 kg. Some of the model components are presented in Fig. 5.
V1 ` The tests were conducted in a subsonic closed circuit wind tunnel located at the Warsaw University of Technology (Fig. 6). The diameter of the circular open test section is 1.6 m and the maximum achievable flow speed is 50 m/s [9]. The movable mounting allows continuous or step-by-step movement to investigate the aerodynamic characteristics in the range of Âą20° angles of attack and sideslip. The series of initial tests for both â&#x20AC;&#x153;+â&#x20AC;? (roll angle 0°) and x (roll angle 45°) stabilizer configurations were performed. Finally, the missile model was mounted in the â&#x20AC;&#x153;+â&#x20AC;? configuration with respect to the horizontal and vertical planes.
Fig. 2. Basic geometric characteristics of the missile model (dimensions in millimeters) Rys. 2. Podstawowe charakterystyki geometryczne modelu rakiety (wymiary w milimetrach)
50
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
' $ ^.J / =$`
Fig. 6. Material model during preliminary wind tunnel measurements Rys. 6. Model materialny w czasie wstÄ&#x2122;pnych pomiarĂłw wagowych
Fig. 7. Six-component aerodynamic internal balance Rys. 7. SzeĹ&#x203A;ciokomponentowa aerodynamiczna waga wewnÄ&#x2122;trzna
Next the mounting interface was slightly modified and the six-component aerodynamic internal balance (Fig. 7) was used to measure the forces and moments which act on the model. Various coordinate systems [10] were used during the experiment (Fig. 8). The positive sign convention was marked with the pink arrows. The aerodynamic loads were measured in the body-fixed coordinate system Obxbybzb. The dynamic pressure was 1 Pa. The flow velocity was obtained from the measured dynamic pressure and was equal to 34.5 m/s. The mean flow temperature in the test section was 28 °C, Mach number 0.1 and Reynolds number 120,000. These conditions correspond to the flow velocity around a full scale missile ~17 m/s (the beginning of the powered flight phase). The tests were conducted for angles of attack from the range â&#x20AC;&#x201C;20° a 20° and sideslip angles â&#x20AC;&#x201C;20° b 5° with 1° step size (for both parameters). The missile has cruciform symmetry. Therefore, measuring loads from the above region allow quick approximation of larger positive angles of sideslip. A fully automatic laboratory test stand was used to acquire the results (Fig. 9). The presence of the balance could dramatically disturb the obtained results, especially the axial force coefficient. The twosteps method was used to overcome this difficulty in order to
Fig. 8. Coordinate systems used in the experiment Rys. 8. UkĹ&#x201A;ady wspĂłĹ&#x201A;rzÄ&#x2122;dnych uĹźyte w eksperymencie
measure the loads properly and ensure high accuracy of data. At first the model with external flow was tested. Next, measurements with no flow were performed to obtain tare weight. Finally, to obtain pure aerodynamic loads acting on the model, the no flow load was subtracted from the results with flow. The nondimensional aerodynamic force coefficients [11] in body fixed frame Obxbybzb were obtained with the formulas: CX =
CY =
CZ =
2X a 0
Ď V02Sm 2Ya 0
Ď V02Sm 2Z a 0
Ď V02Sm
(4)
(5)
(6)
where Xa0, Ya0, Za0 are the measured forces. CX, CY, CZ are axial, side and normal forces nondimensional coefficients, is air density, V0 is flow velocity, Sm = Ď&#x20AC; dm2 4 is the model cross section area and dm is the model diameter.
Fig. 9. Measurement device with a strain/bridge input module Rys. 9. UkĹ&#x201A;ad pomiarowy z moduĹ&#x201A;em wejĹ&#x203A;ciowym
51
Use of Wind Tunnel Measurements Data in Cold Launched Missile Flight Simulations
In a similar way, the moment coefficients were calculated as: CL =
2La 0 Ď V02Smdm
(7)
CM =
2M a 0 Ď V02Smdm
(8)
CN =
2N a 0 Ď V02Smdm
(9)
where cx, cy, cz are drag, side and lift force coefficients, respectively. Similarly, cl, cm, cn are roll, pitch and yaw moment coefficients. Some of the obtained drag force, lift force, rolling and pitching moments coefficients expressed in wind axes were presented in Fig. 10 as a function of angle of attack for various sideslip angles. The drag coefficient presents a typical parabolic curve with the minimum of â&#x20AC;&#x201C;0.35 for zero angles of attack and sideslip. The lift force characteristics are linear, coincide with each other and their slope is negative (approx. â&#x20AC;&#x201C;0.1/°) in the whole range of a. For a = 0° there is a 0.02 bias offset in the coefficient value. A small nonzero rolling moment at a = 0° is observed. This effect is caused by imperfections in fin mounting. With the perfect material model all the curves should cross the plot origin. The slope of pitching moment coefficient curves for b = â&#x20AC;&#x201C;15°, â&#x20AC;&#x201C;10°, â&#x20AC;&#x201C;5°, 0° and 5° is negative and linear in the range â&#x20AC;&#x201C;15° a 15°, which means that the missile is statically stable at low angles of sideslip. In a similar way the selected coefficients of drag force, side force, rolling and yawing moments for various angles of attack as a function of sideslip angle for some specific sideslip angles were presented in Fig. 11. Drag coefficient curves have a similar, parabolic shape. The pair of lines for Âą5°, Âą10°, Âą15° and Âą20° nearly overlaps with each other, which is a correct result. The side force coefficient at angle of attack a = 0° is linear and its slope is negative. The lines crosses with the vertical axis a = 0° at cy = 0.15, which is quite a significant value. Moreover, for larger inflow angles some nonlinearities have appeared. The rolling moment coefficient for a = 0° is nearly a horizontal, straight line but again a bias error with the value â&#x20AC;&#x201C;0.05 has occurred, which means a missile rolling tendency at zero inflow angles. This fact might disturb the missile roll angle immediately after exit from the launch device in the ascending, unpowered phase of flight, which will result in lateral trajectories dispersion. The yawing moment coefficient corresponds with a particular side force and for a = 0° the characteristic is linear with a negative slope, which means missile lateral stability. Nonlinearities occurred especially at a = Âą20° and low b, which results in instability for these regions.
where La0, Ma0, Na0 are the measured moments. CL, CM, CN are rolling, pitching and yawing moments coefficients. The moments were measured about the point located 0.3Â m from the missile base. Standard corrections for open test sections presented in [12] were partially applied to postprocess the results.
X1 : To present the data in the most intuitive and readable manner, the measured data were converted from body fixed Obxbybzb to wind axes Owxwywzw with the expressions [11]: â&#x17D;Ącx â&#x17D;¤ â&#x17D;Ą cos Îą cos β â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘cy â&#x17D;Ľ = â&#x17D;˘ â&#x2C6;&#x2019; cos Îą sin β â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘c â&#x17D;Ľ â&#x17D;˘ â&#x2C6;&#x2019; sin Îą â&#x17D;Ł zâ&#x17D;Ś â&#x17D;Ł
â&#x17D;Ą cl â&#x17D;¤ â&#x17D;Ą cos Îą cos β â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘cm â&#x17D;Ľ = â&#x17D;˘ â&#x2C6;&#x2019; cos Îą sin β â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Łcn â&#x17D;Ś â&#x17D;Ł â&#x2C6;&#x2019; sin Îą
sin β cos β 0
sin β cos β 0
sin Îą cos β â&#x17D;¤ â&#x17D;ĄC X â&#x17D;¤ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x2C6;&#x2019; sin Îą sin β â&#x17D;Ľ â&#x17D;˘CY â&#x17D;Ľ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x17D;Ľ â&#x17D;˘C â&#x17D;Ľ cos Îą â&#x17D;Śâ&#x17D;Ł Z â&#x17D;Ś
(10)
sin Îą cos β â&#x17D;¤ â&#x17D;ĄC L â&#x17D;¤ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x2C6;&#x2019; sin Îą sin β â&#x17D;Ľ â&#x17D;˘C M â&#x17D;Ľ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ cos Îą â&#x17D;Ś â&#x17D;ŁC N â&#x17D;Ś
(11)
Fig. 10. Aerodynamic forces and moments coefficients for various angles of sideslip Rys. 10. WspĂłĹ&#x201A;czynniki siĹ&#x201A; i momentĂłw aerodynamicznych dla róşnych kÄ&#x2026;tĂłw Ĺ&#x203A;lizgu
52
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
' $ ^.J / =$`
Fig. 11. Aerodynamic forces and moments coefficients for various angles of attack Rys. 11. WspĂłĹ&#x201A;czynniki siĹ&#x201A; i momentĂłw aerodynamicznych dla róşnych kÄ&#x2026;tĂłw natarcia
Selected data expressed in a wind axes coordinate system were presented in Table 1â&#x20AC;&#x201C;Table 6.
To assess the whole database space the results were visualized using contour plots (Fig. 12). The dot symbols indicate the measured points.
Fig. 12. Forces and moments coefficients as a function of angles of attack and sideslip Rys. 12. WspĂłĹ&#x201A;czynniki siĹ&#x201A; i momentĂłw jako funkcja kÄ&#x2026;tĂłw natarcia i Ĺ&#x203A;lizgu
53
Use of Wind Tunnel Measurements Data in Cold Launched Missile Flight Simulations
Table 1. Drag force coefficients Tabela 1. Współczynniki siły oporu
a/b [°]
–20
–16
–12
–8
–4
0
4
–20
–1.9577
–1.5791
–1.4293
–1.3136
–1.2416
–1.2542
–1.3220
–16
–1.6612
–1.2769
–1.1110
–0.9793
–0.9160
–0.9600
–0.9847
–12
–1.4268
–1.0363
–0.8721
–0.7323
–0.6783
–0.7142
–0.7427
–8
–1.2734
–0.8830
–0.7098
–0.5795
–0.5145
–0.5233
–0.5645
–4
–1.1796
–0.8087
–0.6071
–0.4659
–0.3908
–0.3882
–0.4397
0
–1.1697
–0.7723
–0.5756
–0.4318
–0.3556
–0.3550
–0.3942
4
–1.2181
–0.8108
–0.6040
–0.4846
–0.3864
–0.3764
–0.4260
8
–1.3141
–0.8945
–0.6979
–0.5726
–0.4901
–0.4827
–0.5287
12
–1.4744
–1.0295
–0.8553
–0.7196
–0.6456
–0.6425
–0.6760
16
–1.7549
–1.2565
–1.0669
–0.9615
–0.8933
–0.8916
–0.8906
20
–2.1002
–1.5795
–1.3669
–1.2873
–1.2133
–1.1852
–1.2208
Table 2. Side force coefficients Tabela 2. Współczynniki siły bocznej
a/b [°]
–20
–16
–12
–8
–4
0
4
–20
2.2609
1.5614
1.0004
0.4021
–0.0258
–0.2011
–0.3682
–16
2.2631
1.5907
1.0926
0.5780
0.0963
–0.1299
–0.4493
–12
2.3577
1.6489
1.2031
0.7213
0.2261
–0.1053
–0.5236
–8
2.3941
1.7102
1.2597
0.7720
0.2989
–0.1045
–0.5659
–4
2.4297
1.7502
1.2999
0.8254
0.3193
–0.1187
–0.5968
0
2.4574
1.7618
1.2815
0.8275
0.3165
–0.1356
–0.6178
4
2.5373
1.7666
1.2947
0.8140
0.3084
–0.1203
–0.6062
8
2.5149
1.7477
1.2631
0.7953
0.3017
–0.1362
–0.5933
12
2.4827
1.6872
1.2385
0.7305
0.2555
–0.1370
–0.5723
16
2.4970
1.5823
1.0914
0.6293
0.1635
–0.1572
–0.5125
20
2.4172
1.5794
0.9713
0.4906
0.0407
–0.2303
–0.4732
Table 3 Lift force coefficients Tabela 3 Współczynniki siły nośnej
54
a/b [°]
–20
–16
–12
–8
–4
0
4
–20
2.4996
2.4199
2.5620
2.6031
2.5397
2.4989
2.5922
–16
2.0724
1.9725
2.0513
2.0558
2.0198
2.0580
2.0424
–12
1.5508
1.4762
1.5831
1.5297
1.5697
1.6223
1.5814
–8
0.9784
0.9503
1.0691
1.0640
1.0761
1.0998
1.0808
–4
0.4752
0.4816
0.5357
0.5535
0.5737
0.5719
0.5210
0
0.1258
0.0881
0.1012
0.1414
0.0944
0.0931
0.0546
4
–0.2539
–0.2509
–0.3392
–0.3562
–0.3934
–0.3909
–0.3983
8
–0.7837
–0.7727
–0.8121
–0.8370
–0.8819
–0.9055
–0.8821
12
–1.3973
–1.2198
–1.3527
–1.3622
–1.3748
–1.4029
–1.4007
16
–1.9321
–1.7594
–1.8126
–1.8866
–1.8797
–1.8630
–1.8500
20
–2.5604
–2.2476
–2.2943
–2.4283
–2.3736
–2.2421
–2.3409
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
' $ ^.J / =$`
Table 4. Rolling moment coefficients Tabela 4. WspóÅ&#x201A;czynniki momentu przechylajÄ&#x2026;cego
a/b [°]
â&#x20AC;&#x201C;20
â&#x20AC;&#x201C;16
â&#x20AC;&#x201C;12
â&#x20AC;&#x201C;8
â&#x20AC;&#x201C;4
0
4
â&#x20AC;&#x201C;20
0.3896
0.2254
0.0856
â&#x20AC;&#x201C;0.0716
â&#x20AC;&#x201C;0.1673
â&#x20AC;&#x201C;0.0743
0.0496
â&#x20AC;&#x201C;16
0.2692
0.1238
0.0886
â&#x20AC;&#x201C;0.0526
â&#x20AC;&#x201C;0.1130
â&#x20AC;&#x201C;0.0486
â&#x20AC;&#x201C;0.0300
â&#x20AC;&#x201C;12
0.1010
0.0246
0.0107
â&#x20AC;&#x201C;0.0852
â&#x20AC;&#x201C;0.1196
â&#x20AC;&#x201C;0.0540
â&#x20AC;&#x201C;0.0628
â&#x20AC;&#x201C;8
0.0849
0.0003
â&#x20AC;&#x201C;0.0147
â&#x20AC;&#x201C;0.0529
â&#x20AC;&#x201C;0.0828
â&#x20AC;&#x201C;0.0512
â&#x20AC;&#x201C;0.0578
â&#x20AC;&#x201C;4
â&#x20AC;&#x201C;0.0056
0.0087
â&#x20AC;&#x201C;0.0314
â&#x20AC;&#x201C;0.0527
â&#x20AC;&#x201C;0.0511
â&#x20AC;&#x201C;0.0578
â&#x20AC;&#x201C;0.0933
0
â&#x20AC;&#x201C;0.0513
â&#x20AC;&#x201C;0.0595
â&#x20AC;&#x201C;0.0466
â&#x20AC;&#x201C;0.0491
â&#x20AC;&#x201C;0.0466
â&#x20AC;&#x201C;0.0648
â&#x20AC;&#x201C;0.0912
4
â&#x20AC;&#x201C;0.0593
â&#x20AC;&#x201C;0.0736
â&#x20AC;&#x201C;0.0595
â&#x20AC;&#x201C;0.0393
â&#x20AC;&#x201C;0.0483
â&#x20AC;&#x201C;0.0361
â&#x20AC;&#x201C;0.0664
8
â&#x20AC;&#x201C;0.0400
â&#x20AC;&#x201C;0.0814
â&#x20AC;&#x201C;0.0426
â&#x20AC;&#x201C;0.0271
0.0005
â&#x20AC;&#x201C;0.0225
â&#x20AC;&#x201C;0.0454
12
â&#x20AC;&#x201C;0.0668
â&#x20AC;&#x201C;0.1237
â&#x20AC;&#x201C;0.0416
â&#x20AC;&#x201C;0.0219
0.0243
â&#x20AC;&#x201C;0.0005
â&#x20AC;&#x201C;0.0264
16
â&#x20AC;&#x201C;0.2089
â&#x20AC;&#x201C;0.1052
â&#x20AC;&#x201C;0.0286
0.0272
0.0729
0.0372
â&#x20AC;&#x201C;0.0161
20
â&#x20AC;&#x201C;0.3176
â&#x20AC;&#x201C;0.2029
â&#x20AC;&#x201C;0.0058
0.0936
0.1520
0.0866
0.0056
Table 5. Pitching force coefficients Tabela 5. WspóÅ&#x201A;czynniki momentu pochylajÄ&#x2026;cego
a/b [°]
â&#x20AC;&#x201C;20
â&#x20AC;&#x201C;16
â&#x20AC;&#x201C;12
â&#x20AC;&#x201C;8
â&#x20AC;&#x201C;4
0
4
â&#x20AC;&#x201C;20
â&#x20AC;&#x201C;0.3664
0.1285
0.6599
0.9613
1.0791
1.0336
1.0873
â&#x20AC;&#x201C;16
â&#x20AC;&#x201C;0.0581
0.3229
0.6779
0.8538
0.9290
1.0677
1.0108
â&#x20AC;&#x201C;12
â&#x20AC;&#x201C;0.0032
0.3761
0.6265
0.7872
0.8602
0.9483
0.9311
â&#x20AC;&#x201C;8
â&#x20AC;&#x201C;0.2631
0.1562
0.3840
0.4851
0.5824
0.6379
0.5853
â&#x20AC;&#x201C;4
â&#x20AC;&#x201C;0.2888
â&#x20AC;&#x201C;0.0401
0.1642
0.2165
0.2700
0.3002
0.2732
0
0.0612
0.0220
0.0389
0.0310
0.0309
0.0205
0.0166
4
0.2797
0.1315
â&#x20AC;&#x201C;0.1033
â&#x20AC;&#x201C;0.1743
â&#x20AC;&#x201C;0.2051
â&#x20AC;&#x201C;0.2251
â&#x20AC;&#x201C;0.2313
8
0.2250
â&#x20AC;&#x201C;0.0730
â&#x20AC;&#x201C;0.3229
â&#x20AC;&#x201C;0.4688
â&#x20AC;&#x201C;0.5300
â&#x20AC;&#x201C;0.5867
â&#x20AC;&#x201C;0.5405
12
0.0773
0.0320
â&#x20AC;&#x201C;0.5494
â&#x20AC;&#x201C;0.6886
â&#x20AC;&#x201C;0.7643
â&#x20AC;&#x201C;0.8221
â&#x20AC;&#x201C;0.8188
16
0.0982
0.0195
â&#x20AC;&#x201C;0.4246
â&#x20AC;&#x201C;0.8332
â&#x20AC;&#x201C;0.9318
â&#x20AC;&#x201C;1.0370
â&#x20AC;&#x201C;0.9700
20
0.4688
0.3783
â&#x20AC;&#x201C;0.1233
â&#x20AC;&#x201C;0.9376
â&#x20AC;&#x201C;1.0597
â&#x20AC;&#x201C;0.9449
â&#x20AC;&#x201C;1.1938
Table 6. Yawing force coefficients Tabela 6. WspóÅ&#x201A;czynniki momentu odchylajÄ&#x2026;cego
a/b [°]
â&#x20AC;&#x201C;20
â&#x20AC;&#x201C;16
â&#x20AC;&#x201C;12
â&#x20AC;&#x201C;8
â&#x20AC;&#x201C;4
0
4
â&#x20AC;&#x201C;20
â&#x20AC;&#x201C;0.2028
â&#x20AC;&#x201C;0.0244
0.0913
0.1862
0.2716
â&#x20AC;&#x201C;0.0851
â&#x20AC;&#x201C;0.4960
â&#x20AC;&#x201C;16
â&#x20AC;&#x201C;0.7635
â&#x20AC;&#x201C;0.4904
â&#x20AC;&#x201C;0.4102
â&#x20AC;&#x201C;0.1583
0.0927
â&#x20AC;&#x201C;0.1027
â&#x20AC;&#x201C;0.2808
â&#x20AC;&#x201C;12
â&#x20AC;&#x201C;1.2948
â&#x20AC;&#x201C;0.9599
â&#x20AC;&#x201C;0.7443
â&#x20AC;&#x201C;0.4794
â&#x20AC;&#x201C;0.1312
â&#x20AC;&#x201C;0.0742
0.0426
â&#x20AC;&#x201C;8
â&#x20AC;&#x201C;1.3242
â&#x20AC;&#x201C;1.0927
â&#x20AC;&#x201C;0.9071
â&#x20AC;&#x201C;0.5731
â&#x20AC;&#x201C;0.2160
â&#x20AC;&#x201C;0.0279
0.1859
â&#x20AC;&#x201C;4
â&#x20AC;&#x201C;1.3477
â&#x20AC;&#x201C;1.1354
â&#x20AC;&#x201C;0.9298
â&#x20AC;&#x201C;0.6136
â&#x20AC;&#x201C;0.2245
â&#x20AC;&#x201C;0.0040
0.2828
0
â&#x20AC;&#x201C;1.3337
â&#x20AC;&#x201C;1.0984
â&#x20AC;&#x201C;0.8767
â&#x20AC;&#x201C;0.5969
â&#x20AC;&#x201C;0.2115
0.0307
0.3309
4
â&#x20AC;&#x201C;1.3842
â&#x20AC;&#x201C;0.9824
â&#x20AC;&#x201C;0.8459
â&#x20AC;&#x201C;0.5119
â&#x20AC;&#x201C;0.1598
0.0709
0.3591
8
â&#x20AC;&#x201C;1.2146
â&#x20AC;&#x201C;0.8714
â&#x20AC;&#x201C;0.7253
â&#x20AC;&#x201C;0.4349
â&#x20AC;&#x201C;0.0879
0.1341
0.3628
12
â&#x20AC;&#x201C;1.0733
â&#x20AC;&#x201C;0.5834
â&#x20AC;&#x201C;0.5320
â&#x20AC;&#x201C;0.2575
0.0271
0.1291
0.2759
16
â&#x20AC;&#x201C;0.6418
â&#x20AC;&#x201C;0.1358
â&#x20AC;&#x201C;0.0589
0.0362
0.2746
0.1668
0.0810
20
0.1192
0.4686
0.5123
0.4348
0.5525
0.2879
â&#x20AC;&#x201C;0.1449
55
Use of Wind Tunnel Measurements Data in Cold Launched Missile Flight Simulations
â&#x17D;¤ â&#x17D;Ą1 sin ÎŚ tan Î&#x2DC; â&#x17D;ĄÎŚ cos ÎŚ tan Î&#x2DC; â&#x17D;¤ â&#x17D;ĄP â&#x17D;¤ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x17D;Ľ = â&#x17D;˘0 â&#x17D;˘Î&#x2DC; cos ÎŚ â&#x2C6;&#x2019; sin ÎŚ â&#x17D;Ľ â&#x17D;˘Q â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x17D;˘Î¨ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ł â&#x17D;Ś â&#x17D;Ł0 sin ÎŚ / cos Î&#x2DC; cos ÎŚ / cos Î&#x2DC; â&#x17D;Ś â&#x17D;ŁR â&#x17D;Ś
The smallest absolute value of drag has occurred at zero inflow angles and the plot has a circular symmetry, which is typical for objects with an axisymmetric body. The contour maps for side force and lift force coefficients have a mirror symmetry with respect to vertical and horizontal lines corresponding with a = 0° and b = 0°. In the rolling moment coefficient plot there are some small irregular regions. The pitching moment coefficient is not perfectly symmetric with respect to a = 0° for b < â&#x20AC;&#x201C;12°. Next, the results were implemented into two-dimensional lookup tables and used in the 6DoF numerical flight simulation.
where U0, V0, W0 are missile linear velocities in the body axis frame, P0, Q0, R0 are missile roll rates, ÎŚ0, Î&#x2DC;0, Ψ0 are initial Euler angles (roll, pitch and yaw), xn, yn, zn are initial position coordinates of the missile center of mass. The dot symbol above some variables denotes a derivative with respect to time. is projectile mass and I is the inertia matrix in the form
Y1
( [ ( % *
)
â&#x17D;ĄI x â&#x17D;˘ I= â&#x17D;˘0 â&#x17D;˘ â&#x17D;˘0 â&#x17D;Ł
A set of Monte-Carlo flight simulations [13] was evaluated to investigate the full-scale missile behavior using the aerodynamic database which was developed using wind tunnel tests methodology. The main goal of the numerical experiments was to assess the repeatability of the cold launch maneuver under various external disturbances. The minimal number of thrusters which allows controlled, rapid orientation change is equal to two [2, 5]. Two lateral thrusters placed before the missile center of mass, 1.3Â m from the base at the opposite sides of the fuselage were used to perform the cold launch maneuver. In this configuration the missile is uncontrolled in the roll channel. Most of the existing cold launch missiles are roll stabilized. The mathematical model of the missile described in [5, 14] was used and implemented into MATLAB 2018a software. Flat Earth approximation was used for the simulation. Air thermodynamic properties were assumed according to [15]. The missile was modeled as a variable mass rigid body with six degrees of freedom. The center of mass location shift due to main motor grain burnout was included in the model. The full-scale missile maximum velocity was predicted to be approximately 90 m/s, so for such a subsonic range it was assumed that the coefficients variation with speed is negligible. The wind influence on the missile trajectory was neglected. The equations of motion of the missile were as follows [5, 16]:
â&#x17D;ĄU â&#x17D;¤ â&#x17D;ĄX b â&#x17D;¤ â&#x17D;Ą 0 â&#x17D;˘ â&#x17D;Ľ 1 â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘V â&#x17D;Ľ = â&#x17D;˘Yb â&#x17D;Ľ â&#x2C6;&#x2019; â&#x17D;˘ R â&#x17D;˘ â&#x17D;Ľ mâ&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘W â&#x17D;Ľ â&#x17D;˘ Z â&#x17D;Ľ â&#x17D;˘ â&#x2C6;&#x2019;Q â&#x17D;Ł â&#x17D;Ś â&#x17D;Ł bâ&#x17D;Ś â&#x17D;Ł
â&#x2C6;&#x2019;R 0 P
â&#x17D;ĄP â&#x17D;¤ â&#x17D;Ą Lb â&#x17D;¤ â&#x17D;Ą 0 â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘Q â&#x17D;Ľ = Iâ&#x2C6;&#x2019;1 â&#x17D;˘M b â&#x17D;Ľ â&#x2C6;&#x2019; Iâ&#x2C6;&#x2019;1 â&#x17D;˘ R â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘R â&#x17D;Ľ â&#x17D;˘N â&#x17D;Ľ â&#x17D;˘ â&#x2C6;&#x2019;Q â&#x17D;Ł â&#x17D;Ś â&#x17D;Ł bâ&#x17D;Ś â&#x17D;Ł
Q â&#x17D;¤ â&#x17D;ĄU â&#x17D;¤ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x2C6;&#x2019;P â&#x17D;Ľ â&#x17D;˘V â&#x17D;Ľ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ 0 â&#x17D;Ľâ&#x17D;Ś â&#x17D;˘â&#x17D;ŁW â&#x17D;Ľâ&#x17D;Ś
0 P
P
O
M
I
A
R
Y
â&#x20AC;˘
A
Iy 0
(16)
Forces Fb and moments Mb which act on the missile were calculated as [16] â&#x17D;ĄX b â&#x17D;¤ â&#x17D;˘ â&#x17D;Ľ Fb = â&#x17D;˘Yb â&#x17D;Ľ = Fg + Fs + Fa + Fc â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘Z â&#x17D;Ľ â&#x17D;Ł bâ&#x17D;Ś
(17)
where Fg are gravity, Fs propulsive, Fa aerodynamic and Fc control forces generated by lateral thrusters. Similarly â&#x17D;Ą Lb â&#x17D;¤ â&#x17D;˘ â&#x17D;Ľ M b = â&#x17D;˘M b â&#x17D;Ľ = M g + M s + M a + M c â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘N â&#x17D;Ľ â&#x17D;Ł bâ&#x17D;Ś
(18)
are the corresponding moments. The gravity loads Fg and Mg in the body coordinate system Obxbybzb were calculated according to [5, 17]. The main motor thrust axis misalignment was included in the model. The propulsive forces are [17]
â&#x17D;ĄX s â&#x17D;¤ â&#x17D;Ącos Ψ T cos Î&#x2DC;T â&#x17D;¤ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ Fs = â&#x17D;˘Ys â&#x17D;Ľ = T t â&#x17D;˘ cos Î&#x2DC;T sin Ψ T â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘Z â&#x17D;Ľ â&#x17D;˘ â&#x2C6;&#x2019; sin Î&#x2DC; â&#x17D;Ľ T â&#x17D;Ł sâ&#x17D;Ś â&#x17D;Ł â&#x17D;Ś
()
(19)
(13)
â&#x17D;Ąx n â&#x17D;¤ â&#x17D;Ącos Î&#x2DC; cos Ψ sin ÎŚ sin Î&#x2DC; cos Ψ â&#x2C6;&#x2019; cos ÎŚ sin Ψ cos ÎŚ sin Î&#x2DC; cos Ψ + sin ÎŚ sin Ψ â&#x17D;¤ â&#x17D;ĄU â&#x17D;¤ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x17D;˘y n â&#x17D;Ľ = â&#x17D;˘ cos Î&#x2DC; sin Ψ sin ÎŚ sin Î&#x2DC; sin Ψ + cos ÎŚ cos Ψ cos ÎŚ sin Î&#x2DC; sin Ψ â&#x2C6;&#x2019; sin ÎŚ cos Ψ â&#x17D;Ľ â&#x17D;˘V â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľâ&#x17D;˘ â&#x17D;Ľ â&#x17D;˘z â&#x17D;Ľ â&#x17D;˘ â&#x2C6;&#x2019; sin Î&#x2DC; â&#x17D;Ľ â&#x17D;˘W â&#x17D;Ľ sin ÎŚ cos Î&#x2DC; cos ÎŚ cos Î&#x2DC; n â&#x17D;Ł â&#x17D;Ś â&#x17D;Ł â&#x17D;Śâ&#x17D;Ł â&#x17D;Ś
56
0â&#x17D;¤ â&#x17D;Ľ 0â&#x17D;Ľ â&#x17D;Ľ I z â&#x17D;Ľâ&#x17D;Ś
0
(12)
Q â&#x17D;¤ â&#x17D;ĄP â&#x17D;¤ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x2C6;&#x2019;P â&#x17D;Ľ I â&#x17D;˘Q â&#x17D;Ľ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ 0 â&#x17D;Ľâ&#x17D;Ś â&#x17D;˘â&#x17D;ŁR â&#x17D;Ľâ&#x17D;Ś
â&#x2C6;&#x2019;R
(15)
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
(14)
B
O
T
Y
K
A
NR 1 / 20 20
' $ ^.J / =$`
and the moments â&#x17D;Ą Ls â&#x17D;¤ â&#x17D;Ą â&#x17D;¤ 0 â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ M s = â&#x17D;˘M s â&#x17D;Ľ = T t â&#x17D;˘ â&#x2C6;&#x2019;ln sin Î&#x2DC;T â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘N â&#x17D;Ľ â&#x17D;˘ â&#x2C6;&#x2019; cos Î&#x2DC; sin Ψ â&#x17D;Ľ T Tâ&#x17D;Ś â&#x17D;Ł sâ&#x17D;Ś â&#x17D;Ł
()
(20)
where T(t) is the main motor thrust, Î&#x2DC;T and ΨT are thrust pitch and yaw misalignment angles; ln is the distance from the center of mass to the main motor nozzle exit plane. The center of mass location from the base before and after main motor burnout was 0.66/0.7 m.
Fig. 13. Lateral thruster thrust force Rys. 13. CiÄ&#x2026;g silnika korekcyjnego
The aerodynamic forces which act on the projectile are
(
â&#x17D;ĄC X Îą , β , E state â&#x17D;˘ 1 Xa = Ď V02S â&#x17D;˘ CY Îą , β â&#x17D;˘ 2 â&#x17D;˘ C Îą, β Z â&#x17D;Ł
( (
) )
)
â&#x17D;¤ â&#x17D;Ľ â&#x17D;Ľ â&#x17D;Ľ â&#x17D;Ľ â&#x17D;Ś
(21)
time of the thrusters was set to 0.9Â s and the thrust force amplitude to approximately 60 N (Fig. 13). The first and second thruster were initialized in 0.95 s and 1 s of flight, respectively. The main motor missile was fired with 0.4 s time delay after second thruster firing. Each of the individual disturbances was modelled as Gauss distribution. The simulation initial conditions are presented in Table 7.
and the aerodynamic moments are described by
â&#x17D;Ą Pd â&#x17D;¤ â&#x17D;˘ C L Îą , β + C LP Îą , β â&#x17D;Ľ 2 V0 â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘ â&#x17D;Ľ 1 Qd â&#x17D;Ľ M a = Ď V02Sd â&#x17D;˘C M Îą , β + C MQ Îą , β â&#x17D;˘ 2 2V0 â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ Rd â&#x17D;Ľ â&#x17D;˘C N Îą , β + C NR Îą , β â&#x17D;Ľ 2V0 â&#x17D;Śâ&#x17D;Ľ â&#x17D;Łâ&#x17D;˘
(
)
(
Table 7. Monte-Carlo simulation initial conditions Tabela 7. Warunki poczÄ&#x2026;tkowe dla symulacji Monte-Carlo
)
(
)
(
)
(
)
(
)
(23)
and â&#x17D;Ą 0 â&#x17D;¤ â&#x17D;˘ â&#x17D;Ľ M c = â&#x2C6;&#x2018; lltT â&#x17D;˘ sin ÎŚi â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ i â&#x17D;˘ â&#x2C6;&#x2019; cos ÎŚ â&#x17D;Ľ iâ&#x17D;Ś â&#x17D;Ł
parameter
mean value
standard deviation
unit
1
m0
15.67
0.05
kg
2
mk
14.94
0.05
kg
3
Ix0
0.057
0.01
kgm2
4
Ixk
0.056
0.01
kgm2
4
Iyk
3.6
0.01
kgm2
4
Iyk
3.45
0.01
kgm2
5
U0
17
1
m/s
6
V0
0
0.1
m/s
7
W0
0
0.1
m/s
8
P0
0
10
°/s
9
Q0
0
1
°/s
10
R0
0
1
°/s
11
ÎŚ0
0
0.2
°
12
Î&#x2DC;0
90
0.1
°
13
Ψ0
0
0.1
°
14
xn
0
0.02
m
15
yn
0
0.02
m
16
zn
0
0.02
m
17
Î&#x2DC;T
0
0.01
°
18
ΨT
0
0.01
°
(22)
where r is air density, V0 is total aerodynamic velocity, S = wd2/4 is the projectile cross section area, d is the missile diameter, a is angle of attack, b â&#x20AC;&#x201C; angle of sideslip. CX, CY, CZ are axial, side and normal force nondimensional coefficients. CL is spin driving moment coefficient due to fin mounting misalignments, and CLP, CMQ, CNR are roll, pitch and yaw damping moment coefficients, which were estimated using the method described in [18]. Estate is the main motor state (0 â&#x20AC;&#x201C; powered flight, 1 â&#x20AC;&#x201C; unpowered). Aerodynamic coefficients were implemented into the software using the lookup table method. Due the high cost of modernization of the laboratory stand in order to measure the damping moment coefficients they were obtained using semiâ&#x20AC;&#x201C;empirical methods presented in [19]. The lateral thruster loads were computed as: â&#x17D;Ą 0 â&#x17D;¤ â&#x17D;˘ â&#x17D;Ľ n Xc = â&#x2C6;&#x2018;T â&#x17D;˘ sin ÎŚi â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ i â&#x17D;˘ â&#x2C6;&#x2019; cos ÎŚ â&#x17D;Ľ iâ&#x17D;Ś â&#x17D;Ł
no.
n
(24)
where l lt is the distance between the center of mass and lateral thruster nozzle projected on the longitudinal axis of the missile and Fi is the angular location of the thruster. The operation
m0, mk â&#x20AC;&#x201C; missile mass, Ix0/Ixk â&#x20AC;&#x201C; longitudinal, Iy0/Iyk and Iz0/Izk â&#x20AC;&#x201C; lateral moments of inertia before/after main motor firing. The Marsenne-Twister algorithm was used to generate pseu-
57
Use of Wind Tunnel Measurements Data in Cold Launched Missile Flight Simulations
Fig. 14. Missile trajectories visualisation Rys. 14. Wizualizacja trajektorii rakiety
Z1
dorandom numbers. 200 numerical simulations were performed using Simulink rapid accelerator mode on a desktop PC with i7â&#x20AC;&#x201C;4790 CPU @3.60 GHz and 16 GB DDR3 RAM. The flight duration for each case was set to 5 s. Figure 14 shows initial portions of the missile trajectories. The missile altitude change maneuver takes place when the object is at the attitude of 17 m. The black, dotted line means a reference trajectory for zero standard deviations each from the parameters. For nonexistent error sources, all the trajectories should be the same and coincide with this line. Strong lateral dispersion on the left and right from the Onxnzn plane is observable. The lateral dispersion at the end of the flight was from â&#x20AC;&#x201C;91 to 88.7. The differences in elevation are smaller but also not negligible. The simulations proved that the fullâ&#x20AC;&#x201C;scale missile is statically stable. The dispersion of trajectories is mainly the result of nonzero initial missile roll rate P0 about its longitudinal axis. It proves that the used methodology of wind tunnel measurements could be used successfully for numerical flight dynamic simulation purposes.
58
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
This paper presents the results of subsonic wind tunnel testing of a model missile intended for the vertical cold launch system. The static aerodynamic characteristics were acquired successfully as a function of angles of attack and sideslip with the internal six component balance. The aerodynamic database obtained during wind tests was used in the Monte-Carlo simulations of the missile trajectories. Due to lack of roll stabilization a significant dispersion has been observed. It was concluded that the fin mounting must be checked carefully to eliminate possible rolling moment due to nonzero fin cant angles. Oscillations of the test object might occur at high angles of attack, which results in limited quality of some coefficients. During wind tunnel tests it was observed that the main problem was connected with testing objects with small lifting surfaces like missile fins, so it is necessary to have high accuracy aerodynamic balance, which determines the quality of the results. For further work, oil, tufts or pressure sensitive
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
' $ ^.J / =$`
paint visualization should be performed to study the flow field around the missile body in detail.
References 1. Titchener P.E., Veitch A.J., UK Soft Vertical Launch â&#x20AC;&#x201C; A Flexible Solution to an Integral Concept for Ground & Naval Air Defence, [in:] RTO MPâ&#x20AC;&#x201C;063, 2000. 2. Taur D.â&#x20AC;&#x201C;R., Chern J.â&#x20AC;&#x201C;S., Optimal Side Jet Control for Vertically Cold Launched Tactical Missiles, [in:] XIAA Guidance, Navigation, and Control Conference and Exhibit, Denver, 2000, DOI: 10.2514/6.2000-4164. 3. OcokoljiÄ&#x2021; G., RaĹĄuo B., Testing an Anti Tank Missile Model with Jet Simulation in the Tâ&#x20AC;&#x201C;35 Subsonic Wind Tunnel, â&#x20AC;&#x153;Scientific Technical Reviewâ&#x20AC;?, Vol. 62, No. 3â&#x20AC;&#x201C;4, 2012, 14â&#x20AC;&#x201C;20. 4. OcokoljiÄ&#x2021; G., RaĹĄuo B., Aerodynamic testing model guided missiles with jets simulations in the Tâ&#x20AC;&#x201C;35 wind tunnel, 2014, 629â&#x20AC;&#x201C;634, DOI: 10.5937/tehnika1404629O. 5. Jacewicz M., GĹ&#x201A;Ä&#x2122;bocki R., Simulation study of a missile cold launch system, â&#x20AC;&#x153;Journal of Theoretical and Applied Mechanicsâ&#x20AC;?, Vol. 56, No. 4, 2018, 901â&#x20AC;&#x201C;913, DOI: 10.15632/jtam-pl.56.4.901. 6. Barlow J.B., Rae W.H., Pope A., Low-Speed Wind Tunnel Testing, New York: John Wiley & Sons, Inc., 1999. 7. Rosema C., Doyle J., Blake W., Missile Data Compendium (DATCOM) â&#x20AC;&#x201C; User Manual â&#x20AC;&#x201C; 2014 Revision, 2014. 8. Moore F., Hymer T., The 2002 Version of the Aeroprediction Code: Part I â&#x20AC;&#x201C; Summary of New Theoretical Methodology, Naval Surface Warfare Center, 2002. 9. SmÄ&#x2122;dra K., Ĺ&#x161;wierkot R., KubryĹ&#x201E;ski K., Low speed wind tunnel test of the jet trainer model at high angles of attack, â&#x20AC;&#x153;Journal of KONES Powertrain and Transportâ&#x20AC;?, Vol. 23, No. 4, 2016, 471â&#x20AC;&#x201C;478, DOI: 10.5604/12314005.1217285.
10. Allerton D., Principles of Flight Simulation, Wiltshire: John Wiley & Sons, 2009. 11. Ĺ adyĹźyĹ&#x201E;ska-KozdraĹ&#x203A; E., Filipowicz M., Maryniak J., Modelowanie dynamiki oraz identyfikacja aerodynamiczna zmodyfikowanego pocisku moĹşdzierzowego kalibru 74 mm, â&#x20AC;&#x17E;Problemy mechatroniki. Uzbrojenie, lotnictwo, inĹźynieria bezpieczeĹ&#x201E;stwaâ&#x20AC;?, Vol. 2, No. 8, 2012, 51â&#x20AC;&#x201C;62. 12. Advisory Group For Aerospace Research & Development, AGARDograph 336 Wind tunnel wall correction, North Atlantic Treaty Organization, 1998. 13. Ilg M., Rogers J., Costello M., Projectile Monte-Carlo Trajectory Analysis Using a Graphics Processing Unit, [in:] AIAA Atmospheric Flight Mechanics Conference, Portland, 2011, DOI: 10.2514/6.2011-6266. 14. GĹ&#x201A;Ä&#x2122;bocki R., Jacewicz M., Missile Vertical Launch System with Reaction Control Jets, Vol. 145, No. 1, 2018, 25â&#x20AC;&#x201C;46, DOI: 10.5604/01.3001.0012.1271. 15. National Aeronautics and Space Administration, U.S. Standard Atmosphere, Washington, D.C., 1976. 16. Jitpraphai T., Costello M., Dispersion Reduction of a Direct Fire Rocket Using Lateral Pulse Jets, â&#x20AC;&#x153;Journal of Spacecraft and Rocketsâ&#x20AC;?, Vol. 38, No. 6, 2001, 929â&#x20AC;&#x201C;936, DOI: 10.2514/2.3765. 17. Department of Defense, Military Handbook. Missile Flight Simulation. Part One â&#x20AC;&#x201C; Surface to Air missiles, Department of Defense, 17 July 1995. 18. Danberg J., Weinacht P., An Approximate Method for Pitch-Damping Prediction, Aberdeen Proving Ground: Army Research Laboratory, 2003. 19. STANAG 4655 â&#x20AC;&#x201C; An Engineering Model To Estimate Aerodynamic Coefficient, NATO Standardization Agency, Bruxelles 2014.
V % A ( ( 1 8 Niniejszy artykuĹ&#x201A; przedstawia wyniki testĂłw w tunelu aerodynamicznym modelu rakiety dedykowanej dla pionowego zimnego startu. Celem pracy byĹ&#x201A;o uzyskanie bezwymiarowych wspĂłĹ&#x201A;czynnikĂłw aerodynamicznych potrzebnych do opracowania bazy w postaci tablic dla numerycznej symulacji lotu o szeĹ&#x203A;ciu stopniach swobody. Model materialny peĹ&#x201A;nowymiarowej rakiety zostaĹ&#x201A; zaprojektowany przy wykorzystaniu programu Siemens UG/NX. Testy zostaĹ&#x201A;y przeprowadzone na Politechnice Warszawskiej przy niskiej prÄ&#x2122;dkoĹ&#x203A;ci przepĹ&#x201A;ywu a charakterystyki statycznych siĹ&#x201A; i momentĂłw uzyskano za pomocÄ&#x2026; szeĹ&#x203A;cioskĹ&#x201A;adnikowej wagi wewnÄ&#x2122;trznej dla szerokiego zakresu kÄ&#x2026;tĂłw natarcia i Ĺ&#x203A;lizgu z krokiem 1°. Ostatecznie, przeprowadzono 200 symulacji Monte-Carlo w programie MATLAB/Simulink w celu zbadania zachowania pocisku w fazie startu z uĹźyciem zmierzonych wartoĹ&#x203A;ci. ZostaĹ&#x201A;o zaobserwowane, Ĺźe moment przechylajÄ&#x2026;cy wynikajÄ&#x2026;cy m.in. z niedokĹ&#x201A;adnoĹ&#x203A;ci montaĹźowych stabilizatorĂłw wpĹ&#x201A;ywa znaczÄ&#x2026;co na uzyskiwane trajektorie. ) U % $ ( $ $ $ %
59
Use of Wind Tunnel Measurements Data in Cold Launched Missile Flight Simulations
/ ; )1
) )1
(' % ORCID: 0000-0002-5703-8830
' % ORCID: 0000-0002-7173-0890
H % % O)!*BP 6 0 > 6 7 ( F @ Q % % 8 6 @ % ; K ( > ( F L % $ % ; % ( (
H % % O)!*?P 6 0 > 6 7 ( F @ Q % 8 6 @ % ; K ( > ( 6 0 7 F % L % ( % $ % ( (
( / % $ *% -1 ( 9 ( / ' % ORCID: 0000-0002-2389-7653 @ 6 6 0 6 7 > ( R 8 6 @ % ; K ( ( F 6 % L $ $ ;]$ $ / $ ; 6 / % / > % % % 6 > % ( ( % > @ % 6 $ % %
60
P
O
M
I
A
R
Y
â&#x20AC;¢
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;¢
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 61â&#x20AC;&#x201C;66, DOI: 10.14313/PAR_235/61
T ( % [ % A/ $ < Y < % ^ R - X $ 7 ( T $ ; T **!_**&$ !)>)?B 0
1 8 Do rozwiÄ&#x2026;zania problemu unikania kolizji przez samolot w przestrzeni powietrznej niezbÄ&#x2122;dne jest wykrycie przeszkody, sprawdzenie czy stanowi zagroĹźenie dla bezpieczeĹ&#x201E;stwa samolotu oraz podjÄ&#x2122;cie wĹ&#x201A;aĹ&#x203A;ciwych decyzji o odpowiednim sposobie jej ominiÄ&#x2122;cia. To wszystko sÄ&#x2026; istotne fazy poprzedzajÄ&#x2026;ce automatyczne ominiÄ&#x2122;cie ruchomej przeszkody. W pracy zaprezentowano algorytm omijania ruchomej przeszkody o niedajÄ&#x2026;cych siÄ&#x2122; przewidzieÄ&#x2021; zmianach jej ruchu. Przedstawiono schemat logicznych dziaĹ&#x201A;aĹ&#x201E; majÄ&#x2026;cych na celu nie tylko bezpieczne unikniÄ&#x2122;cie kolizji z manewrujÄ&#x2026;cÄ&#x2026; przeszkodÄ&#x2026;, ale takĹźe powrĂłt do lotu wzdĹ&#x201A;uĹź zaplanowanej przed startem trasy. ZaproponowanÄ&#x2026; metodÄ&#x2122; zilustrowano symulacyjnym przykĹ&#x201A;adem automatycznego ominiÄ&#x2122;cia wspomnianej przeszkody dla wybranego scenariusza. ) U $ $ $
1. Wprowadzenie WĹ&#x203A;rĂłd wielu róşnych niebezpiecznych scenariuszy, jakie mogÄ&#x2026; wystÄ&#x2122;powaÄ&#x2021; w czasie lotu samolotu, jest zagroĹźenie wystÄ&#x2026;pienia kolizji z ruchomÄ&#x2026; przeszkodÄ&#x2026; wykonujÄ&#x2026;cÄ&#x2026; manewry o niedajÄ&#x2026;cym siÄ&#x2122; przewidzieÄ&#x2021; przebiegu. Nie jest w zwiÄ&#x2026;zku z tym moĹźliwe wyznaczenie przebiegu caĹ&#x201A;ej trajektorii ominiÄ&#x2122;cia wspomnianej przeszkody, podobnie jak w przypadku Ĺ&#x203A;ledzenia celu przez rakietÄ&#x2122; [7]. Dodatkowym czynnikiem, jaki wpĹ&#x201A;ywa na pogorszenie przewidywalnoĹ&#x203A;ci jest ograniczony zasiÄ&#x2122;g wykrywania przeszkĂłd wynikajÄ&#x2026;cy z technicznych moĹźliwoĹ&#x203A;ci zastosowanego detektora przeszkĂłd. W trakcie lotu samolotu zmniejszajÄ&#x2026; siÄ&#x2122; odlegĹ&#x201A;oĹ&#x203A;ci do niektĂłrych obiektĂłw (znajdujÄ&#x2026;cych siÄ&#x2122; w przedniej pĂłĹ&#x201A;pĹ&#x201A;aszczyĹşnie), dziÄ&#x2122;ki czemu moĹźna obserwowaÄ&#x2021; kolejne przeszkody, wczeĹ&#x203A;niej niewykryte. Podobne zjawisko moĹźe wystÄ&#x2122;powaÄ&#x2021; w wyniku ograniczonego kÄ&#x2026;ta widzenia detektora, czÄ&#x2122;sto znacznie mniejszego od 360°. W wielu pracach [6, 8, 10, 12] poĹ&#x203A;wiÄ&#x2122;conych opisywanej problematyce nie sÄ&#x2026; uwzglÄ&#x2122;dniane wymienione uwarunkowania, ktĂłre w sposĂłb znaczÄ&#x2026;cy wpĹ&#x201A;ywajÄ&#x2026; na wybĂłr odpowiedniej metody pozwalajÄ&#x2026;cej na efektywne omijanie ruchomych przeszkĂłd. InnÄ&#x2026; istotnÄ&#x2026; kwestiÄ&#x2026;, ktĂłra powinna podlegaÄ&#x2021; szczegĂłĹ&#x201A;owej analizie w procesie przygotowania dziaĹ&#x201A;aĹ&#x201E; omijania
3 + U
\ H 66 $ ( 66 ' % 3 % *= ** )!*+ $ % % != !* )!)!
!
przeszkĂłd jest dynamika obiektu, jakim jest samolot. Przygotowanie manewrĂłw w pĹ&#x201A;aszczyĹşnie horyzontalnej wymaga znajomoĹ&#x203A;ci zakresĂłw dopuszczalnych parametrĂłw samolotu. Na te ograniczenia dla wybranego typu samolotu moĹźe mieÄ&#x2021; wpĹ&#x201A;yw dĹ&#x201A;uga lista czynnikĂłw, wĹ&#x203A;rĂłd ktĂłrych sÄ&#x2026; m.in. zmienne stanu ruchu samolotu, charakterystyki zastosowanych ukĹ&#x201A;adĂłw wykonawczych oraz fazy lotu.
S1 " L 0
- W powszechnie spotykanych warunkach, w jakich odbywajÄ&#x2026; swoje loty samoloty pasaĹźerskie, powstajÄ&#x2026;ce zagroĹźenia kolizji sÄ&#x2026; rozwiÄ&#x2026;zywane na drodze porozumienia miÄ&#x2122;dzy pilotami lecÄ&#x2026;cych obiektĂłw i naziemnej kontroli ruchu z wykorzystaniem znanych i opisanych metod [6, 8]. Jednak w pracy przyjÄ&#x2122;to odmienne rozwiÄ&#x2026;zanie, zgodne z podanymi wyĹźej zaĹ&#x201A;oĹźeniami, w celu znalezienia rozwiÄ&#x2026;zania dla sytuacji braku Ĺ&#x201A;Ä&#x2026;cznoĹ&#x203A;ci miÄ&#x2122;dzy samolotami i w sytuacjach deficytu czasu [3â&#x20AC;&#x201C;5]. Ocena bieĹźÄ&#x2026;cej sytuacji zagroĹźenia wystÄ&#x2026;pienia kolizji z ruchomymi przeszkodami wymaga sformuĹ&#x201A;owania odpowiedniego kryterium. W pracy przyjÄ&#x2122;to zaĹ&#x201A;oĹźenia omijania ruchomych przeszkĂłd: â&#x2C6;&#x2019; dostÄ&#x2122;pnoĹ&#x203A;Ä&#x2021; informacji o przeszkodach jest moĹźliwa tylko w ograniczonym obszarze stanowiÄ&#x2026;cym bliskie otoczenie samolotu; â&#x2C6;&#x2019; wykrywanie przeszkĂłd i ich omijanie odbywa siÄ&#x2122; tylko w przedniej pĂłĹ&#x201A;pĹ&#x201A;aszczyĹşnie; â&#x2C6;&#x2019; znane sÄ&#x2026; wielkoĹ&#x203A;ci przeszkĂłd i bieĹźÄ&#x2026;ce parametry ich ruchu; â&#x2C6;&#x2019; nie jest dostÄ&#x2122;pna informacja o sposobie ruchu przeszkĂłd w przyszĹ&#x201A;oĹ&#x203A;ci; â&#x2C6;&#x2019; unikniÄ&#x2122;cie kolizji i jej ominiÄ&#x2122;cie odbywa siÄ&#x2122; bez negocjacji z innymi ruchomymi obiektami;
61
8 & : ! : : & ! & ] ` & ! ! & J
V1 ) #L #
â&#x2C6;&#x2019; nie sÄ&#x2026; uwzglÄ&#x2122;dniane przepisy w ruchu lotniczym; â&#x2C6;&#x2019; manewr omijania odbywa siÄ&#x2122; w pĹ&#x201A;aszczyĹşnie poziomej; â&#x2C6;&#x2019; sterowanie i stabilizacja lotu samolotu obejmuje 6 stopni swobody.
Manewr ominiÄ&#x2122;cia ruchomej przeszkody skĹ&#x201A;ada siÄ&#x2122; z fazy antykolizyjnej oraz manewru powrotu do lotu wzdĹ&#x201A;uĹź zaplanowanej trasy. Z uwagi na moĹźliwoĹ&#x203A;Ä&#x2021; wykonywania nieprzewidywalnych manewrĂłw przeszkody, pierwsza faza moĹźe byÄ&#x2021; realizowana ze zmiennym kÄ&#x2026;tem przechylenia w czasie zakrÄ&#x2122;tu (8). Z tego samego powodu faza powrotu do lotu po zaplanowanej trasie moĹźe zostaÄ&#x2021; w kaĹźdej chwili przerwana i ponownie uruchamiany jest manewr omijania. W dalszej czÄ&#x2122;Ĺ&#x203A;ci pracy zostanÄ&#x2026; sformuĹ&#x201A;owane kryteria majÄ&#x2026;ce na celu okreĹ&#x203A;lenie poczÄ&#x2026;tku i koĹ&#x201E;ca wymienionych faz oraz parametry manewrĂłw. JeĹ&#x203A;li po wykryciu przeszkody i stwierdzeniu, Ĺźe wystÄ&#x2122;puje niebezpieczeĹ&#x201E;stwo kolizji odlegĹ&#x201A;oĹ&#x203A;Ä&#x2021; od przeszkody jest odpowiednio duĹźa, to nie ma koniecznoĹ&#x203A;ci natychmiastowego rozpoczÄ&#x2122;cia omijania jej. PrzyjÄ&#x2122;to, Ĺźe odlegĹ&#x201A;oĹ&#x203A;Ä&#x2021; rSPi niewymagajÄ&#x2026;ca natychmiastowego rozpoczÄ&#x2122;cia manewru to taka, dla ktĂłrej potrzebny czas na wykonanie zakrÄ&#x2122;tu jest mniejszy niĹź czas, w jakim samolot zbliĹźy siÄ&#x2122; do przeszkody na odlegĹ&#x201A;oĹ&#x203A;Ä&#x2021; rCMB. Manewr antykolizyjny powinien zostaÄ&#x2021; uruchomiony przed momentem, w ktĂłrym speĹ&#x201A;niony zostanie warunek:
y
OP (x1P, y1P) x rCMB
rSP1
VP
VP rSP2
VSP2
VSP1
VS2
(
rSPi < VSP β i / Ď&#x2030;Zak 1s / Ď 2i â&#x2C6;&#x2019; Ď 1i
VS1
VS1
SP1
SP1
21
VS2
SP2
SP2
OS (x1S, y1S)
VSP β i = VS cos Ψ SV â&#x2C6;&#x2019; βSPi + VPi cos Ψ PVi â&#x2C6;&#x2019; βSPi
Rys. 1. Zmienne opisujÄ&#x2026;ce ukĹ&#x201A;ad relacji samolot â&#x20AC;&#x201C; przeszkoda Fig. 1. The Variables describing the aircraft â&#x20AC;&#x201D; obstacle configuration
Ď 1, Ď 2 = βSP B arcsin (rCMB / rSP ) ,
Istotnym parametrem manewru antykolizyjnego jest wartoĹ&#x203A;Ä&#x2021; zadana kÄ&#x2026;ta przechylenia ÎŚZ samolotu, ktĂłra wyliczana jest z zaleĹźnoĹ&#x203A;ci: ÎŚZ = ÎŚZaki + kÎŚ1Ď ji + kÎŚ 2 Î&#x201D; Ď Î¨ + kÎŚ 3V SP β i
â&#x2C6;&#x2019;
1S
)/(
1P
â&#x2C6;&#x2019;
1S
gdzie: ÎŚZaki â&#x20AC;&#x201C; kÄ&#x2026;t przechylenia odpowiadajÄ&#x2026;cy przyjÄ&#x2122;tej prÄ&#x2122;dkoĹ&#x203A;ci zakrÄ&#x2122;tu, kÎŚ1 â&#x20AC;&#x201C; wspĂłĹ&#x201A;czynnik wzmocnienia dla pochodnej kÄ&#x2026;ta wybranej stycznej, kÎŚ2 â&#x20AC;&#x201C; wspĂłĹ&#x201A;czynnik wzmocnienia od pochodnej róşnicy SVsp = Ď ji â&#x2C6;&#x2019; ΨVR , kÎŚ3 â&#x20AC;&#x201C; wspĂłĹ&#x201A;czynnik wzmocnienia od prÄ&#x2122;dkoĹ&#x203A;ci zbliĹźania samolotu do przeszkody.
)
) .
(2)
oraz dodatkowa zaleĹźnoĹ&#x203A;Ä&#x2021; tego kÄ&#x2026;ta:
βSPi = 2β 0i
(3) RelacjÄ&#x2122; miÄ&#x2122;dzy prÄ&#x2122;dkoĹ&#x203A;ciÄ&#x2026; zakrÄ&#x2122;tu a kÄ&#x2026;tem przechylenia wynikajÄ&#x2026;cÄ&#x2026; z dynamiki lotu okreĹ&#x203A;la wzĂłr:
OdlegĹ&#x201A;oĹ&#x203A;Ä&#x2021; miÄ&#x2122;dzy obiektami: rSP =
(x
1P
â&#x2C6;&#x2019; x1S
) + (y 2
1P
â&#x2C6;&#x2019; y1S
)
(9)
2
(4) W pracy zaproponowano trzy nastÄ&#x2122;pujÄ&#x2026;ce wartoĹ&#x203A;ci odniesienia kÄ&#x2026;ta przechylenia ÎŚZaki: 40°, 50° i 60° wykorzystywane w czasie manewru antykolizyjnego. Ze wzglÄ&#x2122;du na bezpieczeĹ&#x201E;stwo antykolizyjnego manewru kierunek ominiÄ&#x2122;cia przeszkody (kierunek zakrÄ&#x2122;tu) okreĹ&#x203A;la siÄ&#x2122; w nastÄ&#x2122;pujÄ&#x2026;cy sposĂłb:
KÄ&#x2026;t wektora prÄ&#x2122;dkoĹ&#x203A;ci wypadkowej (samolotu i przeszkody) wynosi:
(
)
ΨVR = arctg (y 1S + y 1P ) / (x 1S + x 1P ) .
(5)
jeĹ&#x203A;li speĹ&#x201A;niona jest nierĂłwnoĹ&#x203A;Ä&#x2021; Ď 1 â&#x2C6;&#x2019; ΨVR < Ď 2 â&#x2C6;&#x2019; ΨVR to zakrÄ&#x2122;t wykonywany jest w lewo czyli Ď&#x2030;Zak1s < 0, w przeciwnym razie jest Ď&#x2030;Zak1s > 0.
OkrÄ&#x2026;g o promieniu rCMB jest hipotetycznÄ&#x2026; figurÄ&#x2026; reprezentujÄ&#x2026;cÄ&#x2026; swoim wymiarem sumÄ&#x2122; maksymalnych gabarytĂłw samolotu, przeszkody i marginesu bezpieczeĹ&#x201E;stwa.
62
P
O
M
(8)
(1)
gdzie SP kÄ&#x2026;t patrzenia opisuje zaleĹźnoĹ&#x203A;Ä&#x2021;: 1P
(7)
Ę&#x2DC;Zak1s â&#x20AC;&#x201C; przyjÄ&#x2122;ta prÄ&#x2122;dkoĹ&#x203A;Ä&#x2021; kÄ&#x2026;towa zakrÄ&#x2122;tu w manewrze antykolizyjnym.
W dalszej czÄ&#x2122;Ĺ&#x203A;ci tego rozdziaĹ&#x201A;u zostanÄ&#x2026; podane matematyczne zaleĹźnoĹ&#x203A;ci opisujÄ&#x2026;ce wybrane zmienne [10], pokazane na rys. 1 dla dwĂłch poĹ&#x201A;oĹźeĹ&#x201E; samolotu (indeksy 1 i 2). KÄ&#x2026;ty stycznych do okrÄ&#x2122;gu o promieniu rCMB wynoszÄ&#x2026;:
βSP = Ä&#x201A;Ä&#x201A;Ä&#x201A;Ä&#x201A; ((
(6)
gdzie: VSPÉ´i â&#x20AC;&#x201C; prÄ&#x2122;dkoĹ&#x203A;Ä&#x2021; zbliĹźania siÄ&#x2122; samolotu do przeszkody wynosi:
x
22
)
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
! = f
Do zakoĹ&#x201E;czenia manewru antykolizyjnego niezbÄ&#x2122;dne jest speĹ&#x201A;nienie jednoczeĹ&#x203A;nie dwĂłch warunkĂłw (10):
Wykrycie Przeszkody
(10)
Parametry Przeszkody
Podczas gdy speĹ&#x201A;nione jest: Ď 2i > Ď 1i JednoczeĹ&#x203A;nie speĹ&#x201A;nienie nierĂłwnoĹ&#x203A;ci (10) jest momentem rozpoczÄ&#x2122;cia manewru powrotu. PrzyjÄ&#x2122;to, Ĺźe skĹ&#x201A;ada siÄ&#x2122; on z dwĂłch zakrÄ&#x2122;tĂłw wykonanych z kÄ&#x2026;tem przechylenia ÎŚZak1 rĂłwnym:
Sprawdzenie
WybĂłr lub Zmiana ParametrĂłw Manewru
, (11) gdzie DSPT =
(x
1S
â&#x2C6;&#x2019; xTP
) + (y 2
1S
â&#x2C6;&#x2019; yTP
)
2
jest odlegĹ&#x201A;oĹ&#x203A;ciÄ&#x2026; samolotu o wspĂłĹ&#x201A;rzÄ&#x2122;dnych (x1S y1S) od najbliĹźszego punktu zaplanowanej trasy o wspĂłĹ&#x201A;rzÄ&#x2122;dnych (xTP yTP). Przy czym pierwszy zakrÄ&#x2122;t wykonywany jest z zadanym kÄ&#x2026;tem odchylenia samolotu rĂłwnym koĹ&#x201E;cowemu kÄ&#x2026;towi w manewrze antykolizyjnym i w kierunku przeciwnym do Ď&#x2030;Zak1s, a drugi w tym samym kierunku co Ď&#x2030;Zak1s z zadanym kÄ&#x2026;tem odchylenia rĂłwnym kÄ&#x2026;towi ΨTPi najbliĹźszego odcinka drogi wynikajÄ&#x2026;cego z planu lotu przygotowanego przed startem. ZakoĹ&#x201E;czenie manewru powrotu wymaga speĹ&#x201A;nienia dwĂłch nastÄ&#x2122;pujÄ&#x2026;cych warunkĂłw: ΨTPi â&#x2C6;&#x2019; Ψ S â&#x2030;¤ Îľ Ψ
DSPT â&#x2030;¤ Îľ D
Parametry Samolotu
Kolizji
(12)
Pierwszy warunek dotyczy osiÄ&#x2026;gniÄ&#x2122;cia ĹźÄ&#x2026;danego kursu samolotu z przyjÄ&#x2122;tÄ&#x2026; dokĹ&#x201A;adnoĹ&#x203A;ciÄ&#x2026; ɸΨ a drugi dotyczy poĹ&#x201A;oĹźenia samolotu zgodnego z najbliĹźszym odcinkiem zaplanowanej trasy z dokĹ&#x201A;adnoĹ&#x203A;ciÄ&#x2026; ɸD.
X1 7
L L
*
przeszkĂłd SposĂłb wspĂłĹ&#x201A;dziaĹ&#x201A;ania istotnych elementĂłw podejmowania decyzji o sposobie omijania manewrujÄ&#x2026;cej przeszkody przedstawiono na schemacie (rys. 2). Wykrycie i zidentyfikowanie przez detektor [2] wczeĹ&#x203A;niej nieznanej, manewrujÄ&#x2026;cej przeszkody wraz z estymacjÄ&#x2026; aktualnych parametrĂłw jej ruchu i samolotu stanowiÄ&#x2026; pierwszy etap wyboru bezpiecznego manewru. Powinien zostaÄ&#x2021; poprzedzony analizÄ&#x2026; szeregu zmiennych charakteryzujÄ&#x2026;cych ruch samolotu i przeszkody i ich wzajemnych relacji (rys. 1). Na tej podstawie w sposĂłb ciÄ&#x2026;gĹ&#x201A;y sprawdzane jest czy wystÄ&#x2122;puje zagroĹźenie kolizji z wykrytÄ&#x2026; przeszkodÄ&#x2026; (10). JeĹ&#x203A;li takie zagroĹźenie wystÄ&#x2026;piĹ&#x201A;o to wyliczane
Realizacja Manewru Powrotu
WybĂłr lub Zmiana Manewru Powrotu
Manewru Powrotu
Realizacja Manewru Antykolizyjnego
Manewru Antykolizyjnego
Kontynuacja Plan Lotu
Rys. 2. Automatyczne sterowanie manewrem omijania Fig. 2. Automatic control of anti-collision maneuver
sÄ&#x2026; parametry manewru antykolizyjnego i sprawdzany jest czas uruchomienia tego manewru. Po uruchomieniu automatycznie wykonywanego manewru antykolizyjnego (zgodnie z prawami sterowania (13), (14), (15) i (16)) sprawdzany jest warunek zagroĹźenia i wyliczana jest aktualna wartoĹ&#x203A;Ä&#x2021; kÄ&#x2026;ta przechylenia w zakrÄ&#x2122;cie (8). Po stwierdzenie braku zagroĹźenia kolizjÄ&#x2026; nastÄ&#x2122;puje zakoĹ&#x201E;czenie manewru antykolizyjnego wyliczenie niezbÄ&#x2122;dnych parametrĂłw manewru powrotu na zaplanowanÄ&#x2026; trasÄ&#x2122; i jego uruchomienie. W trakcie trwania tego manewru nadal caĹ&#x201A;y czas sprawdzane jest czy wystÄ&#x2122;puje zagroĹźenie kolizji. JeĹ&#x203A;li pojawi siÄ&#x2122; wspomniane zagroĹźenie nastÄ&#x2122;puje powrĂłt do wyliczenia aktualnych parametrĂłw manewru antykolizyjnego i w przypadku koniecznoĹ&#x203A;ci, czyli gdy czas uruchomienia jest wĹ&#x201A;aĹ&#x203A;ciwy, nastÄ&#x2122;puje przerwanie powrotu i przejĹ&#x203A;cie do realizacji manewru antykolizyjnego. ZakoĹ&#x201E;czenie caĹ&#x201A;ego manewru omijania nastÄ&#x2026;pi w sytuacji, jeĹ&#x203A;li nie wystÄ&#x2122;puje zagroĹźenie kolizji (10) i zostaĹ&#x201A;y osiÄ&#x2026;gniÄ&#x2122;te zaĹ&#x201A;oĹźone dokĹ&#x201A;adnoĹ&#x203A;ci kÄ&#x2026;ta kursu i poĹ&#x201A;oĹźenia wzglÄ&#x2122;dem aktualnego odcinka drogi w planie lotu (12). W symulacji zastosowano nieliniowy model matematyczny dynamiki samolotu typu I-23 Manager zgodnie z [3] i [5] speĹ&#x201A;niajÄ&#x2026;cy typowe zaĹ&#x201A;oĹźenia upraszczajÄ&#x2026;ce [4]. Automatyczne sterowanie manewrem omijania dziaĹ&#x201A;a w oparciu o prawa sterowania w czterech kanaĹ&#x201A;ach (pochylania (13), przechylania (14) odchylania (15) i prÄ&#x2122;dkoĹ&#x203A;ci (16):
δ HS = K1HÎ&#x2DC; (Î&#x2DC;z â&#x2C6;&#x2019; Î&#x2DC;) + K1HQ (Qz â&#x2C6;&#x2019; Q) +1HW (Wz â&#x2C6;&#x2019; W ) + K1Hz (z1z â&#x2C6;&#x2019; z1) + K1HU (U z â&#x2C6;&#x2019; U ) (13) 1
(14) (15) (16)
63
8 & : ! : : & ! & ] ` & ! ! & J
500
gdzie: V0 = â&#x17D;Ąâ&#x17D;ŁU V W â&#x17D;¤â&#x17D;Ś , Ί = â&#x17D;Ąâ&#x17D;ŁP Q R â&#x17D;¤â&#x17D;Ś â&#x20AC;&#x201C; skĹ&#x201A;adowe prÄ&#x2122;dkoĹ&#x203A;ci liniowej i kÄ&#x2026;towej, â&#x17D;Ąâ&#x17D;Łx1 y1 z1 â&#x17D;¤â&#x17D;Ś , Î&#x203A; = â&#x17D;Ąâ&#x17D;ŁÎŚ Î&#x2DC; Ψ â&#x17D;¤â&#x17D;Ś â&#x20AC;&#x201C; poĹ&#x201A;oĹźenie liniowe i kÄ&#x2026;towe samolotu, u = â&#x17D;Ąâ&#x17D;ŁÎ´ HS δVS δ LS δTS â&#x17D;¤â&#x17D;Ś â&#x20AC;&#x201C; wektor sterowania (wychylenie powierzchni sterowych i manetki gazu). FormuĹ&#x201A;a ta przy doborze wĹ&#x201A;aĹ&#x203A;ciwych wsp ĂłĹ&#x201A;czynnikĂłw wzmocnienia zapewnia uzyskanie zakrÄ&#x2122;tu z zadanym kÄ&#x2026;tem przechylenia, ktĂłry odpowiada okreĹ&#x203A;lonemu, w stanie ustalonym promieniowi zakrÄ&#x2122;tu. WspĂłĹ&#x201A;czynniki wzmocnienia wyliczone zostaĹ&#x201A;y metodÄ&#x2026; LQR [1, 9, 11]. Dla przyjÄ&#x2122;tej w badaniach symulacyjnych prÄ&#x2122;dkoĹ&#x203A;ci lotu uzyskano wartoĹ&#x203A;ci podane w tabeli 1. UkĹ&#x201A;ad rĂłwnaĹ&#x201E; róşniczkowych opisujÄ&#x2026;cych ruch samolotu rozwiÄ&#x2026;zywany byĹ&#x201A; za pomocÄ&#x2026; oprogramowania MATLAB z uĹźyciem procedury rk4 z krokiem 0,01 s. W trakcie symulacji lotu samolot wykonaĹ&#x201A; zĹ&#x201A;oĹźony, sterowany manewr ominiÄ&#x2122;cia ruchomej przeszkody poruszajÄ&#x2026;cej siÄ&#x2122; w znany, ale nieprzewidywalny sposĂłb. KsztaĹ&#x201A;t trajektorii obu obiektĂłw pokazano
2
1 PRZESZKODA
400
3
300
6 200
SAMOLOT 0
3
2
1
7
8 9
4 5
4
100
Y [m]
7
5
10
11
12
6
13
8 -100
9 -200
10
-300 -400
13
11 12
-500 -600
-200
0
200
400
600
800
1000
1200
X [m]
Rys. 3. Trajektoria samolotu i manewrujÄ&#x2026;cej przeszkody Fig. 3. Trajectory of the airplane and trajectory of maneuvering obstacle
na rys. 3. Przy czym dla samolotu jej przebieg nie byĹ&#x201A; wczeĹ&#x203A;niej wyznaczony dla znanego ruchu przeszkody ale zostaĹ&#x201A; uzyskany z symulacji zgodnie z przyjÄ&#x2122;tÄ&#x2026; metodÄ&#x2026; dla manewrujÄ&#x2026;cej przeszkody. ZakrÄ&#x2122;ty wykonywane byĹ&#x201A;y z zadanym kÄ&#x2026;tem przechylenia okreĹ&#x203A;lonym zaleĹźnoĹ&#x203A;ciÄ&#x2026; (8) zmiany kÄ&#x2026;ta odchylenia byĹ&#x201A;y konsekwencjÄ&#x2026; zaleĹźnoĹ&#x203A;ci (10) oraz (12). Obiekty przemieszczaĹ&#x201A;y siÄ&#x2122; na staĹ&#x201A;ej wysokoĹ&#x203A;ci rĂłwnej 200 m ze staĹ&#x201A;ymi prÄ&#x2122;dkoĹ&#x203A;ciami lotu
Tabela 1. WspĂłĹ&#x201A;czynniki wzmocnienia praw sterowania Table 1. Controller gains of the control laws
64
â&#x17D;Ą0 sâ&#x17D;¤ K1HU â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ m â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0 sâ&#x17D;¤ K1HW â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ m â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0sâ&#x17D;¤ K1HQ â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0 â&#x17D;¤ K1Hz1 â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ m â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą 0 â&#x17D;¤ K1HÎ&#x2DC; â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
0,4477
0,3579
â&#x20AC;&#x201C;9,8324
0,1032
â&#x20AC;&#x201C;58,4015
â&#x17D;Ą0 sâ&#x17D;¤ K1VV â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ m â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0sâ&#x17D;¤ K1VP â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0sâ&#x17D;¤ K1VR â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą 0 â&#x17D;¤ K1VÎŚ â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą 0 â&#x17D;¤ K VΨ â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
2,1645
1,9199
â&#x20AC;&#x201C;1,286
â&#x20AC;&#x201C;0,9571
0,0
â&#x17D;Ą0 sâ&#x17D;¤ K1LV â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ m â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0sâ&#x17D;¤ K1LP â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0sâ&#x17D;¤ K1LR â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą 0 â&#x17D;¤ K1LÎŚ â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą 0 â&#x17D;¤ K1LΨ â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
1,4796
6,2199
â&#x20AC;&#x201C;16,125
120,594
0,0
â&#x17D;Ą0 sâ&#x17D;¤ K1TU â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ m â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0 sâ&#x17D;¤ K1TW â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ m â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0sâ&#x17D;¤ K1TQ â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą0 â&#x17D;¤ K1Tz 1 â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ m â&#x17D;Śâ&#x17D;Ľ
â&#x17D;Ą 0 â&#x17D;¤ K1TÎ&#x2DC; â&#x17D;˘ â&#x17D;Ľ â&#x17D;Łâ&#x17D;˘ rad â&#x17D;Śâ&#x17D;Ľ
452,1
23,5
â&#x20AC;&#x201C;177,1
â&#x20AC;&#x201C;3,9
â&#x20AC;&#x201C;140,1
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
! = f
wzglÄ&#x2122;dem powierzchni Ziemi, tzn. dla samolotu rĂłwnej VS = 50 m/s, a przeszkody VP = 72 m/s. Uzyskano szereg zmiennych opisujÄ&#x2026;cych ten ruch i sterujÄ&#x2026;cych, z ktĂłrych czÄ&#x2122;Ĺ&#x203A;Ä&#x2021; zaprezentowano poniĹźej. Do automatycznie wykonania manewru omijania ruchomej przeszkody wzdĹ&#x201A;uĹź pokazanej na rys. 3 trajektorii byĹ&#x201A;y niezbÄ&#x2122;dne wychylenia kÄ&#x2026;towe steru kierunku i lotek zamieszczone na rys. 4. Uzyskane wartoĹ&#x203A;ci poĹ&#x201A;oĹźeĹ&#x201E; lotek Ĺ&#x203A;wiadczÄ&#x2026; o krĂłtkotrwaĹ&#x201A;ych okresach, w ktĂłrych te powierzchnie sterowe osiÄ&#x2026;gaĹ&#x201A;y swoje graniczne poĹ&#x201A;oĹźenia. W czasie symulowanego lotu przebiegi prÄ&#x2122;dkoĹ&#x203A;ci kÄ&#x2026;towej przechylania i odchylania (rys. 5) skĹ&#x201A;adaĹ&#x201A;y siÄ&#x2122; z podobnych sekwencji charakterystycznych dla energicznie wykonywanych zakrÄ&#x2122;tĂłw. Przedstawione na rys. 4 zmiany poĹ&#x201A;oĹźenia kÄ&#x2026;towego samolotu potwierdzajÄ&#x2026; przewidywane ekstremalne wartoĹ&#x203A;ci kÄ&#x2026;ta przechylenia bliskie pierwszemu zaĹ&#x201A;oĹźonemu poziomowi odniesienia (40°). Z tego wynika pokazane na wykresie (rys. 5) zmiany kÄ&#x2026;ta odchylenia zgodne z dynamikÄ&#x2026; obiektu. WartoĹ&#x203A;ci ekstremalne tego kÄ&#x2026;ta sÄ&#x2026; konsekwencjÄ&#x2026; logicznych warunkĂłw zgodnie z zaleĹźnoĹ&#x203A;ciami (10) i (12).
5. Wnioski Przedstawiony materiaĹ&#x201A; teoretyczny oraz wyniki symulacji ruchu samolotu omijajÄ&#x2026;cego manewrujÄ&#x2026;cÄ&#x2026; przeszkodÄ&#x2122; pozwala na sformuĹ&#x201A;owanie nastÄ&#x2122;pujÄ&#x2026;cych wnioskĂłw: â&#x2C6;&#x2019; zaproponowane w pracy formuĹ&#x201A;y matematyczno-logiczne i struktura decyzyjna stanowiÄ&#x2026; spĂłjnÄ&#x2026; przesĹ&#x201A;ankÄ&#x2122; do rozwiniÄ&#x2122;cia autonomicznego omijania przez samolot manewrujÄ&#x2026;cych przeszkĂłd; â&#x2C6;&#x2019; uzyskane wyniki symulacji Ĺ&#x203A;wiadczÄ&#x2026; o efektywnoĹ&#x203A;ci dokonanego wyboru parametrĂłw manewru pozwalajÄ&#x2026;cego dla wybranego scenariusza ominÄ&#x2026;Ä&#x2021; bezpiecznie przeszkodÄ&#x2122; o nieprzewidywalnym ruchu; â&#x2C6;&#x2019; zaproponowana metodyka moĹźe zostaÄ&#x2021; wykorzystana do róşnych obiektĂłw latajÄ&#x2026;cych w tym statkĂłw bezzaĹ&#x201A;ogowych, wykonujÄ&#x2026;cych manewry omijania ruchomych przeszkĂłd; przedstawiona metoda wymaga dalszych badaĹ&#x201E; dla szeregu scenariuszy obejmujÄ&#x2026;cych róşne konfiguracje wzajemnych ruchĂłw i poĹ&#x201A;oĹźeĹ&#x201E; samolotu i przeszkody.
Rys. 4. PoĹ&#x201A;oĹźenie lotek, steru kierunku oraz kÄ&#x2026;ty przechylenia i odchylenia samolotu Fig. 4. Ailerons and ruder deflections and roll yaw of airplane
Rys. 5. PrÄ&#x2122;dkoĹ&#x203A;ci kÄ&#x2026;towe przechylania i odchylania samolotu Fig. 5. Angular velocities of roll and yaw of airplane
65
8 & : ! : : & ! & ] ` & ! ! & J
& L 0 7. Koruba Z., Chatys R, Gyroscope-based control and stabilization of unmanned aerial mini-vehicle (mini-UAV), â&#x20AC;&#x153;Aviationâ&#x20AC;?, No. 9, 2005, 10â&#x20AC;&#x201C;16, DOI: 10.3846/16487788.2005.9635898. 8. Lin C.E., Wu Y.-Y., Collision avoidance solution for low-altitude flights, â&#x20AC;&#x153;Journal Aerospace Engineeringâ&#x20AC;?, Vol. 225, No 7, 2011, 779â&#x20AC;&#x201C;790, DOI: 10.1177/0954410011399211. 9. Nelson R.C., Flight Stability and Automatic Control, MCGraw-Hill Book Company, New York 1997. 10. Paielli R.A., Modeling maneuver dynamics in air traffic conflict resolution, â&#x20AC;&#x153;Journal of Guidance, Control, and Dynamicsâ&#x20AC;?, Vol. 26, No. 3, 2003, 407 â&#x20AC;&#x201C; 415, DOI: 10.2514/2.5078. 11. Stevens B.L., Levis F.L., Aircraft Control and Simulation. J. Wiley & Sons, Inc., 2016. 12. Tang J., Piera M.A., Baruwa O.T., A discrete-event modeling approach for the analysis of TCAS-induced collisions with different pilot response times, â&#x20AC;&#x153;Journal Aerospace Engineeringâ&#x20AC;?, Vol. 229, No. 13, 2015, 2416â&#x20AC;&#x201C;2428, DOI: 10.1177/0954410015577147.
1. Athans M., Falb P., Sterowanie optymalne, wstÄ&#x2122;p do teorii i jej zastosowania, WNT, Warszawa 1969. 2. Graffstein J., Functioning of air anti-collision system during test flight, â&#x20AC;&#x153;Aviationâ&#x20AC;?, Taylor & Francis Group Vilnius Gediminas Technical University, Vol. 18, No. 1, 2014, 44â&#x20AC;&#x201C;51, DOI: 10.3846/16487788.2014.865945. 3. Graffstein J., DobĂłr parametrĂłw manewru antykolizyjnego i jego przebieg, â&#x20AC;&#x17E;Prace Instytutu Lotnictwaâ&#x20AC;?, Nr 224, 2012, 31â&#x20AC;&#x201C;43. 4. Graffstein J., Elementy procesu wykrycia zagroĹźenia kolizjÄ&#x2026; i automatycznie sterowany manewr awaryjny. â&#x20AC;&#x17E;Pomiary Automatyka Robotykaâ&#x20AC;?, R. 16, Nr 2/2012, 383-387. 5. Graffstein J., Selected aspects of automatic maneuver control to avoid moving obstacles resulting from the simulation analysis of the course of aircraft movement, Advances in Intelligent Systems and Computing, â&#x20AC;&#x153;Challenges in Automation, Robotics and Measurement Techniquesâ&#x20AC;?, Vol. 440, 2016, 127â&#x20AC;&#x201C;139, DOI: 10.1007/978-3-319-29357-8_12. 6. Jung T., Piera M.A., Ruiz O.S., A causal model to explore the ACAS induced col lisions, Journal Aerospace Engineering, Vol. 228, No. 10, 2015, 1735â&#x20AC;&#x201C;1748, DOI: 10.1177/0954410014537242.
-% 6 ; % ; > " ; % % / " ( #/ 2% 8 To solve the problem of aircraft avoiding collision, it is necessary to detect an obstacle, check if it poses a threat to the safety of the aircraft and make the right decisions about the appropriate way to bypass it. These are all important phases preceding the automatic bypassing of a moving obstacle. The work presents an algorithm for bypassing a moving obstacle with unpredictable changes in its movement. A diagram of logical actions was presented to not only safely avoid collision with a maneuvering obstacle, but also to return to flight along the route planned before the start. The proposed method is illustrated by a simulation example of automatically bypassing an obstacle for the selected scenario. KeywordsU % $ $ a ( $
( $ < ( b ' % ORCID: 0000-0002-9329-8648 ;% 7 ( T - X \ ( > / [ ( % % % / A > [ $ % V % $ ( % A
66
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 67â&#x20AC;&#x201C;74, DOI: 10.14313/PAR_235/67
-% I ( V U % / U [% U - 7 " @ U 0 V % 7 $ 0 % @ $ T % ; . / $ " =$ >*!! 7 A
1 8 W artykule przedstawiono wybrane zagadnienia bezpieczeĹ&#x201E;stwa urzÄ&#x2026;dzeĹ&#x201E; Internetu Rzeczy. Przedstawiono klasyfikacjÄ&#x2122; zagroĹźeĹ&#x201E; w Ĺ&#x203A;rodowisku wspĂłĹ&#x201A;dziaĹ&#x201A;ajÄ&#x2026;cych urzÄ&#x2026;dzeĹ&#x201E; IoT w modelu 5M + E. Jako podstawowÄ&#x2026; przyjÄ&#x2122;to klasyfikacjÄ&#x2122; TOP-10 OWASP dla IoT i dostosowano jÄ&#x2026; do potrzeb analizy przy pomocy diagramu Ishikawy. PowiÄ&#x2026;zano zagroĹźenia z grupami przyczyn i zastosowano diagram Ishikawy do oceny jakoĹ&#x203A;ciowej zagroĹźeĹ&#x201E;. Zaproponowano macierzowy model bezpieczeĹ&#x201E;stwa ukĹ&#x201A;adu urzÄ&#x2026;dzeĹ&#x201E; pracujÄ&#x2026;cych zgodnie z zasadÄ&#x2026; IFTTT. PrzyjÄ&#x2122;to typowy, trĂłjstanowy model oceny stanu bezpieczeĹ&#x201E;stwa kaĹźdego z urzÄ&#x2026;dzeĹ&#x201E; i wykazano przydatnoĹ&#x203A;Ä&#x2021; modelu macierzowego do oceny stanu pracy i bezpieczeĹ&#x201E;stwa systemu. Wskazano na moĹźliwoĹ&#x203A;ci podziaĹ&#x201A;u zadaĹ&#x201E; w modelu macierzowym na obliczenia we mgle i w chmurze. ) U - . $ ( V $ / U $ % $ % ( -
1. Wprowadzenie Ewolucja IoT w okresie 20 lat od wprowadzenia tego pojÄ&#x2122;cia przez Kevina Ashtona przyczyniĹ&#x201A;a siÄ&#x2122; w istotny sposĂłb do powstania PrzemysĹ&#x201A;u 4.0. DÄ&#x2026;ĹźÄ&#x2026;c do intensywnego rozwoju oferowanych produktĂłw producenci czÄ&#x2122;sto marginalizowali problemy cybernetycznego bezpieczeĹ&#x201E;stwa tych urzÄ&#x2026;dzeĹ&#x201E;. Szereg incydentĂłw takich, jak Stuxnet czy wykorzystanie kamer do atakĂłw DDoS obnaĹźyĹ&#x201A;y sĹ&#x201A;aboĹ&#x203A;ci systemu bezpieczeĹ&#x201E;stwa IoT i uwypukliĹ&#x201A;y koniecznoĹ&#x203A;Ä&#x2021; intensyfikacji prac nad bezpieczeĹ&#x201E;stwem tych urzÄ&#x2026;dzeĹ&#x201E;. Prognozy Gartnera [1] juĹź w 2014 r. wskazaĹ&#x201A;y, Ĺźe w 2020 r. liczebnoĹ&#x203A;Ä&#x2021; urzÄ&#x2026;dzeĹ&#x201E; IoT osiÄ&#x2026;gnie 25 miliardĂłw, (z tego ponad 13 mld bÄ&#x2122;dzie w grupie tzw. urzÄ&#x2026;dzeĹ&#x201E; konsumenckich), a zatem problem ich bezpieczeĹ&#x201E;stwa jest wyzwaniem o podstawowym znaczeniu. Prace, ktĂłre pojawiĹ&#x201A;y siÄ&#x2122; w ostatnich kilku latach wskazujÄ&#x2026; na koniecznoĹ&#x203A;Ä&#x2021; poszukiwania nowych metod, gdyĹź konwencjonalne podejĹ&#x203A;cie oparte gĹ&#x201A;Ăłwnie na ochronie punktu koĹ&#x201E;cowego oraz tworzenie zapĂłr na brzegu sieci nie jest adekwatne do oceny i neutralizacji aktualnie wystÄ&#x2122;pujÄ&#x2026;cych zagroĹźeĹ&#x201E;. W artykule [2] zostaĹ&#x201A; dokonany obszerny przeglÄ&#x2026;d stosowanych metod bezpieczeĹ&#x201E;stwa Internetu Rzeczy. W pracy [3] zwrĂłcono uwagÄ&#x2122; na specyfikÄ&#x2122; zagroĹźeĹ&#x201E; i rozwiÄ&#x2026;zaĹ&#x201E; z zakresu bezpieczeĹ&#x201E;stwa w Ĺ&#x203A;rodowisku robotĂłw przemysĹ&#x201A;owych, w pracy [4] wskazano na zĹ&#x201A;oĹźonoĹ&#x203A;Ä&#x2021; ochrony urzÄ&#x2026;dzeĹ&#x201E; w Ĺ&#x203A;rodowisku kon-
3 + U
0 % - $ ' % 3 % *= ** )!*+ $ % % *) !) )!)!
!
sumenckim, zwĹ&#x201A;aszcza ze wzglÄ&#x2122;du na interakcje urzÄ&#x2026;dzeĹ&#x201E; poza sieciÄ&#x2026; TCP/IP, w pracy [16] przedstawiono syntetycznie istotne grupy atakĂłw. Identyfikowanie wektorĂłw zagroĹźeĹ&#x201E; jest prowadzone przez wielu praktykĂłw i badaczy, a takĹźe organizacje, w tym OWASP (ang. Open Web Application Security Project) [5], jednakĹźe w zaproponowanej przez OWASP liĹ&#x203A;cie 10 najistotniejszych zagroĹźeĹ&#x201E; [6] nie ujÄ&#x2122;to problemĂłw wynikajÄ&#x2026;cych z interakcji Ĺ&#x203A;rodowiskowych miÄ&#x2122;dzy urzÄ&#x2026;dzeniami. InteresujÄ&#x2026;ca metodyka analizy takich interakcji, pozwalajÄ&#x2026;ca na ocenÄ&#x2122; tej grupy zagroĹźeĹ&#x201E;, z uwzglÄ&#x2122;dnieniem problemu skalowalnoĹ&#x203A;ci, zostaĹ&#x201A;a przedstawiona w pracy [4]. Do identyfikacji jakoĹ&#x203A;ciowej zagroĹźeĹ&#x201E; moĹźna wykorzystaÄ&#x2021; metody znane z zarzÄ&#x2026;dzania, np. diagramy Ishikawy (metodykÄ&#x2122; 5M + E: Man, Material, Machine, Method, Management + Environment) [7â&#x20AC;&#x201C;9] i â&#x20AC;&#x201C; poszerzajÄ&#x2026;c interpretacjÄ&#x2122; wektora E o interakcje miÄ&#x2122;dzy urzÄ&#x2026;dzeniami â&#x20AC;&#x201C; poĹ&#x201A;Ä&#x2026;czyÄ&#x2021; w analizie listÄ&#x2122; TOP-10 organizacji OWASP i szeroko rozumiane zagroĹźenia Ĺ&#x203A;rodowiskowe. Celem niniejszej pracy byĹ&#x201A;a analiza moĹźliwoĹ&#x203A;ci zastosowania opisu zagroĹźeĹ&#x201E; i interakcji Ĺ&#x203A;rodowiskowej miÄ&#x2122;dzy urzÄ&#x2026;dzeniami IoT z wykorzystaniem modelu macierzowego reprezentujÄ&#x2026;cego ocenÄ&#x2122; stanu bezpieczeĹ&#x201E;stwa i stanu pracy kaĹźdego z urzÄ&#x2026;dzeĹ&#x201E; wchodzÄ&#x2026;cych w skĹ&#x201A;ad systemu IoT.
S1 . *
0 L ,
+ ,
0 47 [^T 7;3) 4 JednÄ&#x2026; z podstawowych metod stosowanych obecnie do szacowania ryzyka zwiÄ&#x2026;zanego z informacjÄ&#x2026; jest analiza jakoĹ&#x203A;ciowa oparta na ocenie ryzyka wywoĹ&#x201A;ania incydentu przez ocenÄ&#x2122; zagroĹźenia na jednym z trzech poziomĂłw â&#x20AC;&#x201C; niskim, umiarkowanym lub wysokim. Dla urzÄ&#x2026;dzeĹ&#x201E; IoT moĹźna przyjÄ&#x2026;Ä&#x2021;, Ĺźe poziomy te
67
G !A . : !: : & ! & ] G odpowiadajÄ&#x2026; trzem stanom bezpieczeĹ&#x201E;stwa â&#x20AC;&#x201C; prawidĹ&#x201A;owemu, niepewnemu i bĹ&#x201A;Ä&#x2122;dnemu. Dla kaĹźdego urzÄ&#x2026;dzenia moĹźna utworzyÄ&#x2021; diagram Ishikawy i â&#x20AC;&#x201C; przypisujÄ&#x2026;c do kaĹźdej z gaĹ&#x201A;Ä&#x2122;zi klasyfikacjÄ&#x2122; zagroĹźenia â&#x20AC;&#x201C; na jednym z trzech poziomĂłw oceniÄ&#x2021; jego stan bezpieczeĹ&#x201E;stwa.
Tabela zawiera klasyfikacjÄ&#x2122; uszczegĂłĹ&#x201A;owionych zagroĹźeĹ&#x201E; z listy TOP-10, podzielonych ze wzglÄ&#x2122;du na ich zwiÄ&#x2026;zek z grupÄ&#x2026; przyczyn. Po takim uszczegĂłĹ&#x201A;owieniu podziaĹ&#x201A;u w miejsce 10 zagroĹźeĹ&#x201E; ujÄ&#x2122;tych na liĹ&#x203A;cie OWASP moĹźna wyróşniÄ&#x2021; 23 zagroĹźenia, z ktĂłrych ponad 80% jest zwiÄ&#x2026;zanych z zarzÄ&#x2026;dzaniem, okoĹ&#x201A;o 60% z personelem instalujÄ&#x2026;cym urzÄ&#x2026;dzenia lub uĹźytkownikiem, a takĹźe sposobem eksploatacji urzÄ&#x2026;dzeĹ&#x201E;, okoĹ&#x201A;o 48% z wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ciami urzÄ&#x2026;dzeĹ&#x201E; zaleĹźnymi od producentĂłw, a 35% od otoczenia. Nie ma przesĹ&#x201A;anek do wiÄ&#x2026;zania jakiegokolwiek zagroĹźenia wskazanego w klasyfikacji OWASP z materiaĹ&#x201A;ami. Jak wspomniano, pewnÄ&#x2026; sĹ&#x201A;aboĹ&#x203A;ciÄ&#x2026; wykazu zagroĹźeĹ&#x201E; w klasyfikacji OWASP i identyfikacji jakoĹ&#x203A;ciowej podatnoĹ&#x203A;ci urzÄ&#x2026;dzeĹ&#x201E; na potencjalne ataki tylko zgodnie z listÄ&#x2026; OWASP TOP-10 jest brak uwzglÄ&#x2122;dnienia zagroĹźeĹ&#x201E; Ĺ&#x203A;rodowiskowych, wynikajÄ&#x2026;cych z oddziaĹ&#x201A;ywania na urzÄ&#x2026;dzenia innych urzÄ&#x2026;dzeĹ&#x201E; oraz parametrĂłw Ĺ&#x203A;rodowiska, analizowanych w szczegĂłlnoĹ&#x203A;ci w pracy [3]. ZagroĹźenia te, jak np. wartoĹ&#x203A;ci parametrĂłw fizycznych Ĺ&#x203A;rodowiska czy wzajemnych zaleĹźnoĹ&#x203A;ci stanĂłw pracy urzÄ&#x2026;dzeĹ&#x201E; mogÄ&#x2026; byÄ&#x2021; analizowane w grupie przyczyn E, przy czym wĂłwczas konieczne jest dodanie do klasyfikacji przedstawionej w tabeli 1 uzupeĹ&#x201A;niajÄ&#x2026;cych zagroĹźeĹ&#x201E; â&#x20AC;&#x17E;otoczeniaâ&#x20AC;? 11.a. â&#x20AC;&#x201C; rozumianego jako zagroĹźenia wynikajÄ&#x2026;ce z bĹ&#x201A;Ä&#x2122;dĂłw lub zaniedbaĹ&#x201E; dostawcĂłw urzÄ&#x2026;dzeĹ&#x201E;, 11.b. â&#x20AC;&#x201C; zagroĹźeĹ&#x201E; wskutek niekontrolowanego wpĹ&#x201A;ywu parametrĂłw Ĺ&#x203A;rodowiska fizycznego i 11.c. â&#x20AC;&#x201C; zagroĹźeĹ&#x201E; bÄ&#x2122;dÄ&#x2026;cych skutkiem wzajemnego oddziaĹ&#x201A;ywania urzÄ&#x2026;dzeĹ&#x201E;. Graficzna prezentacja przeprowadzonej analizy zagroĹźeĹ&#x201E; za pomocÄ&#x2026; diagramu Kaoru Ishikawy jest przedstawiona na rysunku 1.
S1^1 8 0 , 7;3) OWASP, analizujÄ&#x2026;c wektory zagroĹźeĹ&#x201E; dla Internetu Rzeczy, opublikowaĹ&#x201A;a w 2018 r. klasyfikacjÄ&#x2122; 10 najistotniejszych zagroĹźeĹ&#x201E; bezpieczeĹ&#x201E;stwa w tym sektorze. Klasyfikacja ta obejmuje nastÄ&#x2122;pujÄ&#x2026;ce zagroĹźenia: 1. Korzystanie z haseĹ&#x201A; sĹ&#x201A;abych, podatnych na atak siĹ&#x201A;owy, haseĹ&#x201A; publicznie dostÄ&#x2122;pnych lub teĹź niezmiennych (ang. Weak, Guessable, or Hardcoded Passwords). 2. Niezabezpieczone lub zbÄ&#x2122;dne usĹ&#x201A;ugi sieciowe, podatne na zagroĹźenia wynikajÄ&#x2026;ce z naruszenia poufnoĹ&#x203A;ci, integralnoĹ&#x203A;ci, dostÄ&#x2122;pnoĹ&#x203A;ci lub nieuprawnionego uwierzytelnienia (ang. Insecure Network Services). 3. Niezabezpieczone (zwykle mobilne) punkty dostÄ&#x2122;pu w systemie, niewĹ&#x201A;aĹ&#x203A;ciwe przetwarzanie danych w chmurze, niezabezpieczone API, wskutek niewĹ&#x201A;aĹ&#x203A;ciwego zabezpieczenia uwierzytelniania, autoryzacji, szyfrowania i filtrowania/ walidacji danych (ang. Insecure Ecosystem Interfaces). 4. Brak moĹźliwoĹ&#x203A;ci bezpiecznej aktualizacji oprogramowania urzÄ&#x2026;dzenia, w szczegĂłlnoĹ&#x203A;ci sprawdzania poprawnoĹ&#x203A;ci zainstalowanego oprogramowania, szyfrowania aktualizacji w procesie ich przesyĹ&#x201A;ania, brak powiadomieĹ&#x201E; o aktualizacjach i zapewnienia moĹźliwoĹ&#x203A;ci powrotu do ostatniej prawidĹ&#x201A;owo dziaĹ&#x201A;ajÄ&#x2026;cej wersji oprogramowania (ang. Lack of Secure Update Mechanism). 5. Korzystanie z przestarzaĹ&#x201A;ych lub niezabezpieczonych komponentĂłw oprogramowania, jak rĂłwnieĹź ze sprzÄ&#x2122;tu z nieautoryzowanego Ĺ&#x201A;aĹ&#x201E;cucha dostaw (ang. Use of Insecure or Outdated Components). 6. Brak wystarczajÄ&#x2026;cej ochrony prywatnoĹ&#x203A;ci danych osobowych (ang. ). 7. Brak szyfrowania i autoryzacji dostÄ&#x2122;pu w kaĹźdym z trzech stanĂłw danych â&#x20AC;&#x201C; zwĹ&#x201A;aszcza podczas przesyĹ&#x201A;u i przechowywania danych (ang. Insecure Data Transfer and Storage). 8. Brak wsparcia dla bezpieczeĹ&#x201E;stwa urzÄ&#x2026;dzeĹ&#x201E; na kaĹźdym etapie cyklu Ĺźycia, w szczegĂłlnoĹ&#x203A;ci zarzÄ&#x2026;dzania aktualizacjami (ang. Lack of Device Management). 9. Stosowanie urzÄ&#x2026;dzeĹ&#x201E; i oprogramowania dostarczanego z ustawieniami domyĹ&#x203A;lnymi bez wystarczajÄ&#x2026;cych zabezpieczeĹ&#x201E; lub brak moĹźliwoĹ&#x203A;ci rekonfiguracji ustawieĹ&#x201E; fabrycznych (ang. Insecure Default Settings). 10. Brak moĹźliwoĹ&#x203A;ci utwardzania sprzÄ&#x2122;towego (ang. Lack of Physical Hardening). Pewnym mankamentem tej klasyfikacji jest znikome uwzglÄ&#x2122;dnienie wektorĂłw oddziaĹ&#x201A;ywaĹ&#x201E; Ĺ&#x203A;rodowiskowych i brak analizy wzajemnych oddziaĹ&#x201A;ywaĹ&#x201E; miÄ&#x2122;dzy urzÄ&#x2026;dzeniami.
Rys. 1. Diagram Ishikawy oceny stanu bezpieczeĹ&#x201E;stwa IoT w modelu 5M + E Fig. 1. Ishikawa IoT safety assessment diagram in the 5M + E model
Tworzenie diagramu Ishikawy do jakoĹ&#x203A;ciowej oceny stanu bezpieczeĹ&#x201E;stwa urzÄ&#x2026;dzenia lub systemu moĹźe byÄ&#x2021; rĂłwnieĹź z powodzeniem stosowane przy przyjÄ&#x2122;ciu innych klasyfikacji zagroĹźeĹ&#x201E;, np. zaproponowanych w pracy [10].
S1S1 2 + ,
Y( h
V1 (
L , + ,
Przedstawione (tab. 1) zaklasyfikowanie jakoĹ&#x203A;ciowe kaĹźdego z wymienionych zagroĹźeĹ&#x201E; do grupy przyczyn zostaĹ&#x201A;o przeprowadzone z uwzglÄ&#x2122;dnieniem klasycznego modelu 5M + E, przy czym: â&#x2C6;&#x2019; CzĹ&#x201A;owiek oznacza personel instalujÄ&#x2026;cy urzÄ&#x2026;dzenie oraz uĹźytkownika, â&#x2C6;&#x2019; Metoda jest rozumiana bardziej jako procedury stosowane podczas eksploatacji urzÄ&#x2026;dzeĹ&#x201E;, niĹź jako stosowane w trakcie produkcji urzÄ&#x2026;dzeĹ&#x201E; technologie czy normy, â&#x2C6;&#x2019; ZarzÄ&#x2026;dzanie rozumiane jest gĹ&#x201A;Ăłwnie jako konserwacja (pielÄ&#x2122;gnacja) urzÄ&#x2026;dzenia (wystÄ&#x2122;pujÄ&#x2026;ca zwykle jako kolejna przyczyna w podejĹ&#x203A;ciu 8M) a nie struktura organizacyjna, czy teĹź kierownictwo lub organizacja pracy producenta, â&#x2C6;&#x2019; Otoczenie oznacza dostawcĂłw urzÄ&#x2026;dzeĹ&#x201E;.
68
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
W pracy [4] wskazano, iĹź oprĂłcz konwencjonalnych atakĂłw, wĹ&#x203A;rĂłd ktĂłrych moĹźna w szczegĂłlnoĹ&#x203A;ci wymieniÄ&#x2021; ataki DDoS, ataki zwiÄ&#x2026;zane z wykorzystaniem urzÄ&#x2026;dzeĹ&#x201E; IoT, wyciekiem danych i przejÄ&#x2122;ciem kontroli danych nad inteligentnymi licznikami energii elektrycznej czy teĹź przejÄ&#x2122;ciem kontroli nad kamerami dozorujÄ&#x2026;cymi zachowanie maĹ&#x201A;ych dzieci, moĹźliwe sÄ&#x2026; takĹźe skuteczne ataki korzystajÄ&#x2026;ce z urzÄ&#x2026;dzeĹ&#x201E; pracujÄ&#x2026;cych zgodnie z zasadÄ&#x2026; IF-This-Then-That (IFTTT). PrzykĹ&#x201A;adowo wskazano, Ĺźe przejÄ&#x2122;cie kontroli nad inteligentnÄ&#x2026; wtyczkÄ&#x2026; (np. Belkin Wemo) umoĹźliwia wĹ&#x201A;Ä&#x2026;czenie ogrzewania w pokoju, co skutkuje wzrostem temperatury wywoĹ&#x201A;ujÄ&#x2026;cym otwarcie okien i fizyczne naruszenie bezpieczeĹ&#x201E;stwa. A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
;$ ! $ G Tabela 1. Powiązanie zagrożeń OWASP TOP-10 IoT z grupami przyczyn Table 1. Association of OWASP TOP-10 IoT threats with cause groups
×
×
1.b. Hasła publicznie dostępne
×
×
1.c. Hasła niezmienne (sprzętowe)
×
1.a. Słabe hasła
×
2.a. Niezabezpieczone usługi sieciowe 2.b. Zbędne usługi sieciowe
×
×
×
×
×
3.a. Niezabezpieczone punkty dostępu
×
3.b. Niewłaściwe przetwarzanie danych w chmurze
×
×
×
3.c. Niewłaściwy dobór API
×
×
×
4.a. Brak szyfrowania aktualizacji w drodze
×
×
4.b. Brak weryfikacji poprawności zainstalowanego oprogramowania
×
×
×
×
4.c. Brak powiadomień o aktualizacjach
Otoczenie
Zarządzanie
Metoda
×
Zagrożenie
Materiał
Człowiek
Urządzenie
Grupa przyczyn
×
× ×
×
×
×
5.b. Korzystanie z nieautoryzowanego sprzętu
×
×
6. Brak wystarczającej ochrony prywatności
×
×
×
×
×
7.a. Brak szyfrowania i autoryzacji dostępu do danych „w drodze”
×
×
×
×
×
7.b. Brak szyfrowania i autoryzacji dostępu do danych „w spoczynku”
×
×
×
×
7.c. Brak szyfrowania i autoryzacji dostępu do przetwarzanych danych
×
×
×
×
8.a. Brak wsparcia dla zarządzania aktualizacjami ×
8.b. Brak wsparcia dla bezpieczeństwa urządzeń w cyklu życia urządzenia
9.b. Stosowanie urządzeń i oprogramowania z ustawieniami domyślnymi
Aby przeciwdziałać takim potencjalnym zagrożeniom konieczne jest budowanie modeli oddziaływań zarówno w sieci, jak też w środowisku fizycznym. Należy podkreślić, że urządzenia IoT charakteryzują się ograniczonymi zasobami i heterogenicznością systemów operacyjnych, zatem dążenie do tworzenia oprogramowania antywirusowego dla tak szerokiej gamy urządzeń nie jest uzasadnione. Dla pewnej grupy urządzeń, np. smartTV pracujących na platformie systemu Android, takie oprogramowanie jest rozwijane, jednakże – jak wynika z analizy zagrożeń OWASP TOP-10 – założenie o powszechności instalowania i aktualizacji oprogramowania antywirusowego jest nieuprawnione. Aktualizacja oprogramowania użytkowego w celu eliminacji luk także napotyka na szereg przeszkód, m.in. ze względu na konieczność ręcznego wykonywania tego procesu lub też brak aktualizacji oprogramowania przez producentów. W konsekwencji zadania ochrony punktu końcowego muszą być przenoszone na brzeg sieci, względnie do chmury lub mgły.
×
×
×
×
9.a. Brak możliwości rekonfiguracji ustawień fabrycznych
10. Brak możliwości utwardzania sprzętowego
×
×
× ×
×
×
W koncepcji IoTSec przedstawionej w pracy [3] przewiduje się tworzenie dodatkowych elementów sieci, tzw. μmboxów (realizujących funkcje mikrobezpieczeństwa sieci), które działają jako bramki bezpieczeństwa dla każdego urządzenia IoT. Logicznie scentralizowany kontroler IoTSec monitoruje konteksty różnych urządzeń i środowiska operacyjnego i generuje widok globalny dla wymuszania zasad dla różnych urządzeń. Na podstawie tego widoku tworzone są zasady ochrony i konfigurowane są poszczególne μmboxy. Taka koncepcja ochrony jest dość ogólna i może korzystać z różnych modeli zarządzania IoT, np. modelu urządzeń bezpośrednio połączonych do punktu centralnego IoT i kontrolowanych przez smartfony. Założenie o zapewnieniu na smartfonie zasobów wystarczających dla potrzeb bezpieczeństwa systemu jest jednakże założeniem bardzo optymistycznym; pod względem dostępności zasobów i skalowalności systemu realne jest podejście przetwarzania w chmurze, jednakże wiąże się ze zwiększeniem opóźnienia w podejmowaniu decyzji przez oprogramowanie odpowiedzialne
69
G !A . : !: : & ! & ] G
za stan bezpieczeĹ&#x201E;stwa systemĂłw i ich przesyĹ&#x201A;aniu do urzÄ&#x2026;dzeĹ&#x201E; koĹ&#x201E;cowych. W wielu pracach wskazano, Ĺźe przeniesienie zadaĹ&#x201E; scentralizowanego kontrolera IoTSec do warstwy mgĹ&#x201A;y i jednoczesne rozproszenie realizacji tych zadaĹ&#x201E; do kontrolerĂłw monitorujÄ&#x2026;cych pracÄ&#x2122; urzÄ&#x2026;dzeĹ&#x201E; faktyczne i potencjalnie wspĂłĹ&#x201A;dziaĹ&#x201A;ajÄ&#x2026;cych ze sobÄ&#x2026; pozwoli na wykorzystanie zalet koncepcji mgĹ&#x201A;y, przede wszystkim zmniejszenie opóźnieĹ&#x201E; w ocenie bezpieczeĹ&#x201E;stwa dziaĹ&#x201A;ajÄ&#x2026;cych urzÄ&#x2026;dzeĹ&#x201E;.
KaĹźde z urzÄ&#x2026;dzeĹ&#x201E; moĹźe przyjmowaÄ&#x2021; dwa stany pracy: ti â&#x20AC;&#x201C; wĹ&#x201A;Ä&#x2026;czony, fi â&#x20AC;&#x201C; wyĹ&#x201A;Ä&#x2026;czony. Przy takim zaĹ&#x201A;oĹźeniu zbiĂłr stanĂłw pracy dla k urzÄ&#x2026;dzeĹ&#x201E; moĹźna oznaczyÄ&#x2021; jako W2k = {t1, f1, t2, f2, â&#x20AC;Ś, tk, fk}. Wtedy przestrzeĹ&#x201E; wszystkich moĹźliwych stanĂłw bezpieczeĹ&#x201E;stwa i stanĂłw pracy dla rozwaĹźanych w przykĹ&#x201A;adzie trzech urzÄ&#x2026;dzeĹ&#x201E; moĹźna przedstawiÄ&#x2021; jako iloczyn macierzy
V1^1 3 # ObszernÄ&#x2026; analizÄ&#x2122; zagadnieĹ&#x201E; bezpieczeĹ&#x201E;stwa przetwarzania we mgle zawiera przeglÄ&#x2026;dowy artykuĹ&#x201A; [11]. W pracy [4] zwraca siÄ&#x2122; uwagÄ&#x2122;, Ĺźe w opisie interakcji miÄ&#x2122;dzy urzÄ&#x2026;dzeniami zachodzÄ&#x2026; pewne istotne ograniczenia bezpieczeĹ&#x201E;stwa, wynikajÄ&#x2026;ce m.in. z zaĹ&#x201A;oĹźenia, Ĺźe reguĹ&#x201A;y bezpieczeĹ&#x201E;stwa mogÄ&#x2026; byÄ&#x2021; okreĹ&#x203A;lane niezaleĹźne dla kaĹźdego urzÄ&#x2026;dzenia, co moĹźe prowadziÄ&#x2021; do konfliktĂłw reguĹ&#x201A; lub niejednoznacznoĹ&#x203A;ci wynikĂłw (np. generowanie takiego samego sygnaĹ&#x201A;u alarmowego dla róşnych zdarzeĹ&#x201E;), a takĹźe z trudnoĹ&#x203A;ci identyfikacji wszystkich moĹźliwych interakcji. Problem powiÄ&#x2026;zania stanu bezpieczeĹ&#x201E;stwa urzÄ&#x2026;dzeĹ&#x201E; IoT i ich interakcji moĹźe byÄ&#x2021; rozwiÄ&#x2026;zywany przez utworzenie modelu macierzowego stanĂłw bezpieczeĹ&#x201E;stwa i pracy urzÄ&#x2026;dzeĹ&#x201E;. Dla przykĹ&#x201A;adu moĹźna rozwaĹźyÄ&#x2021; trzy urzÄ&#x2026;dzenia, z ktĂłrych dwa D1 i D2 mogÄ&#x2026; zostaÄ&#x2021; wĹ&#x201A;Ä&#x2026;czone wtedy, gdy trzecie urzÄ&#x2026;dzenie D3 przyjmuje okreĹ&#x203A;lony stan, np. jest wyĹ&#x201A;Ä&#x2026;czone. PrzykĹ&#x201A;adem takiego ukĹ&#x201A;adu moĹźe byÄ&#x2021; wyodrÄ&#x2122;bniony w ukĹ&#x201A;adzie typowej automatyki domowej ukĹ&#x201A;ad obejmujÄ&#x2026;cy sterowanie oĹ&#x203A;wietleniem wybranych pomieszczeĹ&#x201E; (D1), siĹ&#x201A;ownikami otwierania okien (D2) i instalacjÄ&#x2122; alarmowÄ&#x2026; (D3). ZakĹ&#x201A;ada siÄ&#x2122;, Ĺźe ukĹ&#x201A;ady sterowania oĹ&#x203A;wietleniem wybranych pomieszczeĹ&#x201E; oraz otwierania okien mogÄ&#x2026; byÄ&#x2021; wĹ&#x201A;Ä&#x2026;czone dopiero wtedy, gdy instalacja alarmowa zostaje wyĹ&#x201A;Ä&#x2026;czona, czyli gdy w domu obecni sÄ&#x2026; mieszkaĹ&#x201E;cy. OczywiĹ&#x203A;cie, moĹźna urzÄ&#x2026;dzenie D3 zastÄ&#x2026;piÄ&#x2021; np. czujnikami ruchu, a wtedy zmieniÄ&#x2021; warunek dopuszczalnoĹ&#x203A;ci wĹ&#x201A;Ä&#x2026;czania D1 i D2 stanem aktywnoĹ&#x203A;ci mieszkaĹ&#x201E;cĂłw, przypisujÄ&#x2026;c mu stan pracy urzÄ&#x2026;dzenia â&#x20AC;&#x17E;wĹ&#x201A;Ä&#x2026;czonyâ&#x20AC;?. ZaĹ&#x201A;oĹźenie o podziale oĹ&#x203A;wietlenia wybranych pomieszczeĹ&#x201E; wynika z koniecznoĹ&#x203A;ci zapewnienia moĹźliwoĹ&#x203A;ci sterowania wĹ&#x201A;Ä&#x2026;czaniem i wyĹ&#x201A;Ä&#x2026;czaniem Ĺ&#x203A;wiateĹ&#x201A; przy wĹ&#x201A;Ä&#x2026;czonej instalacji alarmowej w celu symulacji obecnoĹ&#x203A;ci mieszkaĹ&#x201E;cĂłw i uniemoĹźliwienia potencjalnym wĹ&#x201A;amywaczom ustalenia faktycznej obecnoĹ&#x203A;ci domownikĂłw. ZaĹ&#x201A;oĹźenie o blokadzie systemu sterowania otwieraniem okien, zasygnalizowane juĹź wyĹźej przy omawianiu pracy [4] uniemoĹźliwia automatyczne otwarcie okien w opisanym tam przypadku wzrostu temperatury przy przechwyceniu przez intruza kontroli nad systemem ogrzewania, a blokada systemu sterowania oĹ&#x203A;wietleniem dla wybranych pomieszczeĹ&#x201E; wyklucza straty finansowe wynikajÄ&#x2026;ce z przejÄ&#x2122;cia przez intruza kontroli nad tym systemem, jeĹ&#x203A;li instalacja alarmowa jest wĹ&#x201A;Ä&#x2026;czona. Typowo przyjmuje siÄ&#x2122;, Ĺźe stan bezpieczeĹ&#x201E;stwa kaĹźdego z urzÄ&#x2026;dzeĹ&#x201E; moĹźe przyjmowaÄ&#x2021; trzy wartoĹ&#x203A;ci: p â&#x20AC;&#x201C; prawidĹ&#x201A;owy, n â&#x20AC;&#x201C; niepewny, u â&#x20AC;&#x201C; bĹ&#x201A;Ä&#x2122;dny, nieprawidĹ&#x201A;owy (np. nieaktualizowany, mimo udostÄ&#x2122;pnienia aktualizacji przez producenta). ZbiĂłr moĹźliwych stanĂłw bezpieczeĹ&#x201E;stwa dla k urzÄ&#x2026;dzeĹ&#x201E; moĹźna oznaczyÄ&#x2021; przez
Z = S33 Ă&#x2014; 3 â&#x2039;&#x2026; W3 Ă&#x2014; 23
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
p3 â&#x17D;¤ â&#x17D;Ľ p2 n 3 â&#x17D;Ľ â&#x17D;Ľ p2 u 3 â&#x17D;Ľ â&#x17D;Ľ n 2 p3 â&#x17D;Ľ â&#x17D;Ľ â&#x17D;Ąt1 t1 t1 ! f1 f1 â&#x17D;¤ ! !â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľ â&#x17D;Ľ â&#x2039;&#x2026; â&#x17D;˘t t f ! f f â&#x17D;Ľ 2 2 2 2 2 â&#x17D;Ľ â&#x17D;Ľ (1) n 2 n3 â&#x17D;˘ â&#x17D;Ľ â&#x17D;˘ â&#x17D;Ľâ&#x17D;Ś ! t f t t t 3 3 3 3 3 â&#x17D;Ľ â&#x17D;Ł n2 u3 â&#x17D;Ľ â&#x17D;Ľ u 2 p3 â&#x17D;Ľ â&#x17D;Ľ u 2 n3 â&#x17D;Ľ â&#x17D;Ľ u 2 u 3 â&#x17D;Śâ&#x17D;Ľ p2
W podanym przykĹ&#x201A;adzie uzyskuje siÄ&#x2122; macierz Z o wymiarach 3k Ă&#x2014; 2k:
(2)
Macierz moĹźe byÄ&#x2021; interpretowana jako zbiĂłr Z elementĂłw trĂłjek par: Z ={[(p1, t1), (p2, t2), (p3, t3)], [(p1, t1), (p2, t2), (p3, f3)], â&#x20AC;Ś, [(u1, f1), (u2, f2), (u3, t3)], [(u1, f1), (u2, f2), (u3, f3)]}. W zbiorze Z wszystkich moĹźliwych stanĂłw bezpieczeĹ&#x201E;stwa i stanĂłw pracy moĹźna wybieraÄ&#x2021; trĂłjkÄ&#x2122; par okreĹ&#x203A;lajÄ&#x2026;cÄ&#x2026; aktualny stan pracy i bezpieczeĹ&#x201E;stwa urzÄ&#x2026;dzeĹ&#x201E;, np. poĹźÄ&#x2026;dany stan [(p1, t1), (p2, t2), (p3, f3)], wskazujÄ&#x2026;cy stan pracy wĹ&#x201A;Ä&#x2026;czonego urzÄ&#x2026;dzeĹ&#x201E; D1 z bezpiecznym oprogramowaniem, wĹ&#x201A;Ä&#x2026;czonego urzÄ&#x2026;dzenia D2 z bezpiecznym oprogramowaniem i wyĹ&#x201A;Ä&#x2026;czonego urzÄ&#x2026;dzenia D3, z bezpiecznym oprogramowaniem. W rozwaĹźanym przykĹ&#x201A;adzie poĹźÄ&#x2026;danymi stanami ukĹ&#x201A;adu sÄ&#x2026; tylko dwie trĂłjki: Z* = {[(p1, t1), (p2, t2), (p3, f3)], [(p1, f1), (p2, f2), (p3, t3)]} natomiast pozostaĹ&#x201A;e stany albo stanowiÄ&#x2026; potencjalne zagroĹźenie bezpieczeĹ&#x201E;stwa lub wskazujÄ&#x2026; na niedopuszczalne dziaĹ&#x201A;anie urzÄ&#x2026;dzeĹ&#x201E; i powinny byÄ&#x2021; odpowiednio sygnalizowane lub blokowane. W rozwaĹźanym przykĹ&#x201A;adzie ze zbioru wszystkich stanĂłw Z moĹźna wyróşniÄ&#x2021;, oprĂłcz zbioru Z* takĹźe zbiĂłr Z** stanĂłw dopuszczalnych, w tym takĹźe stanowiÄ&#x2026;cych potencjalne zagroĹźenie bezpieczeĹ&#x201E;stwa, w ktĂłrych D1 i D2 sÄ&#x2026; wĹ&#x201A;Ä&#x2026;czone, D3 wyĹ&#x201A;Ä&#x2026;-
Sk = {p1, n1, u1, p2, n2, u2, â&#x20AC;Ś, pk, nk, uk}.
70
â&#x17D;Ą p1 â&#x17D;˘ â&#x17D;˘ p1 â&#x17D;˘ â&#x17D;˘ p1 â&#x17D;˘ â&#x17D;˘ p1 â&#x17D;˘ â&#x17D;˘! =â&#x17D;˘ â&#x17D;˘u â&#x17D;˘ 1 â&#x17D;˘ â&#x17D;˘u1 â&#x17D;˘ â&#x17D;˘u1 â&#x17D;˘ â&#x17D;˘u1 â&#x17D;˘ â&#x17D;Łâ&#x17D;˘u1
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
;$ ! $ G
czone lub teĹź â&#x20AC;&#x201C; jeĹ&#x203A;li D3 jest w stanie â&#x20AC;&#x17E;wĹ&#x201A;Ä&#x2026;czoneâ&#x20AC;?, to D1 i D2 sÄ&#x2026; wyĹ&#x201A;Ä&#x2026;czone. Przy takim zaĹ&#x201A;oĹźeniu macierz odwzorowujÄ&#x2026;cÄ&#x2026; zbiĂłr stanĂłw Z** moĹźna przedstawiÄ&#x2021; jako zmodyfikowane rĂłwnanie (1) w postaci:
Zâ&#x2C6;&#x2014;â&#x2C6;&#x2014; = S33 Ă&#x2014;3 â&#x2039;&#x2026; W3 Ă&#x2014; 2
â&#x17D;Ą p1 â&#x17D;˘ â&#x17D;˘ p1 â&#x17D;˘ â&#x17D;˘p â&#x17D;˘ 1 â&#x17D;˘p â&#x17D;˘ 1 â&#x17D;˘ â&#x17D;˘! =â&#x17D;˘ â&#x17D;˘u1 â&#x17D;˘ â&#x17D;˘u1 â&#x17D;˘ â&#x17D;˘u1 â&#x17D;˘ â&#x17D;˘u1 â&#x17D;˘ â&#x17D;˘â&#x17D;Łu1
p3 â&#x17D;¤ â&#x17D;Ľ p2 n 3 â&#x17D;Ľ â&#x17D;Ľ p2 u 3 â&#x17D;Ľ â&#x17D;Ľ n 2 p3 â&#x17D;Ľ â&#x17D;Ľ â&#x17D;Ąt f â&#x17D;¤ â&#x17D;Ľ 1 1â&#x17D;Ľ ! !â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘ â&#x17D;Ľ â&#x17D;Ľ â&#x2039;&#x2026; t 2 f2 â&#x17D;Ľ n 2 n3 â&#x17D;Ľ â&#x17D;˘ â&#x17D;˘ â&#x17D;Ľ â&#x17D;Ľ â&#x17D;Ł f3 t 3 â&#x17D;Ś n2 u3 â&#x17D;Ľ â&#x17D;Ľ u 2 p3 â&#x17D;Ľ â&#x17D;Ľ u 2 n3 â&#x17D;Ľ â&#x17D;Ľ u 2 n3 â&#x17D;Ľâ&#x17D;Ś p2
(3)
lub teĹź zastÄ&#x2026;pienie tych elementĂłw macierzy Z, ktĂłre reprezentujÄ&#x2026; stany niedozwolone zerami: â&#x17D;Ą 0 p1 â&#x2039;&#x2026; t1 + p2 â&#x2039;&#x2026; t 2 + p3 â&#x2039;&#x2026; f3 â&#x17D;˘ â&#x17D;˘ 0 p1 â&#x2039;&#x2026; t1 + p2 â&#x2039;&#x2026; t 2 + n3 â&#x2039;&#x2026; f3 Z=â&#x17D;˘ â&#x17D;˘! ! â&#x17D;˘ â&#x17D;˘ 0 u â&#x2039;&#x2026;t + u â&#x2039;&#x2026;t + u â&#x2039;&#x2026; f 1 1 2 2 3 3 â&#x17D;Ł
! p1 â&#x2039;&#x2026; f1 + p2 â&#x2039;&#x2026; f2 + p3 â&#x2039;&#x2026; t3 ! p1 â&#x2039;&#x2026; f1 + p2 â&#x2039;&#x2026; f2 + n3 â&#x2039;&#x2026; t3 !
!
! u1 â&#x2039;&#x2026; f1 + u 2 â&#x2039;&#x2026; f2 + u 3 â&#x2039;&#x2026; t3
rzeczywistym komunikatu o wykrytym zagroĹźeniu bezpieczeĹ&#x201E;stwa systemu. W zaleĹźnoĹ&#x203A;ci od wiedzy a priori o ukĹ&#x201A;adzie moĹźna rozwaĹźaÄ&#x2021; dowolne scenariusze stanĂłw pracy i bezpieczeĹ&#x201E;stwa systemĂłw i ustalaÄ&#x2021; zbiory Z* i Z**. W szczegĂłlnoĹ&#x203A;ci moĹźna zakĹ&#x201A;adaÄ&#x2021;, Ĺźe do zbioru Z* mogÄ&#x2026; naleĹźeÄ&#x2021; tylko takie elementy, w ktĂłrych ocena stanu bezpieczeĹ&#x201E;stwa jest ustalona jako prawidĹ&#x201A;owa lub teĹź takie elementy, dla ktĂłrych stany pracy przyjmujÄ&#x2026; wyznaczone wartoĹ&#x203A;ci. W identyfikacji stanu bezpieczeĹ&#x201E;stwa i ustalania urzÄ&#x2026;dzeĹ&#x201E; IoT w systemie, dla ktĂłrego sÄ&#x2026; wyznaczane zbiory Z* i Z** moĹźna posĹ&#x201A;uĹźyÄ&#x2021; siÄ&#x2122; rozmaitymi metodykami, np. opisanÄ&#x2026; w pkt. 2 metodykÄ&#x2026; diagramĂłw Ishikawy czy teĹź wywodzÄ&#x2026;cym siÄ&#x2122; z tzw. dobrych praktyk frameworkiem CSA [12] posĹ&#x201A;ugujÄ&#x2026;cym siÄ&#x2122; takĹźe trĂłjpoziomowÄ&#x2026; ocenÄ&#x2026; bezpieczeĹ&#x201E;stwa badanego systemu. PrzeglÄ&#x2026;d wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci rozmaitych frameworkĂłw zostaĹ&#x201A; przedstawiony w pracy [13]. Kontroler, analizujÄ&#x2026;cy stany pracy, musiaĹ&#x201A;by dysponowaÄ&#x2021; odpowiednimi zasobami w celu zapamiÄ&#x2122;tywania macierzy Z oraz Z* i wykonania operacji porĂłwnania stanĂłw w czasie rzeczywistym w celu zezwolenia lub zablokowania przejĹ&#x203A;cia do kolejnego stanu ukĹ&#x201A;adu. ZaleĹźnoĹ&#x203A;Ä&#x2021; (4) moĹźna uogĂłlniÄ&#x2021; dla n stanĂłw bezpieczeĹ&#x201E;stwa i m stanĂłw pracy urzÄ&#x2026;dzeĹ&#x201E; zapisujÄ&#x2026;c je w postaci:
0â&#x17D;¤ â&#x17D;Ľ 0â&#x17D;Ľ â&#x17D;Ľ !â&#x17D;Ľ â&#x17D;Ľ 0 â&#x17D;Ľâ&#x17D;Ś
(4) Macierz Z jest macierzÄ&#x2026; rzadkÄ&#x2026;, co implikuje moĹźliwoĹ&#x203A;ci stosowania metod numerycznych charakterystycznych dla tej grupy macierzy, ale â&#x20AC;&#x201C; jak widaÄ&#x2021; z powyĹźszego przykĹ&#x201A;adu â&#x20AC;&#x201C; nie jest macierzÄ&#x2026; symetrycznÄ&#x2026;.
V1S1 _ #
L , + , OgĂłlnie, dla k urzÄ&#x2026;dzeĹ&#x201E;, charakteryzujÄ&#x2026;cych siÄ&#x2122; typowymi trzema stanami bezpieczeĹ&#x201E;stwa (w szczegĂłlnoĹ&#x203A;ci eksploatowanego na nich oprogramowania), z ktĂłrych kaĹźde moĹźe byÄ&#x2021; wĹ&#x201A;Ä&#x2026;czone lub wyĹ&#x201A;Ä&#x2026;czone, zapis przestrzeni wszystkich stanĂłw pracy i bezpieczeĹ&#x201E;stwa moĹźna przedstawiÄ&#x2021; nastÄ&#x2122;pujÄ&#x2026;co:
(6) gdzie: sj,i â&#x20AC;&#x201C; stan (poziom) bezpieczeĹ&#x201E;stwa j dla urzÄ&#x2026;dzenia i, j = 1, 2, â&#x20AC;Ś, n; i = 1, 2, â&#x20AC;Ś, k wp,j â&#x20AC;&#x201C; stan (poziom) pracy p dla urzÄ&#x2026;dzenia i, p = 1, 2, â&#x20AC;Ś, m; i = 1, 2, â&#x20AC;Ś, k. Moc zbioru Z zaleĹźy wykĹ&#x201A;adniczo od liczby urzÄ&#x2026;dzeĹ&#x201E; k i wymaga znacznych zasobĂłw pamiÄ&#x2122;ci, jednakĹźe dysponujÄ&#x2026;c informacjami o stanach poĹźÄ&#x2026;danych i o stanach dopuszczalnych moĹźna redukowaÄ&#x2021; problem budowy i zapisywania macierzy stanĂłw bezpieczeĹ&#x201E;stwa i pracy do okreĹ&#x203A;lenia poĹźÄ&#x2026;danego zbioru Z* lub dopuszczalnego zbioru Z** i analizy przez kontroler, czy stany rzeczywiste lub stany, do ktĂłrych system opisywany macierzÄ&#x2026; Z ma przejĹ&#x203A;Ä&#x2021;, wystÄ&#x2122;pujÄ&#x2026; w zbiorze Z* lub Z**. RozwaĹźanie zbiorĂłw Z* i Z** zamiast zbioru Z skutkuje takĹźe moĹźliwoĹ&#x203A;ciÄ&#x2026; korzystania z oprogramowania stosowanego do obliczeĹ&#x201E; macierzy rzadkich, co istotnie zmniejsza zapotrzebowanie na zasoby kontrolera.
V1V1
,
* (5) ZbiĂłr stanĂłw poĹźÄ&#x2026;danych Z* zawiera arbitralnie ustalone i wybrane stany, ktĂłre z punktu widzenia bezpieczeĹ&#x201E;stwa urzÄ&#x2026;dzeĹ&#x201E; i ich interakcji uznaje siÄ&#x2122; za prawidĹ&#x201A;owe i bezpieczne. Analogicznie, moĹźna â&#x20AC;&#x201C; takĹźe arbitralnie â&#x20AC;&#x201C; ustaliÄ&#x2021; zbiĂłr Z**, zawierajÄ&#x2026;cy stany, ktĂłre z punktu widzenia bezpieczeĹ&#x201E;stwa systemu sÄ&#x2026; obarczone pewnym ryzykiem wymagajÄ&#x2026;cym powiadomienia uĹźytkownika, jednakĹźe mogÄ&#x2026; byÄ&#x2021; uznane przez kontroler za dopuszczalne i skutkujÄ&#x2026; jedynie przesyĹ&#x201A;aniem w czasie
Zasoby wymagane do zastosowana proponowanego modelu macierzowego Z mogÄ&#x2026; byÄ&#x2021; udostÄ&#x2122;pnione w chmurze. Za takim rozwiÄ&#x2026;zaniem przemawia skalowalnoĹ&#x203A;Ä&#x2021; rozwiÄ&#x2026;zaĹ&#x201E; chmurowych, jednakĹźe w warunkach koniecznoĹ&#x203A;ci podejmowania w czasie rzeczywistym decyzji o ocenie bezpieczeĹ&#x201E;stwa stanu istniejÄ&#x2026;cego i stanu, do ktĂłrego ma przejĹ&#x203A;Ä&#x2021; system, krytycznym parametrem staje siÄ&#x2122; czas przesĹ&#x201A;ania danych, wypracowania decyzji i przesĹ&#x201A;ania jej do urzÄ&#x2026;dzeĹ&#x201E;. Czasy transmisji danych do chmury siÄ&#x2122;gajÄ&#x2026; co najmniej setek milisekund i mogÄ&#x2026; byÄ&#x2021; nieakceptowalne.
71
G !A . : !: : & ! & ] G
Rozwijana w ostatnich kilku latach koncepcja przetwarzania danych we mgle rozszerza model rozwiÄ&#x2026;zaĹ&#x201E; chmurowych przez moĹźliwoĹ&#x203A;Ä&#x2021; wykonywania obliczeĹ&#x201E; rozproszonych, lokalnie, w róşnorodnych Ĺ&#x203A;rodowiskach i wypracowywanie decyzji z mniejszymi opóźnieniami w porĂłwnaniu do tradycyjnego podejĹ&#x203A;cia przetwarzania danych w chmurze. Propozycja obliczeĹ&#x201E; we mgle zaproponowana w dokumentach CISCO [14] zostaĹ&#x201A;a sformalizowana w dokumencie NIST SP 500-325 [15]. W pracy [17] wskazano, Ĺźe obliczenia we mgle mogÄ&#x2026; byÄ&#x2021; rozwaĹźane jako nowa warstwa miÄ&#x2122;dzy warstwÄ&#x2026; procesĂłw produkcji i warstwÄ&#x2026; nadrzÄ&#x2122;dnego sterowania procesami. Dobre praktyki ochrony automatyki przemysĹ&#x201A;owej dla infrastruktury krytycznej, np. opublikowane przez RzÄ&#x2026;dowe Centrum BezpieczeĹ&#x201E;stwa [18] wskazujÄ&#x2026;, Ĺźe wymagane czasy reakcji sÄ&#x2026; rzÄ&#x2122;du milisekund. Zasadnicze znaczenie dla speĹ&#x201A;nienia tego wymagania ma czas opóźnienia pakietĂłw transmitowanych w sieci. Zagadnienia szacowania opóźnienia dla obliczeĹ&#x201E; we mgle zostaĹ&#x201A;y przedstawione w pracy [19]. PrzyjÄ&#x2122;to typowo, Ĺźe sumaryczna wartoĹ&#x203A;Ä&#x2021; opóźnienia transmisji pakietĂłw wyraĹźa siÄ&#x2122; zaleĹźnoĹ&#x203A;ciÄ&#x2026;: Dend-to-end = N¡(dproc + dqueue + dseri + dprop)
blokadzie przejĹ&#x203A;cia ukĹ&#x201A;adu do stanu przyszĹ&#x201A;ego. JeĹźeli decyzja podejmowana przez kontroler w chmurze zezwala na przejĹ&#x203A;cie do przyszĹ&#x201A;ego stanu, to stan ten jest dopisywany do zbioru Z*, przy czym decyzja uĹźytkownika, ktĂłra co do zasady jest podejmowana po czasie dĹ&#x201A;uĹźszym niĹź czas podjÄ&#x2122;cia decyzji przez kontroler w chmurze, ma najwyĹźszy priorytet. Za podziaĹ&#x201A;em zadaĹ&#x201E; kontrolera na warstwy mgĹ&#x201A;y i chmury przemawia takĹźe istotne poprawienie bezpieczeĹ&#x201E;stwa systemu w sytuacji utraty Ĺ&#x201A;Ä&#x2026;cznoĹ&#x203A;ci z chmurÄ&#x2026;, gdyĹź zadanie notyfikacji uĹźytkownika o potencjalnym zagroĹźeniu jest realizowane w warstwie mgĹ&#x201A;y, a zadanie podjÄ&#x2122;cia decyzji przez kontroler w warstwie chmury jest realizowane po odzyskaniu Ĺ&#x201A;Ä&#x2026;cznoĹ&#x203A;ci. W sytuacji utraty Ĺ&#x201A;Ä&#x2026;cznoĹ&#x203A;ci z chmurÄ&#x2026; kontroler w warstwie mgĹ&#x201A;y moĹźe zmieniaÄ&#x2021; algorytm pracy w ten sposĂłb, Ĺźe jeĹ&#x203A;li stan przyszĹ&#x201A;y jest elementem zbioru Z** â&#x20AC;&#x201C; Z*, to nastÄ&#x2122;puje wstrzymanie decyzji do odzyskania Ĺ&#x201A;Ä&#x2026;cznoĹ&#x203A;ci z chmurÄ&#x2026; lub teĹź do podjÄ&#x2122;cia przez uĹźytkownika decyzji o moĹźliwoĹ&#x203A;ci przejĹ&#x203A;cia ukĹ&#x201A;adu do stanu przyszĹ&#x201A;ego. Za umiejscowieniem kontrolera dla systemĂłw urzÄ&#x2026;dzeĹ&#x201E; IoT w warstwie mgĹ&#x201A;y i rozproszeniu jego zadaĹ&#x201E; przemawia rĂłwnieĹź przesĹ&#x201A;anka moĹźliwoĹ&#x203A;ci dekompozycji macierzy Z* i Z** dla takich systemĂłw, w ktĂłrych moĹźna wyróşniÄ&#x2021; podzbiory urzÄ&#x2026;dzeĹ&#x201E;, ktĂłrych stany pracy oddziaĹ&#x201A;ujÄ&#x2026; na siebie w danym podzbiorze, lecz nie wpĹ&#x201A;ywajÄ&#x2026; na stan pracy urzÄ&#x2026;dzeĹ&#x201E; w innych podzbiorach.
(7)
gdzie: dproc â&#x20AC;&#x201C; opóźnienie zwiÄ&#x2026;zane z przetwarzaniem pakietu w wÄ&#x2122;Ĺşle sieci, dqueue â&#x20AC;&#x201C; opóźnienie zwiÄ&#x2026;zane z kolejkowaniem, dseri â&#x20AC;&#x201C; opóźnienie zwiÄ&#x2026;zane z serializacjÄ&#x2026;, dprop â&#x20AC;&#x201C; opóźnienie zwiÄ&#x2026;zane z propagacjÄ&#x2026;, N â&#x20AC;&#x201C; liczba segmentĂłw sieci, jakie pakiet przebywa w ekosystemie IoT.
X1 Zaproponowany macierzowy model pozwala na opisanie stanu bezpieczeĹ&#x201E;stwa i stanu pracy systemĂłw urzÄ&#x2026;dzeĹ&#x201E; IoT charakteryzujÄ&#x2026;cych siÄ&#x2122; dowolnÄ&#x2026; liczbÄ&#x2026; stanĂłw bezpieczeĹ&#x201E;stwa i stanĂłw pracy. OkreĹ&#x203A;lanie macierzy Z* stanĂłw poĹźÄ&#x2026;danych oraz macierzy Z** stanĂłw dopuszczalnych upraszcza zagadnienie przechowywania i przeszukiwania macierzy Z opisujÄ&#x2026;cej przestrzeĹ&#x201E; wszystkich hipotetycznie moĹźliwych stanĂłw systemu. Identyfikacja jakoĹ&#x203A;ciowa stanĂłw bezpieczeĹ&#x201E;stwa kaĹźdego urzÄ&#x2026;dzenia moĹźe byÄ&#x2021; realizowana zaproponowanÄ&#x2026; metodÄ&#x2026; analizy uszczegĂłĹ&#x201A;owionej i poszerzonej o zagroĹźenia Ĺ&#x203A;rodowiskowe listy OWASP TOP-10 dla urzÄ&#x2026;dzeĹ&#x201E; IoT przy zastosowaniu diagramu Ishikawy.
Wskazano, Ĺźe aktualnie wartoĹ&#x203A;ci dproc oraz dseri sÄ&#x2026; rzÄ&#x2122;du mikrosekund na wÄ&#x2122;zeĹ&#x201A;, dprop â&#x20AC;&#x201C; okoĹ&#x201A;o 5 Îźs/km. WartoĹ&#x203A;Ä&#x2021; opóźnienia dqueue moĹźe byÄ&#x2021; optymalizowana dziÄ&#x2122;ki stosowaniu lepszych polityk niĹź FIFO i zastosowaniu technik QoS. W konsekwencji, skoro dla obliczeĹ&#x201E; we mgle w porĂłwnaniu do obliczeĹ&#x201E; czasu opóźnienia dla transmisji chmurowych moĹźna zmniejszyÄ&#x2021; liczbÄ&#x2122; segmentĂłw do jednego, a czas propagacji ze wzglÄ&#x2122;du na fizycznÄ&#x2026; bliskoĹ&#x203A;Ä&#x2021; wÄ&#x2122;zĹ&#x201A;Ăłw jest najmniejszy z moĹźliwych, czas odpowiedzi na ĹźÄ&#x2026;danie elementu wykonawczego speĹ&#x201A;ni warunek opóźnienia rzÄ&#x2122;du milisekund i jest akceptowalny. W przypadku gdy wÄ&#x2122;zĹ&#x201A;y mgĹ&#x201A;y nie sÄ&#x2026;siadujÄ&#x2026; ze sobÄ&#x2026;, do oszacowania opóźnienia moĹźna stosowaÄ&#x2021; przeanalizowane w [19] algorytmy NCS (ang. Network Coordinate System), takie jak GNP (ang. Global Network Positioning), NPS (ang. Network Positioning System), Vivaldi i Pharos, jednakĹźe ze wzglÄ&#x2122;du na duĹźÄ&#x2026; zmiennoĹ&#x203A;Ä&#x2021; poĹ&#x201A;oĹźenia wÄ&#x2122;zĹ&#x201A;Ăłw poszukiwane sÄ&#x2026; nowe algorytmy, ktĂłre umoĹźliwiÄ&#x2026; precyzyjniejsze szacowanie opóźnieĹ&#x201E; w ekosystemach IoT. Dla uzyskiwania wynikĂłw dobrze przybliĹźajÄ&#x2026;cych wartoĹ&#x203A;ci rzeczywistego opóźnienia, obliczane w algorytmach NCS istotne sÄ&#x2026; wÄ&#x2122;zĹ&#x201A;y o staĹ&#x201A;ych lokalizacjach, np. serwery aplikacji, w tym aplikacji kontroli poprawnoĹ&#x203A;ci stanu bezpieczeĹ&#x201E;stwa i pracy urzÄ&#x2026;dzeĹ&#x201E;. Dla rozwaĹźanego modelu macierzowego zbiory Z* i Z** mogÄ&#x2026; byÄ&#x2021; umieszczane na kontrolerach w warstwie mgĹ&#x201A;y, w staĹ&#x201A;ych lokalizacjach, co pozwala na ocenÄ&#x2122; stanu bezpieczeĹ&#x201E;stwa i pracy w czasie â&#x20AC;&#x17E;jednego skokuâ&#x20AC;?, a zatem z wzglÄ&#x2122;dnie staĹ&#x201A;ym opóźnieniem rzÄ&#x2122;du pojedynczych milisekund. JeĹźeli stan rzeczywisty lub przyszĹ&#x201A;y jest elementem zbioru Z*, kontroler zezwala na pracÄ&#x2122; lub przejĹ&#x203A;cie do przyszĹ&#x201A;ego stanu (np. nie podejmuje Ĺźadnej akcji). JeĹźeli przyszĹ&#x201A;y stan jest elementem zbioru Z** â&#x20AC;&#x201C; Z*, do uĹźytkownika wysyĹ&#x201A;ane jest ostrzeĹźenie, przejĹ&#x203A;cie jest wstrzymywane, a jednoczeĹ&#x203A;nie do chmury wysyĹ&#x201A;ana jest informacja o przyszĹ&#x201A;ym stanie w celu wypracowania przez kontroler w chmurze decyzji o zezwoleniu lub
72
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
& L 0
1. Gartner Says 4.9 Billion Connected â&#x20AC;&#x153;Thingsâ&#x20AC;? Will Be in Use in 2015. [www.gartner.com/en/newsroom/press-releases/2014-11-11-gartner-says-nearly-5-billion-connected-thingswill-be-in-use-in-2015]. 2. Kouicem D.E., Bouabdallah A., Kakhlef H., Internet of things security: A top-down survey, â&#x20AC;&#x153;Computer Networksâ&#x20AC;?, Vol. 141, 2018, 199â&#x20AC;&#x201C;221, DOI: 10.1016/j.comnet.2018.03.012. 3. Quarta D., Pogliani M., Polino M., Maggi F., Zanchettin A.M., Zanero S., An Experimental Security Analysis of an Industrial Robot Controller, [www.ieee-security.org/TC/ SP2017/papers/20.pdf]. 4. Zu T., Sekar V., Seshan S., Agarwal Y., Xu Ch., Handling a trillion (unfixable) flaws on a billion devices: Rethinking network security for the Internet-of-Things. Proceedings of the 14th ACM Workshop on Hot Topics in Networks, November 2015 Article No. 5, DOI: 10.1145/2834050.2834095. 5. OWASP TOP10 Internet of Things 2018, [www.owasp.org/ index.php/OWASP_Internet_of_Things_Project]. 6. [www.owasp.org/images/1/1c/OWASP-IoT-Top-10-2018final.pdf]. 7. PaĹ&#x201A;Ä&#x2122;ga M., KnapiĹ&#x201E;ski M., Rydz D., Identyfikacja i ocena zagroĹźeĹ&#x201E; bezpieczeĹ&#x201E;stwa informacji za pomocÄ&#x2026; wybranych
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
;$ ! $ G
instrumentĂłw zarzÄ&#x2026;dzania jakoĹ&#x203A;ciÄ&#x2026;. MateriaĹ&#x201A;y z konferencji: Innowacje w ZarzÄ&#x2026;dzaniu JakoĹ&#x203A;ciÄ&#x2026;, 2018, 283â&#x20AC;&#x201C;295. 8. Dobrynin I., Radivilowa T., Maltseva N., Ageyev D., Use of Approaches to the Methodology of Factor Analysis of Information Risks for the Quantitative Assessment of Information Risks Based on the Formation of Cause-And-Effect Links, 2018 International Scientific-Practical Conference Problems of Infocommunications. Science and Technology, DOI: 10.1109/INFOCOMMST.2018.8632022. 9. Wawak S., ZarzÄ&#x2026;dzanie jakoĹ&#x203A;ciÄ&#x2026;. Podstawy, systemy i narzÄ&#x2122;dzia, Helion, Gliwice 2011. 10. Frustaci M., Pace P., Aloi G., Fortino G., Evaluating Critical Security Issues of the IoT World: Present and Future Challenges, â&#x20AC;&#x153;IEEE Internet of Things Journalâ&#x20AC;?, Vol. 5, No. 4, 2018, 2483â&#x20AC;&#x201C;2495, DOI: 10.1109/JIOT.2017.2767291. 11. Khan S., Parkinson S., Qin Y., Fog computing security: a review of current applications and security solutions, â&#x20AC;&#x153;Journal of Cloud Computing, Advances, Systems and Applicationsâ&#x20AC;?, Vol. 6, No. 19, 2017, DOI: 10.1186/s13677-017-0090-3. 12. CSA Guide to the IoT Security Controls Framework, CSA IoT Controls Framework, https://cloudsecurityalliance. org/artifacts/guide-to-the-iot-security-controls-framework, 03.05.2019. 13. Ammar M., Russello G., Crispo B., Internet of Things: A survey on the security of IoT frameworks, â&#x20AC;&#x153;Journal of Information Security and Applicationsâ&#x20AC;?, Vol. 38, 2018, 8â&#x20AC;&#x201C;27, DOI: 10.1016/j.jisa.2017.11.002. 14. Fog Computing and the Internet of Things: Extend the Cloud to Where the Things Are, 2015, [www.cisco.com/c/dam/ en_us/solutions/trends/iot/docs/computing-overview.pdf]. 15. https://csrc.nist.gov/publications/detail/sp/500-325/final, marzec 2018. 16. Gurunath R., Agarwal M., Nandi A., Samanta D., An Overview: Security Issue in IoT Network, Proceedings of the Second International Conference on I-SMAC (IoT in Social, Mobile, Analytics and Cloud) (I-SMAC 2018), IEEE Xplore Part Number:CFP18OZV-ART; ISBN:978-1-5386-1442-6, 104â&#x20AC;&#x201C;107. 17. Matt C., Fog Computing â&#x20AC;&#x201C; Complementing Cloud Computing to Facilitate Industry 4.0, â&#x20AC;&#x153;Business & Information Systems
Engineeringâ&#x20AC;?, Vol. 60, No. 4, 2018, 351â&#x20AC;&#x201C;355, DOI: 10.1007/ s12599-018-0540-6. 18. Standardy i dobre praktyki ochrony infrastruktury krytycznej. Automatyka przemysĹ&#x201A;owa w sektorze elektroenergetycznym. RzÄ&#x2026;dowe Centrum BezpieczeĹ&#x201E;stwa, 2019, https://rcb.gov. pl/wp-content/uploads/Standardy-i-dobre-praktyki-ochronyinfrastruktury-krytycznej-%E2%80%93-automatykaprzemys%C5%82owa-w-sektorze-elektroenergetycznym.pdf. 19. Li J., Zhang J., Jin J., Yang Y., Yuan D., Gao L., Latency Estimation for Fog-based Internet of Things, 27th International Telecommunication Networks and Applications Conference (ITNAC) 2017, DOI: 10.1109/ATNAC.2017.8215403.
-% I 6 7 " E " % 6 6 0 % 6 - 7 Q 2% 8 The paper presents selected issues of Internet of Things security. The classification of threats in the environment of cooperating IoT devices in the 5M + E model is presented. The TOP-10 OWASP classification for IoT was adopted as the basic one and was adapted to the needs of the analysis using the Ishikawa diagram. Threats were mapped to cause groups and the Ishikawa diagram was used to qualitatively assess the threats. A matrix security model of the ecosystem of devices operating in accordance with the IFTTT principle was proposed. A typical three-state model for assessing the safety status of each device was adopted and the usefulness of the matrix model for assessing the state of work and system security was justified. The possibilities of dividing tasks in the matrix model into fog computing and in the cloud were pointed out. KeywordsU - 6 7 ( $ $ E % $ - % (
73
G !A . : !: : & ! & ] G
( " ' % ORCID: 0000-0002-5253-7710 ;% T % ; . / > @ U 0 V > % 7 $ A / *++=R)!!G ; / $ / ( % % > A 6 > #% T V
( / " % #/ Y T / [ ( % ( I / > U A % I %A
74
P
O
M
I
A
R
Y
â&#x20AC;¢
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;¢
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 75â&#x20AC;&#x201C;82, DOI: 10.14313/PAR_235/75
K A % A A Zygmunt Lech Warsza Y < % ^ R @ - ; @ A @-;@$ ; \ )!)$ !)>&=B 0
Jacek Puchalski H A [% " $ K )$ !!>!!* 0
Streszczenie: OmĂłwiono zasady szacowania niepewnoĹ&#x203A;ci punktĂłw funkcji opisujÄ&#x2026;cej charakterystykÄ&#x2122; na podstawie wynikĂłw pomiarĂłw w dwu punktach kontrolnych. NiepewnoĹ&#x203A;ci typu B o rozkĹ&#x201A;adzie rĂłwnomiernym szacuje siÄ&#x2122; na podstawie wartoĹ&#x203A;ci dopuszczalnych maksymalnych bĹ&#x201A;Ä&#x2122;dĂłw przyrzÄ&#x2026;du przyjmujÄ&#x2026;c wspĂłĹ&#x201A;czynnik korelacji rĂłwny 1 dla pomiarĂłw tym samym przyrzÄ&#x2026;dem oraz 0 dla róşnych przyrzÄ&#x2026;dĂłw. NiepewnoĹ&#x203A;ci typu A pomiarĂłw w punktach kontrolnych szacuje siÄ&#x2122; metodÄ&#x2026; statystycznÄ&#x2026;. Przy pomiarach tych przeprowadzonych synchronicznie estymuje siÄ&#x2122; teĹź wspĂłĹ&#x201A;czynnik korelacji. NastÄ&#x2122;pnie metodÄ&#x2026; Monte Carlo estymuje siÄ&#x2122; niepewnoĹ&#x203A;ci skĹ&#x201A;adowe, zĹ&#x201A;oĹźone i rozszerzone oraz korelacjÄ&#x2122; punktĂłw funkcji opisujÄ&#x2026;cej badanÄ&#x2026; charakterystykÄ&#x2122;. ) U $ Y ; <$ A $ % "
1. Wprowadzenie W pomiarach laboratoryjnych i przemysĹ&#x201A;owych, w badaniu systemĂłw pomiarowych, ich czĹ&#x201A;onĂłw i elementĂłw oraz w kontroli aparatury, procesĂłw produkcji i wyrobĂłw rozróşniamy dwa rodzaje zagadnieĹ&#x201E;: â&#x2C6;&#x2019; wyznaczanie przebiegĂłw funkcji opisujÄ&#x2026;cych badanÄ&#x2026; charakterystykÄ&#x2122; i dokĹ&#x201A;adnoĹ&#x203A;ci jej modelu wg okreĹ&#x203A;lonego kryterium, np. najmniejszych kwadratĂłw, dla zbioru wynikĂłw obserwacji pomiarowych rozmieszczonych dowolnie, lub w sposĂłb okreĹ&#x203A;lony, np. rĂłwnomiernie w badanym zakresie xmax â&#x20AC;&#x201C; x0; â&#x2C6;&#x2019; ustalenie, w ktĂłrych punktach i z jakÄ&#x2026; dokĹ&#x201A;adnoĹ&#x203A;ciÄ&#x2026; naleĹźy kontrolowaÄ&#x2021; badanÄ&#x2026; charakterystykÄ&#x2122;, by stwierdziÄ&#x2021; czy nie przekroczono wymaganej niepewnoĹ&#x203A;ci bezwzglÄ&#x2122;dnej lub wzglÄ&#x2122;dnej. Dotyczy to m.in. kalibracji przyrzÄ&#x2026;dĂłw, czujnikĂłw, przetwornikĂłw i innych czĹ&#x201A;onĂłw systemĂłw pomiarowych, analizy wĹ&#x201A;aĹ&#x203A;ciwoĹ&#x203A;ci substancji pod wpĹ&#x201A;ywem zmian jej skĹ&#x201A;adu, kontroli wytwarzania elementĂłw i podzespoĹ&#x201A;Ăłw, monitorowania i diagnostyki urzÄ&#x2026;dzaĹ&#x201E; oraz statystycznej kontroli jakoĹ&#x203A;ci i sterowania ciÄ&#x2026;gĹ&#x201A;ymi i dyskretnymi procesami produkcji masowej. W badaniach uĹźytkowych istnieje wiele ograniczeĹ&#x201E; dotyczÄ&#x2026;cych gÄ&#x2122;stoĹ&#x203A;ci punktĂłw pomiarowych, czasu podejmowania i trwania
3 + U
( X 0 $ *+ B'( 3 % !& !) )!)! $ % % *! ! )!)!
!
eksperymentu, dostÄ&#x2122;pnoĹ&#x203A;ci obiektu badaĹ&#x201E;, prĂłbek i zautomatyzowanej aparatury oraz kosztĂłw wykonania pomiarĂłw. NiezbÄ&#x2122;dne staje siÄ&#x2122; zminimlizowanie liczby pomiarĂłw w punktach kontrolnych oraz wybĂłr odpowiedniego ich rozmieszczenia, czasu i wielkoĹ&#x203A;ci pozyskiwanych zbiorĂłw danych. ZaleĹźy to od rodzaju badaĹ&#x201E; i zakresu wartoĹ&#x203A;ci badanych wielkoĹ&#x203A;ci oraz od moĹźliwoĹ&#x203A;ci uzyskania wymaganej w tych badaniach niepewnoĹ&#x203A;ci pomiarĂłw i od dokĹ&#x201A;adnoĹ&#x203A;ci uĹźytej aparatury pomiarowej. WystÄ&#x2122;puje teĹź wymaganie dotyczÄ&#x2026;ce rozmieszczenia punktĂłw kontrolnych zaleĹźne z innych przyczyn niĹź dokĹ&#x201A;adnoĹ&#x203A;Ä&#x2021; pomiarĂłw, np. ograniczenie objÄ&#x2122;toĹ&#x203A;ci, wymiarĂłw, przepĹ&#x201A;ywĂłw, mocy i energii, zuĹźycie uĹźytych substancji itp.
S1 . #
* W pomiarach wystÄ&#x2122;pujÄ&#x2026; bĹ&#x201A;Ä&#x2122;dy o przebiegu zdeterminowanym, zwane bĹ&#x201A;Ä&#x2122;dami systematycznymi i bĹ&#x201A;Ä&#x2122;dy przypadkowe. BĹ&#x201A;Ä&#x2122;dy systematyczne o znanym przebiegu i wartoĹ&#x203A;ciach eliminuje siÄ&#x2122; za pomocÄ&#x2026; poprawek. PozostaĹ&#x201A;e, tj. nieznane bĹ&#x201A;Ä&#x2122;dy systematyczne i bĹ&#x201A;Ä&#x2122;dy przypadkowe podlegajÄ&#x2026; ocenie dokĹ&#x201A;adnoĹ&#x203A;ci wynikĂłw pomiaru, w ktĂłrej stosuje siÄ&#x2122; obecnie zalecenia zawarte w miÄ&#x2122;dzynarodowym przewodniku GUM [1]. PodstawÄ&#x2026; tej oceny jest estymacja niepewnoĹ&#x203A;ci standardowej u, zwanej zĹ&#x201A;oĹźonÄ&#x2026;, jako sumy geometrycznej dwu niepewnoĹ&#x203A;ci skĹ&#x201A;adowych u = uA2 + uB2 . SkĹ&#x201A;adnik uA, czyli niepewnoĹ&#x203A;Ä&#x2021; typu A, wyznacza siÄ&#x2122; w znany sposĂłb z rozrzutu wartoĹ&#x203A;ci okreĹ&#x203A;lonej liczby powtarzanych pomiarĂłw wielkoĹ&#x203A;ci mierzonej. SkĹ&#x201A;adnik uB, czyli niepewnoĹ&#x203A;Ä&#x2021; typu B, ujmuje zrandomizowany Ĺ&#x201A;Ä&#x2026;czny wpĹ&#x201A;yw przewidywanych oddziaĹ&#x201A;ywaĹ&#x201E; na obiekt badany, system pomiarowy i na wskazania przyrzÄ&#x2026;dĂłw
75
@ !: & _ & J < ! ! J < & : J ! < PozostaĹ&#x201A;e macierze we wzorze (1a) dla pomiarĂłw poĹ&#x203A;rednich menzurandu 2D Y = [y1, y2]T i elementy diagonalne jego macierzy UY oraz wspĂłĹ&#x201A;czynnik korelacji, sÄ&#x2026; nastÄ&#x2122;pujÄ&#x2026;ce:
w okreĹ&#x203A;lonych dopuszczalnych warunkach i w znamionowym okresie eksploatacji, nieznanych co do wartoĹ&#x203A;ci w danym eksperymencie [1, 2]. Oszacowanie to opiera siÄ&#x2122; na wiedzy o przewidywanych zakresach i rozkĹ&#x201A;adach prawdopodobieĹ&#x201E;stwa tych oddziaĹ&#x201A;ywaĹ&#x201E;. Szacuje siÄ&#x2122; teĹź heurystycznie czÄ&#x2026;stkowe ich udziaĹ&#x201A;y w niepewnoĹ&#x203A;ci uB i Ĺ&#x201A;Ä&#x2026;cznÄ&#x2026; estymatÄ&#x2122; jej wartoĹ&#x203A;ci wg okreĹ&#x203A;lonego kryterium. Autorzy w kilku publikacjach [3â&#x20AC;&#x201C;6] omĂłwili szczegĂłĹ&#x201A;owo proponowanÄ&#x2026; metodÄ&#x2122; estymacji niepewnoĹ&#x203A;ci punktĂłw charakterystyki przetwornika pomiarowego lub badanego urzÄ&#x2026;dzenia na podstawie pomiarĂłw kontrolnych w dwu lub wiÄ&#x2122;cej okreĹ&#x203A;lonych, np. kraĹ&#x201E;cowych punktach zakresu badanej charakterystyki. TakÄ&#x2026; kontrolÄ&#x2122; przetwornika moĹźna przeprowadziÄ&#x2021; in situ podczas pracy w rzeczywistych warunkach uĹźytkowania. OmĂłwiono dwie metody estymacji wartoĹ&#x203A;ci i niepewnoĹ&#x203A;ci dla dwu punktĂłw funkcji opisujÄ&#x2026;cej tÄ&#x2122; charakterystykÄ&#x2122;. Metoda I â&#x20AC;&#x201C; deterministyczna â&#x20AC;&#x201C; sĹ&#x201A;uĹźy do wyznaczania niepewnoĹ&#x203A;ci uB1, uB2 z wartoĹ&#x203A;ci dopuszczalnego bĹ&#x201A;Ä&#x2122;du maksymalnego podanego przez producenta lub otrzymanego w wyniku wiarygodnej kalibracji. MetodÄ&#x2026; II â&#x20AC;&#x201C; statystycznÄ&#x2026; â&#x20AC;&#x201C; z rozrzutu wartoĹ&#x203A;ci x1, x2 powtarzanych pomiarĂłw w obu punktach kontrolnych szacuje siÄ&#x2122; niepewnoĹ&#x203A;ci skĹ&#x201A;adowe uA1, uA2. Z nich, dla dowolnych wartoĹ&#x203A;ci xci badanej charakterystyki, ktĂłrych nie mierzy siÄ&#x2122; bezpoĹ&#x203A;rednio, znajduje siÄ&#x2122; oszacowania odchyleĹ&#x201E; standardowych unc niepewnoĹ&#x203A;ci bezwzglÄ&#x2122;dnych i wzglÄ&#x2122;dnych di (uxi â&#x20AC;&#x201C; ux0)/xi. SÄ&#x2026; one funkcjÄ&#x2026; wzglÄ&#x2122;dnego poĹ&#x201A;oĹźenia kc punktu xci w przedziale miÄ&#x2122;dzy punktami kontrolnymi. MoĹźna teĹź wyznaczyÄ&#x2021; zakres zmiennej x o zadanych granicznych wartoĹ&#x203A;ciach niepewnoĹ&#x203A;ci oraz niepewnoĹ&#x203A;ci punktĂłw yi wielkoĹ&#x203A;ci zaleĹźnych od x wg funkcji opisujÄ&#x2026;cej charakterystykÄ&#x2122; y = f(x) przetwornika lub badanego urzÄ&#x2026;dzenia [3â&#x20AC;&#x201C;6]. RozwaĹźania uogĂłlnia siÄ&#x2122; przez normalizacjÄ&#x2122; niepewnoĹ&#x203A;ci unc, tj. odniesieniu ich do niepewnoĹ&#x203A;ci ux2 (rys. 1), do szerokoĹ&#x203A;ci przedziaĹ&#x201A;u miÄ&#x2122;dzy punktami kontrolnymi x2 â&#x20AC;&#x201C; x1, do zakresu pomiarowego xmax â&#x20AC;&#x201C; x0 lub do wartoĹ&#x203A;ci xmax. Do wyznaczenia relacji miÄ&#x2122;dzy niepewnoĹ&#x203A;ciami w punkcie estymowanym oraz jednym z punktĂłw kontrolnych, lub miÄ&#x2122;dzy dwoma punktami estymowanymi, autorzy zastosowali macierzowe prawo propagacji wariancji w pomiarach poĹ&#x203A;rednich wieloparametrowych [3â&#x20AC;&#x201C;6]. Macierze kowariancji UX i UY wieloparametrowych menzurandĂłw, tj. mierzonego bezpoĹ&#x203A;rednio, czyli wejĹ&#x203A;ciowego X i wyznaczanego poĹ&#x203A;rednio menzurandu wyjĹ&#x203A;ciowego Y = F(X), powiÄ&#x2026;zane sÄ&#x2026; wynikajÄ&#x2026;cym z prawa propagacji wariancji ogĂłlnym rĂłwnaniem macierzowym (1a) o postaci rozwiniÄ&#x2122;tej (1b) dla macierzy skĹ&#x201A;adowych typĂłw A i B:
uy21 = uy21A + uy21B ,
Ď y1,2 =
uy22 = uy22A + uy22B ,
Ď Auy1Auy 2A + Ď Buy1Buy 2B uy21A + uy21B uy22A + uy22B
liniowych.
W praktyce naleĹźy korzystaÄ&#x2021; ze wzoru (1b), tj. osobno szacowaÄ&#x2021; niepewnoĹ&#x203A;ci typu A i B. Wynika to z przyjÄ&#x2122;tej w przewodniku GUM definicji niepewnoĹ&#x203A;ci uA i uB. PierwszÄ&#x2026; z nich wyznacza siÄ&#x2122; dla rzeczywistych odchyleĹ&#x201E; losowych w krĂłtkim czasie zbierania wynikĂłw pomiarĂłw, a druga jest przyjmowana heurystycznie dla odchyleĹ&#x201E; przewidywanych w okresie waĹźnoĹ&#x203A;ci kalibracji uĹźytych przyrzÄ&#x2026;dĂłw. Skorelowane mogÄ&#x2026; byÄ&#x2021; tylko zbiory odchyleĹ&#x201E; menzurandu o niepewnoĹ&#x203A;ciach jednego typu. Pomiary kontrolne wartoĹ&#x203A;ci punktĂłw x1, x2 charakterystyki, np. do celĂłw monitoringu lub diagnostyki, powinno siÄ&#x2122; wykonywaÄ&#x2021; wielokrotnie i synchronicznie w podobnych warunkach, tymi samymi lub podobnymi przyrzÄ&#x2026;dami i na zakresach o jednakowej lub zbliĹźonej dokĹ&#x201A;adnoĹ&#x203A;ci. UmoĹźliwia to wyznaczenie wspĂłĹ&#x201A;czynnika korelacji rA(x1, x2) miÄ&#x2122;dzy zbiorami odchyleĹ&#x201E; w obu punktach kontrolnych. Od wartoĹ&#x203A;ci tego wspĂłĹ&#x201A;czynnika zaleĹźy wartoĹ&#x203A;Ä&#x2021; niepewnoĹ&#x203A;ci typu A estymowanej w punktach xci i korelacja miÄ&#x2122;dzy wartoĹ&#x203A;ciami xci dwu dowolnych punktĂłw charakterystyki. JeĹ&#x203A;li te warunki nie sÄ&#x2026; speĹ&#x201A;nione, to dla bezpieczeĹ&#x201E;stwa naleĹźy zaĹ&#x201A;oĹźyÄ&#x2021;, Ĺźe ich niepewnoĹ&#x203A;ci nie sÄ&#x2026; skorelowane i przyjmuje siÄ&#x2122; wspĂłĹ&#x201A;czynnik korelacji r1,2 = 0. Przy wyznaczaniu wartoĹ&#x203A;ci niepewnoĹ&#x203A;ci uB sĹ&#x201A;uĹźÄ&#x2026;cej do oceny niepewnoĹ&#x203A;ci zĹ&#x201A;oĹźonej u podczas dalszych badaĹ&#x201E; obiektu z uĹźyciem tego samego przyrzÄ&#x2026;du, naleĹźy uwzglÄ&#x2122;dniÄ&#x2021; jego niepewnoĹ&#x203A;Ä&#x2021; typu B oraz wspĂłĹ&#x201A;czynnik korelacji 1. MetodÄ&#x2026; II â&#x20AC;&#x201C; statystycznÄ&#x2026; â&#x20AC;&#x201C; z rozrzutĂłw wynikĂłw pomiarĂłw wartoĹ&#x203A;ci punktĂłw kontrolnych szacuje siÄ&#x2122; ich estymatory i odchylenia jako niepewnoĹ&#x203A;ci standardowe typu A o oznaczeniach u1A, u2A. JeĹ&#x203A;li dla niepewnoĹ&#x203A;ci skĹ&#x201A;adowych uA i uB przyjmie siÄ&#x2122; jako przybliĹźenie rozkĹ&#x201A;ady normalne, to wg przewodnika GUM niepewnoĹ&#x203A;ci zĹ&#x201A;oĹźone i rozszerzone wyznacza siÄ&#x2122; metodÄ&#x2026; klasycznÄ&#x2026;. Dla prĂłbek z innych rozkĹ&#x201A;adĂłw i rozkĹ&#x201A;adu rĂłwnomiernego bĹ&#x201A;Ä&#x2122;du stosuje siÄ&#x2122; metodÄ&#x2026; Monte Carlo wg Suplementu 1 do przewodnika GUM [1].
Jako przykĹ&#x201A;ad podano poniĹźej macierz kowariancji Ux menzurandu dwuelementowego (2D) X = [x1, x2]T o wspĂłĹ&#x201A;czynniku korelacji rx1,2 i jej macierze skĹ&#x201A;adowe typĂłw A i B, tj.: UXA, UXB.
V1 *
#
*
UY = SUXST
(1a)
UY = UYA + UYB = SUXAST + SUXBST
(1b)
gdzie: S = â&#x2C6;&#x201A;y j â&#x2C6;&#x201A;x i
â&#x2C6;&#x201A;F â&#x20AC;&#x201C; macierz czuĹ&#x201A;oĹ&#x203A;ci (jakobian) o elementach â&#x2C6;&#x201A;X
tak samo wyznaczanych dla funkcji liniowych, jak i nie-
V1^1 9 q 3 NiepewnoĹ&#x203A;Ä&#x2021; typu A, wyznacza siÄ&#x2122; z serii wielokrotnych pomiarĂłw w danym punkcie pomiarowym. Zwykle przyjmuje siÄ&#x2122;, Ĺźe rozkĹ&#x201A;ad odchyleĹ&#x201E; wielkoĹ&#x203A;ci mierzonej ma rozkĹ&#x201A;ad gaussowski. NiepewnoĹ&#x203A;Ä&#x2021; estymowana w punkcie znormalizowana wzglÄ&#x2122;dem koĹ&#x201E;cowego punktu kontrolnego dla skorelowanych odchyleĹ&#x201E; (bĹ&#x201A;Ä&#x2122;dĂłw) od estymatorĂłw wartoĹ&#x203A;ci mierzonych w dwu punktach kontrolnych ma, wg [5], nastÄ&#x2122;pujÄ&#x2026;cÄ&#x2026; postaÄ&#x2021;
(1c)
76
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
! : " < ; # <
()
unA k =
( )=
uA k uA 2
Îľ A2 (1 â&#x2C6;&#x2019; k ) + k 2 + 2 Ď AÎľ A (1 â&#x2C6;&#x2019; k ) k 2
()
()
()
()
()
2 2 uC2 k = uA2 k + uB2 k = unA k uA2 2 + unB k uB2 2
(2)
gdzie: uA(k), unA â&#x20AC;&#x201C; niepewnoĹ&#x203A;Ä&#x2021; typu A i jej wartoĹ&#x203A;Ä&#x2021; znormalizowana do uA2; uA1, uA2 â&#x20AC;&#x201C; niepewnoĹ&#x203A;ci typu A w poczÄ&#x2026;tkowym i koĹ&#x201E;cowym punkcie kontrolnym; eA = uA1/uA2; rA â&#x20AC;&#x201C; wspĂłĹ&#x201A;czynnik korelacji miÄ&#x2122;dzy danymi pomiarowymi w punktach kontrolnych x1, x2; k â&#x20AC;&#x201C; wzglÄ&#x2122;dna pozycja punktu xc w przedziale miÄ&#x2122;dzy punktami kontrolnymi 0 k 1 o estymowanej niepewnoĹ&#x203A;ci uA.
Po oznaczeniu stosunku niepewnoĹ&#x203A;ci typu A i B w punkcie koĹ&#x201E;cowym przez r = uA2/uB2, otrzymuje siÄ&#x2122; wzĂłr dla niepewnoĹ&#x203A;ci uc znormalizowanej do jej wartoĹ&#x203A;ci w punkcie koĹ&#x201E;cowym:
(5)
V1S1 9 q & NiepewnoĹ&#x203A;Ä&#x2021; typu B ma z zaĹ&#x201A;oĹźenia odmienny charakter statystyczny niĹź typu A. Wyznacza siÄ&#x2122; jÄ&#x2026; heurystycznie na podstawie dopuszczalnego bĹ&#x201A;Ä&#x2122;du maksymalnego uĹźytych przyrzÄ&#x2026;dĂłw i wiedzy uzyskanej o warunkach pomiarĂłw i ich oddziaĹ&#x201A;ywaĹ&#x201E; przewidywanych w dĹ&#x201A;ugim okresie uĹźytkowania przyrzÄ&#x2026;du w danym eksperymencie pomiarowym, nie dĹ&#x201A;uĹźszym jednak niĹź waĹźnoĹ&#x203A;Ä&#x2021; jego kalibracji. Przyjmuje siÄ&#x2122; zwykle, Ĺźe rozkĹ&#x201A;ad statystyczny przewidywanych bĹ&#x201A;Ä&#x2122;dĂłw opisanych niepewnoĹ&#x203A;ciÄ&#x2026; typu B ma rozkĹ&#x201A;ad prostokÄ&#x2026;tny (jednostajny). PrzykĹ&#x201A;adowo dla typowego miernika uniwersalnego niepewnoĹ&#x203A;Ä&#x2021; ta jest opisana liniowÄ&#x2026; charakterystykÄ&#x2026; wyznaczonÄ&#x2026; przez dwa parametry: skĹ&#x201A;adnik addytywny i multiplikatywny. Jej znormalizowanÄ&#x2026; formuĹ&#x201A;Ä&#x2122; moĹźna przedstawiÄ&#x2021; w postaci:
()
unB k =
( )=
uB k uB 2
(
)
2
(
)
â&#x17D;ĄÎľ B 1 â&#x2C6;&#x2019; k + k â&#x17D;¤ = 1 â&#x2C6;&#x2019; Îľ B k + Îľ B â&#x17D;Ł â&#x17D;Ś
(4)
(3)
gdzie: uB(k) â&#x20AC;&#x201C; interpolowana niepewnoĹ&#x203A;Ä&#x2021; typu B, eB = uB1/uB2, uB1, uB2 â&#x20AC;&#x201C; niepewnoĹ&#x203A;ci typu B w punktach pomiarowych. FormuĹ&#x201A;Ä&#x2122; (3) otrzymuje siÄ&#x2122; z (2) przy zaĹ&#x201A;oĹźeniu peĹ&#x201A;nej korelacji, tj. rB = 1. Przebiegi znormalizowanych niepewnoĹ&#x203A;ci standardowych typu A (metoda II) i typu B (Metoda I) podano na rys. 1.
V1V1 9 q Do wyznaczenia caĹ&#x201A;kowitej niepewnoĹ&#x203A;ci stosuje siÄ&#x2122; ogĂłlnie przyjÄ&#x2122;tÄ&#x2026; zasadÄ&#x2122; splotu nieskorelowanych wielkoĹ&#x203A;ci typu A i typu B. Dla punktu xc otrzymuje siÄ&#x2122; niepewnoĹ&#x203A;Ä&#x2021; zĹ&#x201A;oĹźonÄ&#x2026; geometrycznie jako:
lub po uproszczeniu:
(6) WariancjÄ&#x2122; jako kwadrat znormalizowanej niepewnoĹ&#x203A;ci w funkcji r opisuje parabola o ramionach skierowanych w gĂłrÄ&#x2122;, gdyĹź wspĂłĹ&#x201A;czynnik przy skĹ&#x201A;adniku kwadratowym, niezaleĹźnie od wspĂłĹ&#x201A;czynnika korelacji rA, jest nieujemny. WspĂłĹ&#x201A;czynnik rĂłwna siÄ&#x2122; zeru, gdy eB = 1 oraz r = 0 lub Ď A =
1 + Îľ A2 . 2Îľ A
Na rysunkach 2aâ&#x20AC;&#x201C;f podano znormalizowane charakterystyki niepewnoĹ&#x203A;ci zĹ&#x201A;oĹźonej (5) dla róşnych parametrĂłw r, eA, eB, i rA. uB 2 1 u r oraz A 2 = stanowiÄ&#x2026;ce = 2 uC 2 uC 2 1+r 1+ r2 udziaĹ&#x201A;y niepewnoĹ&#x203A;ci odpowiednio typu B i typu A w estymowanej niepewnoĹ&#x203A;ci zĹ&#x201A;oĹźonej. Dla krzywych na rysunkach 2aâ&#x20AC;&#x201C;f przyjÄ&#x2122;to parametry r odpowiadajÄ&#x2026;ce udziaĹ&#x201A;om niepewnoĹ&#x203A;ci typu A i B w niepewnoĹ&#x203A;ci caĹ&#x201A;kowitej, tj.: linia zielona r = 3,33, uA2/uC2 = 96%, uB2/uC2 = 29%; linia czerwona r = 1, uA2/uC2 = uB2/uC2 = 71%; linia niebieska r = 0,3, uA2/uC2 = 29%, uB2/uC2 = 96%. Z rysunkĂłw 2 wynika, Ĺźe wzrost udziaĹ&#x201A;u niepewnoĹ&#x203A;ci typu A (linia zielona ) powoduje zwiÄ&#x2122;kszenie caĹ&#x201A;kowitej niepewno-
SÄ&#x2026; to wyraĹźenia
Rys. 1. Znormalizowane niepewnoĹ&#x203A;ci bezwzglÄ&#x2122;dne jako funkcje unc = f(k) wzglÄ&#x2122;dnego poĹ&#x201A;oĹźenia k dla ilorazu niepewnoĹ&#x203A;ci Îľ = 2/3; Îľ = 1 oraz wspĂłĹ&#x201A;czynnika korelacji Ď 1,2 = 1; Ď 1,2 = 0 punktĂłw kontrolnych (metody: I i II) [7] Fig. 1. Normalized absolute uncertainty as a function of unc = f(k) of the relative position k for the quotient of uncertainties Îľ = 2/3; Îľ = 1 and a correlation coefficient Ď 1,2 = 1 and Ď 1,2 = 0 (methods: I and II) of control points data [7]
77
@ !: & _ & J < ! ! J < & : J ! <
a)
b)
c)
d)
e)
f)
Rys. 2. Znormalizowana standardowa niepewność złożona un w funkcji względnego położenia k punktu xc dla różnych wartości parametru r – udziału niepewności składowych typu A, B w niepewności un dla: εA = εB = 1 i a) ρA = 0; b) ρA = 0,5; dla εA = εB= 0,5 i c) ρA = 0; d) ρA = –0,5; oraz dla e) εA = 0,1; εB = 0,8; ρA = 0; i f) εA = 0,2; εB = 0,1; ρA = –1 Fig. 2. Normalized combined standard uncertainty un as a function of relative location parameter k of point xc for various values of parameter r – share of component uncertainties types A, B in uncertainty un for: εA = εB = 1 and a) ρA = 0; b) ρA = 0,5; for εA = εB= 0,5 and c) ρA = 0; d) ρA = –0,5; and e) εA = 0,1; εB = 0,8; ρA = 0; f) εA = 0,2; εB = 0,1; ρA = –1
ści w interpolowanym przedziale w porównaniu do sytuacji, gdy dominuje udział niepewności typu B. Tylko na wykresie (rys. 2f) dla współczynnika korelacji 1, w niedużym początkowym przedziale interpolacji, jest na odwrót, tj. dominacja niepewności B powoduje zwiększenie niepewności całkowitej. Przy współczynnikach korelacji między obserwacjami w punktach kontrolnych k = 0, k = 1 w przebiegach interpolowanej niepewności typu
78
P
O
M
I
A
R
Y
•
A
U
T
O
M
A występuje minimum. Natomiast przy braku korelacji przebieg zbliża się do liniowego. Trójwymiarową zależność niepewności znormalizowanej (6) w funkcji parametru położenia k i współczynnika korelacji rA dla wybranych parametrów eA = eB dla różnych wartości parametru r przedstawia rysunek 3. W przypadku pełnej korelacji dla odchyleń o niepewności typu A, tj. rA = 1, niezależnie od jej udziału r w niepewności A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
! : " < ; # <
Rys. 3. ZaleĹźnoĹ&#x203A;ci znormalizowanej niepewnoĹ&#x203A;ci un w funkcji 0 â&#x2030;¤ k â&#x2030;¤ 1 poĹ&#x201A;oĹźenia w kontrolowanym przedziale i dla peĹ&#x201A;nego zakresu wspĂłĹ&#x201A;czynnikĂłw korelacji â&#x20AC;&#x201C;1 â&#x2030;¤ Ď A â&#x2030;¤ 1 dla niepewnoĹ&#x203A;ci typu A przy róşnych udziaĹ&#x201A;ach niepewnoĹ&#x203A;ci skĹ&#x201A;adowych typu A i B w un , tj. r = 0,3; 1; 3,33 i wartoĹ&#x203A;ciach stosunkĂłw niepewnoĹ&#x203A;ci punktĂłw pomiarowych ÎľA = ÎľB = 0,5 Fig. 3. Relationships of normalized uncertainty un in function 0 â&#x2030;¤ k â&#x2030;¤ 1 of place in the estimated range and for a full range of correlation coefficients â&#x20AC;&#x201C;1 â&#x2030;¤ Ď A â&#x2030;¤ 1 for type A uncertainty with different participation of A and B uncertainty components in un, i.e. r = 0.3; 1; 3.33, and parameter values ÎľA = ÎľB = 0.5
zĹ&#x201A;oĹźonej, zaleĹźnoĹ&#x203A;Ä&#x2021; niepewnoĹ&#x203A;ci w funkcji k ma charakter liniowy. W miarÄ&#x2122; zmniejszania siÄ&#x2122; wspĂłĹ&#x201A;czynnika korelacji rA zaznaczajÄ&#x2026; siÄ&#x2122; róşnice w stosunku do nadal liniowego charakteru przy dominacji niepewnoĹ&#x203A;ci typu B (r = 0,3). Zmniejszenie niepewnoĹ&#x203A;ci nastÄ&#x2122;puje ze zwiÄ&#x2122;kszeniem udziaĹ&#x201A;u niepewnoĹ&#x203A;ci typu A dla r = 1; 3,33 (rys. 3) â&#x20AC;&#x201C; powierzchnie niebieska i purpurowa, przy czym minima niepewnoĹ&#x203A;ci sytuujÄ&#x2026; siÄ&#x2122; dla wartoĹ&#x203A;ci k mniejszych od 0,5 w pobliĹźu centrum przedziaĹ&#x201A;u interpolacji. Najmniejsze wartoĹ&#x203A;ci uzyskuje siÄ&#x2122; dla rA = â&#x20AC;&#x201C;1 i caĹ&#x201A;kowitej dominacji niepewnoĹ&#x203A;ci typu A.
X1 ; MiarÄ&#x2026; dokĹ&#x201A;adnoĹ&#x203A;ci wg Przewodnika GUM jest niepewnoĹ&#x203A;Ä&#x2021; rozszerzona wyznaczajÄ&#x2026;ca przedziaĹ&#x201A;, w ktĂłrym moĹźe znaleĹşÄ&#x2021; siÄ&#x2122; estymator wartoĹ&#x203A;ci mierzonej z okreĹ&#x203A;lonym prawdopodobieĹ&#x201E;stwem p. Do jej oszacowania niezbÄ&#x2122;dna jest znajomoĹ&#x203A;Ä&#x2021; wspĂłĹ&#x201A;czynnika rozszerzenia kp jako mnoĹźnika zĹ&#x201A;oĹźonej niepewnoĹ&#x203A;ci standardowej. ZaleĹźy on od rodzaju rozkĹ&#x201A;adu i licznoĹ&#x203A;ci prĂłbki i jest wyznaczany analitycznie dla rozkĹ&#x201A;adu Gaussa, Studenta i kilku innych, np. prostokÄ&#x2026;tnego i trapezowego [2]. W pozostaĹ&#x201A;ych typach rozkĹ&#x201A;adĂłw, splotach i sumach rozkĹ&#x201A;adĂłw stosuje siÄ&#x2122; rozwiÄ&#x2026;zania caĹ&#x201A;kowania numerycznego czy teĹź metody Monte Carlo bazujÄ&#x2026;ce na generatorach prĂłb pseudolosowych. Dla przedziaĹ&#x201A;u interpolowanego znormalizowana niepewnoĹ&#x203A;Ä&#x2021; rozszerzona wynosi: Un(k) = kp(k)¡un(k)
(7)
Metoda propagacji niepewnoĹ&#x203A;ci pozwala wyĹ&#x201A;Ä&#x2026;cznie na oszacowanie niepewnoĹ&#x203A;ci standardowych dla rozkĹ&#x201A;adĂłw wielkoĹ&#x203A;ci wyjĹ&#x203A;ciowych (w tym tekĹ&#x203A;cie omawia siÄ&#x2122; funkcjÄ&#x2122; liniowÄ&#x2026; i tego typu bĹ&#x201A;Ä&#x2122;dy nie wystÄ&#x2122;pujÄ&#x2026;). Wskutek linearyzacji funkcji pomiaru dla wiÄ&#x2122;kszych niepewnoĹ&#x203A;ci wielkoĹ&#x203A;ci mierzonych pojawiajÄ&#x2026; siÄ&#x2122; dodatkowe bĹ&#x201A;Ä&#x2122;dy wielkoĹ&#x203A;ci wyjĹ&#x203A;ciowych. W tej metodzie jest wyznaczany numerycznie przedziaĹ&#x201A; rozszerzenia. Do interpolacji zmiennej losowej wewnÄ&#x2026;trz przedziaĹ&#x201A;u wykorzystano sumÄ&#x2122; waĹźonÄ&#x2026; dwĂłch zmiennych losowych: w punkcie poczÄ&#x2026;tkowym i koĹ&#x201E;cowym. Zmienne te stanowiÄ&#x2026; sploty dwĂłch rozkĹ&#x201A;adĂłw:
Gaussa dla niepewnoĹ&#x203A;ci typu A i jednostajnego dla niepewnoĹ&#x203A;ci typu B. Rozszerzony obszar pokrycia, odchylenie standardowe oraz wspĂłĹ&#x201A;czynnik rozszerzenia dla prawdopodobieĹ&#x201E;stwa p = 95% rozkĹ&#x201A;adu wypadkowego wyznaczono metodÄ&#x2026; Monte Carlo w Ĺ&#x203A;rodowisku programistycznym MATLAB. WykreĹ&#x203A;lono charakterystyki zaleĹźnoĹ&#x203A;ci wspĂłĹ&#x201A;czynnika rozszerzenia kp dla niepewnoĹ&#x203A;ci rozszerzonej w funkcji parametru poĹ&#x201A;oĹźenia k w przedziale interpolowanym dla róşnych stosunkĂłw niepewnoĹ&#x203A;ci eA, eB udziaĹ&#x201A;Ăłw niepewnoĹ&#x203A;ci typu A/B zawartych w parametrze r i dla kilku wspĂłĹ&#x201A;czynnikĂłw korelacji rA. PrzyjÄ&#x2122;to uproszczenie zerowych wartoĹ&#x203A;ci oczekiwanych zastosowanych rozkĹ&#x201A;adĂłw. KorelacjÄ&#x2122; dla rozkĹ&#x201A;adĂłw Gaussa otrzymano przez zastosowanie dwĂłch nieskorelowanych zmiennych losowych XA1 i X o rozkĹ&#x201A;adzie Gaussa i o zerowych wartoĹ&#x203A;ciach oczekiwanych oraz odchyleniach standardowych odpowiednio eAuA2 oraz uA 2 1 â&#x2C6;&#x2019; Ď A2
(
1 â&#x2C6;&#x2019; Ď A Îľ A
)
2
.
(
)
2
Za pomocÄ&#x2026; XA1 i X A 2 = Ď AX A1 Îľ A + 1 â&#x2C6;&#x2019; Ď A Îľ A X opisane sÄ&#x2026; zmienne losowe dla punktĂłw skrajnych przedziaĹ&#x201A;u interpolacji niepewnoĹ&#x203A;ci typu A. Ich odchylenia standardowe wynoszÄ&#x2026; odpowiednio eAuA2 i uA2. SÄ&#x2026; one skorelowane ze wspĂłĹ&#x201A;czynnikiem korelacji rA, a zmienna interpolowana dla typu A ma postaÄ&#x2021;: XA = (1 â&#x20AC;&#x201C; k)XA1 + kXA2
(8)
Zmienna losowa XB dla typu B jest sumÄ&#x2026; dwĂłch caĹ&#x201A;kowicie skorelowanych zmiennych o róşnych odchyleniach standardowych, tj.: XB = (1 â&#x20AC;&#x201C; k)XB1 + kXB2 (9) Ich wartoĹ&#x203A;ci oczekiwane sÄ&#x2026; rĂłwne zeru, a odchylenia standardowe wynoszÄ&#x2026; eBuB2 oraz uB2. Wypadkowa zmienna losowa X w przedziale interpolacji wyraĹźa siÄ&#x2122; wzorem: X = XA + XB = (1 â&#x20AC;&#x201C; k)(XA1 + XB1) + k(XA2 + XB2)
(10)
79
@ !: & _ & J < ! ! J < & : J ! <
Po normalizacji do niepewności końcowego punktu przedziału interpolacji otrzymuje się:
Xn =
(1 − k )( X
A1
)
(
+ X B1 + k X A 2 + X B 2 u
2 A2
+u
)
wia, że współczynnik rozszerzenia jest najmniejszy w środku przedziału i dla zerowej korelacji niepewności A, czyli dla rA = 0, znajduje się dla k = 0,45; kp = 1,69. Przemieszcza się on do środka dla rA = 0,5 i kp = 1,72, przy czym wartości jego rosną w kierunku końców przedziału do kp = 1,73–1,74. Dla rozkładu o dominacji niepewności typu A, tj. rozkładu Gaussa, otrzymano współczynnik równy około 1,96. Na rysunku 5 porównano korytarze niepewności dla liniowej charakterystyki przetwornika. Korytarz hiperboliczny wyznaczono metodą regresji dla jednakowej niepewności 10 punktów, a korytarz paraboliczny – wg metody dwupunktowej. Metoda ta służy głównie do estymacji niepewności typu A i jej zmian w warunkach pracy przetwornika. Natomiast charakterystykę znamionową tego przetwornika wyznacza się metodą wielopunktową w procesie kalibracji w warunkach laboratoryjnych.
(11)
2 B2
Współczynnik rozszerzenia kp dla wartości xc o położeniu k i p = 95% podano na rysunku 4. Współczynnik ten wyznacza się ze średniej arytmetycznej sumy wartości granicznych o pokryciu 2,5% i 97,5%, znormalizowanej do odchylenia standardowego rozkładu wypadkowego. Skorzystano ze standardowych funkcji prctile() i std() środowiska MATLAB. Z rysunku 4 wynika, że znormalizowana niepewność wypadkowa Xn osiąga minimum około k = 0,35 dla kp = 1,87, a na krańcach interpolowanego przedziału wzrasta do kp = 1,91. Dominacja niepewności typu B o rozkładzie prostokątnym, spra-
Rys. 4. Zależność współczynnika rozszerzenia kp estymowanej niepewności rozszerzonej w funkcji parametru k dla stopnia pokrycia 95% i różnych wartości r, εA , εB , ρA Fig. 4. Dependence of the expansion coefficient kp of the estimated expanded uncertainty as a function of the parameter k for a coverage degree of 95% and various values of r, εA , εB , ρA
Rys 5. Ilustracja charakterystyki liniowej wyznaczonej metodą regresji z hiperbolicznym korytarzem niepewności i metodą dwupunktową z korytarzem parabolicznym Fig. 5. Illustration of the linear characteristic determined by the regression method with a hyperbolic corridor of uncertainty and a two-point method with a parabolic corridor
80
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
! : " < ; # <
Y1
W pracy zaprezentowano metodÄ&#x2122; estymacji niepewnoĹ&#x203A;ci zĹ&#x201A;oĹźonej i rozszerzonej dla punktĂłw funkcji opisujÄ&#x2026;cej charakterystykÄ&#x2122; przetwornika pomiarowego lub badanego urzÄ&#x2026;dzenia w rzeczywistych warunkach jego pracy. Metoda bazuje na pomiarach kontrolnych w dwĂłch punktach tej charakterystyki. Z wynikĂłw pomiarĂłw wyznacza siÄ&#x2122; niepewnoĹ&#x203A;ci typu A. Natomiast niepewnoĹ&#x203A;ci typu B szacowane sÄ&#x2026; heurystycznie z danych technicznych stosowanej aparatury oraz jej warunkĂłw pracy i warunkĂłw badanego obiektu. NiepewnoĹ&#x203A;Ä&#x2021; typu A estymuje siÄ&#x2122; dla wybranego punktu funkcji jako waĹźonÄ&#x2026; sumÄ&#x2122; zmiennych losowych opisujÄ&#x2026;cych wyniki obu pomiarĂłw kontrolnych, zaleĹźnÄ&#x2026; od wzglÄ&#x2122;dnego poĹ&#x201A;oĹźenia w przedziale interpolacyjnym. NiepewnoĹ&#x203A;Ä&#x2021; typu B przyrzÄ&#x2026;du lub przetwornika zaleĹźy liniowo od mierzonej wielkoĹ&#x203A;ci i opisuje odchylenie standardowe spodziewanego zbioru odchyleĹ&#x201E; od jej estymaty w okresie waĹźnoĹ&#x203A;ci kalibracji aparatury i w okreĹ&#x203A;lonych warunkach pomiaru. JeĹ&#x203A;li pomiary w obu kontrolowanych punktach wykonuje siÄ&#x2122; tÄ&#x2026; samÄ&#x2026; aparaturÄ&#x2026;, to moĹźna traktowaÄ&#x2021;, Ĺźe wskazania sÄ&#x2026; w peĹ&#x201A;ni skorelowane. W pracy wyznaczono znormalizowanÄ&#x2026; niepewnoĹ&#x203A;Ä&#x2021; zĹ&#x201A;oĹźonÄ&#x2026; i rozszerzonÄ&#x2026; mierzonego poĹ&#x203A;rednio menzurandu wyjĹ&#x203A;ciowego metodÄ&#x2026; propagacji niepewnoĹ&#x203A;ci skĹ&#x201A;adowych. WspĂłĹ&#x201A;czynnik rozszerzenia zĹ&#x201A;oĹźonej niepewnoĹ&#x203A;ci pomiaru wyznaczono dla niepewnoĹ&#x203A;ci typu A metodÄ&#x2026; propagacji rozkĹ&#x201A;adu Gaussa, zaĹ&#x203A; dla niepewnoĹ&#x203A;ci typu B z propagacji rozkĹ&#x201A;adu jednostajnego. Zanalizowano zaleĹźnoĹ&#x203A;ci wspĂłĹ&#x201A;czynnika rozszerzenia od przyjÄ&#x2122;tych parametrĂłw, w tym w funkcji poĹ&#x201A;oĹźenia analizowanego punktu w interpolowanym przedziale i w zaleĹźnoĹ&#x203A;ci od udziaĹ&#x201A;Ăłw wariancji (kwadratĂłw niepewnoĹ&#x203A;ci) typu A, B w niepewnoĹ&#x203A;ci caĹ&#x201A;kowitej. W treĹ&#x203A;ci pracy sformuĹ&#x201A;owano wnioski szczegĂłĹ&#x201A;owe wynikajÄ&#x2026;ce z analizy zaleĹźnoĹ&#x203A;ci zaprezentowanych na wykresach. PrzedstawionÄ&#x2026; metodÄ&#x2122; moĹźna wykorzystaÄ&#x2021; m.in. do: â&#x2C6;&#x2019; kontroli niepewnoĹ&#x203A;ci aparatury in situ, pracujÄ&#x2026;cej w róşnych rzeczywistych warunkach otoczenia, zarĂłwno w przemyĹ&#x203A;le, jak i w innych dziedzinach,
â&#x2C6;&#x2019; monitoringu i statystycznego sterowania jakoĹ&#x203A;ciÄ&#x2026; procesĂłw wytwĂłrczych i innych, â&#x2C6;&#x2019; szybkiego wyrywkowego sprawdzania wiarygodnoĹ&#x203A;ci stanowisk i systemĂłw pomiarowych stosowanych w badaniach naukowych i technicznych w przemyĹ&#x203A;le, medycynie, badaniach Ĺ&#x203A;rodowiska i w technice wojskowej.
& L 0 1. JCGM100:2008, Evaluation of measurement data -Guide to the expression of uncertainty in measurement; +JCGM101:2008 Supplement 1 â&#x20AC;&#x201C; Propagation of distributions using a Monte Carlo method; JCGM102:2011 Supplement 2 â&#x20AC;&#x201C; Extension to any number of output quantities. 2. Warsza Z.L., Metody rozszerzenia analizy niepewnoĹ&#x203A;ci pomiarĂłw. Monografia PIAP 2016, ISBN 978-83-6127831â&#x20AC;&#x201C;3. 3. Warsza Z.L., Puchalski J., Estymacja niepewnoĹ&#x203A;ci charakterystyki z pomiarĂłw w punktach kontrolnych, â&#x20AC;&#x17E;Pomiary Automatyka Robotykaâ&#x20AC;?. R. 22, Nr 4, 2018, 39â&#x20AC;&#x201C;50, DOI: 1014311/PAR_230/39. 4. Warsza Z.L., Puchalski J., Ocena niepewnoĹ&#x203A;ci charakterystyki z dwu pomiarĂłw kontrolnych, â&#x20AC;&#x17E;PrzemysĹ&#x201A; Chemicznyâ&#x20AC;?, T. 98, Nr 6, 2019, 967â&#x20AC;&#x201C;974, DOI: 10.15199/62.2019.6.22. 5. Warsza Z.L., Puchalski J., Ocena niepewnoĹ&#x203A;ci punktĂłw charakterystyki z dwu pomiarĂłw kontrolnych, Zeszyty Naukowe WydziaĹ&#x201A;u Elektrotechniki i Automatyki Politechniki GdaĹ&#x201E;skiej, Nr 66, 2019, 101â&#x20AC;&#x201C;108, DOI: 10.32016/1.66.21. 6. Warsza Z.L., Puchalski J., Idzkowski A., Application of the vector method for estimating characteristic function based on measurements uncertainty at two control points. Proc. of AMSA V 18â&#x20AC;&#x201C;20 Sept. 2019, Novosibirsk NSTU, 60â&#x20AC;&#x201C;73, ISSN 2313-870X (amsa.conf.nstu.ru). 7. Warsza Z.L., Puchalski J., Estimation of the uncertainty in selected points of measured function from two control measurements. Extended abstract and presentation on MATHMET 2019, Lisbon, Portugal, 22. Nov. 2019.
K 6 KE % % 6 @ 6 6 7 " Abstract: The idea of estimation the
uncertainty of function points describing the characteristics on the basis of measurement results at two control points was discussed. The uncertainties type B are estimated as for data with uniform distribution based on the permissible maximum errors of instrument, assuming a correlation coefficient of 1 for the measurements by same instrument and 0 by different. The uncertainties type A are estimated by the statistical method as for data with normal distribution. For synchronous control measurements, a correlation coefficient is also estimated. On this basis, component, complex and extended uncertainties and correlation coefficient are estimated for other points of the function describing the examined characteristic of tested object, using the Monte Carlo method. KeywordsU $ ; % <$ f $ " %
81
@ !: & _ & J < ! ! J < & : J ! <
( ( 3 ! 7 9
( 9
*+ B'( ORCID: 0000-0002-3537-6134
'( ( ORCID: 0000-0002-5055-8550
;/ 0 % K ( @ 0 *+?+$ % > *+BG$ % % *+G! @ L - K *+?=R*+B *++&R*++?$ @ 0 *+B!R*+G!$ @ Z *+G!R*+G= O ( % 0 % 7 . % P$ # ( L # % ; > @ - " ( H % 0 % *+G=R*+=) % ; @ A - @ *+= R*++) Q % " K% J % *++)R*++?$ @ . % *+= R)!!) #/ ( A @ - > ; @ A @-;@ ; % &! / $ B ( 6 $ % / % $ ** A > ) % A @ @ ( 7 " ( ( @ @;. ; % " (
;/ 0 % 8 7 > " O*+=B P 0 % K > O*+== P @ 0 > 0 *+=GR*++? @ 0 $ *++? / % [ T *! / V > ( 6 % [ [ [ @ ( > 6 % " 8 A % > [% U 6 #% )!!B H A > % " % [ ( % > A A % % ( $ / ( A ( % >
82
P
O
M
I
A
R
Y
â&#x20AC;¢
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;¢
R
O
B
O
T
Y
K
A
NR 1 / 20 20
Pomiary Automatyka Robotyka, ISSN 1427-9126, R. 24, Nr 1/2020, 83â&#x20AC;&#x201C;87, DOI: 10.14313/PAR_235/83
@ A % / / ( ! 5 1 ) 9 1 - @ Z $ 0 % " < % " $ 7 [ @ U @ ( G$ )?> *& T
Streszczenie: W artykule przedstawiono trzy wybrane metody pozycjonowania robota mobilnego w terenie oraz ich weryfikacjÄ&#x2122; na torze testowym, zbudowanym na potrzeby zawodĂłw European Rover Challenge 2019. Badania zrealizowano z uĹźyciem Ĺ&#x201A;azika marsjaĹ&#x201E;skiego â&#x20AC;&#x17E;IMPULS IIâ&#x20AC;? zbudowanego przez studentĂłw Politechniki Ĺ&#x161;wiÄ&#x2122;tokrzyskiej. Przeprowadzone badania pozwoliĹ&#x201A;y na porĂłwnanie dokĹ&#x201A;adnoĹ&#x203A;ci pozycjonowania robota mobilnego w terenie. Do analizy oraz wizualizacji badaĹ&#x201E; posĹ&#x201A;uĹźyĹ&#x201A;a aplikacja umoĹźliwiajÄ&#x2026;ca sterowanie oraz Ĺ&#x203A;ledzenie pozycji robota. Dodatkowo zostaĹ&#x201A;y wykonane pomiary odlegĹ&#x201A;oĹ&#x203A;ci Ĺ&#x201A;azika od zadanego punktu. Analiza mapy terenu oraz zastosowane algorytmy pozwalajÄ&#x2026; na dojazd robotem do zadanego punktu. ) U / / $ H@ $ U $ ( $ $ (
1. Wprowadzenie WspĂłĹ&#x201A;czesny rozwĂłj robotyki jest duĹźym wyzwaniem dla konstruktorĂłw i naukowcĂłw ze wzglÄ&#x2122;du na juĹź istniejÄ&#x2026;ce technologie czy wymagania uĹźytkownikĂłw. MoĹźna spotkaÄ&#x2021; wiele urzÄ&#x2026;dzeĹ&#x201E;, ktĂłre realizujÄ&#x2026; Ĺ&#x203A;ciĹ&#x203A;le okreĹ&#x203A;lone zadania, m.in. roboty spawalnicze, sprzÄ&#x2026;tajÄ&#x2026;ce, wojskowe. Obecnie konstruktorzy skupiajÄ&#x2026; siÄ&#x2122; na rozwoju systemĂłw autonomicznych. DziÄ&#x2122;ki nim robot bÄ&#x2122;dzie mĂłgĹ&#x201A; samodzielnie podejmowaÄ&#x2021; decyzje â&#x20AC;&#x201C; na podstawie widoku z kamer oraz informacji pochodzÄ&#x2026;cych z czujnikĂłw. Kierunek rozwoju systemĂłw nawigacyjnych dla robotĂłw mobilnych jest przedmiotem wielu publikacji [1â&#x20AC;&#x201C;3]. Nowoczesne urzÄ&#x2026;dzenie poruszajÄ&#x2026;ce siÄ&#x2122; w trudnym terenie powinno mieÄ&#x2021; wbudowane systemy autonomicznego pozycjonowania, wykrywania elementĂłw, przeszkĂłd czy nawet podejmowania decyzji. Do takich zadaĹ&#x201E; zostaĹ&#x201A; rĂłwnieĹź przygotowany Ĺ&#x201A;azik marsjaĹ&#x201E;ski â&#x20AC;&#x17E;IMPULS IIâ&#x20AC;?. W artykule zostaĹ&#x201A;y przedstawione metody pozwalajÄ&#x2026;ce na pozycjonowanie robota mobilnego w trenie, sÄ&#x2026; to: â&#x2C6;&#x2019; wyznaczanie wspĂłĹ&#x201A;rzÄ&#x2122;dnych robota za pomocÄ&#x2026; odbiornika GPS i cyfrowego kompasu, â&#x2C6;&#x2019; nawigacja inercyjna na podstawie odometrii i czujnikĂłw bezwĹ&#x201A;adnoĹ&#x203A;ciowych (Ĺźyroskop i akcelerometr), â&#x2C6;&#x2019; rozwiniÄ&#x2122;cie nawigacji inercyjnej z wykorzystaniem systemĂłw wizyjnych.
3 + U
T < $ / +B'( 3 % *) ** )!*+ $ % % !? *) )!*+
!
S1 ) L
â&#x20AC;&#x17E;IMPULS IIâ&#x20AC;? Istnieje wiele rozwiÄ&#x2026;zaĹ&#x201E; problemu okreĹ&#x203A;lenia pozycji robota mobilnego w terenie [4]. Jednym z nich jest zastosowanie bezpoĹ&#x203A;rednich odczytĂłw lokalizacji za pomocÄ&#x2026; moduĹ&#x201A;u GPS, a uĹźycie odbiornika dziaĹ&#x201A;ajÄ&#x2026;cego w trybie róşnicowym pozwala zminimalizowaÄ&#x2021; bĹ&#x201A;Ä&#x2122;dy pozycji. Robot mobilny zostaĹ&#x201A; wyposaĹźony w moduĹ&#x201A; GPS pracujÄ&#x2026;cy w trybie róşnicowym, charakteryzujÄ&#x2026;cy siÄ&#x2122; parametrami przedstawionymi w Tabeli 1. Tabela 1. Parametry moduĹ&#x201A;u GPS Table 1. GPS module parameters
DokĹ&#x201A;adnoĹ&#x203A;Ä&#x2021; pozycji poziomej
2,5 m
DokĹ&#x201A;adnoĹ&#x203A;Ä&#x2021; poĹ&#x201A;oĹźenia w pionie
5,0 m
RozdzielczoĹ&#x203A;Ä&#x2021; pozycji
1 mm
DokĹ&#x201A;adnoĹ&#x203A;Ä&#x2021; statyczna
0,3°
DokĹ&#x201A;adnoĹ&#x203A;Ä&#x2021; dynamiczna
0,3°
RozdzielczoĹ&#x203A;Ä&#x2021; kÄ&#x2026;towa
< 0,05°
PowtarzalnoĹ&#x203A;Ä&#x2021; kÄ&#x2026;towa
< 0,1°
Podczas planowania trasy przejazdu robota wymagane jest okreĹ&#x203A;lenie wspĂłĹ&#x201A;rzÄ&#x2122;dnych geograficznych poszczegĂłlnych punktĂłw. JeĹźeli ich wyznaczenie jest wykonane podczas przejazdu trasy przez robota, to bĹ&#x201A;Ä&#x2026;d pozycji jest rĂłwny bĹ&#x201A;Ä&#x2122;dowi odczytĂłw pozycji zastosowanego w nim lokalizatora GPS. JeĹ&#x203A;li natomiast punkty zostaĹ&#x201A;y wyznaczone za pomocÄ&#x2026; innego urzÄ&#x2026;dzenia lokalizacyjnego, bĹ&#x201A;Ä&#x2122;dy odczytĂłw pozycji sumujÄ&#x2026; siÄ&#x2122;, przez co dokĹ&#x201A;adnoĹ&#x203A;Ä&#x2021; pozycjonowania robota w trakcie ruchu po wyznaczonym torze maleje. DuĹźÄ&#x2026; niedogodnoĹ&#x203A;ciÄ&#x2026; metody z uĹźyciem
83
PorĂłwnanie metod pozycjonowania robota mobilnego w terenie
odbiornika GPS jest znaczne pogorszenie lub brak sygnaĹ&#x201A;u z satelitĂłw nadawczych w zamkniÄ&#x2122;tych pomieszczeniach, co skutkuje brakiem moĹźliwoĹ&#x203A;ci wyznaczenia pozycji urzÄ&#x2026;dzenia. KolejnÄ&#x2026; metodÄ&#x2026; pozycjonowania robota w terenie jest system nawigacji inercyjnej oparty na algorytmach przyrostowych. W przypadku robota â&#x20AC;&#x17E;IMPULS IIâ&#x20AC;? jest to fuzja odometrii polegajÄ&#x2026;cej na zliczaniu przez procesor pokonanego dystansu za pomocÄ&#x2026; sygnaĹ&#x201A;Ăłw generowanych przez enkodery inkrementalne bÄ&#x2122;dÄ&#x2026;ce na wyposaĹźeniu zespoĹ&#x201A;u napÄ&#x2122;dowego robota oraz moduĹ&#x201A;u nawigacji inercyjnej. PrzeliczajÄ&#x2026;c zmiany poĹ&#x201A;oĹźenia kÄ&#x2026;towego kĂłĹ&#x201A; okreĹ&#x203A;lone zostaje poĹ&#x201A;oĹźenie, natomiast system inercyjny zwraca orientacjÄ&#x2122; robota w lokalnym ukĹ&#x201A;adzie wspĂłĹ&#x201A;rzÄ&#x2122;dnych. UkĹ&#x201A;ad ten zostaje okreĹ&#x203A;lony wraz ze startem ruchu robota. RozwiÄ&#x2026;zanie to nie wymaga sygnaĹ&#x201A;Ăłw zewnÄ&#x2122;trznych okreĹ&#x203A;lajÄ&#x2026;cych poĹ&#x201A;oĹźenie, lecz wykorzystuje czujniki umieszczone na robocie. Jednak w przypadku uĹ&#x203A;lizgu kĂłĹ&#x201A; algorytm ten dodaje przemieszczenie, ktĂłre nie zostaĹ&#x201A;o zrealizowane przez robota. Metoda ta oparta na caĹ&#x201A;kowaniu powoduje teĹź nieograniczonÄ&#x2026; kumulacjÄ&#x2122; bĹ&#x201A;Ä&#x2122;dĂłw. Znaczny wpĹ&#x201A;yw ma tutaj rĂłwnieĹź bĹ&#x201A;Ä&#x2026;d orientacji robota w ukĹ&#x201A;adzie wspĂłĹ&#x201A;rzÄ&#x2122;dnych. OstatniÄ&#x2026; prezentowanÄ&#x2026; metodÄ&#x2026; pozycjonowania robota mobilnego jest poĹ&#x201A;Ä&#x2026;czenie nawigacji przyrostowej z wykrywaniem za pomocÄ&#x2026; kamer, znacznikĂłw nawigacyjnych w postaci ARTag o znanym poĹ&#x201A;oĹźeniu, ksztaĹ&#x201A;cie i wielkoĹ&#x203A;ci. Zastosowanie systemu wizyjnego pozwala na wprowadzenie poprawki do pozycji wyznaczonej za pomocÄ&#x2026; algorytmu nawigacji inercyjnej, znaczÄ&#x2026;co zwiÄ&#x2122;kszajÄ&#x2026;c precyzjÄ&#x2122; pozycjonowania robota w terenie. Do efektywnych obliczeĹ&#x201E;, wymaganych przy operacjach morfologicznych, zastosowano wydajnÄ&#x2026; jednostkÄ&#x2122; obliczeniowÄ&#x2026; NVIDIA Jetson TX.
dratowej, czarnej ramki i wewnÄ&#x2122;trznej macierzy binarnej, ktĂłra okreĹ&#x203A;la jego identyfikator (id). Czarna ramka uĹ&#x201A;atwia detekcjÄ&#x2122; znacznika ARTag, a binarna kodyfikacja pozwala na jego identyfikacjÄ&#x2122; oraz zastosowanie technik wykrywania i korekcji bĹ&#x201A;Ä&#x2122;dĂłw. Detekcja znacznika polega na wykonaniu nastÄ&#x2122;pujÄ&#x2026;cych operacji na pojedynczym zdjÄ&#x2122;ciu z kamery cyfrowej. Algorytm obejmuje proces: â&#x20AC;&#x201C; progowania adaptacyjnego, â&#x20AC;&#x201C; przeprowadzenia operacji morfologicznych (dylatacji, otwarcia, domkniÄ&#x2122;cia oraz erozji), â&#x20AC;&#x201C; analizy otrzymanego obrazu binarnego. Rozpoznanie markera rozpoczyna siÄ&#x2122; od wykrycia kwadratowych ksztaĹ&#x201A;tĂłw, ktĂłre sÄ&#x2026; zbliĹźone do znacznika ARTag. NastÄ&#x2122;pnie obraz poddany jest progowaniu, segmentacji, operacjom morfologicznym oraz szukaniu konturĂłw. Kontury wklÄ&#x2122;sĹ&#x201A;e lub odbiegajÄ&#x2026;ce ksztaĹ&#x201A;tem od kwadratu sÄ&#x2026; odrzucane. Kolejnym etapem jest filtrowanie (usuwanie zbyt maĹ&#x201A;ych lub zbyt duĹźych konturĂłw, usuwanie konturĂłw zbyt blisko siebie itp.). Po detekcji ksztaĹ&#x201A;tu kandydujÄ&#x2026;cego nastÄ&#x2122;puje sprawdzenie czy wykryty element jest znacznikiem typu ARTag. Realizacja nastÄ&#x2122;puje przez analizÄ&#x2122; wewnÄ&#x2122;trznej kodyfikacji markera. Ten krok rozpoczyna siÄ&#x2122; od wyszukania bitĂłw kaĹźdego znacznika. Jest to moĹźliwe dziÄ&#x2122;ki zastosowaniu transformacji perspektywicznej, ktĂłra pozwala uzyskaÄ&#x2021; marker w jego kanonicznej formie. NastÄ&#x2122;pnie obraz kanoniczny jest progowany do oddzielania biaĹ&#x201A;ych i czarnych bitĂłw. Obraz jest podzielony na komĂłrki zgodnie z wielkoĹ&#x203A;ciÄ&#x2026; znacznika, wielkoĹ&#x203A;ciÄ&#x2026; ramki oraz liczbÄ&#x2026; czarnych lub biaĹ&#x201A;ych pikseli na kaĹźdej komĂłrce, aby ustaliÄ&#x2021; czy jest to bit biaĹ&#x201A;y, czy czarny. Na koniec bity sÄ&#x2026; analizowane w celu ustalenia, czy obiekt pasuje do biblioteki zapisanych znacznikĂłw ARTag.
V1 ) -
#
X1 & #
L
System wizyjny robota â&#x20AC;&#x17E;IMPULS IIâ&#x20AC;? skĹ&#x201A;ada siÄ&#x2122; z gĹ&#x201A;owicy zawierajÄ&#x2026;cej dwie kamery pracujÄ&#x2026;ce w rozdzielczoĹ&#x203A;ci 1080Â px oraz jednostki obliczeniowej NVIDIA Jetson TX. Na podstawie otrzymanego obrazu algorytm zwraca poprawki pozycji robota, a nastÄ&#x2122;pnie za pomocÄ&#x2026; interfejsu komunikacji szeregowej przesyĹ&#x201A;a je do jednostki gĹ&#x201A;Ăłwnej robota. Program realizujÄ&#x2026;cy wyznaczanie pozycji oraz wprowadzanie poprawek, zostaĹ&#x201A; napisany w jÄ&#x2122;zyku C++ z wykorzystaniem autorskich rozwiÄ&#x2026;zaĹ&#x201E; rozpoznawania obrazu wspomaganych bibliotekami OpenCV. Znacznik typu ARTag (rys. 1) jest zĹ&#x201A;oĹźony z kwa-
Rys. 1. PrzykĹ&#x201A;adowy znacznik nawigacyjny umieszczony w punkcie o Ĺ&#x203A;ciĹ&#x203A;le okreĹ&#x203A;lonych wspĂłĹ&#x201A;rzÄ&#x2122;dnych znanych a priori Fig. 1. Example of landmark placed in known specific point
84
P
O
M
I
A
R
Teren, na ktĂłrym zostaĹ&#x201A;y przeprowadzone badania, to tor przygotowany na potrzeby zawodĂłw robotycznych European Rover Challenge 2019, mieszczÄ&#x2026;cy siÄ&#x2122; na terenie Politechniki Ĺ&#x161;wiÄ&#x2122;tokrzyskiej. Dostarczone od organizatorĂłw dane pozwoliĹ&#x201A;y na wyznaczenie mapy (rys. 2), na ktĂłrej zaznaczone zostaĹ&#x201A;y zarĂłwno punkty docelowe (czerwone), jak i miejsca ustawienia znacznikĂłw ARTag (szare). Badanie polegaĹ&#x201A;o na wykonaniu serii przejazdĂłw Ĺ&#x201A;azikiem â&#x20AC;&#x17E;IMPULS IIâ&#x20AC;? po wyznaczonej trasie z wykorzystaniem wcze-
Rys. 2. Mapa terenu zawodĂłw ERC 2019 Fig. 2. ECR 2019 competition terrain map
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
8 : ! & 8 / < $ $ ;$ !
Rys. 3. Pomiar odlegĹ&#x201A;oĹ&#x203A;ci robota od miejsca docelowego Fig. 3. Measuring the distance between the rover and the target point
Ĺ&#x203A;niej opisanych systemĂłw pozycjonowania robota oraz na pomiarze odlegĹ&#x201A;oĹ&#x203A;ci urzÄ&#x2026;dzenia od podanych punktĂłw (rys. 3). Pomiary zostaĹ&#x201A;y wykonane taĹ&#x203A;mÄ&#x2026; mierniczÄ&#x2026; z dokĹ&#x201A;adnoĹ&#x203A;ciÄ&#x2026; do 10 mm. Róşnice pozycji Ĺ&#x201A;azika od punku docelowego wyznaczano od Ĺ&#x203A;rodka geometrycznego Ĺ&#x201A;azika, do Ĺ&#x203A;rodka geometrycznego znacznika umieszczonego na torze. Otrzymane wyniki zostaĹ&#x201A;y zaprezentowanie w Tabeli 2. Rozrzut wynikĂłw, rozumiany jako róşnica miÄ&#x2122;dzy maksymalnÄ&#x2026; a minimalnÄ&#x2026; otrzymanÄ&#x2026; wartoĹ&#x203A;ciÄ&#x2026; pomiaru przedstawiono na rys. 4. PrzedziaĹ&#x201A;y, w jakich zawierajÄ&#x2026; siÄ&#x2122; otrzymane wartoĹ&#x203A;ci, przedstawia rys. 5.
Dla zebranych wynikĂłw zostaĹ&#x201A; wyznaczony Ĺ&#x203A;redni bĹ&#x201A;Ä&#x2026;d kwadratowy â&#x20AC;&#x201C; wzĂłr (1) S =
â&#x2C6;&#x2018; (x
i
â&#x2C6;&#x2019;x
)
2
(1)
n
gdzie: â&#x20AC;&#x201C; wartoĹ&#x203A;Ä&#x2021; Ĺ&#x203A;rednia x dla caĹ&#x201A;ej serii pomiarowej, n â&#x20AC;&#x201C; liczba pomiarĂłw, xi â&#x20AC;&#x201C; wartoĹ&#x203A;Ä&#x2021; i-tego pomiaru. WartoĹ&#x203A;Ä&#x2021; Ĺ&#x203A;redniego bĹ&#x201A;Ä&#x2122;du kwadratowego dokĹ&#x201A;adnoĹ&#x203A;ci dla opisanych metod pozycjonowania robota mobilnego przedstawia rys. 6.
Tabela 2. UĹ&#x203A;rednione wyniki róşnicy poĹ&#x201A;oĹźenia robota od punktu docelowego [m] Table 2. Average distance between the rover and the target point [m]
Punkt 1
Punkt 2
Punkt 3
Ĺ&#x161;rednia
Pozycjonowanie GPS
0,28
0,21
0,48
0,32
Nawigacja inercyjna
1,09
1,21
2,09
1,46
Nawigacja inercyjna + ARTag
0,36
0,53
0,47
0,46
Rys. 4. Rozrzut wynikĂłw pomiarĂłw Fig. 4. Standard deviation of measurments data
85
PorĂłwnanie metod pozycjonowania robota mobilnego w terenie
Rys. 5. PrzedziaĹ&#x201A;y, w ktĂłrych mieszczÄ&#x2026; siÄ&#x2122; dane pomiarowe dla poszczegĂłlnych punktĂłw Fig. 5. Specific points measurement data in characteristic range
standardowe [m]
1,00
0,89
0,90 0,80 0,70 0,60
ATRAGS
0,50
GPS
0,40
IMU
0,30
0,30
0,20
0,20 0,10 0,00
Rys. 6. Ĺ&#x161;redni bĹ&#x201A;Ä&#x2026;d kwadratowy Fig. 6. Mean Squared Error
5. Wnioski
& L 0
Na podstawie analizy otrzymanych wynikĂłw moĹźna stwierdziÄ&#x2021;, Ĺźe najmniejszy bĹ&#x201A;Ä&#x2026;d pozycji robota zostaĹ&#x201A; uzyskany podczas przejazdu trasy z uĹźyciem odczytu z róşnicowego odbiornika GPS. Natomiast najwiÄ&#x2122;kszy bĹ&#x201A;Ä&#x2026;d zostaĹ&#x201A; uzyskany przy wykorzystaniu nawigacji inercyjnej. Poprawki otrzymywane na podstawie znacznikĂłw ARTag znaczÄ&#x2026;co redukujÄ&#x2026; odchyĹ&#x201A;kÄ&#x2122; pomiaru pozycji robota, skutkiem czego wyniki sÄ&#x2026; zbliĹźone do metody wykorzystujÄ&#x2026;cej system GPS. Pozycjonowanie robota bazujÄ&#x2026;ce jedynie na nawigacji inercyjnej wykazuje najwiÄ&#x2122;kszy rozrzut otrzymanych wynikĂłw. Oznacza to, Ĺźe metoda ta jest najmniej powtarzalna. W przypadku tym bĹ&#x201A;Ä&#x2026;d pozycji roĹ&#x203A;nie wraz z kolejnymi punktami docelowymi, co jest spowodowane ciÄ&#x2026;gĹ&#x201A;Ä&#x2026; akumulacjÄ&#x2026; bĹ&#x201A;Ä&#x2122;dĂłw powodowanych przez uĹ&#x203A;lizgi kĂłĹ&#x201A;. Najmniejsza róşnica miÄ&#x2122;dzy minimalnÄ&#x2026; a maksymalnÄ&#x2026; wartoĹ&#x203A;ciÄ&#x2026; bĹ&#x201A;Ä&#x2122;du wystÄ&#x2122;puje w przypadku nawigacji inercyjnej, rozszerzonej o poprawki otrzymywane z systemu wizyjnego. RozwiÄ&#x2026;zanie to cechuje siÄ&#x2122; najwiÄ&#x2122;kszÄ&#x2026; powtarzalnoĹ&#x203A;ciÄ&#x2026; otrzymanych wynikĂłw.
1. SkrzypczyĹ&#x201E;ski P., PostÄ&#x2122;py autonomii robotĂłw mobilnych: percepcja i nawigacja. â&#x20AC;&#x17E;Pomiary Automatyka Robotykaâ&#x20AC;?, R. 14, Nr 2, 2010, 73â&#x20AC;&#x201C;92. 2. Trojnacki M., Szynkarczyk P., Tendencje rozwoju mobilnych robotĂłw lÄ&#x2026;dowych (3). Autonomia robotĂłw mobilnych stan obecny i perspektywy rozwoju. â&#x20AC;&#x17E;Pomiary Automatyka Robotykaâ&#x20AC;?, R. 12, Nr 9, 2008, 5â&#x20AC;&#x201C;9. 3. Giergiel J., Giergiel M., MaĹ&#x201A;ka P., Metody nawigacji minirobotĂłw koĹ&#x201A;owych na przykĹ&#x201A;adzie minirobota koĹ&#x201A;owego m.r.k. â&#x20AC;&#x17E;Pomiary Automatyka Kontrolaâ&#x20AC;?, R. 53, Nr 10, 2007, 50â&#x20AC;&#x201C;54. 4. Borenstein J., Everett H.R., Feng L., Wehe D., Mobile robot positioning: Sensors and techniques. â&#x20AC;&#x153;Journal of Robotic Systemsâ&#x20AC;?, Vol. 14, No. 4, 1997, 231â&#x20AC;&#x201C;249.
86
P
O
M
I
A
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
8 : ! & 8 / < $ $ ;$ !
6 " / . / @ ( " % #b>. % % Abstract: The article presents three selected methods of positioning the mobile robot in the off-road conditions and their verification on the test track built for the European Rover Challenge 2019 competition. The research was carried out using the Mars rover â&#x20AC;&#x17E;IMPULS IIâ&#x20AC;? built by students of the Kielce University of Technology. The research allowed comparison of the mobile robot positioning accuracy in the off-road conditions. The analysis and visualization of research was done using an application that allows control and tracking of the robotâ&#x20AC;&#x2122;s position. Additionally, measurements of the roverâ&#x20AC;&#x2122;s distance from the given point were made. Terrain map analysis and applied algorithms allow robot to get to the given point. KeywordsU / / $ H@ $ " $ ( $ % $ (
( ! 5
( 1
( ) 9 1
( -
/ +B'( ORCID: 0000-0002-2584-3536
'( ORCID: 0000-0002-4669-5851
+?'( ORCID: 0000-0002-1377-1088
% % *++?'( ORCID: 0000-0003-1149-0538
Q V - % % / % [ A U 0 % % [ > / $ % $ A [ Y [ U ( Y 0 [ / > 0 % " < % " @ Z 0 [( A % > % % % A U J [( % / ( % L > . ( )!*+ ;$ K . ( )!*= K . ( )!*+ T
87
NR 3/2015
88
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
# : ! : ! ! G B VPKULhVKT * KP B V?KDKD
Informacje dla Autorรณw ! $ ! > 8 : : / B ;!. Kh : KDVp * & ! J ! ! & : ! < > .! : E ! $ & ] ! ! ! ! < < :& ! !: ! !: < !: ! !: ] ! ! $ & : J < A ] & ] ! ! ! : ! ` & & ! & ! : ! ! [ A`\* ! $J ! < ` . & & : < ! < & < : A !: & : !: & ] !: J . ! : & *
Wskazรณwki dla Autorรณw + *
L ! $! $ & L < !: Pomiary Automatyka Robotyka & ! & $ E `& ] ! ' : % > ! $ ! $ [ & ] ! QD J \ ` ! & : : > : ` ? J L: A [ ! & $ & ! \ > ! $ [ ` _ VCD>KDD $J \ ` ! & : : > $ [C>Q < $\ ` ! & : ` ! : : > `_E ! $ > ` ! & : [ * :\ > & & ! & ! : ` ! & : ` ! : > ! $! ` ! & ` ! : > ? A ? ` & ' : * & * * & * f _ : * pDD & : * VDDD & _ & : ] A _ *
! $ & : E ` _E J ] : D T ! & & E ` _ V ! [PD DDD J & : pDDD :K J \ * Q $ . * ; & !& ! $J & ] ! < ` ` _E ! & $ `_ * Nie drukujemy komunikatรณw! ! $ : ] !E $] A ! < J [ ` ! ! $ \ ` _ CDD>UCD J < ' A *
& ! J J ! ` ! ! ! : : ! <* # & ] ! & ] ] & E ! $ *
) 3: : +
~
L *
*~ #
! * ! & ] $ ] & _E _E ! $ * ! : $J $ ! < & ] & & & * J _E & ! ` : ] E $ ! & !: : ] !E & : ! & $ : ` x J $ * 7 3 #
: # ) : J ! ` * & J _ & * # !$ ] ! $ .! ]E : ! ] & < ! $ > J < A ` A * & & & & < ! < & J ! $ ' : ! & ! ` !: : * ; & !& . ! < & :J & :! ]*
Kwartalnik naukowotechniczny Pomiary Automatyka Robotyka jest indeksowany w bazach BAZTECH, Google Scholar oraz INDEX COPERNICUS O- ] )!*=L G $B+P$ V w bazie naukowych / V ;.-;J7; @ [ [ % realizacji idei Otwartej Nauki, % / / naukowo-technicznym Pomiary Automatyka Robotyka. @ "J 0 / naukowe w kwartalniku Pomiary Automatyka Robotyka wynosi obecnie )! O naukowych i recenzowanych A 6 % % % * )!*+ $ )G+!)P @ % naukowe โ automatyka, elektrotechnika i elektronika.
Qh
GBq^ / + @ " X ^ Â&#x2022;;
7 +
0
*
+ * "
L
L < Pomiary Automatyka Robotyka . ] & ! ` / B ;!. ] ] ` : ! $ J !: ? J ! $J & & & & ! ` : ! $ _ ] % 1. 0 "
wymieniowego Autora L > : ! & !& J * b < < &c * & ! ! J & J J ! < $ & & !$ :! J : $ : * 2. 0 " "
L * #L~
#
jej powstanie > : % > & . ! ! : ] $ & & ! $! ` &J$ ! ! J !: ? ! ` ] & : & ! & & > & . ! `& & !& b < c * ! `& ! J ] ! $ & ! $ $ !: &J$ !: & ` < : & !& J $ $ & & Â&#x201D;
hD
P
O
M
I
A
: ! : & ! & ] : `& ] < ] !: . ] : & & < !: $ : ! ! ! !: *
3. 0 " # *
! L ,~ # *
+
L > & !& A & & ! L ! & : ! !: & ' : x J _ J & `. ! < * bA c > ' : ! ! !: : : & ' : & ` A *
. # # ! $ : !: & :! J . : $! ' : ] ! < ! < ' ! < ! & ' ! . ! < & < < > $ : ! : : . E E _ * & :! ? & ! < _ ! < ]. ! <*
_
przeniesienie praw + * #
L +
[&Â&#x20AC; < ] & ! ` ! $ & `& & : ] ! < & < ! `* X: & & ! & & : ! $ * ; & !& ! ! < ! $ : ] *
Redakcja kwartalnika Pomiary Automatyka Robotyka '
.
# ! ! $J & ! < L < !: # : ! : ! ! & :! & ! < J & $ ] ` & : : ^G &*%
Mariusz Olszewski, Modern Industrial Robotics, â&#x20AC;&#x17E;Pomiary Automatyka Robotykaâ&#x20AC;?, ISSN 1427-9126, R. 24, Nr 1/2020, 5â&#x20AC;&#x201C;20, DOI: 10.14313/PAR_235/5.
R
Y
â&#x20AC;˘
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;˘
R
O
B
O
T
Y
K
A
NR 1 / 20 20
czasopisma
pomiary
sprawdzian
miara
POLSPAR
eksperyment
automatyka PIAP
! $!
seminarium
kalendarium
szkolenie
kwartalnik
federacja
nauka
publikacje
automatyka
stowarzyszenie
HORIZON 2020 ]. innowacje organizacja projekt konkurs
konferencje
relacja
POLSPAR
POLSA
publikacje
AutoCAD streszczenie
agencja kosmiczna
dr h.c.
innowacje
IFAC
ZPSA
& x
profesura
recenzje
relacja
szkolenie
doktorat
robotyka seminarium
sterowanie
[
esa
szkolenie
92
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR
1/2020
;Â&#x2122; @BG
J ( % $ AV % @ 6 \ T ! * # ( @ ! # # # % 9 9 ! 9 ! # ! 9 ! 9 # ! #
#! # 9 B
% # ! # ! 9 9( ; '++C ( E ! ! " ! 2 ! ! "2 #* 2 ! ) % / % " 1 ! E ! ! # 2 ! ( 9 ! E 9 * * # (
( 9 %( ( Janusz Kacprzyk @;J$ ( F U T A ; % J K 8 $ 8 -KKK$ J ( % @ A -KKK - ( $ -KKK Q T J ( % @ A " % T 6 < % - 8 ; O-8 ;P @ @ ( 7 < % U # \ / 0 % K @ 0 O*+G!P @ % [ / *+GG - < % U @;J 7 V / *++! % A` 6 ( < 6 [ ;$ 0 $ 0 < $ " \ % &!! / $ =! 6 % 6
Foreign Member of the Royal Flemish Academy of Belgium for Science and the Arts # ' 8 & ! V ! KDKD * $ : 8 J q : : B * 8m [8 m : : Y Â&#x2014; Y ; < && 8 \ & . ] : ] !& J * $ & / ! VUUK * & B & & : $ ] J VQVT * . ' : ! : Â&#x2DC; : VhUV * # ] !$ ' ` ! : ` ! Â&#x2DC; : !$ J ` ! : ! $ J ! <* # ! $ ! & Â&#x2DC; : `$! !E ! $ X ! = : ` & $ jGj * 8 !: : 8m :!_ : ! & $ ! ! & J ! ! !& !* # ' 8 & ! ! !: & : $ : : *
hp
; @BG
hP
P
O
M
I
A
R
Y
•
A
U
T
O
M
A
T
Y
K
A
•
R
O
B
O
T
Y
K
A
NR 1 / 20 20
# : ! : ! ! G B VPKULhVKT * KP B V?KDKD
Academician of the International Academy of Systems and Cybernetics Sciences # ' 8 & ! VP KDKD * $ ! ! $ : [ : :\ ! $ ! : ! < ! ! * ! < : ! : ! < ! ! > ! Up : J $ _ * # ' 8 & ! !: J < & < $ J : * : & '* ; *
( ^YT[ & 3 9 ^ ] ` & '* 8 & ! $! & ! _ VCDL $ : B J !$ ` VK & x KDVh * # ' !: $ & : ] ! : *
:!Â&#x161;
hC
KALENDARIUM
Kalendarium wybranych imprez Nazwa konferencji
Data konferencji : $
/
Informacje dodatkowe
Conference on European Control Conference ECC 2020
12â&#x20AC;&#x201C;15 / 05 / 2020 10 / 10 / 2019
#
www: < & %?? KD* mail: ' W KD*
XX Krajowa Konferencja Automatyki KKA 2020
22â&#x20AC;&#x201C;24 / 06 / 2020 20 / 01 / 2020
FJ x #
www: < & %?? * *&* *& mail: W ' *&* *&
14th International Conference : + Â&#x17E; Computing CONTROLO 2020
01â&#x20AC;&#x201C;03 / 07 / 2020 01 / 02 / 2020
Bragança Portugalia
www: < & %?? KDKD* & *& mail: KDKDW & *&
21 Gq + ; +
12â&#x20AC;&#x201C;17 / 07 / 2020 31 / 10 / 2019
Berlin Niemcy
25th International Conference / < / : MMAR 2020
24â&#x20AC;&#x201C;27 / 08 /2020 02 / 03 / 2020
/ ` ! #
24th G !:& : on Mathematical Theory of B ! : MTNS 2020
24â&#x20AC;&#x201C;28 / 08 / 2020 12 / 01 / 2020
+ : Wielka Brytania
www: < & %??: KDKD* * :* * ?
VT* 8 8 '
! KKR 2020
02â&#x20AC;&#x201C;06 / 09 / 2020 02 / 03 /2020
8 8$ #
www: < & %?? *& * *& mail: W& * *&
CK* / ` ! 8 ' / J MKM 2020
07â&#x20AC;&#x201C;09 / 09 / 2020
# #
22nd # @ && EPE 2020 ECCE
07â&#x20AC;&#x201C;11 / 09 / 2020 19 / 12 / 2019
Lyon Francja
17th Gq + !:& : G ' : + # : in Manufacturing INCOM 2021
07â&#x20AC;&#x201C;09 / 06 / 2021
& ;` !
www: < & %?? :KDKV*
pD*DQ>Dp*Dh ? KDKV
Jokohama Japonia
www: < &%?? * : KDKV* mail: : KDKVW * * * &
jjGGG ; + ' < G / : Confederation IMEKO 2021
96
P
O
M
I
A
R
Y
â&#x20AC;¢
A
U
T
O
M
A
T
Y
www: < &%?? * ' KDKD*
www: < &%??:: * *& ? mail: :: W:: * *&
www: < & %??: :KDKD*& mail: : * ! !W: :KDKD*&
www: < &%?? * & KDKD* :? mail: ' W & KDKD* :
K
A
â&#x20AC;¢
R
O
B
O
T
Y
K
A
NR 1 / 20 20
8^Bq@ @B+ @ v #^;G@ ÂĄ
III Konferencja GĂłrnictwa Kosmicznego $ ! BF # # # % #E ! #* # 0 E 9 E ! E E 0 # ( G ! # # # # # # ! # ( #* 'H ! # '+'+ (
; A : ! : ] ! < ` J L : !: ] ` ] : ! ] & ! ] & ! L & ! < & J ] ! < L & ] $J. & : <* + ` kosmos jako obszar niezagospodarowany & :! $ ] ] & $ * 8 & : J ! < & ] : ] & ! ` $ _ : â&#x20AC;&#x201C; przez projekty badawcze i konstrukcyjne, & ! ] & ` < & L ` `E* ` ] E $` &` ] $` J .! : $ : < * & _ ] & & ] ! < & ! ]L ! < !_ < ] ! < J : : !:* q :! ! J : ] ` J : !: & ] :& : . _ ! : . L ] J & _ ] & : ` ! ! < L J & ! ! < ` ! < wsparcia naukowego, technicznego czy : * ^ ! _ ogromnym wyzwaniem â&#x20AC;&#x201C; ekstremalne : : ] & ! < ! :J & L wiednich procedur oraz przygotowania kadry & J & ! ! < & ! w warunkach skrajnie nieprzyjaznych $ * # ' !$ ` KP : KDVQ * & & : # =g & '* < * ! ;! $ G .! / < ! & '* * < * .* 8 ;! $ = = A ! ^ < ! & '* * < * .* / ! ] # J
8 : + : 8 : ! < # : B [ &
< + # \ #^" > # 8 : ;! G .! / < ! & ! : =J Lg 8 *
; : $! < ' ` podzielona na trzy sekcje tematyczne:
( * Wyzwania technologiczne, konstrukcyjne : $ J : & ] : ! ! ! !: transportu i eksploracji kosmosu.
) 5# =J L & ! & ! J J & : [& & *\ . & ! < : ! ! !A : $J : . ! < ! J & J * : ! ] !: : ! J ! < & : ] : : & & ! ! < : $J *
) ~ & :J : ! < & J ! ! J : ! : J : ] ! < & ! < : ` ! ! < ! ] ! < & ! & J & : ] . &$! $ : $! ! : E ] & `*
J$ ' : < &%?? * * <* *& ? L ?*
97
8^Bq@ @B+ @ v #^;G@ ¡
@ V % / @ / % E #E #E ! ! # 9 9 * E * % #E * %* ! % F E ( 3 9 B # E % EF # ! * 9 9 % 9 @ / % 7
@! %* E * (
# `_E J J ! < . ! ! ! & < < ` ` < VC>Vh 8] $ # * > ^ ! : < @ & " ! J . # . !: & : < : & @ &!* ;! & : & J J & . ! $ _ <` ] @ " ! -
hQ
P
O
M
I
A
R
& _ @ + & ¢
> :J F ; ! & @ & q 8 : $J J * > . ` J < @ " & q !E & ' :` & & :! $ . & E & < < ! < & * B # 8] : ] ` ! & ] J ! < $J !: Y
â&#x20AC;¢
A
U
T
O
M
A
T
Y
K
A
â&#x20AC;¢
R
^ 0 U K8T O P \ J; ; O P
: & & ! < ! < . < !& '! * > ;! : ] !: & .! : ` & & $ ! : : & ! $ % & & . O
B
O
T
Y
K
A
NR 1 / 20 20
# : ! : ! ! G B VPKULhVKT * Kp B V?KDVh
! ! & _ . &! > :J 8 ! ' ; # < # J &J$ !* > ! J ! < : !:! & J @ " ] & ! $ _E * . $ : ] & E &! $!: _ ! < :! : E J $ J ! < < * !: : J ] !: & ` ! < < : !E `& =# & _ & ] & ! > ! ` ] *
^& J ! # @: ! @ & " : . ` + : J & ] ` & ! : ! : ] .! !: ` # ' : ] ] : ! ! & & ' J > A :! ! * 8 . < ! ` !: ! `_ & ! ] ! ; ! ;$ < # B : <* ^ : & `_ ! ]% @ & q 8 : # < # # + :
& :& L # & < ! ! : ` / B ;!. / $ ; J ; & * ` : ` ! ! < J @ &
" & A : + @+% Y + ' & < *
Q T 6 0 % K.0 @ Â&#x2DC; 6 Â&#x2DC;] # % . /
hh
8^Bq@ @B+ @ v #^;G@ ยก
?) " % T 6 " (A 9 C N B '+'+ ( %* * # *F E ) * # ) (
/ ` ! 8 ' / J ! ] ' ] ! ] & _ & < * # ' & ] B 8 / @ ! @ !$ ` $ _ VhTT * ! !$ & : ! : * ;J $ ` & :! $ ! < & : J > / ` ! ! < B / J > & _ ` ! < & ! : & : & :$ ! < J . $ .] ! < ! : : ! ! ! * # /B/ & & '* @ : : VhTU * = < > & & '* VhTQ * 8 & $ $ ` ' : $ /B/ : & & ! < :$ ! < ! < & ! !: : ! < & J ! < > J J ! < $ ! ! < & ! & ! ! E ` :$ ! < J * = & -
Komitet Organizacyjny MKM 2020 # ] ! 8 : B < * .* $ : = !_ & '* #+ ; & ] ! 8 : B < * .* / ] & '* #^ # ] ! 8 : ^ ! < * .* ! & '* #
Konferencja organizowana jest 8 ^ $ =$J ! @ ! J # < [& < !\ 8 : / # B ^ $ 8 =$J X ` / *
1 ( > 4 / * ? + 9 @ ) # * 7 ) % 7 8 ' ` ` ! < ` < & & ` & $ . g ^ # < *
P
O
M
I
A
R
; ` ! < ' : ' :! < & %??: :KDKD*&
0 ! 2 7 7 " + 8 > : & : ! $ . ! : > $ _ & : > ! :! & : : & ! < & : ! < > & & : : ! & ! $J > & : ! _ : < ! < > & : ! _ ! ! < > & : ! _ : ! ! < > & : ! _ < : ! < > & : ! & < & :! $ ! < > .! : $ > & : ! & ! ' > & : ! : ! ! > & : ! ! > : > ! ! : *
9 ;<7 (1( <=<=
VDD
J : ! < !$ * 8 J J ! & . :& ! ! $ * # & CD ! < ' < ! < & _ $ # `$! $ ! ] J : ] ! < ` : ]* J . CK* ' ` ] & & J ! < _ ! < : ] ! < ` : ] # . & & :! $ ! : ] ! < ` & : : * ^ ! $ ] ! $ & : & . J & :! $ $ J ! @ ! J # < & &J ย < ] : & ! $ _ ]*
Y
โ ข
A
U
T
O
M
A
T
Y
K
A
โ ข
R
O
B
O
T
Y
K
A
NR 1 / 20 20
49
' $ ^.J / =$`
Use of Wind Tunnel Measurements Data in Cold Launched Missile Flight Simulations
61
! = f
67
;$ ! $ G
75
! : " < ; # <
83
Koncepcja automatycznie sterowanego manewru omijania przeszkody + " #L
! ,
/L , + , 4
#
* # *
# * 8 : ! & 8 / < $ $ ;$ !
# L L