五、ROS使用serial包进行串口通信

2023-05-16

五、ROS使用serial包进行串口通信

    • 1.下载串口调试助手CuteCom
    • 2.下载虚拟串口模拟器socat
    • 3.下载串口调试助手minicom
    • 4.安装serial串口功能包
    • 5.创建工作空间
    • 6.创建功能包
    • 7.创建发布者
    • 8.配置CMakeLists.txt
    • 9.运行发布者节点
    • 10.创建订阅者
    • 11.重新配置CMakeLists.txt
    • 12.运行节点

1.下载串口调试助手CuteCom

CuteCom是Linux下少数带有界面的串口调试助手

sudo apt-get install cutecom

在这里插入图片描述

2.下载虚拟串口模拟器socat

为了方便调试,再下载一个虚拟串口模拟器socat

sudo apt-get install socat

输入指令,生成虚拟串口

socat -d -d pty,raw,echo=0 pty,raw,echo=0

观察终端输出的日志,注意/dev/pts/6 和/dev/pts/7,这两个口就是虚拟串口对,不同的设备生成的会不一样,而且名称经常会变,之后我们可以像访问真实的串口设备一样访问这两个虚拟串口了,但是注意:若要使得这对虚拟串口一直有效,必须使这个终端一直开着

然后再新建一个终端,输入以下指令,监听/dev/pts/6中的数据

cat < /dev/pts/6

然后再新建一个终端,输入以下指令,让虚拟串口/dev/pts/7对 /dev/pts/6发送数据

sudo echo 666  > /dev/pts/7

然后可以看到6实时接收到7发送过来的数据
在这里插入图片描述

3.下载串口调试助手minicom

但是CuteCom找不到socat生成的虚拟串口,很迷,不知道为啥

所以如果手头暂时没有设备,要创建虚拟串口来调试代码,可以换一款串口调试助手
下载minicom

sudo apt install minicom

使用前配置minicom,这个界面就很捞

minicom -s

先写一个脚本,让minicom往虚拟串口循环发送数据(模拟传感器)
在这里插入图片描述

#!/bin/bash      
flag=1
while [  $flag = 1 ]
do
echo "hahahahahahahaha   666666666666666"
sleep 1
done

!是特殊的表示符,其后面跟的是解释此脚本的shell的路径

用管理员权限打开minicom,配置一下脚本路径

sudo minicom -s
  1. 控制键盘方向建,选中Filenames and paths,回车:
  2. 键盘输入D,进入Script Program,添加脚本路径
  3. 设置为/bin/bash,回车保存退出
  4. 返回设置界面,选中Save setup as def,回车保存为默认设置,退出minicom。这样设置完毕以后,每次重新打开minicom,解释此脚本的shell路径就一直被保存在那里了
    在这里插入图片描述

打开minicom,配置串口的一些设置,并运行test.sh脚本

minicom -s

控制键盘方向建,选中Serial port setup,回车:

  1. 键盘输入 A,光标会跳到第一行最后,编辑想要连接的串口,比如我这次的设备使用的串口是 /dev/pts/4,运行脚本让虚拟串口4往外发送数据,编辑完回车保存;
  2. 键盘输入 E,弹出波特率选项,输入选项的字母,回车保存,或者ESC退出;
  3. 键盘输入 F,改为 No;
  4. 键盘输入 G,改为 No。
    在这里插入图片描述

设置完后,回车,返回设置界面,选中Exit,回车就可以输入命令了

  1. 按下Ctrl + A,再按Z进入帮助界面
  2. 输入G,选择run scripts(G)
  3. 输入C,在Name of script中输入脚本的绝对路径/home/yao/My_Ros_WorkSpace/test.sh
  4. 回车保存
  5. 再回车,即可执行test.sh脚本
    可以看到虚拟串口4执行脚本后,往外发送数据到虚拟串口9(他俩默认是通的)

4.安装serial串口功能包

