当前位置: 首页 > news >正文

Windows 10 ARM工控主板CAN总线实时性能测试

        在常规的Windows系统中支持CAN总线应用,需要外接CAN总线适配器,通常为USBCAN模块或PCI接口CAN卡。实时性本身是CAN总线的显著特性之一,但由于Windows并非实时操作系统,应用程序容易受到系统CPU负载影响,导致调度周期不确实,这就限制了CAN总线在Windows系统中的应用。

        英创公司推出的名片尺寸Windows工控主板ESM8400,其核心是基于NXPiMX8MP 4ARM64 MPU,安装Windows 10 IoT企业版操作系统,Windows 10 IoT企业版就是完整版本的Windows 10,而且支持软实时特性。ESM8400自带两路CAN总线接口,结合Windows 10 IoT企业版的软实时特性,可以实现可靠的10ms(甚至更小)循环周期调度,这使得ESM8400可作为软实时IPC直接应用于对控制周期有严格时序要求的控制回路中,以触发状态机的行为,然后通过CAN总线调度较小的硬实时控制单元。

        本文将介绍基于安装Windows 10 IoT企业版的ESM8400 CAN总线实时应用的测试目标、测试方法,以及对测试数据进行统计与分析。对于开发实时应用程序的具体编程细节将在单独的一篇文档中进行说明。

1. 测试目标

        模拟工业自动化现场实际应用,在ESM8400应用程序中生成10ms的固定循环周期,在每个循环周期内调用CAN接口以250kBits/s波特率连续发送6帧数据。最终统计分析两个时间指标:

        1、10ms循环周期在各种软件配置、以及各种CPU负载情况下的实际最大时间是多少。

        2、在各种工况下连续发送6CAN数据的耗时情况,并统计最长耗时。

2.  测试方法

2.1 硬件环境

        ESM8400评估底板直接支持1CAN总线接口,通过PCAN模块(USBCAN)连接到计算机。测试时需要注意短接评估底板上的CAN总线匹配电阻跳线器。

2.2 PCAN-View

        PCAN-View是PCAN模块对应的Windows应用程序,PCAN-View可以记录接收的CAN数据,同时可记录每帧数据的时间戳,时间戳精度为0.1ms。时间戳由PCAN模块自身标记,不会受测试计算机软件系统调度问题所影响。所以利用接收到的CAN数据时间戳,可以对各项时间指标进行精确的统计。

 

2.3 测试程序

        ESM8400上运行的测试程序利用Windows系统的高精度定时器QPC实现10ms的循环定时,每个循环周期内连续发送6CAN数据,测试发送12WCAN数据(2W个循环)后程序退出。下面是测试程序的主要代码,关于ESM8400 CAN接口在Windows中的使用细节,将在另一编文档中进行说明。

    CFlexCAN        can;

    flexcan_frame_t frame;

    volatile        BOOLEAN txComplete = TRUE;

    LARGE_INTEGER   frequency;

    LARGE_INTEGER   end, last;

   

// 设置本进程优先级

    // SetPriorityClass(GetCurrentProcess(), REALTIME_PRIORITY_CLASS);

// 将本进程设置为仅在CPU3, CPU4上运行

    // SetProcessAffinityMask(GetCurrentProcess(), (1 << 3) | (1 << 2));

// 打开ESM8400 CAN1,波特率设置为250kBit/s

    can.Open(1, 250000);

// 获取QPC的频率

    result = QueryPerformanceFrequency(&frequency);

