Виртуальные устройства, что это и как связать с физическими

Материал из XIOT Wiki
Перейти к навигации Перейти к поиску

1. Введение

Виртуальные устройства — это не просто программные аналоги физического оборудования, а логические объекты, которые описывают всю структуру и поведение системы XIOT в целом. Они формируют цифровую модель объекта автоматизации — начиная от отдельных датчиков и реле, и заканчивая комнатами, этажами и всем домом.

Каждое виртуальное устройство представляет собой самостоятельный элемент системы, обладающий набором характеристик: состояние, температура, освещённость, активность, режим, сцена и другие. Вместе эти устройства образуют иерархию, где каждый уровень обобщает данные нижестоящих:

  • Устройство — описывает конкретный элемент оборудования (например, лампу, радиатор или датчик).
  • Комната — объединяет устройства и агрегируют их состояния (например, «свет включён», «температура 23°C»).
  • Этаж — агрегирует информацию из нескольких комнат.
  • Дом — объединяет все уровни и обеспечивает глобальное управление и сценарии.

🧩 Такая архитектура позволяет работать не с отдельными датчиками или реле, а с целыми логическими группами:

  • добавив несколько лампочек в одну комнату, можно управлять ими как одним объектом — включить, выключить или узнать, есть ли где-то свет, за это отвечают характеристики комнаты;
  • несколько температурных датчиков в помещении передают значения в комнату, где они усредняются, и система работает с единым показателем «температура в комнате»;
  • команды, переданные на уровень комнаты, автоматически распространяются на все устройства внутри неё;
  • состояние дома формируется из состояния этажей, комнат и оборудования, создавая единую модель объекта.

Таким образом, виртуальные устройства в XIOT — это универсальные логические компоненты, связывающие физику, аналитику и пользовательский интерфейс в единую структуру. Благодаря этому платформа способна работать с любым оборудованием по единому принципу, обеспечивая масштабируемость, простоту настройки и интеллектуальное объединение данных на всех уровнях — от лампочки до целого здания.

2. Архитектура и принцип работы

Архитектура виртуальных устройств в платформе XIOT построена таким образом, чтобы каждый объект системы — от отдельного датчика до всего дома — представлял собой самостоятельную логическую единицу с понятными характеристиками и едиными правилами взаимодействия. Все виртуальные устройства существуют внутри контроллера XIOT-PLC и управляются общей системой логики, сценариев и обмена данными с физическим оборудованием.

2.1. Создание и хранение устройств

Виртуальные устройства создаются при построении проекта в редакторе XIOT-EDITOR. Интегратор определяет структуру проекта: дом → этажи → комнаты → устройства. Редактор передаёт эту структуру в контроллер, где для каждого элемента автоматически создаётся программный объект.

Каждое виртуальное устройство хранится в памяти контроллера как независимый модуль, содержащий:

  • набор характеристик (например: включено/выключено, температура, влажность, освещённость, режим работы и т.д.);
  • внутреннюю логику обработки данных;
  • ссылки на другие устройства и сценарии;
  • информацию о привязке к физическим тегам оборудования.

Структура полностью иерархическая:

  • Дом содержит этажи,
  • Этаж — комнаты,
  • Комната — устройства,
  • Устройства — отдельные характеристики.

2.2. Взаимодействие с физическими устройствами

Каждая характеристика виртуального устройства может быть связана с физическим тегом — это канал обмена данными между контроллером и реальным оборудованием. Контроллер XIOT-PLC принимает данные от физических датчиков и исполнительных модулей, обновляет соответствующие характеристики виртуальных устройств и передаёт результаты выше по структуре — в комнату, этаж и дом.

Пример работы:

  • Физический датчик температуры передаёт измерение через свой тег в контроллер.
  • Контроллер обновляет характеристику виртуального устройства «Датчик температуры».
  • Датчик передаёт полученное значение в виртуальное устройство «Комната», к которой он привязан.
  • Комната агрегирует значения всех своих датчиков температуры (например, вычисляет среднее) и записывает результат в собственную характеристику «Температура».
  • Далее это значение используется другими виртуальными устройствами — например, климат-контролем, сценариями отопления или аналитикой.