sudo apt install ros-melodic-serial  

5.创建工作空间

首先进入一个不含中文路径的目录,右键在终端打开,新建一个文件夹collect_workspace作为工作空间

mkdir collect_workspace
cd  collect_workspace
mkdir src
cd src
catkin_init_workspace
cd ..
catkin_make
catkin_make install
code .

将工作空间用VSCode打开,提高开发效率
每次新建一个工作空间都需要重新配置编译规则,这里可以看我前面的文章

6.创建功能包

选中src,右键Create Catkin Package
录入功能包名字"collect_pkg",回车
录入依赖"roscpp rospy std_msgs serial",再回车
避免依赖名字可能写错了,也可以(Ctrl + Shift + B)编译一下,看看有没有问题!

其中roscpp是使用C++实现的库,而rospy则是使用python实现的库,std_msgs是标准消息库,创建ROS功能包时,一般都会依赖这三个基本的库,这里因为要用到serial,所以需要将刚下载的包添加进来

目的:发布者实时获取从串口发送过来的数据(传感器采集的数据),并对数据进行处理,将处理完的数据通过消息发送出去,订阅者实时接收这个消息。

7.创建发布者

选中collect_pkg→src,右键新建一个发布者的实现代码myserial_pub.cpp
修改 .vscode/c_cpp_properties.json,设置 "cppStandard"为 “c++17”并保存,否则会报错

#include<ros/ros.h>
#include<serial/serial.h>
#include<std_msgs/String.h>
#include<iostream>
#include<string>
#include<sstream>

//using namespace std; //声明命名空间

//函数功能:将数据经由串口发送出去
//入口参数1:[serial::Serial &ser]:     串口类名称
//入口参数2:[std::string &serial_msg]:  要通过串口发送出去的字符串
int serial_write(serial::Serial &ser, std::string &serial_msg)
{
    ser.write(serial_msg);
    return 0;
}

//函数功能:将从串口接收到的数据保存到数组中
//入口参数1:[serial::Serial &ser]:     串口类名称
//入口参数2:[std::string &serial_msg]:  从串口读取的字符串
int serial_read(serial::Serial &ser, std::string &serial_msg)
{
    serial_msg = ser.read( ser.available() );
    return 0;
}


int main(int argc, char** argv)
{
    //初始化,节点名为serial_publisher
    ros::init(argc, argv,"serial_publisher");
    //创建句柄seuNB,用于管理资源
    ros::NodeHandle seuNB;

    //用Publisher类,实例化一个发布者对象yao,发布一个名为"Serial_Topic"的话题,话题的消息类型为std_msgs::String,消息发布队列长度为10(注意话题名中间不能有空格)
    ros::Publisher yao = seuNB.advertise<std_msgs::String>("Serial_Topic",10);

    //实例化一个serial类
    serial::Serial ser;

    //初始化串口相关设置
    ser.setPort("/dev/pts/4");         //设置打开的串口名称:这里打开一个虚拟串口
    ser.setBaudrate(115200);           //设置串口的波特率
    serial::Timeout to = serial::Timeout::simpleTimeout(1000);  //创建timeout
    ser.setTimeout(to);                //设置串口的timeout

    //打开串口
    try
    {
        ser.open();         //打开串口
    }
    catch(const std::exception& e)
    {
        ROS_ERROR_STREAM("Unable to open port.");        //打开串口失败,打印日志信息,然后结束程序
        return -1;
    }

    //判断串口是否成功打开
    if(ser.isOpen())
    { 
        ROS_INFO_STREAM("Serial Port is opened.\n");    //成功打开串口,打印日志信息
    }
    else
    {
        return -1;  //打开串口失败,打印日志信息,然后结束程序
    }


    ros::Rate loop_rate(50); //指定循环频率50  
    while(ros::ok())
    {
        //获取缓冲区内的字节数
        size_t n = ser.available();
        if(n!=0)
        {
            ROS_INFO_STREAM("Reading from serial port:\n"); //表明正在开始读取串口数据
            std_msgs::String msg2333; 	//msg2333为从串口处接收到的字符串
            msg2333.data = ser.read(ser.available()); 
            yao.publish(msg2333);  //将消息发布出去
            ROS_INFO_STREAM("Read: " << msg2333.data);  //添加日志:顺便将发布的数据打印到终端
        }
        
        loop_rate.sleep();
    }
    
    //关闭串口
	ser.close();
    return 0;
}

