1. Обязательно представиться на русском языке кириллицей (заполнить поле "Имя").
  2. Фиктивные имена мы не приветствуем. Ивановых и Пупкиных здесь уже достаточно.
  3. Не надо писать свой вопрос в первую попавшуюся тему - всегда лучше создать новую тему.
  4. За поиск, предложение и обсуждение пиратского ПО и средств взлома - бан без предупреждения. Непонятно? - Читать здесь.
  5. Рекламу и частные объявления "куплю/продам/есть халтура" мы не размещаем ни на каких условиях.
  6. Перед тем как что-то написать - читать здесь, а затем здесь и здесь.
  7. Не надо писать в ЛС администраторам свои технические вопросы. Администраторы форума отлично знают как работает форум, а не все-все контроллеры, о которых тут пишут.

Передать непромышленные протоколы к ПЛК

RS-485, ProfiBUS, 4-20 mA, Wi-Fi, GSM и так далее

Модератор: Глоб.модераторы

Ответить

Автор темы
Aeroplan
освоился
освоился
Сообщения: 234
Зарегистрирован: 16 сен 2016, 12:27
Имя: Владимир
Страна: Россия
Благодарил (а): 51 раз
Поблагодарили: 41 раз

Передать непромышленные протоколы к ПЛК

Сообщение Aeroplan »

Добрый день, коллеги.
У меня есть пара датчиков давления Хоневелл с интерфейсами I2C и SPI. Датчики очень хорошие, прям понравились в работе... Только работают они либо с ардуинкой, либо с малинкой.
А никто из Вас еще не пытался данные с таких датчиков на что-то общепромышленное передать? На какой-либо ПЛК и прочее... Расстояние буквально в объеме полкуба, в пределах одного маленького щитка.
Без ардуины, малины и прочих программируемых вещей. Никаких адаптеров-преобразователей не существует для этих дел?

pike
специалист
специалист
Сообщения: 600
Зарегистрирован: 08 авг 2008, 10:43
Имя: Щукин Андрей Александрович
Страна: Россия
город/регион: Москва
Благодарил (а): 7 раз
Поблагодарили: 63 раза

Передать непромышленные протоколы к ПЛК

Сообщение pike »

Это интерфейсы для разводки на платах, как внешние интерфейсы промышленных устройств беспреспективнны.
Мне российские умельцы притаскивали до ковида измерительное устройство с интерфейсом I²C: в результате всех метаний и потуг они сами и делали переходник на ModbusTCP.
Авторы ТЗ, с которыми я работаю, не имеют права жаловаться на дороги, ЖКХ, бюрократию и правительство.

Автор темы
Aeroplan
освоился
освоился
Сообщения: 234
Зарегистрирован: 16 сен 2016, 12:27
Имя: Владимир
Страна: Россия
Благодарил (а): 51 раз
Поблагодарили: 41 раз

Передать непромышленные протоколы к ПЛК

Сообщение Aeroplan »

Да, похоже придется делать магическую коробочку с ардуинкой внутри в качестве преобразователя-передатчика данных от датчиков в мастер-ПЛК по ModbusRTU

SaNNy
освоился
освоился
Сообщения: 259
Зарегистрирован: 01 фев 2010, 10:37
Имя: Александр
Страна: Россия
город/регион: Брянск
Благодарил (а): 10 раз
Поблагодарили: 33 раза

Передать непромышленные протоколы к ПЛК

Сообщение SaNNy »

Аватара пользователя

Jackson
администратор
администратор
Сообщения: 18749
Зарегистрирован: 17 июн 2008, 16:01
Имя: Евгений свет Брониславович
Страна: Россия
город/регион: Санкт-Петербург
Благодарил (а): 973 раза
Поблагодарили: 1852 раза

Передать непромышленные протоколы к ПЛК

Сообщение Jackson »

Aeroplan писал(а): 01 авг 2023, 11:23 Только работают они либо с ардуинкой, либо с малинкой.
"Что один человек собрал - то другой завсегда разобрать сможет" (с)
Раз датчик общается - значит есть протокол, у которого есть описание. Находите описание протокола, берёте ПЛК (или прочее) и пишете собственный драйвер протокола. Телемаркет.
Aeroplan писал(а): 01 авг 2023, 11:23 Без ардуины, малины и прочих программируемых вещей. Никаких адаптеров-преобразователей не существует для этих дел?
У AnyBUS смотрели? У Гугла спрашивали?
По вопросам работы Форума можно обратиться по этим контактам.

