news 2026/3/28 8:54:48

树莓派CAN(FD) 测试

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
树莓派CAN(FD) 测试

双向压力测试

#!/usr/bin/env python3# -*- coding: utf-8 -*-importosimporttimeimportsocketimportstructimportselectimportthreadingimportsubprocessimportargparse# ===== CAN 常量 =====SOL_CAN_RAW=getattr(socket,"SOL_CAN_RAW",101)CAN_RAW_FILTER=getattr(socket,"CAN_RAW_FILTER",1)CAN_RAW_LOOPBACK=getattr(socket,"CAN_RAW_LOOPBACK",3)CAN_RAW_RECV_OWN_MSGS=getattr(socket,"CAN_RAW_RECV_OWN_MSGS",4)CAN_ECHO_FLAG=0x20000000STD_MASK=0x7FFCAN_ID=0x123PAYLOAD=bytes([0x11,0x22,0x33,0x44,0x55,0x66,0x77,0x88])CAN_FRAME_FMT="=IB3x8s"# can_id, dlc, pad, data# ===== 工具函数 =====defrun(cmd):subprocess.run(cmd,shell=True,stdout=subprocess.DEVNULL,stderr=subprocess.DEVNULL)defsetup_can():run("sudo ifconfig can0 down")run("sudo ifconfig can1 down")run("sudo ip link set can0 up type can bitrate 1000000")run("sudo ip link set can1 up type can bitrate 1000000 dbitrate 1000000 restart-ms 1000 berr-reporting on fd on")run("sudo ifconfig can0 txqueuelen 65536")run("sudo ifconfig can1 txqueuelen 65536")defopen_can(iface,is_tx):s=socket.socket(socket.AF_CAN,socket.SOCK_RAW,socket.CAN_RAW)s.bind((iface,))flt=struct.pack("=II",CAN_ID,STD_MASK)s.setsockopt(SOL_CAN_RAW,CAN_RAW_FILTER,flt)ifis_tx:s.setsockopt(SOL_CAN_RAW,CAN_RAW_LOOPBACK,0)else:s.setsockopt(SOL_CAN_RAW,CAN_RAW_RECV_OWN_MSGS,0)returnsdefpack_frame():returnstruct.pack(CAN_FRAME_FMT,CAN_ID,8,PAYLOAD)deffmt_frame():return"ID=0x123 DATA=11 22 33 44 55 66 77 88"# ===== 发送线程 =====defsend_loop(sock,rate,end_t,stat,key,tag):interval=1.0/rate next_t=time.perf_counter()frame=pack_frame()printed=Falsewhiletime.perf_counter()<end_t:now=time.perf_counter()ifnow<next_t:time.sleep(min(0.0005,next_t-now))continuetry:sock.send(frame)stat[key]+=1ifnotprinted:print(f"[{tag}TX OK]{fmt_frame()}")printed=TrueexceptOSError:passnext_t+=interval# ===== 接收线程 =====defrecv_loop(sock,end_t,stat,key,tag):printed=Falsewhiletime.perf_counter()<end_t:r,_,_=select.select([sock],[],[],0.05)ifnotr:continueframe=sock.recv(16)can_id,dlc,data=struct.unpack(CAN_FRAME_FMT,frame)ifcan_id&CAN_ECHO_FLAG:continueif(can_id&STD_MASK)==CAN_IDanddata[:8]==PAYLOAD:stat[key]+=1ifnotprinted:print(f"[{tag}RX OK]{fmt_frame()}")printed=True# ===== 主程序 =====defmain():parser=argparse.ArgumentParser()parser.add_argument("--no-setup",action="store_true",help="跳过 can 配置")parser.add_argument("--duration",type=float,default=3.0,help="每档测试秒数")parser.add_argument("--rates",default="10,50,100,200,500,1000,2000,3000,4000,5000")args=parser.parse_args()ifnotargs.no_setup:setup_can()tx0=open_can("can0",True)tx1=open_can("can1",True)rx0=open_can("can0",False)rx1=open_can("can1",False)rates=[int(x)forxinargs.rates.split(",")]print("\n=== CAN0 <-> CAN1 双向收发测试 ===")print("ID=0x123 DATA=11 22 33 44 55 66 77 88\n")print("rate(Hz) | can0->can1 sent/recv drop% | can1->can0 sent/recv drop%")forrateinrates:stat={"s0":0,"r1":0,"s1":0,"r0":0}start=time.perf_counter()send_end=start+args.duration recv_end=send_end+0.5ts0=threading.Thread(target=send_loop,args=(tx0,rate,send_end,stat,"s0","can0"))ts1=threading.Thread(target=send_loop,args=(tx1,rate,send_end,stat,"s1","can1"))tr0=threading.Thread(target=recv_loop,args=(rx0,recv_end,stat,"r0","can0"))tr1=threading.Thread(target=recv_loop,args=(rx1,recv_end,stat,"r1","can1"))tr0.start();tr1.start()ts0.start();ts1.start()ts0.join();ts1.join()tr0.join();tr1.join()d01=0ifstat["s0"]==0else(stat["s0"]-stat["r1"])/stat["s0"]*100d10=0ifstat["s1"]==0else(stat["s1"]-stat["r0"])/stat["s1"]*100print(f"{rate:7d}|{stat['s0']:5d}/{stat['r1']:5d}{d01:6.2f}%"f" |{stat['s1']:5d}/{stat['r0']:5d}{d10:6.2f}%")ifd01>1ord10>1:print(">> 已明显开始丢包,再提速意义不大了")breakprint("\n=== 测试结束 ===")if__name__=="__main__":ifos.geteuid()!=0:print("请 sudo 运行")exit(1)main()

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/24 8:56:25