8.配置CMakeLists.txt

# 生成可执行文件
add_executable(myserial_pub src/myserial_pub.cpp)
# 链接库
target_link_libraries(myserial_pub  ${catkin_LIBRARIES})

9.运行发布者节点

打开一个终端,输入指令,生成虚拟串口

socat -d -d pty,b115200 pty,b115200

根据生成的虚拟串口,重新设置一下代码中的串口名称,必须一致,例如这里选择/dev/pts/7,否则无法打开串口,然后Ctrl + S保存、Ctrl + Shift + B编译

在VSCode中新建一个终端,运动ROS master

roscore

再新建一个终端,运行发布者节点

source devel/setup.bash
rosrun   collect_pkg   myserial_pub

然后外面再新建一个终端,往/dev/pts/7中写入数据
在这里插入图片描述

10.创建订阅者

选中collect_pkg→src,右键新建一个发布者的实现代码myserial_sub.cpp

#include "ros/ros.h"
#include "std_msgs/String.h"

void mesg2333_callback(const std_msgs::String::ConstPtr &msg_p)//订阅到的消息是std_msgs::string类型,这个函数的参数类型是它的常量指针的引用
{
    //通过msg获取订阅到的消息,并对它进行处理,即在终端中打印出来
    ROS_INFO("serial_subscriber订阅的消息是:%s",msg_p->data.c_str());
}

int main(int argc, char *argv[])
{
    setlocale(LC_CTYPE, "zh_CN.utf8"); //设置编码,防止中文乱码

    //初始化节点名为:serial_subscriber
    ros::init(argc,argv,"serial_subscriber"); 
    //创建句柄seuNB666,用来管理资源
    ros::NodeHandle seuNB666;

    //用Subscriber类,实例化一个发布者对象,发布一个名为"Serial_Topic"的话题,话题的消息类型为std_msgs::String,消息发布队列长度为10(注意话题名中间不能有空格)
    ros::Subscriber yao666 = seuNB666.subscribe<std_msgs::String>("Serial_Topic",10,mesg2333_callback); //订阅的话题名,队列长度,回调函数

    //循环读取接收的数据,并调用回调函数处理:mesg2333_callback()每订阅到一次消息都需要执行一次,为了让回调函数多次执行,需要再执行完一次之后需要回头
    ros::spin(); 

    return 0;
}

然后再修改一下发布者输出日志的一些信息

#include<ros/ros.h>
#include<serial/serial.h>
#include<std_msgs/String.h>
#include<iostream>
#include<string>
#include<sstream>

//using namespace std; //声明命名空间

//函数功能:将数据经由串口发送出去
//入口参数1:[serial::Serial &ser]:     串口类名称
//入口参数2:[std::string &serial_msg]:  要通过串口发送出去的字符串
int serial_write(serial::Serial &ser, std::string &serial_msg)
{
    ser.write(serial_msg);
    return 0;
}

//函数功能:将从串口接收到的数据保存到数组中
//入口参数1:[serial::Serial &ser]:     串口类名称
//入口参数2:[std::string &serial_msg]:  从串口读取的字符串
int serial_read(serial::Serial &ser, std::string &serial_msg)
{
    serial_msg = ser.read( ser.available() );
    return 0;
}