Автор темы
Aeroplan
освоился
освоился
Сообщения: 234
Зарегистрирован: 16 сен 2016, 12:27
Имя: Владимир
Страна: Россия
Благодарил (а): 51 раз
Поблагодарили: 41 раз

Передать непромышленные протоколы к ПЛК

Сообщение Aeroplan »

Jackson писал(а): 01 авг 2023, 15:30 пишете собственный драйвер протокола.
Ну если бы я был программистом, то уже сваял бы, но увы... вынужден спрашивать дорогу, как блуждающий путник.
Jackson писал(а): 01 авг 2023, 15:30 У Гугла спрашивали?
Внятного ответа от него не получил... AnyBus посмотрю, спасибо.

Отправлено спустя 2 минуты 48 секунд:
Похоже, то, что нужно. От этого плясать и попробуем... Спасибо.
Аватара пользователя

Serex
эксперт
эксперт
Сообщения: 2099
Зарегистрирован: 15 авг 2011, 21:36
Имя: Пупков Сергей Викторович
Страна: Россия
город/регион: Москва
Благодарил (а): 138 раз
Поблагодарили: 174 раза

Передать непромышленные протоколы к ПЛК

Сообщение Serex »

У меня такой валяется, но все руки не доходят опробовать. Доступен для быстрой покупки.
https://www.chipdip.ru/product/umft201xb-01

Автор темы
Aeroplan
освоился
освоился
Сообщения: 234
Зарегистрирован: 16 сен 2016, 12:27
Имя: Владимир
Страна: Россия
Благодарил (а): 51 раз
Поблагодарили: 41 раз

Передать непромышленные протоколы к ПЛК

Сообщение Aeroplan »

К сожалению, USB не сильно поможет, тоже не полевая шина.
Аватара пользователя

Jackson
администратор
администратор
Сообщения: 18749
Зарегистрирован: 17 июн 2008, 16:01
Имя: Евгений свет Брониславович
Страна: Россия
город/регион: Санкт-Петербург
Благодарил (а): 973 раза
Поблагодарили: 1852 раза

Передать непромышленные протоколы к ПЛК

Сообщение Jackson »

Aeroplan писал(а): 01 авг 2023, 20:21 Ну если бы я был программистом, то уже сваял бы, но увы... вынужден спрашивать дорогу, как блуждающий путник.
Вы ведь задали вопрос: как установить связь напрямую без единого конвертера, только проводами. А другого пути нет: конвертер должен быть, просто либо он внешний либо он внутри ПЛК в виде драйвера. Без вариантов.
Aeroplan писал(а): 01 авг 2023, 20:21 Похоже, то, что нужно. От этого плясать и попробуем
Только это как раз и есть внешний конвертер, от которых Вы просили отказаться. :)

Ну да ладно, главное чтобы у Вас заработало.

Корректнее формулируйте вопросы - быстрее и точнее получите ответы.
По вопросам работы Форума можно обратиться по этим контактам.

Sokolov_Dmitry
не первый раз у нас
не первый раз у нас
Сообщения: 324
Зарегистрирован: 31 окт 2017, 16:45
Имя: Дмитрий
Страна: Россия
город/регион: Калининград
Благодарил (а): 9 раз
Поблагодарили: 84 раза

Передать непромышленные протоколы к ПЛК

Сообщение Sokolov_Dmitry »

ищите два переходника, первый uart ttl в I2C/SPI и второй uart ttl в необходимый вам интерфейс rs485/232 или TCP (суперпорт USR-K7 например)
Аватара пользователя

Jackson
администратор
администратор
Сообщения: 18749
Зарегистрирован: 17 июн 2008, 16:01
Имя: Евгений свет Брониславович
Страна: Россия
город/регион: Санкт-Петербург
Благодарил (а): 973 раза
Поблагодарили: 1852 раза

Передать непромышленные протоколы к ПЛК