全行业AI智能体方案!500+实战案例,从医疗到金融,一站式解锁应用思路

一、项目介绍:全行业AI智能体的“灵感与实战宝库” 在AI智能体技术全面爆发的当下,开发者和企业往往面临“场景落地难、框架选型迷、案例参考少”的三重困境。而GitHub上的500-AI-Agents-Projects项目,正是为破解这些痛点而生的开源资源合集。 该项目由ashishpatel26维护,…

作者头像 李华
网站建设 2026/3/27 15:22:36

硅橡胶密封胶703/704/705/706怎么选

卡夫特RTV硅橡胶K-703/704/705/706全系列产品解析与技术选型指南 一、产品矩阵与技术定位 型号核心特性耐温范围透明度典型应用场景703半流淌型&#xff0c;耐冷水性突出-60℃~200℃乳白色水下仪器密封、冷冻设备灌封704通用型&#xff0c;抗垂流优化-60℃~250℃乳白色/黑色车…

作者头像 李华
网站建设 2026/3/27 15:32:25

本地微调大语言模型全攻略:从安装PyTorch到导入Ollama,一步步实践!

简介 本文详细介绍了本地微调大语言模型的全流程&#xff0c;包括安装PyTorch并检查GPU兼容性、安装LLaMAFactory、下载Qwen模型、准备数据集、使用LoRA技术进行微调&#xff08;包括unsloth优化&#xff09;、测试效果、转换为GGUF格式并导入Ollama。整个过程提供了详细的命令…

作者头像 李华
网站建设 2026/3/23 1:09:04

n8n与Coze对比分析,自动化工具选择攻略,建议收藏!

简介 本文详细对比了n8n和Coze两款自动化工具&#xff0c;n8n适合技术开发者处理复杂逻辑和系统集成&#xff0c;开源免费但技术门槛较高&#xff1b;Coze面向业务人员&#xff0c;无代码可视化但扩展性有限。企业可根据用户群体、流程复杂度、部署需求等选择合适工具&#xff…

作者头像 李华
网站建设 2026/3/27 18:25:17

AI美化PPT工具“内卷”升级:这款凭什么在2025脱颖而出?

制作PPT时&#xff0c;83%的用户曾因“排版耗时”“格式混乱”“专业度不足”等问题&#xff0c;最终放弃优化视觉呈现。进入2025年&#xff0c;AI美化工具已从“单一功能”向“全链路服务”升级。本次测评围绕技术架构、实用效率、场景适配三大核心维度&#xff0c;结合商务汇…

作者头像 李华
网站建设 2026/3/27 15:19:39

通过偏振光干涉生成空间变化的偏振

摘要 干涉测量是光学计量的重要技术。 例如&#xff0c;在VirtualLab Fusion中构建具有相干激光光源的马赫泽德干涉仪。 特别是在此示例中插入两个偏振片以控制两个干涉光束的偏振态。 通过旋转其中一个偏振器&#xff0c;可以达到干涉图案变化的可视化&#xff0c;最终产…

作者头像 李华