Таким образом, виртуальные устройства обеспечивают связку между физическим оборудованием и логической моделью дома: датчики формируют данные, комнаты их обобщают, а система в целом принимает решения и управляет оборудованием на основе актуальной информации. Такой подход позволяет контроллеру XIOT-PLC работать с реальной инфраструктурой как с единой цифровой моделью здания.

2.3. Внутренняя логика устройств и обновление данных

Виртуальные устройства в XIOT работают по событийной модели. Любое изменение данных — например, поступление значения с физического тега или обновление характеристики другим устройством — мгновенно вызывает внутреннюю логику обработки.

Когда контроллер получает новое значение от физического оборудования, оно не просто записывается напрямую. Сначала устройство выполняет цепочку действий:

1. ⚙️ Обработка события — срабатывает внутренняя логика виртуального устройства.

2. 🧮 Валидация значения — система проверяет корректность поступивших данных (тип, диапазон, частота обновлений).

3. 🔧 Нормализация и фильтрация — устраняется шум, устраняются ложные всплески и скачки, значение при необходимости округляется или корректируется.

4. 💾 Применение к характеристике — обработанное значение записывается в соответствующую характеристику устройства.

5. 🧠 Выполнение дополнительной логики — при необходимости активируются связанные характеристики или события.


Например:

  • Физический датчик температуры передаёт в контроллер значение, выходящее за пределы допустимого диапазона, указанного в настройках виртуального датчика.
  • Внутренняя логика устройства определяет, что это аномальное значение, и помимо фильтрации активирует характеристику «Ошибка датчика температуры».
  • Если значение корректно, оно применяется к характеристике «Температура», и далее передаётся на уровень комнаты, где участвует в расчёте средней температуры.

Таким образом, каждая характеристика в системе XIOT — это не просто числовое значение, а результат интеллектуальной обработки и контроля достоверности данных. Благодаря такой событийной модели платформа поддерживает устойчивую работу, защищена от ложных показаний и автоматически отслеживает корректность всех подключённых датчиков и исполнительных устройств.

2.4. Принцип связи уровней

Архитектура XIOT организована по иерархическому принципу, где каждый уровень системы связан с вышестоящими и нижестоящими объектами. Передача данных происходит в двух направлениях — восходящем и нисходящем, что обеспечивает двусторонний обмен информацией между устройствами, комнатами, этажами и домом.

  • 🔼 Восходящий поток — данные поднимаются от нижнего уровня к верхнему.
 Значения, полученные от физических датчиков, обновляют характеристики виртуальных устройств (например, «Датчик температуры»).  
 Затем эти данные передаются в «Комнату», где агрегируются (например, рассчитывается средняя температура по нескольким датчикам), далее — на уровень «Этаж» и «Дом», где формируются сводные показатели состояния объекта.
  • 🔽 Нисходящий поток — команды управления передаются сверху вниз.
 Если пользователь включает свет в комнате, команда распространяется на все устройства, входящие в эту комнату.  
 Аналогично, команда «Выключить весь свет в доме» спускается вниз по иерархии — через этажи и комнаты — до каждой конкретной лампы или реле.

💡 Такая архитектура обеспечивает логическую целостность системы и удобное управление на любом уровне детализации: можно управлять отдельным устройством, целой комнатой, этажом или всем домом — команда будет выполнена корректно на всех вложенных уровнях. При этом состояние каждого уровня формируется автоматически на основе актуальных данных подчинённых объектов, что делает модель полностью синхронной и самодостаточной.

2.5. Хранение и синхронизация