Сообщение Jackson »

Sokolov_Dmitry писал(а): 02 авг 2023, 13:44 ищите два переходника, первый uart ttl в I2C/SPI и второй uart ttl в необходимый вам интерфейс rs485/232 или TCP (суперпорт USR-K7 например)
Выше дали ссылку на переходник I2C в RS-485 ModBUS сразу.
По вопросам работы Форума можно обратиться по этим контактам.

Sokolov_Dmitry
не первый раз у нас
не первый раз у нас
Сообщения: 324
Зарегистрирован: 31 окт 2017, 16:45
Имя: Дмитрий
Страна: Россия
город/регион: Калининград
Благодарил (а): 9 раз
Поблагодарили: 84 раза

Передать непромышленные протоколы к ПЛК

Сообщение Sokolov_Dmitry »

Jackson писал(а): 02 авг 2023, 14:58 Выше дали ссылку на переходник I2C в RS-485 ModBUS сразу
ссылка выще это не i2c в модбас, а датчик (со своим протоколом и интерфейсом i2c) в модбас. Я пока что переходники интерфейсов предложил, подключиться к датчику можно терминальной программой для тестирования опроса датчика.

Автор темы
Aeroplan
освоился
освоился
Сообщения: 234
Зарегистрирован: 16 сен 2016, 12:27
Имя: Владимир
Страна: Россия
Благодарил (а): 51 раз
Поблагодарили: 41 раз

Передать непромышленные протоколы к ПЛК

Сообщение Aeroplan »

Jackson писал(а): 02 авг 2023, 11:12 Только это как раз и есть внешний конвертер, от которых Вы просили отказаться. :)
Да, я несколько неопределенно обрисовал "хотелки". Совершенно ясно, что одними проводами тут не обойтись. Совершенно ясно, что преобразователь интерфейса - либо/либо. Схема с ардуино вполне самодостаточна, вероятно. И, скорее всего, является наиболее дешевой и простой. Но это не "серийное" решение, его не купишь готовым в коробочке с гарантиями и бух/документами. Вот я к чему. Ну и недоверие к ардуино, как к игрушке для детских радиокружков - стереотип, но он присутствует. Все же я надеялся, что есть редкий зверь в коробке, у которого два порта с разных сторон и он умеет передавать один регистр из I2C в ModBus. Но увы и ах.
Поэтому, раз до сих пор на рынке не появилось ни одного такого универсального преобразователя, придется "лепить" что-то самодельное: либо "коробочку с ардуино", либо протокол в ПЛК. И в одном, и в другом случае - это будут муки творчества для меня из-за недостатка опыта и совершенно поверхностных знаний и навыков в программировании такого уровня. Будем учиться.
Вариант с написанием протокола в ПЛК - наиболее "промышленное" решение, тем более, что это не должно стать большим трудом. Передавать необходимо один параметр из каждого датчика. Датчиков предполагается не более 8 штук. Типовое решение - 2 датчика давления.
Скурить мануалов придется немало, если хватит времени и "головы" - разберемся.
Спасибо всем.

Yuriy_Mashinskiy
здесь недавно
здесь недавно
Сообщения: 8
Зарегистрирован: 11 апр 2022, 10:22
Имя: Юрий
Страна: Росссия
город/регион: Москва
Благодарил (а): 2 раза
Поблагодарили: 1 раз

Передать непромышленные протоколы к ПЛК

Сообщение Yuriy_Mashinskiy »

Aeroplan писал(а): 03 авг 2023, 09:09
Jackson писал(а): 02 авг 2023, 11:12 Только это как раз и есть внешний конвертер, от которых Вы просили отказаться. :)
Да, я несколько неопределенно обрисовал "хотелки". Совершенно ясно, что одними проводами тут не обойтись. Совершенно ясно, что преобразователь интерфейса - либо/либо. Схема с ардуино вполне самодостаточна, вероятно. И, скорее всего, является наиболее дешевой и простой. Но это не "серийное" решение, его не купишь готовым в коробочке с гарантиями и бух/документами. .... Будем учиться.
Полноценного решения сейчас не предложу, но муки творчества можно упростить если взять "малинку" и поставить на него бесплатную версию нашего Эликонт-КС (100 сигналов по любым протоколам бесплатно). Дистрибутив можно скачать без регистрации и СМС :) https://ptk-sura.ru/products/kommunikat ... licont-cs/. В таком случае вам останется только наваять драйвер I2C в модбас (гитхаб поможет), а отдать дальше сможете сразу и по OPC UA и по mqtt и по другим протоколам.
Кстати в ближайшее время будет и модбас сервер поддержан.
отвечу на вопросы по ПТК "СУРА", контроллерам Эликонт и прочим продуктам для АСУ ТП от АО "ЭЛАРА"
elara.ru | ptk-sura.ru