int main(int argc, char** argv)
{
    setlocale(LC_CTYPE, "zh_CN.utf8"); //设置编码,防止中文乱码

    //初始化,节点名为serial_publisher
    ros::init(argc, argv,"serial_publisher");
    //创建句柄seuNB,用于管理资源
    ros::NodeHandle seuNB;

    //用Publisher类,实例化一个发布者对象yao,发布一个名为"Serial_Topic"的话题,话题的消息类型为std_msgs::String,消息发布队列长度为10(注意话题名中间不能有空格)
    ros::Publisher yao = seuNB.advertise<std_msgs::String>("Serial_Topic",10);

    //实例化一个serial类
    serial::Serial ser;

    //初始化串口相关设置
    ser.setPort("/dev/pts/2");         //设置打开的串口名称:这里打开一个虚拟串口
    ser.setBaudrate(115200);           //设置串口的波特率
    serial::Timeout to = serial::Timeout::simpleTimeout(1000);  //创建timeout
    ser.setTimeout(to);                //设置串口的timeout

    //打开串口
    try
    {
        ser.open();         //打开串口
    }
    catch(const std::exception& e)
    {
        ROS_ERROR_STREAM("Unable to open port.");        //打开串口失败,打印日志信息,然后结束程序
        return -1;
    }

    //判断串口是否成功打开
    if(ser.isOpen())
    { 
        ROS_INFO_STREAM("Serial Port is opened.\n");    //成功打开串口,打印日志信息
    }
    else
    {
        return -1;  //打开串口失败,打印日志信息,然后结束程序
    }

    //设置消息编号
    int count = 0;

    ros::Rate loop_rate(50); //指定循环频率50  
    while(ros::ok())
    {
        //获取缓冲区内的字节数
        size_t n = ser.available();
        if(n!=0)
        {

            std_msgs::String msg2333; 	//msg2333为从串口处接收到的字符串           
            msg2333.data = ser.read(ser.available()); 
            yao.publish(msg2333);  //将消息发布出去
            ROS_INFO_STREAM("serial_publisher发布的消息是:"  << msg2333.data);  //添加日志:顺便将发布的数据打印到终端
        }

        loop_rate.sleep();
    }
    
    //关闭串口
	ser.close();
    return 0;
}

11.重新配置CMakeLists.txt

增加两句

# 生成可执行文件
add_executable(myserial_pub src/myserial_pub.cpp)
# 链接库
target_link_libraries(myserial_pub  ${catkin_LIBRARIES})

# 生成可执行文件
add_executable(myserial_sub src/myserial_sub.cpp)
# 链接库
target_link_libraries(myserial_sub  ${catkin_LIBRARIES})

12.运行节点

然后在功能包"collect_pkg"下面,新建一个名为"launch"的文件夹
然后在名为"launch"的文件夹里面继续新建一个后缀为.launch的文件,名字随便起
我这里是"start_serial.launch",主要是为了启动串口通讯的两个节点

<launch>
    <!--添加被执行的节点-->
    <!--  <node pkg="功能包名" type="CMakeLists中配置的可执行文件名" name="为节点简单的命名一下,这个name可以随便取" output="设置日志的输出目标" />  -->

    <!--启动发布者-->
    <node  pkg="collect_pkg"  type="myserial_pub"  name="publisher_node" output="screen" />
    <!--启动订阅者-->   
    <node  pkg="collect_pkg"  type="myserial_sub"  name="subscriber_node" output="screen"/>


</launch>

外部终端1

socat -d -d pty,b115200 pty,b115200

修改虚拟串口名,Ctrl + S保存,Ctrl + Shift + B编译
VScode终端

source devel/setup.bash
roslaunch  collect_pkg   start_serial.launch

外部终端2

minicom -s

设置虚拟串口名/dev/pts/XXX
输入脚本路径/home/yao/My_Ros_WorkSpace/test.sh
在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