// 计算10毫秒对应的QPC计数,减去1是为了补偿可能的调度延迟

    LARGE_INTEGER interval = { frequency.QuadPart / 100 - 1 };

    QueryPerformanceCounter(&last);

    end = last;

    while(1){

        // 等待直到达到或超过预定的10毫秒间隔

        do {

            QueryPerformanceCounter(&end);

        } while ((end.QuadPart - last.QuadPart) < interval.QuadPart);

        // 更新上一次循环结束的时间

        last = end;

// 连续发送6CAN数据,每帧的CAN ID16

        for (int i = 1; i < 7; i++) {

            frame.mfs_1.id = i;

            can.Write(&frame);

            while (!can.txComplete) {};

            can.txComplete = FALSE;

            frame.mfp.mfp_w.dataWord1++;

// 此处可进行其它操作,注意代码执行时间不要超过循环定时

// 每个循环发送6帧,发送超过12W(2W个循环)后退出程序

        if (frame.mfp.mfp_w.dataWord1 > 120010)

            break;

    }

3.  进行测试

3.1 测试项目

        将测试程序分别设置为NormalRealtime优先级类,在CPU空闲和CPU负载75%的情况下,测试程序运行于Windows 10标准模式和软实时环境进行了6个项目的对比测试。

测试项目

CPU负载

Windows 10 系统模式

进程优先级类

1

空闲

标准模式

Normal

2

75%

标准模式

Normal

3

75%

标准模式

RealTime

4

空闲

软实时模式,

3个标准CPU + 1个实时CPU

RealTime

5

75%

软实时模式,

3个标准CPU + 1个实时CPU

RealTime

6

75%

软实时模式,

2个标准CPU + 2个实时CPU

RealTime

对于测试项目的进一步说明:

        1、ESM8400的处理器i.MX8MP4CPU核心,在Windows标准模式下,测试程序由系统自动调度在某个CPU上运行。在3+1软实时模式下,应用程序通过SetProcessAffinityMask函数设置当前进程在CPU4(实时核心)上运行,在2+2软实时模式下,通过SetProcessAffinityMask函数设置当前进程在CPU3CPU4上运行。

        2、测试程序进程优先级类由SetPriorityClass系统API配置为NORMAL_PRIORITY_CLASSREALTIME_PRIORITY_CLASS

        3、测试时利用CPU Stress程序为系统增加75%的高优先级 (HIGH_PRIORITY_CLASS)负载。

        4、在启用的Windows 10 软实时的情况下,可以看到在CPU Stress中增加的75%负载,Windows系统分别施加到了CPU1~CPU3上,不占用CPU4资源,这就是Windows IoT企业版的软实时特性之一——CPU隔离技术的体现。(下图中为1个实时核心 + 3个标准核心)

3.2 数据统计与分析

        每个测试项目执行2W次循序,得到12W帧、带精度为0.1ms时间戳的CAN数据,将6个测试超过72W帧数据导入Excel

 

        如前面的测试程序所示,每个循环发送的第1CAN数据的ID1,最后第6CAN ID6,这里利用每一个ID1CAN帧时间戳、统计10ms循环的实际最大时间,利用ID16CAN帧时间戳计算连续发送6CAN数据的实际耗时。统计结果如下:

1. 各工况下CAN数据发送的耗时情况

        CAN总线在250kBit/s波特率下,理论上每秒最多能传输约2300CAN标准帧,传输6个标准帧的最短时间理论上需要约2.6ms。分别统计发送6帧数据耗时在3ms内、3ms~6ms之间、6ms~9ms之间以及耗时超过9ms的次数。

  

从上面的统计结果可以看到:

  • Win10标准模式下,如果不对应用进程优先级作任何设置,即使CPU空闲,也有一次发送时间超过9ms,当CPU负载增加时,CAN的发送时间变得很不确实,接近1000次发送时间超过9ms
  • Win10标准模式下,无论CPU负载如何,发送耗时都小于等于6ms。唯一在CPU负载75%时,有一次耗时处于6ms~9ms之间,根据原始数据查得这次耗时为6.1ms
  • 在分配2个实时核心的情况下,发送实时性要好于1个实时核心。这是因为测试程序实际上有两个线程:一个主循环线程;一个完成端口线程,用于为发送结果提供异步通知。
  • Windows标准模式下,将应用程序设置为实时进程,得到了最好的实时性能,这将在稍后的测试总结中进一步说明。

2. 最大时间统计

        通过统计发送6帧数据的最长耗时,以及统计10ms周期的实际最大时间更能直观的反应系统在各个工况下的性能表现,和可预测性。

4.  测试总结

        在Windows标准模式下,如果不对应用进程优先级做特别设置,程序的调度响应时间将很不确定,在本次测试中,原本10ms的循环定时周期实际上最长测得为160ms

        在Windows标准模式下,提高进程优先级可显著提高响应的实时性,但需要注意的是在标准模式下, Windows线程可以被调度到任意CPU上,Windows的音频驱动、SysMainDPS等后台服务可能会在某一时间对关键应用程序造成影响,这会增加系统的不可预测性。

        在ESM8400上启用Windows的软实时特性,对多核CPU进行隔离应用,将关键应用进程固定在实时CPU上运行,能得到可预测的实时性能,具备在对控制周期有严格时序要求的使用场景中应用的能力。

相关文章:

Windows 10 ARM工控主板CAN总线实时性能测试

在常规的Windows系统中支持CAN总线应用&#xff0c;需要外接CAN总线适配器&#xff0c;通常为USB转CAN模块或PCI接口CAN卡。实时性本身是CAN总线的显著特性之一&#xff0c;但由于Windows并非实时操作系统&#xff0c;应用程序容易受到系统CPU负载影响&#xff0c;导致调度周期…...

如何在不依赖函数调用功能的情况下结合工具与大型语言模型

当大型语言模型&#xff08;LLM&#xff09;原生不支持函数调用功能时&#xff0c;如何实现智能工具调度&#xff1f;本文通过自然语言解析结构化输出控制的方法来实现。 GitHub代码地址 核心实现步骤 定义工具函数 使用tool装饰器声明可调用工具&#xff1a; from langcha…...

【Linux AnolisOS】关于Docker的一系列问题。尤其是拉取东西时的网络问题,镜像源问题。

AnolisOS 8中使用Docker部署&#xff08;全&#xff09;_anolis安装docker-CSDN博客 从在虚拟机安装龙蜥到安装docker上面这篇文章写的很清晰了&#xff0c;我重点讲述我解决文章里面问题一些的方法。 问题1&#xff1a; docker: Get https://registry-1.docker.io/v2/: net/h…...

【Elasticsearch】Mapping概述

以下是Elasticsearch中提到的关于Mapping的各模块概述&#xff1a; --- 1.Dynamic mapping&#xff08;动态映射&#xff09; 动态映射是指Elasticsearch在索引文档时&#xff0c;自动检测字段类型并创建字段映射的过程。当你首次索引一个文档时&#xff0c;Elasticsearch会根…...

GPT-4o悄然升级:能力与个性双突破,AI竞技场再掀波澜

在大模型竞技场中&#xff0c;GPT-4o悄悄发布了全新版本&#xff0c;凭借其卓越的多项能力&#xff0c;迅速超越了DeepSeek-R1&#xff0c;成功登上并列第一的位置。这次更新不仅在数学&#xff08;第6名&#xff09;上有所突破&#xff0c;还在创意写作、编程、指令遵循、长文…...

如何选择合适的超参数来训练Bert和TextCNN模型?

选择合适的超参数来训练Bert和TextCNN模型是一个复杂但关键的过程&#xff0c;它会显著影响模型的性能。以下是一些常见的超参数以及选择它们的方法&#xff1a; 1. 与数据处理相关的超参数 最大序列长度&#xff08;max_length&#xff09; 含义&#xff1a;指输入到Bert模…...

C# SpinLock 类 使用详解

总目录 前言 SpinLock 是 C# 中一种轻量级的自旋锁&#xff0c;属于 System.Threading 命名空间&#xff0c;专为极短时间锁竞争的高性能场景设计。它通过忙等待&#xff08;自旋&#xff09;而非阻塞线程来减少上下文切换开销&#xff0c;适用于锁持有时间极短&#xff08;如…...

【linux】在 Linux 上部署 DeepSeek-r1:32/70b:解决下载中断问题

【linux】在 Linux 上部署 DeepSeek-r1:32/70b:解决下载中断问题 【承接商业广告,如需商业合作请+v17740568442】 文章目录 【linux】在 Linux 上部署 DeepSeek-r1:32/70b:解决下载中断问题问题描述:解决方法方法一:手动中断并重启下载方法二:使用 Bash 脚本自动化下载在…...

机器学习所需要的数学知识【01】

总览 导数 行列式 偏导数 概理论 凸优化-梯度下降 kkt条件...

4.【线性代数】——矩阵的LU分解

四 矩阵的LU分解 1. AB的逆矩阵2. 转置矩阵3. ALU3.1 2x2矩阵3.2 3x3矩阵3.3 nxn的矩阵分解的次数&#xff1f; 1. AB的逆矩阵 { ( A B ) ( B − 1 A − 1 ) I ( B − 1 A − 1 ) ( A B ) I ⇒ ( A B ) − 1 B − 1 A − 1 \begin{cases} (AB)(B^{-1}A^{-1}) I\\ (B^{-1}A^…...

【清晰教程】本地部署DeepSeek-r1模型

【清晰教程】通过Docker为本地DeepSeek-r1部署WebUI界面-CSDN博客 目录 Ollama 安装Ollama DeepSeek-r1模型 安装DeepSeek-r1模型 Ollama Ollama 是一个开源工具&#xff0c;专注于简化大型语言模型&#xff08;LLMs&#xff09;的本地部署和管理。它允许用户在本地计算机…...

Spring Cloud工程搭建

目录 工程搭建 搭建父子工程 创建父工程 Spring Cloud版本 创建子项目-订单服务 声明项⽬依赖 和 项⽬构建插件 创建子项目-商品服务 声明项⽬依赖 和 项⽬构建插件 工程搭建 因为拆分成了微服务&#xff0c;所以要拆分出多个项目&#xff0c;但是IDEA只能一个窗口有一…...

使用Redis实现分布式锁,基于原本单体系统进行业务改造

一、单体系统下&#xff0c;使用锁机制实现秒杀功能&#xff0c;并限制一人一单功能 1.流程图&#xff1a; 2.代码实现&#xff1a; Service public class VoucherOrderServiceImpl extends ServiceImpl<VoucherOrderMapper, VoucherOrder> implements IVoucherOrderSe…...

【MediaTek】 T750 openwrt-23.05编 cannot find dependency libexpat for libmesode

MediaTek T750 T750 采用先进的 7nm 制程,高度集成 5G 调制解调器和四核 Arm CPU,提供较强的功能和配置,设备制造商得以打造精巧的高性能 CPE 产品,如固定无线接入(FWA)路由器和移动热点。 MediaTek T750 平台是一款综合的芯片组,集成了 5G SoC MT6890、12nm 制程…...

CHARMM-GUI EnzyDocker: 一个基于网络的用于酶中多个反应状态的蛋白质 - 配体对接的计算平台

❝ "CHARMM-GUI EnzyDocker for Protein−Ligand Docking of Multiple Reactive States along a Reaction Coordinate in Enzymes"介绍了 CHARMM-GUI EnzyDocker&#xff0c;这是一个基于网络的计算平台&#xff0c;旨在简化和加速 EnzyDock 对接模拟的设置过程&…...

c# 2025/2/17 周一

16. 《表达式&#xff0c;语句详解4》 20 未完。。 表达式&#xff0c;语句详解_4_哔哩哔哩_bilibili...

vite【详解】常用配置 vite.config.js / vite.config.ts

官网 https://cn.vitejs.dev/guide/ vite 常用配置 Vite 配置文件通常是 vite.config.js &#xff08;使用 CommonJS 语法&#xff09;或者 vite.config.ts&#xff08;使用 TypeScript 语法&#xff09;&#xff0c;默认内容为 import { defineConfig } from vite import vue…...

最新智能优化算法: 阿尔法进化(Alpha Evolution,AE)算法求解23个经典函数测试集,MATLAB代码

一、阿尔法进化算法 阿尔法进化&#xff08;Alpha Evolution&#xff0c;AE&#xff09;算法是2024年提出的一种新型进化算法&#xff0c;其核心在于通过自适应基向量和随机步长的设计来更新解&#xff0c;从而提高算法的性能。以下是AE算法的主要步骤和特点&#xff1a; 主…...

用于可靠工业通信的5G-TSN集成原型:基于帧复制与消除可靠性的研究

论文标题 中文标题&#xff1a;用于可靠工业通信的5G-TSN集成原型&#xff1a;基于帧复制与消除可靠性的研究 英文标题&#xff1a;5G-TSN Integrated Prototype for Reliable Industrial Communication Using Frame Replication and Elimination for Reliability 作者信息 …...

HaProxy源码安装(Rocky8)

haproxy具有高性能、高可用性、灵活的负载均衡策略和强大的将恐和日志功能&#xff0c;是法国开发者 威利塔罗(Willy Tarreau)在2000年使用C语言开发的一个开源软件&#xff0c;是一款具 备高并发(一万以上)、高性能的TCP和HTTP负载均衡器&#xff0c;支持基于cookie的持久性&a…...

设计模式和设计原则回顾

设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...

工业安全零事故的智能守护者:一体化AI智能安防平台

前言&#xff1a; 通过AI视觉技术&#xff0c;为船厂提供全面的安全监控解决方案&#xff0c;涵盖交通违规检测、起重机轨道安全、非法入侵检测、盗窃防范、安全规范执行监控等多个方面&#xff0c;能够实现对应负责人反馈机制&#xff0c;并最终实现数据的统计报表。提升船厂…...

React Native在HarmonyOS 5.0阅读类应用开发中的实践

一、技术选型背景 随着HarmonyOS 5.0对Web兼容层的增强&#xff0c;React Native作为跨平台框架可通过重新编译ArkTS组件实现85%以上的代码复用率。阅读类应用具有UI复杂度低、数据流清晰的特点。 二、核心实现方案 1. 环境配置 &#xff08;1&#xff09;使用React Native…...

MODBUS TCP转CANopen 技术赋能高效协同作业

在现代工业自动化领域&#xff0c;MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步&#xff0c;这两种通讯协议也正在被逐步融合&#xff0c;形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...

Linux-07 ubuntu 的 chrome 启动不了

文章目录 问题原因解决步骤一、卸载旧版chrome二、重新安装chorme三、启动不了&#xff0c;报错如下四、启动不了&#xff0c;解决如下 总结 问题原因 在应用中可以看到chrome&#xff0c;但是打不开(说明&#xff1a;原来的ubuntu系统出问题了&#xff0c;这个是备用的硬盘&a…...

C++.OpenGL (10/64)基础光照(Basic Lighting)

基础光照(Basic Lighting) 冯氏光照模型(Phong Lighting Model) #mermaid-svg-GLdskXwWINxNGHso {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-GLdskXwWINxNGHso .error-icon{fill:#552222;}#mermaid-svg-GLd…...

Spring AI与Spring Modulith核心技术解析

Spring AI核心架构解析 Spring AI&#xff08;https://spring.io/projects/spring-ai&#xff09;作为Spring生态中的AI集成框架&#xff0c;其核心设计理念是通过模块化架构降低AI应用的开发复杂度。与Python生态中的LangChain/LlamaIndex等工具类似&#xff0c;但特别为多语…...

分布式增量爬虫实现方案

之前我们在讨论的是分布式爬虫如何实现增量爬取。增量爬虫的目标是只爬取新产生或发生变化的页面&#xff0c;避免重复抓取&#xff0c;以节省资源和时间。 在分布式环境下&#xff0c;增量爬虫的实现需要考虑多个爬虫节点之间的协调和去重。 另一种思路&#xff1a;将增量判…...

C++使用 new 来创建动态数组

问题&#xff1a; 不能使用变量定义数组大小 原因&#xff1a; 这是因为数组在内存中是连续存储的&#xff0c;编译器需要在编译阶段就确定数组的大小&#xff0c;以便正确地分配内存空间。如果允许使用变量来定义数组的大小&#xff0c;那么编译器就无法在编译时确定数组的大…...

iOS性能调优实战:借助克魔(KeyMob)与常用工具深度洞察App瓶颈

在日常iOS开发过程中&#xff0c;性能问题往往是最令人头疼的一类Bug。尤其是在App上线前的压测阶段或是处理用户反馈的高发期&#xff0c;开发者往往需要面对卡顿、崩溃、能耗异常、日志混乱等一系列问题。这些问题表面上看似偶发&#xff0c;但背后往往隐藏着系统资源调度不当…...