【中央任务调度系统—通信开发】

简介: 【中央任务调度系统—通信开发】

一、 方案设计目标

学习socket通信、掌握C++编程、熟悉ROS通信机制,完成中央任务调度系统与ROS系统之间数据的交互。


二、 技术指标

上位机开发工具指定为Visual Studio或者Qt;

在Windows上创建客户端,ROS上创建服务器端;

开发上位机人机交互界面,最终实现Windows端“哈喽,轻舟机器人!”“Hello,AI Word!”“1024 1024 1024”等内容与ROS端互传。


三、 主要研究内容

开发上位机,选择Qt,实现效果如图3-1所示:

3.png


图3-1

关于TCP通信

该方案使用TCP通信,TCP协议全称: 传输控制协议, 顾名思义, 就是要对数据的传输进行一定的控制。TCP通信的开始过程可以简述为三次握手,其过程如下:

1, TCP服务器时刻准备接受客户端进程的连接请求, 此时服务器就进入了 LISTEN(监听)状态

2, TCP客户端进程向服务器发出连接请求报文,此时,TCP客户端进程进入了 SYN-SENT(同步已发送状态)状态。

3, TCP服务器收到请求报文后, 如果同意连接, 则发出确认报文。

4, TCP客户端进程收到确认后还, 要向服务器给出确认。

5, 此时,TCP连接建立,客户端进入ESTABLISHED(已建立连接)状态。当服务器收到客户端的确认后也进入ESTABLISHED状态,此后双方就可以开始通信了。

TCP断开连接可以概述为四次挥手:

1, 客户端进程发出连接释放报文,并且停止发送数据。此时客户端进入FIN-WAIT-1(终止等待1)状态。

2, 服务器收到连接释放报文,发出确认报文,此时服务端就进入了CLOSE-WAIT(关闭等待)状态。

3, 客户端收到服务器的确认请求后,此时客户端就进入FIN-WAIT-2(终止等待2)状态,等待服务器发送连接释放报文(在这之前还需要接受服务器发送的最终数据)

4, 服务器将最后的数据发送完毕后,就向客户端发送连接释放报文,此时,服务器就进入了LAST-ACK(最后确认)状态,等待客户端的确认。

5, 客户端收到服务器的连接释放报文后,必须发出确认,当客户端撤销相应的TCB后,才进入CLOSED状态。

6, 服务器只要收到了客户端发出的确认,立即进入CLOSED状态。双方就结束通信。

使用TCP通信将ROS作为服务端,Windows作为服务端,主要代码如下:

import socket
import threading
HOST = '192.168.31.22' # 默认本地IP
PORT = 9877
class RecvThread(threading.Thread):
    def __init__(self, connection):
        threading.Thread.__init__(self)
        self.isEnd = 0
        self.connection = connection
    def run(self):
        while True:
            recv_msg = self.connection.recv(1024)
            if recv_msg:
                buf = recv_msg.decode("gbk")
                print('[---Recv---]\n' + buf + '\n[---End---]')
            else:
                break
        self.isEnd = 1
        print('\n Disconnection!!!')
def main():
    global HOST
    global PORT
    HOST = socket.gethostbyname(socket.gethostname())
    print('欢迎使用江汉大学`轻舟机器人服务器端!')
    print('请输入本地IP, 回车空缺默认为:' + str(HOST))
    ip = input('in:')
    if ip:
        HOST = str(ip)
    print('请输入端口号,回车空缺默认为:'+ str(PORT))
    port = input('in:')
    if port:
        PORT = int(port)
    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  
    sock.bind((HOST, PORT))
    print('本地:' + str(sock.getsockname()))
    sock.listen(5)  
    while True:
        connection, address = sock.accept()
        print('Connection success!')
        print('对方:' + str(connection.getpeername()))
        connection.send(b'welcome to server!')
        connection.send("我是轻舟机器人".encode("gbk"))
        t = RecvThread(connection)
        t.start()
        while t.isEnd == 0:
            buff = input()
            connection.send(buff.encode("gbk"))
        connection.close()
    sock.close()
if __name__ == '__main__':
    main()


实现效果图3-2如下:

3.2.png

图3-2

至此已完成所有技术指标。


四、 技术创新点

在Windows上连接ROS小海龟并控制,Qt效果图如图4-1所示:

4.png


图4-1

整个系统通信方式如图4-2所示:

4.1.png


图4-2

主要代码如下:

