Порядок выполнения логики в FBD

В данный форум Вы можете заносить найденные Вами ошибки.При добавления ошибки пожалуйста приложите файлик error.log который находится в папке с установленной программой
Ответить
Arsbond
Рядовой
Сообщения: 10
Зарегистрирован: 25 сен 2015, 05:35
Откуда: Химки

Порядок выполнения логики в FBD

Сообщение Arsbond »

Добрый день!
Обнаружился такой баг: при стандартном для восприятия расположении трех блоков SWITCH (два промежуточных слева друг над другом, последний правее и посередине) логика отрабатывает некорректно. При перемещении третьего блока вниз (ниже первых двух) он в коде выполняется последним и логика отрабатывает корректно. Выявилось это при анализе кода после компиляции.
Во вложении два скрина с расположением блоков и соответствующим кодом для понимания.
У вас нет необходимых прав для просмотра вложений в этом сообщении.
Evgesha
Лейтенант
Сообщения: 537
Зарегистрирован: 29 окт 2015, 09:57
Откуда: Kazakhstan
Имя: Evgesha

Порядок выполнения логики в FBD

Сообщение Evgesha »

тоже самое заметил в блоках mux. пришлось делать проскок в в одном блоке меньше чем в другом(плата номер 5).
У вас нет необходимых прав для просмотра вложений в этом сообщении.
Последний раз редактировалось Evgesha 09 авг 2016, 13:26, всего редактировалось 1 раз.
Balzamalex
Сержант
Сообщения: 102
Зарегистрирован: 07 сен 2015, 21:21

Порядок выполнения логики в FBD

Сообщение Balzamalex »

Была подобная тема - отправилась в "непринятые"
порядок операторов в СиКоде не соответсвует порядку на плате
Слимпер
Майор
Сообщения: 1009
Зарегистрирован: 06 сен 2015, 16:56
Откуда: Новосибирск

Порядок выполнения логики в FBD

Сообщение Слимпер »

Arsbond писал(а):Обнаружился такой баг: при стандартном для восприятия расположении трех блоков SWITCH (два промежуточных слева друг над другом, последний правее и посередине) логика отрабатывает некорректно. При перемещении третьего блока вниз (ниже первых двух) он в коде выполняется последним и логика отрабатывает корректно. Выявилось это при анализе кода после компиляции.Во вложении два скрина с расположением блоков и соответствующим кодом для понимания.
Ну тут не баг, а недопонимание 

support, писал:

Затем обрабатываются оконечные блоки. Это в основном блоки которые не имеют выходов. Например вывод на дисплей, вывод на UART, запись в переменные. 
Порядок обработки блоков внутри групп организован следующим образом.  Первым обрабатывается блок наиболее близкий по прямой (пришлось вспоминать расчёт гипотенузы в прямоугольном треугольнике) к правому верхнему углу платы. Последним соответственно самый дальний.
Логические блоки  (например AND, OR, входы, математика) не рассчитываются. При обработке блоков других типов запрашивается состояние выходов таких блоков. Они в ответ выдают логические выражения (готовый код С) соответствующие своей логике.  Такое решение принято для экономии памяти контроллера. Не хорошо было бы для каждого логического или математического действия создавать переменную. В большинстве случаев в этом нет необходимости. 
Ну где то так. Это очень упрощённо, на самом деле логика компилятора намного сложнее. Я даже не очень представляю как её описать подробно. На это потребуется много времени и сил.
 
Т.е. все обрабатывается как и должно. Когда вы сдинули блок в низ все отработало корректно.
Только можно не так сильно это делать.
Слимпер
Майор
Сообщения: 1009
Зарегистрирован: 06 сен 2015, 16:56
Откуда: Новосибирск

Порядок выполнения логики в FBD

Сообщение Слимпер »

А вот, что уже интересно
Вариант 1 

[spoiler=Спойлер][/spoiler]Все правильно и корректно, претензий нет.
Вариант 2

[spoiler=Спойлер]
[/spoiler]
 
Вот тут уже как не сдвигай, правильной последовательности получить не получится.
У вас нет необходимых прав для просмотра вложений в этом сообщении.
Ответить

Вернуться в «Новые»

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и 1 гость