Русская версия
Українська версія
| Module: | FLibComplex1 |
| Name: | Library of functions compatible with SCADA Complex1. |
| Тип: | Specials |
| Source: | spec_FLibComplex1.so |
| Version: | 1.0.4 |
| Author: | Roman Savochenko |
| Translated: | Maxim Lysenko |
| Description: | Provides the library of functions compatible with SCADA Complex1 of the firm SIC "DIYA". |
| License: | GPL |
Special module FLibComplex1 provides the OpenSCADA system with the static library of functions compatible with SCADA Complex1 of firm SIC 'DIYA'. These functions are used in the SCADA system Complex1 in the form of algoblocks to create inner-computings on the virtual controller. Provision of the library of these functions lets to do the transfer of computational algorithms from the system Complex1.
To address the functions of this library must it is necessary to use the path: <Special.FLibComplex1.*>, where '*' - function identifier in the library.
Below is the description of each function of the librariy. For each function it was evaluated the execution time. Measurements were made on the system with the following parameters: Athlon 64 3000 + (ALTLinux 4.0 (32bit)) by measuring the total execution time of the function when you call it 1000 times. Sampling was carried out of the five calculations, rounded to integer. Time is in angle brackets and is measured in microseconds.
Description: Set alarm sign in the case of going out of the variable for the specified boundary.
Formula:
out = if(val>max || val<min) true; else false;
Description: Operation of branching in accordance with the condition "<".
Formula:
out=if(in1<(in2_1*in2_2*in2_3*in2_4)) in3_1*in3_2*in3_3*in3_4;
else in4_1*in4_2*in4_3*in4_4;
Description: Operation of branching in accordance with the condition ">".
Formula:
out=if(in1>(in2_1*in2_2*in2_3*in2_4)) in3_1*in3_2*in3_3*in3_4;
else in4_1*in4_2*in4_3*in4_4;
Description: Full check of the conditions, including more, less and equal.
Formula:
out = if(in1<(in2_1*in2_2*in2_3*in2_4)) in3_1*in3_2*in3_3*in3_4;
else if( in1>(in4_1*in4_2*in4_3*in4_4) in5_1*in5_2*in5_3*in5_4;
else in6_1*in6_2*in6_3*in6_4;
Description: Function contains the control algorithm of digital signals acquisition for valves and pumps that contain: signs of "Open", "Close" and the command "Open", "Close", "Stop". Supports work with pulse commands, i.e. can read the signal through the specified period of time.
Parameters:
| ID | Parameter | Type | Mode |
| cmdOpen | Command "Open" | Bool | Out |
| cmdClose | Command "Close" | Bool | Out |
| cmdStop | Command "Stop" | Bool | Out |
| stOpen | Position "Opened" | Bool | In |
| stClose | Position "Closed" | Bool | In |
| tCmd | Command hold time (s) | Integer | In |
| frq | Frequency of calculation (milliseconds) | Integer | In |
Description: Makes division of the set of variables.
Formula:
out = (in1_1*in1_2*in1_3*in1_4*in1_5 + in2_1*in2_2*in2_3*in2_4*in2_5 + in3) /
(in4_1*in4_2*in4_3*in4_4*in4_5 + in5_1*in5_2*in5_3*in5_4*in5_5 + in6);
Description: Calculating the exponent under the group of variables.
Formula:
out=exp (in1_1*in1_2*in1_3*in1_4*in1_5 + (in2_1*in2_2*in2_3*in2_4*in2_5+in3) /
(in4_1*in4_2*in4_3*in4_4*in4_5+in5) )
Description: Calculation of the gas flow.
Formula:
f = K1*((K3+K4*x)^K2);
Description: Iterative calculation with the increment specifying. Gain ratio for different directions is different.
Formula:
out = if( in1 > in2 ) in2 + in3*(in1-in2);
else in2 - in4*(in2-in1);
Описание: Задержка изменения переменной. Практически это фильтр без привязки ко времени.
Формула:
y = y - Klag*( y - x );
Описание: Простое умножение с делением.
Формула:
out=(in1_1*in1_2*in1_3*in1_4*in1_5*in1_6)/
(in2_1*in2_2*in2_3*in2_4);
Описание: Разветвленное умножение+деление.
Формула:
out=in1_1*in1_2*in1_3*in1_4*in1_5*
(in2_1*in2_2*in2_3*in2_4*in2_5+(in3_1*in3_2*in3_3*in3_4*in3_5)/
(in4_1*in4_2*in4_3*in4_4*in4_5));
Описание: Пропорционально-интегрально-дифференциальный регулятор.
Параметры:
| ID | Параметр | Тип | Режим | По умолчанию |
| var | Переменная | Веществен. | Вход | 0 |
| sp | Задание | Веществен. | Вход | 0 |
| max | Макс. шкалы | Веществен. | Вход | 100 |
| min | Мин. шкалы | Веществен. | Вход | 0 |
| manIn | Ручной ввод (%) | Веществен. | Вход | 0 |
| out | Выход (%) | Веществен. | Возврат | 0 |
| auto | Автомат | Bool | Вход | 0 |
| casc | Каскад | Bool | Вход | 0 |
| Kp | Kp | Веществен. | Вход | 1 |
| Ti | Ти (мс) | Целый | Вход | 1000 |
| Td | Тд (мс) | Целый | Вход | 0 |
| Tf | Тфильтр (мс) | Целый | Вход | 0 |
| Hup | Верхняя граница выхода (%) | Веществен. | Вход | 100 |
| Hdwn | Нижняя граница выхода (%) | Веществен. | Вход | 0 |
| Zi | Нечувствительность (%) | Веществен. | Вход | 1 |
| K1 | Коэф. входа 1 | Веществен. | Вход | 0 |
| in1 | Вход 1 | Веществен. | Вход | 0 |
| K2 | Коэф. входа 2 | Веществен. | Вход | 0 |
| in2 | Вход 2 | Веществен. | Вход | 0 |
| K3 | Коэф. входа 3 | Веществен. | Вход | 0 |
| in3 | Вход 3 | Веществен. | Вход | 0 |
| K4 | Коэф. входа 4 | Веществен. | Вход | 0 |
| in4 | Вход 4 | Веществен. | Вход | 0 |
| f_frq | Частота вычисления (%) | Вещественный | Вход | 1 |
Структура:
file:pid.png
Описание: Возведение в степень.
Формула:
out=(in1_1*in1_2*in1_3*in1_4*in1_5)^
(in2_1*in2_2*in2_3*in2_4*in2_5 + (in3_1*in3_2*in3_3*in3_4*in3_5)/
(in4_1*in4_2*in4_3*in4_4*in4_5));
Описание: Выбор одного из четырёх вариантов.
Формула:
out = if( sel = 1 ) in1_1*in1_2*in1_3*in1_4;
if( sel = 2 ) in2_1*in2_2*in2_3*in2_4;
if( sel = 3 ) in3_1*in3_2*in3_3*in3_4;
if( sel = 4 ) in4_1*in4_2*in4_3*in4_4;
Описание: Простое суммирование с умножением.
Формула:
out=in1_1*in1_2+in2_1*in2_2+in3_1*in3_2+in4_1*in4_2
+ in5_1*in5_2+in6_1*in6_2+in7_1*in7_2+in8_1*in8_2;
Описание: Суммирование с делением группы значений.
Формула:
out = in1_1*in1_2*(in1_3+in1_4/in1_5) +
in2_1*in2_2*(in2_3+in2_4/in2_5) +
in3_1*in3_2*(in3_3+in3_4/in3_5) +
in4_1*in4_2*(in4_3+in4_4/in4_5);
Описание: Суммирование с умножением группы значений.
Формула:
out = in1_1*in1_2*(in1_3*in1_4+in1_5) +
in2_1*in2_2*(in2_3*in2_4+in2_5) +
in3_1*in3_2*(in3_3*in3_4+in3_5) +
in4_1*in4_2*(in4_3*in4_4+in4_5);