Автор темы
Aeroplan
освоился
освоился
Сообщения: 234
Зарегистрирован: 16 сен 2016, 12:27
Имя: Владимир
Страна: Россия
Благодарил (а): 51 раз
Поблагодарили: 41 раз

Передать непромышленные протоколы к ПЛК

Сообщение Aeroplan »

На счет малинки - это сильно не ардуино по "чувствам", но все же не промышленное изделие. Ну и плюс ко всему "гитхаб" - плацдарм программистов, а я не программист.
Мой опытный образец прибора сделан на ODROID C4. Мне он показался более серьезным, с конкретным изготовителем, на тот момент поинтереснее "наборами" и прочее. ПО системы управления была "собрана" на линуксе инструментами питона. Для всего этого развлечения я привлекал хорошего товарища, профессионального программиста. Не за шашлыки с винишком, за реальные рубли. Однако, опытный образец не пошел в продажу по объективным причинам, которые не зависели от навыков программиста. Датчики с интерфейсом I2C в итоге должны стать частью общей АСУ, в которой помимо них есть еще куча сервоприводов, пневмооборудование и прочие наши родные промышленные штуки.
В общем, надо теперь "пересадить" все на платформу ПЛК, с которой я сам могу разбираться, дорабатывать, перерабатывать, программировать и переподключать. В этом я разберусь самостоятельно и не буду вынужден постоянно дергать своего товарища.
А для этого необходимо данные с датчиков "запихать" в ПЛК, минуя "линуксонесущие" непромышленные изделия.
Если я правильно сейчас представляю это действо, то если написать протокол опроса датчиков (их не так уж и много), то всякая необходимость в "коробочках" отпадет... И модуль опроса - он же универсальный станет. Любой датчик по этому протоколу можно будет опрашивать.
Я пока не ясно представляю, как на физическом уровне I2C подключить к ПЛК. К 232 порту?

Отправлено спустя 4 минуты 49 секунд:
Если интересно, это датчики давления Honeywell.

pike
специалист
специалист
Сообщения: 600
Зарегистрирован: 08 авг 2008, 10:43
Имя: Щукин Андрей Александрович
Страна: Россия
город/регион: Москва
Благодарил (а): 7 раз
Поблагодарили: 63 раза

Передать непромышленные протоколы к ПЛК

Сообщение pike »

Aeroplan писал(а): 03 авг 2023, 12:13 Датчики с интерфейсом I2C в итоге должны стать частью общей АСУ, в которой помимо них есть еще куча сервоприводов, пневмооборудование и прочие наши родные промышленные штуки.
I²C - это шина (не протокол!) для разводки связи на плате или соседних платах. Разводить это в шкафу с мощными источниками РЧП, такими как сервопривода идея так себе, только для любителей решать постоянно возникающие проблемы.

Honeywell много чего не промышленного выпускает, в том числе и для производства настольных лабораторных приборов.
Авторы ТЗ, с которыми я работаю, не имеют права жаловаться на дороги, ЖКХ, бюрократию и правительство.

Автор темы
Aeroplan
освоился
освоился
Сообщения: 234
Зарегистрирован: 16 сен 2016, 12:27
Имя: Владимир
Страна: Россия
Благодарил (а): 51 раз
Поблагодарили: 41 раз

Передать непромышленные протоколы к ПЛК

Сообщение Aeroplan »