from posixpath import split
import rospy
from geometry_msgs.msg import Twist # 发布的消息类型
import socket
HOST = '192.168.31.22' # 默认本地IP
PORT = 9866
if __name__ == "__main__":
  rospy.init_node("key_py")
  pub = rospy.Publisher("/tcp_cmd", Twist, queue_size=1000)
  rospy.Duration(3)
  HOST = socket.gethostbyname(socket.gethostname())
  sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  
  sock.bind((HOST, PORT))
  rospy.loginfo('本地:' + str(sock.getsockname()))
  sock.listen(5)  
  # 发布数据
  while not rospy.is_shutdown():
    connection, address = sock.accept()
    rospy.loginfo('Connection success!')
    rospy.loginfo('对方:' + str(connection.getpeername()))
    while True:
      recv_msg = connection.recv(1024)
      if recv_msg:    
        # rospy.loginfo(recv_msg.decode('gbk'))
        buff = recv_msg.decode('gbk')
        data = buff.split(',',5)
        data = list(map(float, data))
        rospy.loginfo(data)
        # 创建数据
        msg = Twist()
        msg.linear.x = data[0]
        msg.linear.y = data[1]
        msg.linear.z = data[2]
        msg.angular.x = data[3]
        msg.angular.y = data[4]
        msg.angular.z = data[5]
        pub.publish(msg)
      else:
        rospy.loginfo('\n Disconnection!!!')
        connection.close()
        break


实现效果如下图4-3、4-4所示:

4.3.png


图4-3


.4.png

图4-4


五、 研究展望

自定义ROS机器人上位机跳读控制,控制阿克曼小车运动;

将上位机UI界面优化


相关实践学习
Docker镜像管理快速入门
本教程将介绍如何使用Docker构建镜像,并通过阿里云镜像服务分发到ECS服务器,运行该镜像。
阿里云资源编排ROS使用教程
资源编排(Resource Orchestration)是一种简单易用的云计算资源管理和自动化运维服务。用户通过模板描述多个云计算资源的依赖关系、配置等,并自动完成所有资源的创建和配置,以达到自动化部署、运维等目的。编排模板同时也是一种标准化的资源和应用交付方式,并且可以随时编辑修改,使基础设施即代码(Infrastructure as Code)成为可能。 产品详情:https://www.aliyun.com/product/ros/
目录
相关文章
|
19天前
|
前端开发
第8期 volta保证团队开发环境的完全统一
第8期 volta保证团队开发环境的完全统一
24 0
|
9月前
|
设计模式 缓存 JavaScript
学完大佬的分布式系统核心:进程间的通信,事件驱动后,我顿悟了
在GUI编程中,事件是非常常见的。比如,用户在界面单击了按钮,就会发送一个“点击”事件,相应地,会有一个处理“点击”事件的事件处理器来处理该事件。因此,所谓事件驱动,简单地说就是你点什么按钮(即产生什么事件),计算机就执行什么操作(即调用什么函数)。当然事件也不仅限于用户的操作。事件驱动的核心自然是事件。
|
10月前
|
消息中间件 大数据 Linux
Linux进程间通信:实现协作与数据交换的多种方式
多任务并发执行是一种常见的应用场景。在Linux操作系统中,进程间通信(Inter-Process Communication,IPC)是实现多任务协作与数据交换的关键技术。本文将介绍Linux中常用的IPC方式,包括管道、消息队列、共享内存和套接字。
212 0
|
JSON 小程序 JavaScript
【小程序】协同工作和发布
【小程序】协同工作和发布
198 0
【小程序】协同工作和发布
|
安全 JavaScript NoSQL
Worktile 3.1 版发布 让协同工作更简单
Worktile是一款基于 MongoDB、Express、AngularJS 和 Nodejs 打造的团队协作工具。其愿景是让工作更简单。本月新发布了 3.1 版,让我们一起来看看 Worktile 的亮点吧。
319 0
Worktile 3.1 版发布 让协同工作更简单
|
存储 云安全 消息中间件
任务管理入门:如何有效控制大规模设备
在IoT领域核心的场景之一就是云和设备交互。
任务管理入门:如何有效控制大规模设备
|
小程序 安全 IDE
小程序协同工作及版本管理
本节介绍了小程序的成员管理以及支付宝小程序的五种版本。
小程序协同工作及版本管理
|
存储 C++ Docker
(四):C++分布式实时应用框架——状态中心模块
C++分布式实时应用框架——状态中心模块   上篇:(三):C++分布式实时应用框架——系统管理模块     技术交流合作QQ群:436466587 欢迎讨论交流     版权声明:本文版权及所用技术归属smartguys团队所有,对于抄袭,非经同意转载等行为保留法律追究的权利!     状态中心是分布式系统中不可或缺的部分。
1329 0