Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Modbus "Holding Registers" на PXC001
Диалог специалистов АВОК > ОБЩИЙ ФОРУМ > Автоматизация систем > BACnet по-русски
PuzanZero
Уважаемые знатоки Siemens. Помогите разобраться.
У меня есть сторонний девайс который по ModBus-протоколу завязан на PXC001-E.D.
Я настроил прямую и обратную адресацию согласно методичке в приложении (т.е. для FbAddr я ставлю адрес девайса +1000).

В этом случае, блок АО один раз перезаписывает на стороннем девайсе значение Modbus-переменной, при изменении PrVal (всё как и положено), однако при изменении этой переменной непосредственно в самом девайсе, в блоке АО не меняется ни PrVal ни FbVal (см.скриншот ниже).

Я пробовал использовать и другие коды доступа (03,06), но это не помогает.
Единственный выход, который я нашёл - это создать отдельный блок (как это сделано для аналогичной BOOL-евой переменной справа). Но это не решение.

Подскажите, пожалуйста, как сделать так, чтобы эта переменная перезаписывалась в блоке АО при её изменении на стороннем девайсе, а не только передавалась в стороннее устройство при её изменении на PXC001?

signet
Почему для чтения, вы используете 16 функцию? Я бы сказал, что нужно 04 функцию (Read Input Registers). В стороннем устройстве вы пишите, что регистр 01 чтение/запись, а сами читаете с 1001 регистра? тоже не понятно, нужно так же и читать с 01, используя функцию 04. На запись я бы использовал 03 функцию.
Sigezmund
Signet, согласен с Вашими замечениями, но так написано в документации. Это очень странно. Может попробовать для фитбэка указать корректные данные (адрес устройства, функция, регистр)?
PuzanZero
Как бы да, вы отчасти правы. Если я делаю адресацию блока АО как показано на скриншоте ниже, то FbVal выдаёт правильное значение



Вот только с аналогичной конструкцией ВО у меня почему-то нестыковки. Если её разделить на два блока (как на скриншоте слева) то она функционирует нормально, а если объединить в один блок (как на скриншоте справа) то он выдаёт ошибку "Feedback error".


PuzanZero
Но самая главная загвоздка в другом.
Дело в том, что когда эту переменную выводят на DesigoInsight (или на пульт PXM20), то там показано значение PrVal блока AO.
Но если значение этой переменной изменилось на стороне подчинённого устройства (а не через контроллер PXC001), то получится так, что PrVal имеет одно значение, а реальное (FbVal) другое (как на скриншоте https://i.imgur.com/QxLCwRv.png ).
И такая ситуация будет дезинформировать пользователя.
Может быть можно как-то сделать чтобы при изменении FbVal менялось и PrVal ?
Andrew123
>>Может быть можно как-то сделать чтобы при изменении FbVal менялось и PrVal ?
Попробовать блоки NOT+CMP_R, т.е.
AO.EnPgm = NOT(CMP_R(PrVal, FbVal).Eq); AO.ValPgm=FbVal; AO.SwiKind=Trigger.

P.S. С PXC001 и блоками AO (BO) была особенность - перезапись при обрыве-восстановлении связи.
Например, BO это пуск установки по Modbus. Исходное состояние - установка запущена BO=1. Вытыкаем кабель связи. Останавливаем установку с локального пульта. PXC об этом не знает. Втыкаем кабель связи. PXC перезапишет свое значение BO=1 - установка запускается. Получается вроде самопроизвольный запуск установки (для кого-то неожиданный).
signet
Цитата(PuzanZero @ 5.5.2020, 9:54) *
Но самая главная загвоздка в другом.
Дело в том, что когда эту переменную выводят на DesigoInsight (или на пульт PXM20), то там показано значение PrVal блока AO.
Но если значение этой переменной изменилось на стороне подчинённого устройства (а не через контроллер PXC001), то получится так, что PrVal имеет одно значение, а реальное (FbVal) другое (как на скриншоте https://i.imgur.com/QxLCwRv.png ).
И такая ситуация будет дезинформировать пользователя.
Может быть можно как-то сделать чтобы при изменении FbVal менялось и PrVal ?


Настроить это ни как нельзя, идиотская особенность Сименса. Я делаю пометку "запись" или "чтение", чтоб пользователь видел, если чтение отличается от записи, значит кто-то по месту менял уставку.
Можно конечно FbVal замкнуть на вход более высокого приоритета (например SwEn) и с помощью импульсного счетчика записывать FbVal, но это шиза.
PuzanZero
Цитата(signet @ 12.5.2020, 0:30) *
Настроить это ни как нельзя, идиотская особенность Сименса. Я делаю пометку "запись" или "чтение", чтоб пользователь видел, если чтение отличается от записи, значит кто-то по месту менял уставку.
Можно конечно FbVal замкнуть на вход более высокого приоритета (например SwEn) и с помощью импульсного счетчика записывать FbVal, но это шиза.


в общем я сделал вот такую конструкцию, как предложил Andrew123:

задержка, как оказалось, там тоже необходима. оно как-бы худо-бедно, но работает приемлемо.

Но вот проблема которую мне так и не удалось решить, связана с тем, что при перебоях связи или питания, контроллер PXC001 перезаписывает в сторонний девайс значение DefVal блока АО.
Причём, DefVal в ПЗУ контроллера PXC001 не сохраняется и получается так, что при сбое питания контроллер всегда будет сбрасывает переменную SpTSu в 22 (значение забитое мной в программе).

Вы не знаете, можно ли как-то решить эту проблему?
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Форум IP.Board © 2001-2025 IPS, Inc.