131 lines
19 KiB
Markdown
131 lines
19 KiB
Markdown
# XiUOS 简介
|
||
|
||
## 背景
|
||
|
||
XiUOS (X Industry Ubiquitous Operating System) 未名工业物联操作系统是一款面向工业物联场景的泛在操作系统,来自[未名泛在操作系统研究计划](/about/xuos)。所谓泛在操作系统(UOS: Ubiquitous Operating Systems),是支持互联网时代人机物融合泛在计算应用模式的新型操作系统,是传统操作系统概念的泛化与延伸。在泛在操作系统技术体系中,不同的泛在计算设备和泛在应用场景需要符合各自特性的不同UOS,XiUOS即是面向工业物联场景的一种UOS,主要由一个极简的微型实时操作系统(RTOS)内核和其上的智能工业物联框架构成,支持工业物联网(IIoT: Industrial Internet of Things)应用。
|
||
|
||
XiUOS诞生于浙江省北京大学信息技术高等研究院,其研发获得了杭州市萧山区政府的大力支持。萧山是浙江乃至中国的制造业重镇,工业基础雄厚,正在谋求传统制造业数字化转型升级、实现新旧动能转换,寻求工业互联网和物联网等信息技术的助力。XiUOS未名工业物联操作系统正是在这样的背景下应运而生,希望通过研发的工业物联网软硬件系统为助力,促进先进计算技术和工业场景的深度融合,助推工业企业的数字化转型,是产业应用需求和学术研究计划结合的产物。
|
||
|
||
## 定位
|
||
|
||
XiUOS是一种工业物联网操作系统,目标是通过工业物联网的部署和应用,促进工业领域人、机、物的深度互联,促进工厂的数字化转型升级,使能智能化工业生产新体系。要实现该目标,工业物联网操作系统需要解决“感、联、知、控“四方面的问题:
|
||
|
||
- 感: 复杂多样的工业生产实体智能地识别、感知和采集生产相关数据;
|
||
- 联: 工业数据在互联互通的网络上进行传输和汇聚;
|
||
- 知: 对这些网络化的工业大数据形成快速处理和实效分析;
|
||
- 控: 将数据分析所得到的信息反馈到工业生产中,对生产活动进行改善。
|
||
|
||
其中,**感** 和 **联** 主要在物联网节点级设备、传感器等设备上实现,**知**
|
||
和 **控** 的核心主要在边缘计算设备和数据中心设备上实现。面向物联网节点级设备的
|
||
未名工业物联网操作系统,主要定位于**感**、**联**和**控**的层次,具备相当的节点级智能,将感知获得的数据传递给边缘设备和数据中心设备,具有对PLC等的控制能力,能对**知**提供支持,如下图所示。
|
||
|
||