Архитектура XIOT разделяет хранение данных на два уровня — локальный и облачный. Такое решение обеспечивает надёжность, отказоустойчивость и полную синхронизацию состояния системы между контроллером, редактором и приложениями.

  • 🧩 **Локальное хранение:**
 Все текущие состояния виртуальных устройств (включено, температура, режим, статус и т.д.) сохраняются непосредственно в памяти контроллера XIOT-PLC.  
 Это позволяет системе продолжать работу автономно даже без связи с облаком — все сценарии, расчёты и реакции выполняются локально в реальном времени.
  • ☁️ **Облачное хранение:**
 Структура проекта (дом, этажи, комнаты, устройства, их характеристики и настройки) хранится в облаке и в редакторе XIOT-EDITOR.  
 Облако обеспечивает централизованное резервное копирование и восстановление конфигурации.
  • 🔄 **Синхронизация:**
 При каждом переходе между страницами интерфейса управления или настройки, облако и приложения получают от контроллера актуальные состояния всех устройств.  
 Таким образом, пользователь всегда видит реальные данные системы, а любые изменения вносятся мгновенно и синхронно на всех уровнях.
  • 🛠️ **Замена контроллера:**
 В случае выхода из строя контроллера его легко заменить на новый — достаточно загрузить последнюю сохранённую конфигурацию из редактора (облака).  
 После загрузки структура проекта и все связи автоматически восстановятся, и система продолжит работу в прежнем режиме.

💡 Такой подход обеспечивает стабильность, отказоустойчивость и простоту обслуживания: данные устройства живут на контроллере, а структура и настройки проекта — в облаке.

2.6. Виртуальные устройства и сценарии

Виртуальные устройства тесно связаны со сценариями автоматизации, которые формируют поведение системы в зависимости от состояний и событий. Каждый сценарий может управлять характеристиками устройств, реагировать на их изменения и формировать новые состояния, используя единый событийный механизм платформы XIOT.

Примеры взаимодействия:

  • изменение состояния устройства может запустить сценарий (например, при превышении температуры включается вентилятор);
  • сценарий может одновременно управлять несколькими устройствами (например, выключить весь свет при активации режима «Уход из дома»);
  • сценарии могут использовать агрегированные значения (например, среднюю температуру комнаты) для принятия решений на более высоком уровне.

📘 Таким образом, виртуальные устройства являются не просто отражением оборудования, а активными элементами логической системы. Они могут инициировать события, реагировать на изменения и взаимодействовать со сценариями, создавая динамическую и интеллектуальную модель управления зданием.

---

2.7. Роль виртуальных устройств в интерфейсе пользователя

Вся визуальная структура в приложении и редакторе XIOT строится на основе виртуальных устройств. Каждое устройство, комната, этаж и дом автоматически отображаются в интерфейсе как интерактивные элементы, отражающие реальное состояние системы.

  • В Lite-версии интерфейс формируется автоматически на основе иерархии устройств, создавая готовый интерфейс управления для пользователя без дополнительных настроек.
  • В Pro-версии интегратор может самостоятельно проектировать страницы, добавлять элементы управления, графики, индикаторы и кнопки, которые напрямую связаны с характеристиками виртуальных устройств.

💡 Все визуальные элементы получают данные в реальном времени и мгновенно отображают изменения, происходящие в системе. Это обеспечивает пользователю полную синхронизацию между физическим состоянием объекта и его визуальной моделью в приложении.

---

2.8. Итог архитектуры

Архитектура виртуальных устройств в XIOT создаёт единую цифровую модель здания, объединяющую физические теги, сценарии, аналитику и визуальный интерфейс. Каждый уровень — от датчика до дома — функционирует по общим принципам: 📡 события → 🧮 обработка → 📊 агрегация → ⚙️ передача данных.

Такой подход обеспечивает:

  • точную синхронизацию между физическим оборудованием и виртуальной моделью;
  • стабильную работу системы без внешних зависимостей;
  • гибкое масштабирование проекта любого уровня сложности — от квартиры до многоэтажного здания;
  • прозрачность и управляемость на всех уровнях — от отдельных устройств до целых зон и сценариев.

🧠 Благодаря этой архитектуре XIOT позволяет строить интеллектуальные, надёжные и масштабируемые системы автоматизации, где каждый элемент — от датчика до дома — является частью единого живого цифрового пространства.

Источник — https://wiki.xiot.ru/index.php?title=Виртуальные_устройства,_что_это_и_как_связать_с_физическими&oldid=2508