组合惯导串口数据解析

2024-05-27 18:44

本文主要是介绍组合惯导串口数据解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先是给串口usb以权限:

sudo chmod 666 /dev/ttyUSB0

但是不能每次启动都执行一次,所以需要给一个永久的权限指令:

sudo gedit /etc/udev/rules.d/70-ttyusb.rules
KERNEL==“ttyUSB[0-9]*, MODE=0666

然后就能让ttyUSB0-ttyUSB9默认的权限都变成了666,普通用户也可以读写串口了。

或者将其添加到一个组:

ls -l /dev/ttyUSB0
whoami

当前用户加入到dialout用户组

sudo usermod -aG dialout username

然后重启即可。
然后是用python解析串口的数据:

#!/usr/bin/env python3
# -*- coding: utf-8 -*-import json
import serial
import rospy
import std_msgs.msg
from car_interfaces.msg import GpsImuInterface, GpsImuAddInterface
import math
from datetime import datetime, timedelta
import time
import pyproj
import signal
import os
import sys# 获取当前脚本文件的所在目录
script_directory = os.path.dirname(os.path.abspath(__file__))
# 图片文件相对于脚本文件的路径
image_relative_path = 'lib'
# 构建图片文件的完整路径
icon_path = os.path.join(script_directory, image_relative_path)
# absolute_path = os.path.abspath(icon_path)# print(absolute_path)
sys.path.append(icon_path)
from base_function import *buf_pos_lat = 0
buf_pos_lon = 0
buf_vel = 0
buf_angle_heading = 0def connect_to_serial(port_name, baud_rate):try:return serial.Serial(port_name, baudrate=baud_rate, timeout=1)except serial.SerialException as e:rospy.logerr(f"Unable to connect to {port_name} with baud rate {baud_rate}: {e}")return Nonedef read_from_port(serial_port):global buf_pos_latglobal buf_pos_longlobal buf_velglobal buf_angle_headingcontent = {}# 此处放置读取串口的逻辑 ...# start = time.time()buf_new = serial_port.readline()# print("buf new",buf_new,"serial_port",serial_port)# print(buff)# print()if ("INSPVAXA" in buf_new.decode() and "FINESTEERING" in buf_new.decode()):buf_whole_array = buf_new.decode().split(";")buf_front_arary = buf_whole_array[0].split(",")# print(buf_whole_array)buf_back_array = buf_whole_array[1].split(",")buf_pos_lon = float(buf_back_array[3])buf_pos_lat = float(buf_back_array[2])# buf_pos_alt = float(buf_back_array[4])buf_vel_east= float(buf_back_array[7])buf_vel_north= float(buf_back_array[6])buf_vel_u= float(buf_back_array[8])# 车速通过串口拿不到数据buf_vel= math.sqrt(buf_vel_east**2+buf_vel_north**2+buf_vel_u**2)buf_angle_heading = angle_2_angle(float(buf_back_array[11]))if(buf_back_array[0] == "INS_SOLUTION_GOOD"):buf_system_state = 3else:buf_system_state = 0# 搜星数量buf_gps_num_sats_used = 0buf_gps_num_sats_1 = 0buf_gps_num_sats_2 = 0if buf_front_arary[4] == "FINEBACKUPSTEERING":buf_satellite_status = 1else:buf_satellite_status = 0# 差分延时buf_gps_age = 0buf_pos_x = 0buf_pos_y = 0# 进程处理时间buf_process_time=0# 惯导通信故障buf_gps_cfault = Falsecontent["time_stamp"] = time.time()content["Lat"] = buf_pos_lat # GPS_MSG.PosLatcontent["Lon"] = buf_pos_lon # GPS_MSG.PosLoncontent["Head"] = buf_angle_heading # GPS_MSG.AngleHeadingcontent["Speed"] = buf_vel # GPS_MSG.Velcontent["UTM_x"] = from_latlon(buf_pos_lat, buf_pos_lon)[0]content["UTM_y"] = from_latlon(buf_pos_lat, buf_pos_lon)[1]# print(content)# msg.PosLon =1# # msg.PosLan =1# msg.VelE =2# # msg.posX =  388652.2938084109# # msg.posY =  4963429.720356053# msg.posX =  from_latlon(buf_pos_lat, buf_pos_lon)[0]# msg.posY =  from_latlon(buf_pos_lat, buf_pos_lon)[1]# msg.Vel = buf_vel# msg.AngleHeading = buf_angle_heading# msg.GpsNumSatsUsed = 20return contentdef main():global buf_pos_latglobal buf_pos_longlobal buf_velglobal buf_angle_headingsignal.signal(signal.SIGINT, quit)# 使用ROS参数服务器来获取参数# serial_port_name = rospy.get_param("~serial_port", "/dev/ttyUSB0")# baud_rate = rospy.get_param("~baud_rate", 115200)serial_port_name = "/dev/ttyUSB0"baud_rate = 115200rospy.init_node("gps_imu_pub", anonymous=True)pub_location = rospy.Publisher('/ztbus/location', std_msgs.msg.String, queue_size=10)pub = rospy.Publisher("gps_imu", GpsImuInterface, queue_size = 10) msg = GpsImuInterface()while not rospy.is_shutdown():start = time.time()try:serial_port = connect_to_serial(serial_port_name, baud_rate)# print()data = read_from_port(serial_port)# print(data,"#"*8)except:print("except")continueif data :msg.PosLon =buf_pos_lonmsg.PosLat =buf_pos_latmsg.posX = from_latlon(buf_pos_lat, buf_pos_lon)[0]msg.posY = from_latlon(buf_pos_lat, buf_pos_lon)[1]msg.Vel = buf_velmsg.AngleHeading = buf_angle_headingpub_location.publish(json.dumps(data))pub.publish(msg)# rospy.loginfo("Data published to /ztbus/location topic.")prGreen("pub ok")end = time.time()interval = end -startprint('gps_interval = ', interval)# rospy.loginfo("Shutting down GPS IMU publisher node.")if __name__ == "__main__":main()

这里我的建议是将串口改成CAN口,协议也比较好确定。

这篇关于组合惯导串口数据解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1008286

相关文章

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

深度解析Python装饰器常见用法与进阶技巧

《深度解析Python装饰器常见用法与进阶技巧》Python装饰器(Decorator)是提升代码可读性与复用性的强大工具,本文将深入解析Python装饰器的原理,常见用法,进阶技巧与最佳实践,希望可... 目录装饰器的基本原理函数装饰器的常见用法带参数的装饰器类装饰器与方法装饰器装饰器的嵌套与组合进阶技巧

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决