|
||
|
||
## 特色
|
||
|
||
目前市面上已有非常多成功的物联网操作系统,如国外的[FreeRTOS](https://freertos.org),[Zephyr](https://www.zephyrproject.org),[RIOT](http://www.riot-os.org),[µC/OS](https://www.micrium.com/rtos),国内的[RT-Thread](https://www.rt-thread.org),[LiteOS](https://www.huawei.com/minisite/liteos),[AliOS Things](http://www.alios.cn/things)等,这些系统多是从实时嵌入式系统(RTOS: Real time OS)发展而来,通常具有非常小巧的实时内核,多运行在资源受限的微控制单元(MCU: Microcontroller Unit)/单片机上,对低功耗有较高要求,常见的处理器为ARM Cortex-M系列。
|
||
|
||
XiUOS和现有大多数的物联网OS关注点并不相同,具有自己的特色:
|
||
|
||
- XiUOS不仅着眼于内核的基础功能,如简单实时的调度,静态内存的预分配与动态内存的碎片合并相结合的机制,任务隔离巧妙耦合硬件体系结构特征的算法;而且更关注基础功能之上的业务驱动的高级功能,如以感知数据本身为中心的传感器驱动方法,以方便用户设备联网的无线网络自动接入功能,在节点端启动图像与声音识别的智能化功能;
|
||
- XiUOS不仅注重于OS本身在多领域的通用性,而且更寻求其在工业物联领域的独特性,将复杂的工业控制流程解耦为多个不可再分的“控制元”,以软件定义的方式对各种“控制元”进行再组合或构造,从而在节点端完成对工业设备的实时控制,满足工业企业的对精准控制的刚需;
|
||
- XiUOS不仅关切单个节点设备本身功能和效用的发挥,而且更聚焦于在大规模工业生产环境中组成的网络化集群,强调对大规模部署和管理运维的支持,强调节点设备群构成的物联体系对工业生产的促进作用;
|
||
- XiUOS吸取现有闭源和开源RTOS在各自细分领域的特征,更加关注生态的开放性,依托并逐步融入现有的主流开源生态体系,形成其在工业领域的重要角色和作用。
|
||
|
||
|
||
此外,XiUOS是软硬件协同的物联网解决方案,提供自研的有特色的硬件系统,支持ARM和RISC-V两种体系结构的处理器,在同一物理终端上同时支持多种通信方式和多种总线接口,可直接部署于工业生产环境,使得工业物联网用户不必关心底层各类硬件的实施细节,从而更加专注于应用逻辑本身的效能。
|
||
|
||
简而言之,现有物联网OS主要关注的是做优秀的单节点OS,XiUOS是在现有单节点OS的基础上构建面向多节点的网络化智能物联软件栈,为工业物联网领域应用开发、系统部署、管理运维提供友好方案,因此现有物联网OS和XiUOS功能是主要是互补的而非竞争的,如Linux之于Android。
|
||
|
||
|
||
## 设计
|
||
|
||
### 部署
|
||
|
||
XiUOS是面向工业领域多节点设备的网络化OS,其部署主要包括节点端的多节点集
|
||
群和边缘端/云端的计算设施,如下图所示。
|
||
|
||

|
||
|
||
在节点端,支持多种工厂环境传感设备,既包括基础的环境传感器感知温湿度、烟雾气体、噪音等,也包括智能传感器可对人体、物体、声音进行识别,这些传感器支持多种网络通信互联协议,可以按需自组网络,通过网关设备向外交换数据,实现智能物联框架的“感、联”功能。网关设备对同一个集群中的节点设备进行管理,负责和边缘/云端系统交换数据,并可具备有限的“知、控”功能。
|
||
|
||
节点端感知的数据经网关传输给边缘/云端系统之后,边缘/云端的工业互联网平台可对汇聚而来的数据进行分析,将有价值的数据在控制中心的大屏、管理人员的移动设备上进行展示,并根据工业应用的业务规则,通知和调度“设备、排程、人员”,对生产过程进行优化,完成“知、控”。
|
||
|
||
### 结构
|
||
|
||
节点设备层的XiUOS体系结构如下图所示,主要包括硬件层、系统层、框架层和应用层。
|
||
|
||

|
||
|
||
#### 硬件层
|
||
|
||
硬件层主要是XiUOS支持的处理器、感知器件和通信器件,以及工业领域的可编程逻辑控制器PLC。
|
||
|
||
- 处理器: 支持ARM Cortex-M系列和RISC-V架构的处理器,以及FPGA芯片。
|
||
|
||
- 通信器: 支持5G/4G/WIFI/BT/NBIoT/LoRa等的网络通信器件。
|
||
|
||
- 感知器: 支持工业领域的各种环境感知传感器,如烟雾、气体、噪声、电流电压等,还支持对声音和物体进行感知识别的摄像头、麦克风等音视频设备。
|
||
|
||
- 控制器: 主要PLC厂商如西门子、施耐德、欧姆龙、三菱、台达等的PLC系统,XiUOS可从PLC中获取工业生产相关数据。
|
||
|
||
自主研发的硬件系统对处理器、通信器、感知器提供综合支持,具有如下特点:
|
||
|
||
- XiUOS的硬件系统支持RISC-V和ARM两种体系结构,强调RISC-V和ARM在工业应用中的共生共赢,又注重突出各自特点;
|
||
- XiUOS的硬件系统在同一物理实体终端上同时支持 4G、NB-IoT、WiFi、ZigBee、LoRA、BlueTooth、Ethernet,在硬件上天然地使得现有应用能够方便、快捷地“联”结各种网络;
|
||
- XiUOS的硬件系统在同一物理实体终端上同时支持 SPI、IIC、UART、CAN、RS485、RS232、USB、SDIO等总线接口,在硬件上天然地满足工业物联网对外设多样性的需求;
|
||
- XiUOS的硬件系统能够直接部署于工业生产环境中,而非验证性的开发板评估板。
|
||
|
||
XiUOS硬件系统中的处理器、通信器、传感器、控制器采用解耦的模块化设计,利于XiUOS操作系统方便地通过软件定义的方式屏蔽各种硬件外设的差异,使得工业物联网用户不必关心底层硬件的实施细节,从而更加专注于应用逻辑本身的效能。
|
||
|
||
|
||
|
||
#### 系统层
|
||
|
||
系统层主要完成单节点的系统管理功能,包括基本的内存管理、调度管理、设备管理等。在[未名泛在操作系统研究计划](/about/xuos)中,不同应用场景的UOS系统层能力可以是不同的,主要体现在内核可以根据应用场景的需求进行定制化,甚至可以有不同的内核,这种定制化由未名泛在操作系统的核心XUOS Core提供。未名工业物联操作系统XiUOS遵循该设计和理念,其系统层--面向工业物联场景的泛在操作系统核心(XUOS Core for IIoT)--的内核(Kernel)理论上可以有多种选择,如自研的XiUOS微内核,对POSIX规范支持较完善的实时操作系统NuttX,国内非常具有影响力的RT-Thread等。
|
||
|
||
目前XiUOS的应用框架主要在NuttX和RT-Thread这两款相对而言POSIX较友好、发展较成熟的开源RTOS上开展实验和设计,这可以最大化地复用开源社区的优秀成果,特别是各种硬件驱动。
|
||
|
||
自研XiUOS微内核的研发也在进行中,一些新的算法和新的设计将主要在自研内核中进行探索和验证。
|
||
|
||
系统层为上层框架支持尽可能符合POSIX规范的API。
|
||
|
||
#### 框架层
|
||
|
||
框架层是XiUOS未名工业物联操作系统的关键部分。
|
||
|
||
框架层是面向工业物联场景进行设计的,也可用于有相似需求的智慧城市、智能农场/仓储等场景,核心是“感、联、控、智”框架。
|
||
|
||
- **感**: 传感框架的主要任务是简化传感器的驱动、控制和数据管理。
|
||
|
||
传感器多种多样,包括简单的温度、湿度、气压、噪音、污染物、电流电压等传感器,还有复杂的摄像头、麦克风等,这些传感器首先要能方便地接入到系统中,XiUOS提供方便的IIC、UART 等接口驱动,方便接入新传感器。
|
||
|
||
每种传感器在底层使用上都有区别,为了简化编程,XiUOS设计了统一的传感器编程模型,提供统一的面向数据的编程抽象,屏蔽底层设备的使用差异,开发者只需要使用 open/write/ioctl/等接口就可以对各种传感器进行操作和开发。
|
||
|
||
传感器种类多样,读取的数据格式也是多种多样,XiUOS对传感器数据进行了抽象,对主流的传感器数据可完成自动的解析及结构化。对于开发者添加的新传感器,提供方便的解析库以及数据结构化规范,方便开发者进行数据解析和管理。
|
||
|
||
- **联**: 互联框架的主要任务是提供网络互联能力,尤其是复杂环境下的无线自组网能力。
|
||
|
||
基本的网络互联支持包括提供各种网络协议栈和消息通信库。协议栈包括 TCP/IP、NB-IoT、LoRa等的软件栈支持,方便开发者开发通信功能。此外,还提供丰富便捷的消息通信组件,包括 MQTT、CoAP 等常用IoT 通信库。
|
||
|
||
XiUOS支持节点自组织网络,不需要手工配置,可极大简化工厂、野外等复杂环境下的部署和管理。
|
||
|
||
|
||
- **控**: 控制框架的主要任务是提供控制能力,包括告警和设备监测与控制。XiUOS提供对 PLC 的数据采集库,支持从PLC采集数据,可对设备进行实时监控和远程控制。
|
||
|
||
- **智**: 智能框架是XiUOS的一个特色,将智能识别和分析能力下沉到物联网节点设备上(通常为带加速器的ARM Cortex-M/A 或 RISC-V处理器),使之在节点端即可实时对声音、物体、人体、缺陷模式等进行识别,大大拓展物联网节点的应用范围,内容包括AI算法加速库、微型AI引擎等。
|
||
|
||
AI算法加速库提供工业物联网方面的常用 AI 模型,比如仪表盘识别模型等。微型AI引擎提供运行系统,如TensorFlow Lite for IoT,方便开发者开发常用AI算法。此外,还根据处理器和加速器的具体情况,提供加速器驱动,来高效利用节点端算力。
|
||
|
||
|
||
|
||
XiUOS框架层还提供一些重要的共性基础设施,包括C/C++基础库、MicroPython脚本引擎、轻量级实时数据库、安全系统、在线更新OTA等。
|
||
|
||
## 路线图
|
||
|
||
XiUOS 将整体[开源发布](../about/license.md),采用[木兰协议](https://license.coscl.org.cn/MulanPSL/)。XiUSO的具体开放路线采取逐步开放的方式,按照研发的成熟度分期分批发布系统的各个部分。
|
||
|
||
|
||
<div class="mxgraph" style="" data-mxgraph="{"highlight":"#0000ff","lightbox":false,"nav":true,"edit":"_blank","xml":"<mxfile host=\"Electron\" modified=\"2020-11-04T08:19:42.098Z\" agent=\"5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/537.36 (KHTML, like Gecko) draw.io/13.7.9 Chrome/85.0.4183.121 Electron/10.1.3 Safari/537.36\" version=\"13.7.9\" etag=\"QJnymXIoKJaKc_ZdlvFl\" type=\"device\"><diagram name=\"页-1\" id=\"页-1\">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</diagram></mxfile>"}"></div>
|
||
<script type="text/javascript" src="https://viewer.diagrams.net/js/viewer-static.min.js"></script>
|