五、ROS使用serial包进行串口通信 的相关文章

  • systemctl 启动/停止/重新加载 nginx

    systemctl 启动 停止 重新加载 nginx 一 新建nginx service脚本 span class token function sudo span span class token function vim span us
  • Unable to determine application id: com.android.tools.idea.run.ApkProvisionException: ERROR: APK pat

    Unable to determine application id com android tools idea run ApkProvisionException ERROR APK path is not specified for
  • Java获取文件的MD5

    Java获取文件的MD5 主要是通过读取文件的字符流 xff0c 然后赋值给MessageDigest对象 xff0c 最后将文件流转换成16进制的字符串 span class token keyword import span span
  • android整合好视通sdk经验总结(二)

    一 无法正常访问好视通服务接口 当按照android整合好视通sdk经验总结 xff08 一 xff09 步骤整合完毕后 xff0c 在这里修改申请的应用id和服务地址 修改完毕后运行发现无法正常初始化sdk xff0c 错误码30 xff
  • 视觉SLAM⑤--相机与图像

    目录 5 0 本章简介 5 1 相机模型 5 1 1针孔相机模型 5 1 2 畸变模型 5 1 3 双目相机模型 5 1 4 RGB D相机模型 5 2 图像 5 3 实践 xff1a 计算机中的图像 5 3 1 OpenCV的基本使用方法
  • 视觉SLAM⑩后端Ⅱ(滑动窗口滤波和优化与位姿图)

    目录 10 0 本章概述 10 1 滑动窗口滤波和优化 10 1 1 实际环境下的BA结构 10 1 2 滑动窗口法 10 2 位姿图 10 2 1 位姿图的意义 10 2 2位姿图的优化 10 3 非线性优化整体总结 xff1a 前端 后
  • 学习C++:C++进阶(五)CMake应用篇---集成第三方库和依赖管理

    目录 第二部分 xff1a 实用 CMake xff08 Practical CMake Getting Your Hands Dirty with CMake xff09 3 0 集成第三方库和依赖管理 xff08 Integrating
  • 2.ORB-SLAM2改进版本--稠密建图版本解析

    目录 1 修改思路 2 基本概念 nbsp 2 1 统计滤波 2 2 体素滤波
  • FreeRTOS 的命名规则

    初学 FreeRTOS 的用户对其变量和函数的命名比较迷惑 xff0c 下面专门做一下介绍 xff1a 变量 uint32 t 定义的变量都加上前缀 ul u 代表 unsigned 无符号 xff0c l 代表 long 长整型 uint
  • 【单目测距和双目测距比较】

    单目测距和双目测距比较 单 双目方案的优势与难点单目测距双目测距 双目测距实现步骤实现过程 单 双目方案的优势与难点 单目测距 优点 xff1a 单目的优势在于成本较低 xff0c 对计算资源的要求不高 xff0c 系统结构相对简单 缺点
  • ROS学习笔记(3):添加第三方依赖库

    最近在工控机上加入CAN卡 xff0c 想利用CAN卡来做为数据收发 现在在工程中加入CAN卡的头文件和自己做的cpp文档 已经申明了 函数 xff0c 但是还是会出现上图所示的错误 xff0c 经过一晚上的战斗算是搞清楚了 感谢 64 头
  • Java面试题及答案2019版(上)

    1 面向对象的特征有哪些方面 xff1f 答 xff1a 面向对象的特征主要有以下几个方面 xff1a 抽象 xff1a 抽象是将一类对象的共同特征总结出来构造类的过程 xff0c 包括数据抽象和行为抽象两方面 抽象只关注对象有哪些属性和行
  • git到远程出现的一些问题以及解决方法

    我们首先回顾一下 git reset命令 xff1a 1 git reset mixed xff1a 此为默认方式 xff0c 等同于不带任何参数的git reset 2 git reset soft 回退到某个版本 xff0c 只回退了c
  • CMakeLists.txt 和 package.xml 重要内容详解

    边学边看 xff0c 学到什么分享什么 CMakeLists txt 构建配置文件package xml 功能包配置文件 上面的意思个人理解就是功能包本身如果要在别处运行 xff0c 需要什么样的条件在xml文件中看 功能包自身 xff0c
  • Docker运行Prometheus(普罗米修斯)

    1 编辑yaml格式 xff0c 进行自我监控 mkdir etc prometheus cd etc prometheus vi etc prometheus prometheus yml global scrape interval 1
  • Kubernetes(k8s)安装Dashboard(控制面板)

    参考文章 xff1a https www jianshu com p f7ebd54ed0d1 1 默认情况下不会部署 Dashboard xff0c 可以通过以下命令部署 xff1a kubectl apply f https raw g
  • 航模无刷电机常见参数

    1 xff0c KV值 xff1a 表示电机运行速度的指标 xff0c 电机转速 61 KV值 x 工作电压 2 xff0c 空载电流 xff1a 指电机不带负载 xff08 螺旋桨等 xff09 时的额定工作电流 3 xff0c 电阻 x
  • RealSense D435i深度相机介绍

    文章目录 D435i硬件结构及各个组件原理详解前言一 硬件参数信息二 视觉处理器D4三 深度模块四 红外投影仪 Infrared Projector 五 彩色图像信号处理机 ISP 六 IMU D435i硬件结构及各个组件原理详解 前言 R
  • Ubuntu20.04下安装intel Realsense SDK

    1 安装安装依赖项 sudo apt span class token operator span get install libudev span class token operator span dev pkg span class
  • MiniFly的学习经历

    MiniFly的学习经历 基于MiniFly的无人机编队系统一台遥控器同步控制多台无人机无线通讯方面遥控代码部分无人机通信代码部分 一台遥控器分布控制多台无人机无人机控制部分 使用电脑的串口上位机控制无人机遥控串口通信接收指令指令设计 基于

