2019-12-06 15:42:39

先暂时做个资料保存

要同时用两个红外相机,但是没有做硬件上的 时间戳同步,就是笔记本上同时插着两个相机。

两个topic发布各自相机的图像,然后要有个节点同时订阅两个topic并把两张图像拼接成一张图像再做处理。

直接搜 ros sub two topic结果都是2个callback函数,各自处理各自的topic,和想要的不太一样。

自己融合两个线程中时间戳不那么严格一致的数据太麻烦了

想要的是两张图片的时间戳如果相近,就当做是在同一时刻采集的,然后合成一张图像或者一个topic。

然后发现了下面的链接:

https://stackoverflow.com/questions/55458218/is-it-possible-to-time-synchronize-two-topics-in-ros-of-same-message-type

https://www.cnblogs.com/gdut-gordon/p/10293446.html

http://wiki.ros.org/message_filters#Example_.28Python.29-1

https://blog.csdn.net/chishuideyu/article/details/77479758

https://github.com/DiaboloKiat/sis_lab_all/blob/de74759c3779aa32916a5c61dbc735f8d17c909c/03-ROS_tutorial_1/catkin_ws/src/tutorial/src/test_my_message.py

应该是一个 message_filters ,使用其  ApproximateTime Policy  ,然后就只有一个callback了

https://stackoverflow.com/questions/48830056/use-data-from-multiple-topics-in-ros-python

这个看起来也有点用,先保存

2019-12-06 16:42:49

下面是部分代码,直接改的上面的链接里的代码,384*288 的两张图像

 def callback(left_data, right_data):
temper_left = bridge1.imgmsg_to_cv2(left_data, "mono16")
temper_right = bridge2.imgmsg_to_cv2(right_data, "mono16") disp1 = cv2.normalize(temper_left, None, 0, 255, cv2.NORM_MINMAX)
disp1 = disp1.astype(np.uint8)
disp_color1 = cv2.applyColorMap(disp1, color_map_choice ) disp2 = cv2.normalize(temper_right, None, 0, 255, cv2.NORM_MINMAX)
disp2 = disp2.astype(np.uint8)
disp_color2 = cv2.applyColorMap(disp2, color_map_choice ) disp = np.concatenate((disp_color1, disp_color2), axis=1 ) cv2.imshow("Image window", disp)
cv2.waitKey( 10 ) def gotdesired():
rospy.init_node('image_converter', anonymous=True) sub_left = message_filters.Subscriber("left_infra", Image, queue_size=1, buff_size=110592*6 )
sub_right = message_filters.Subscriber("right_infra", Image, queue_size=1, buff_size=110592*6 ) ts = message_filters.ApproximateTimeSynchronizer([sub_left, sub_right], 10, 0.1, allow_headerless = True)
ts.registerCallback(callback) # spin() simply keeps python from exiting until this node is stopped
rospy.spin()

ros中同时订阅两个topic(2张图像)合并成一个topic(1张图像)的更多相关文章

  1. 如何将两个/多个PDF文件合并成一个?

    原文链接:https://docsmall.com/blog/how-to-merge-pdf 工作中我们总会遇到将PDF合并的问题,比如: 多次扫描的PDF文件,需要合并到一个 PDF文件需要追加一 ...

  2. Clojure:将两个list合并成一个map

    假设我们有两个list,分别是: (def a [“one” “two” “three”]) (def b [1 2 3]) 我们要把它们合为一个键值对应的map,做法很简单: 1. 先将a和b合为一 ...

  3. SQL Server 2005中的分区表(四):删除(合并)一个分区(转)

    在前面我们介绍过如何创建和使用一个分区表,并举了一个例子,将不 同年份的数据放在不同的物理分区表里.具体的分区方式为: 第1个小表:2010-1-1以前的数据(不包含2010-1-1). 第2个小表: ...

  4. SQL Server 2005中的分区表(四):删除(合并)一个分区

    在前面我们介绍过如何创建和使用一个分区表,并举了一个例子,将不 同年份的数据放在不同的物理分区表里.具体的分区方式为: 第1个小表:2010-1-1以前的数据(不包含2010-1-1). 第2个小表: ...

  5. mysql中的多行查询结果合并成一个

    SELECT GROUP_CONCAT(md.data1) FROM DATA md,contacts cc WHERE md.conskey=cc.id AND md.mimetype_id= 5 ...

  6. 将两个DataTable合并成一个DataTable

    转载自 http://blog.csdn.net/wangxiaojia42121/article/details/53330464 谢谢 //两个结构一样的DT合并DataTable DataTab ...

  7. remap——ROS中修改订阅的节点名称

    跑数据集或者使用不同传感器时,难免会遇到需要修改topic名称的时候,此时可以有两种做法. 一.直接修改源码.如果有launch文件,则修改launch文件对应的topic 二.直接进行remap操作 ...

  8. python中如何将两个list合并成一个list,不用for语句

    1, add 2, 用list的extend方法,L1.extend(L2),该方法将参数L2的全部元素添加到L1的尾部,例如: 3, 用切片(slice)操作,L1[len(L1):len(L1)] ...

  9. 牛客网:将两个单调递增的链表合并为一个单调递增的链表-Python实现-两种方法讲解

    方法一和方法二的执行效率,可以大致的计算时间复杂度加以对比,方法一优于方法二   1. 方法一: 思路: 1. 新创建一个链表节点头,假设这里就叫 head3: 2. 因为另外两个链表都为单调递增,所 ...

随机推荐

  1. linux 对外开放端口

    查看守护进程端口 netstat -ntpl 查看开放的端口 iptables -nvL 查看端口是否可访问:telnet ip 端口号 (如本机的35465:telnet localhost 354 ...

  2. SimpleDateFormat线程安全问题

    今天线上出现了问题,从第三方获取的日期为 2019-12-12 11:11:11,通过SimpleDateFormat转换格式后,竟然出现完全不正常的日期数据,经百度,得知SimpleDateForm ...

  3. python 比对PDF文件

    基本思路: 1.读取pdf内容,存放到不同的 list 2.比较 list 的相似度 ------------------------ 实现------------------------- 1.PD ...

  4. express相关操作

    1.   安装应用生成器npm install express-generator –g 2.   生成项目Express --view=ejs myapp 3.   进入项目安装依赖包 npm in ...

  5. C# 校验车架号(VIN码)第9位是否有效算法

    public static bool checkVIN(string vin) { //VIN码从第1位到第17位的“加权值”: Dictionary<int, int> vinMapWe ...

  6. 四款免费好用的Bootstrap ui编辑器

    Bootstrap带来了设计革命,本文介绍的四种免费Bootstrap在线设计工具,可视化所见所得设计网页,然后输出Html/CSS代码,其中有些甚至可以实现拖曳,也有可以设定自己的主题模板Theme ...

  7. 2.1 使用JAXP 对 xml文档进行DOM解析

    //使用 jaxp 对xml文档进行dom解析 public class Demo2 { //必要步骤 @Test public void test() throws Exception { //1. ...

  8. vue打包dist文件时,图片找不到

    1.vue打包dist文件时,图片找不到,无法像在本地一样查看 问题描述: 本地代码:<div class="icon"><img :src="'../ ...

  9. 【Day3】项目实战。百度针对Xpath的反爬策略和解决方式

    import lxml.etree as le with open('edu.html','r',encoding='utf-8') as f: html = f.read() html_x = le ...

  10. insmod: can't insert 'xxx.ko': unknown symbol in module, or unknown parameter

    手动加载内核模块时候,报如下错误信息 insmod: can't insert 'xxx.ko': unknown symbol in module, or unknown parameter 问题原 ...