pike писал(а): 03 авг 2023, 12:48 Honeywell много чего не промышленного выпускает, в том числе и для производства настольных лабораторных приборов.
Не в бровь. Я именно такой прибор и должен сделать. Только прибор этот с сервомоторчиком, с пневмоклапанами, с упомянутыми датчиками давления, датчиками индуктивными и оптическими на оптоволокне. Это не измеритель давления, это полноценный аппарат в 100 литров объема. Но он настольный, лабораторный. Можно и в цех его поставить, но жалко - красивый.
Сертифицированный датчик давления нужного мне типа стоит как чугунный мост, едет в РФ год и в приборе занимает более поллитра пространства. А внутри его нержавеющего килограммового корпуса спрятан тот же хонейвел (с наперсток в 20 грамм) с платой преобразования I2C в 4-20...
pike писал(а): 03 авг 2023, 12:48 I²C - это шина (не протокол!) для разводки связи на плате или соседних платах.
Вот и я считаю, что мне на соседние платы передать надо. А про шину я так и не понял... Если это шина, то она как RS232 шина? По этой шине можно Модбас передать? По RS232 можно передать модбас и по 485 можно и по тисипи можно. Модбас - протокол - верно? А какой протокол в I2C? У каждого производителя свой? И каждый засовывает в микросхему драйверы для этого протокола, чтобы его могли процессоры понять? Вот это мне непонятно пока.

Отправлено спустя 2 минуты 46 секунд:
4-20 - тоже неплохо, но надо потребителю как-то погрешности канала измерения объяснять, подтверждать и прочее. I2C - цифровая передача, погрешность только у датчика, а этим производитель датчика озабочен достаточно сильно. Понимаете цель задачи? Вынимаем из системы лишний участок проблем с погрешностями и сопутствующими документооборотами...

Отправлено спустя 1 минуту 4 секунды:
Ну это моя сермяжная надежда, что так можно...
Аватара пользователя

Jackson
администратор
администратор
Сообщения: 18749
Зарегистрирован: 17 июн 2008, 16:01
Имя: Евгений свет Брониславович
Страна: Россия
город/регион: Санкт-Петербург
Благодарил (а): 973 раза
Поблагодарили: 1852 раза

Передать непромышленные протоколы к ПЛК

Сообщение Jackson »

Yuriy_Mashinskiy писал(а): 03 авг 2023, 11:46 Полноценного решения сейчас не предложу, но муки творчества можно упростить если взять "малинку" и поставить на него бесплатную версию нашего Эликонт-КС (100 сигналов по любым протоколам бесплатно).
Автор же сразу и обозначил что от подобных решений хотел бы уйти.

Aeroplan, А датчик-то уже не проще поменять? :) I2C - не промышленная вещь. Если сделать с самого начала по промышленному - не?
По вопросам работы Форума можно обратиться по этим контактам.

olexsa
эксперт
эксперт
Сообщения: 1584
Зарегистрирован: 29 май 2009, 21:40
Имя: Александр
Страна: Россия
город/регион: Курган
Благодарил (а): 86 раз
Поблагодарили: 208 раз

Передать непромышленные протоколы к ПЛК

Сообщение olexsa »

pike писал(а): 03 авг 2023, 12:48 I²C - это шина (не протокол!)
А какой же тогда протокол используется ? Все время предполагал, что это и шина, и протокол. Заблуждался?

Универсал
эксперт
эксперт
Сообщения: 1341
Зарегистрирован: 14 фев 2013, 23:42
Имя: Евгений
Страна: Россия
город/регион: МО
Благодарил (а): 6 раз
Поблагодарили: 232 раза

Передать непромышленные протоколы к ПЛК

Сообщение Универсал »

Думаю, не проблема каким-нибудь ПЛК с достаточно быстрыми транзисторными выходами напрямую читать I2C датчики. Если только дискретные входы имеют достаточно низкие уровни логической единицы, ниже 5 вольт.
Когда-то в седые доинтернетовские времена под DOS писал прогу для прошивки памяти телевизоров. Документацию по шине и даташит на память присылал муж сестры из Хельсинкского университета. Подключал память к LPT порту, под DOS можно было дёргать ножками.
Хохмы ради делал прогу и на ассемблере, и на С, и даже на Бейсике.
Аватара пользователя