随机推荐

  • 【NOJ1044】【算法实验三】【BFS_分支限界】独轮车

    1044 独轮车 时限 xff1a 1000ms 内存限制 xff1a 10000K 总时限 xff1a 3000ms 描述 独轮车的轮子上有红 黄 蓝 白 绿 xff08 依顺时针序 xff09 5种颜色 在一个如下图所示的20 20的迷
  • 【杭电100题】2073 无限的路

    题目链接 xff1a http acm hdu edu cn showproblem php pid 61 2073 xff08 c语言的double类型printf lf 显示0 00000问题 xff09 xff1a https blo
  • 【杭电100题】2094 产生冠军

    原题 xff1a http acm hdu edu cn showproblem php pid 61 2094 最近很喜欢用map 把成功者 失败者都存起来 然后在成功者里把曾经失败的划掉 最后成功者里如果只剩一个人 xff0c 冠军产生
  • docker命令详解

    镜像下载 搜索镜像docker search 43 镜像名字 docker search centos 从Docker Hub中搜索符合条件的镜像 下载镜像 docker pull 43 镜像名字 docker pull centos 查看
  • uCos中的信号量机制

    文章目录 1 背景2 概述2 1 主要机制及应用2 2 同步或通信的基本方式 3 信号量3 1 主要机制及应用3 2 分类3 3 互斥信号量3 3 1 嵌套 递归 资源访问3 3 2 删除安全 3 4 各种互斥机制的比较3 5 二值信号量3
  • opencv里的几种图像数据格式(CV_8UC3,CV_32FC3,CV_64FC3等)

    opencv里的几种图像数据格式 xff08 CV 8UC3 xff0c CV 32FC3 xff0c CV 64FC3等 xff09 参考 xff1a https blog csdn net qq 29540745 article det
  • android:使用audiotrack 类播放wav文件

    参考 xff1a http mindtherobot com blog 624 android audio play an mp3 file on an audiotrack http baike baidu com view 14471
  • 逆变电路

    逆变的概念 与整流相对应 xff0c 直流电 变成 交流电 交流侧接电网 xff0c 为 有源逆变 交流侧接负载 xff0c 为 无源逆变 xff0c 本章主要讲述无源逆变 逆变与变频 变频电路 xff1a 分为 交交变频 和 交直交变频
  • windows找不到树莓派IP地址

    树莓派用网线连接电脑 xff0c 第一次正常 xff0c 而第二次用arp a找不到树莓派的地址 xff0c 网上查资料 xff0c 网络共享关闭再重新打开依旧找不到 xff0c 后来发现网络处以太网一直显示正在识别 xff0c 把以太网禁
  • unity报错NullReferenceException: Object reference not set to an instance of an object

    在做unity3d的UDP通信时 xff0c 遇到了该的错误 之前初始化用的Start xff0c 运行正常 xff0c 某天突然报错 xff0c 后面看到了文章 https blog csdn net u011185231 article
  • Unity3D UDP通信

    补一下前面遇到的问题 最近在做树莓派与Unity3D的UDP通信 xff0c 树莓派通过网线连接电脑 xff0c 设置网络共享 树莓派作为客户端 xff08 python xff09 xff0c Unity3D作为服务端 xff08 C x
  • ROS机械臂模型的调试

    用传感器串口输出数据控制虚拟机ROS中的6DOF机械臂模型 xff08 每次重新调试都需要一定的时间熟悉过程 xff0c 所以记录一下 不记录代码只记录调试过程 xff09 串口配置 传感器通过USB转TTL模块接到电脑 xff0c 在虚拟
  • openrave

    配置IKFAST求解器 xff0c 装openrave装了一天终于在差三分钟十一点的时候出来了界面 ubuntu18的boost默认1 65 xff0c 但是好像和openrave不匹配 xff0c 换成了1 58 如果后续使用没问题就来详
  • ROS1代码转ROS2

    先占个坑 xff0c 等我做完写总结
  • 四元数基本概念&&四元数3D旋转(求两个四元数的夹角)

    四元数基本概念 1 四元数定义向量形式 xff1a 模长 xff1a 2 四元数加减法 3 四元数的逆和共轭 当q是单位四元数时 xff0c 4 四元数乘法4 1 标量乘法 xff1b 标量s 四元数与标量相乘满足乘法交换律 xff1a 4
  • 树莓派安装64bit系统并安装miniconda

    树莓派安装64bit系统并安装miniconda 某机械臂只有arm64的动态链接库 xff0c 所以如题 中间过程无比曲折 xff0c 记录一下 1 安装64bit系统 1 1 下载系统 树莓派系统官网 xff1a https www r
  • 四旋翼无人机学习第23节--原理图与PCB库开源计划

    在之前的教程中 xff0c 我们学到了原理图和PCB库的绘制方法 xff0c 了解了绘制的基本方法 在之后的学习中 xff0c 我打算从头开源自己的原理图和PCB库 不定期更新 xff0c 方便大家快速的进行PCB设计 这里有几点想要说明
  • 基于openmv的无人机Apriltag动态追踪降落完整项目资料(labview+openmv+apriltag+正点原子四轴)

    前言 xff1a 之前假期做的一个小项目 xff0c 炸了好几套桨叶233 xff0c 分享出来希望能帮助更多人快速学习 使用正点原子ATK MiniFly 飞行器二次开发多旋翼Apriltag追踪 xff1b 使用LABVIEW自主设计地
  • 某公司算法岗笔试题(部分)

    今天参加了第一次笔试 xff0c 准备的不是很好 xff0c 分享几道题 1 选择题 xff1a int i 61 1 const int j 61 1 下列错误的是 xff1a const int p1 61 amp i const in
  • 五、ROS使用serial包进行串口通信

    五 ROS使用serial包进行串口通信 1 下载串口调试助手CuteCom2 下载虚拟串口模拟器socat3 下载串口调试助手minicom4 安装serial串口功能包5 创建工作空间6 创建功能包7 创建发布者8 配置CMakeLis