Serex
эксперт
эксперт
Сообщения: 2099
Зарегистрирован: 15 авг 2011, 21:36
Имя: Пупков Сергей Викторович
Страна: Россия
город/регион: Москва
Благодарил (а): 138 раз
Поблагодарили: 174 раза

Передать непромышленные протоколы к ПЛК

Сообщение Serex »

Универсал писал(а): 05 авг 2023, 11:02 Думаю, не проблема каким-нибудь ПЛК с достаточно быстрыми транзисторными выходами напрямую читать I2C датчики.
Ну не!! Проблема. Быстрые входа обслуживаются отдельной микросхемой-счетчиком. Из программы есть только доступ к регистрам-счетчика. Так что ваша задумка может быть прокатит, если скорость шины будет скажем 300 бод :)
Аватара пользователя

Jackson
администратор
администратор
Сообщения: 18749
Зарегистрирован: 17 июн 2008, 16:01
Имя: Евгений свет Брониславович
Страна: Россия
город/регион: Санкт-Петербург
Благодарил (а): 973 раза
Поблагодарили: 1852 раза

Передать непромышленные протоколы к ПЛК

Сообщение Jackson »

Универсал писал(а): 05 авг 2023, 11:02 Думаю, не проблема каким-нибудь ПЛК с достаточно быстрыми транзисторными выходами напрямую читать I2C датчики.
Универсал писал(а): 05 авг 2023, 11:02 Когда-то в седые доинтернетовские времена под DOS писал прогу для прошивки памяти телевизоров.
Только это не телевизор, не ПК, не под ДОСом, и порт не LPT. :ges_down:
Выше Serex объяснил.

Отправлено спустя 5 минут 24 секунды:
Serex писал(а): 06 авг 2023, 21:49 Так что ваша задумка может быть прокатит, если скорость шины будет скажем 300 бод :)
Думаю, скорость значительно меньше будет чтобы гарантированно.

А вообще, что это за колхоз? Квартирный датчик скрещивается с промышленным ПЛК. По-моему, тут что-то надо поменять: либо ПЛК на комнатный контроллер, либо датчик на промышленный, и всё. Иначе - геморроя и разговоров больше.
По вопросам работы Форума можно обратиться по этим контактам.

Универсал
эксперт
эксперт
Сообщения: 1341
Зарегистрирован: 14 фев 2013, 23:42
Имя: Евгений
Страна: Россия
город/регион: МО
Благодарил (а): 6 раз
Поблагодарили: 232 раза

Передать непромышленные протоколы к ПЛК

Сообщение Универсал »

Serex писал(а): 06 авг 2023, 21:49
Универсал писал(а): 05 авг 2023, 11:02 Думаю, не проблема каким-нибудь ПЛК с достаточно быстрыми транзисторными выходами напрямую читать I2C датчики.
Ну не!! Проблема. Быстрые входа обслуживаются отдельной микросхемой-счетчиком. Из программы есть только доступ к регистрам-счетчика. Так что ваша задумка может быть прокатит, если скорость шины будет скажем 300 бод :)
Что мешает выбрать тактовую частоту 100 Гц, или даже 10?
Аватара пользователя

Serex
эксперт
эксперт
Сообщения: 2099
Зарегистрирован: 15 авг 2011, 21:36
Имя: Пупков Сергей Викторович
Страна: Россия
город/регион: Москва
Благодарил (а): 138 раз
Поблагодарили: 174 раза

Передать непромышленные протоколы к ПЛК

Сообщение Serex »

Универсал писал(а): 07 авг 2023, 12:05 Что мешает выбрать тактовую частоту 100 Гц, или даже 10?
Так это уже уровень микроконтроллеров каких-то. Типа AtMega или Pic16. Ни разу не видел промышленного ПЛК, у которого был бы доступ к внутренней тактовой частоте.

Универсал
эксперт
эксперт
Сообщения: 1341
Зарегистрирован: 14 фев 2013, 23:42
Имя: Евгений
Страна: Россия
город/регион: МО
Благодарил (а): 6 раз
Поблагодарили: 232 раза

Передать непромышленные протоколы к ПЛК

Сообщение Универсал »

Я имел в виду тактовую частоту линии SCL шины I2C.
Ответить

Вернуться в «Интерфейсы, протоколы, связь»