机器人操作系统(ROS)中控制与智能的一点差异

举报
zhangrelay 发表于 2021/07/15 02:34:01 2021/07/15
【摘要】 PyRobot: An Open Source Robotics Research Platform https://pyrobot.org 这里以机器人操作系统(ROS)为例,简要介绍一下。 为什么选用机器人操作系统?目的:通过标准消息等,控制任意机器人。 以Cozmo机器人为例: 启动Cozmo的ros2驱动: 2019-06-24 1...

PyRobot: An Open Source Robotics Research Platform https://pyrobot.org

这里以机器人操作系统(ROS)为例,简要介绍一下。

为什么选用机器人操作系统?目的:通过标准消息等,控制任意机器人。

以Cozmo机器人为例:

启动Cozmo的ros2驱动:

2019-06-24 18:54:31,011 cozmo.general INFO     App connection established. sdk_version=1.4.10 cozmoclad_version=3.4.0 app_build_version=00003.00004.00000
2019-06-24 18:54:31,012 cozmo.general INFO     Found robot id=1
2019-06-24 18:54:31,029 cozmo.general INFO     Connected to iOS device_id=1 serial=570e1c0859620b942675b7f7010c14f3e086de48
2019-06-24 18:54:31,317 cozmo.general INFO     Robot id=1 serial=45a25ba6 initialized OK
[INFO] []: camera calibration URL: file:///home/relaybot/Robtools/Cozmo/ros2cozmo/src/cozmo_driver/config/cozmo_camera.yaml

$ ros2 topic list

/backpack_led
/battery
/cmd_vel
/cozmo_camera/camera_info
/cozmo_camera/image
/diagnostics
/head_angle
/imu
/joint_states
/lift_height
/odom
/say
/tf


通过/backpack_led控制LED灯,/cmd_vel控制Cozmo速度和转向,/say让cozmo开口说话。

以/say为例:

$ ros2 topic pub -r 0.1  /say s_msgs/String "data: Hello relay, I am cozmo."

publisher: beginning loop
publishing std_msgs.msg.String(data='Hello relay, I am cozmo.')

publishing std_msgs.msg.String(data='Hello relay, I am cozmo.')

publishing std_msgs.msg.String(data='Hello relay, I am cozmo.')

publishing std_msgs.msg.String(data='Hello relay, I am cozmo.')

publishing std_msgs.msg.String(data='Hello relay, I am cozmo.')

publishing std_msgs.msg.String(data='Hello relay, I am cozmo.')

publishing std_msgs.msg.String(data='Hello relay, I am cozmo.')

publishing std_msgs.msg.String(data='Hello relay, I am cozmo.')

publishing std_msgs.msg.String(data='Hello relay, I am cozmo.')


ros2命令很多参数与ros1类似。在学习ros2时,可以顺便复习一下ros1。

这时,我们查看一下cozmo摄像头,先复习如下指令:

$ ros2 run image_tools showimage -- -h
Usage:
 -h: This message.
 -r: Reliability QoS setting:
    0 - best effort
    1 - reliable (default)
 -d: Queue depth. 10 (default)
 -f: Publish frequency in Hz. 30 (default)
 -k: History QoS setting:
    0 - only keep last sample
    1 - keep all the samples (default)
 -s: Camera stream:
    0 - Do not show the camera stream
    1 - Show the camera stream
 -t TOPIC: use topic TOPIC instead of the default


使用如下命令:

$ ros2 run image_tools showimage -t /cozmo_camera/image

获取赛道信息:

可以适当调整头部角度或将手臂抬起,获取更远视角或避免盲区等。

$ ros2 topic pub -r 0.1 /head_ale std_msgs/Float64 "data: -20.0"

$ ros2 topic pub -r 0.1 /lift_hght std_msgs/Float64 "data: 1.0"

 

 

 


这时候回到主题:

如何使用自动控制算法实现自动行驶?参考学习代码如下:

实际为白色虚线,参考为黄色实线:https://github.com/okoeth/cozmo-linefollow


       def image_callback(self, msg):
       image = self.bridge.imgmsg_to_cv2(msg,desired_encoding='bgr8')
       hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)
       lower_yellow = numpy.array([ 10,  10,  10])
       upper_yellow = numpy.array([255, 255, 250])
       mask = cv2.inRange(hsv, lower_yellow, upper_yellow)
      # BEGIN CROP
       h, w, d = image.shape
       search_top = 3*h/4
       search_bot = search_top + 20
       mask[0:search_top, 0:w] = 0
       mask[search_bot:h, 0:w] = 0
      # END CROP
      # BEGIN FINDER
       M = cv2.moments(mask)
      if M['m00'] > 0:
       cx = int(M['m10']/M['m00'])
       cy = int(M['m01']/M['m00'])
      # END FINDER
      # BEGIN CIRCLE
       cv2.circle(image, (cx, cy), 20, (0,0,255), -1)
      # END CIRCLE
       cv2.imshow("window", image)
       cv2.waitKey(3)
  
 

如何使用人工智能算法实现自动行驶?https://github.com/benjafire/CozmoSelfDriveToyUsingCNN/


      #!/usr/bin/env python
      """
      Copyright (c) 2017, benjamin wu
      All rights reserved.
      Redistribution and use in source and binary forms, with or without
      modification, are permitted provided that the following conditions are met:
       * Redistributions of source code must retain the above copyright
       notice, this list of conditions and the following disclaimer.
       * Redistributions in binary form must reproduce the above copyright
       notice, this list of conditions and the following disclaimer in the
       documentation and/or other materials provided with the distribution.
       * Neither the name of Ryan Dellana nor the
       names of its contributors may be used to endorse or promote products
       derived from this software without specific prior written permission.
      THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
      ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
      WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
      DISCLAIMED. IN NO EVENT SHALL Ryan Dellana BE LIABLE FOR ANY
      DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
      (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
      LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
      ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
      (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
      SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
      """
      from __future__ import absolute_import
      from __future__ import division
      from __future__ import print_function
      import argparse
      import numpy as np
      import cv2
      import tensorflow as tf
      import pickle
      from cozmo_cnn_models import cnn_cccccfffff
      import os
      import cv2
      import numpy as np
      import time
      def load_dataset(path, percent_testing=None):
      assert percent_testing is None or (percent_testing >= 0.0 and percent_testing <= 1.0)
       x, y, fnames = [], [], []
      for i in os.walk(path):
       (d, sub_dirs, files_) = i
       fnames.extend(files_)
       seq_fname = []
      for fname in fnames:
       seq = float(fname.split('_')[0])
       seq_fname.append((seq, fname))
       seq_fname.sort()
      for (seq, fname) in seq_fname:
      #img = cv2.imread(path+'/'+fname, 1) for black and white
       img = cv2.imread(path+'/'+fname)
       img = cv2.resize(img, (200, 150), interpolation=cv2.INTER_CUBIC)
       img = img[35:,:,:]
       x.append(img)
       timestamp, lwheel, rwheel = fname.split('_')
       timestamp, lwheel, rwheel = float(timestamp), float(lwheel)/100.0,float(rwheel.split('.jpg')[0])/100.0
      #y.append([[lwheel], [rwheel]])
       y.append(np.array([lwheel, rwheel]))
       print('( timestamp, lwheel, rwheel):',  timestamp,lwheel,rwheel)
       train_x, train_y, test_x, test_y = [], [], [], []
      if percent_testing is not None:
       tst_strt = int(len(x)*(1.0-percent_testing))
       train_x, train_y, test_x, test_y = x[:tst_strt], y[:tst_strt], x[tst_strt:], y[tst_strt:]
      else:
       train_x, train_y = x, y
      return train_x, train_y, test_x, test_y
      #path = '/Users/benja/code/cozmo_sdk_examples_0.15.0/apps/TestImgv2/'
      path = '' # plz fill the img dir you want to train 
      train_x, train_y, test_x, test_y = load_dataset(path=path, percent_testing=0.20)
      num_epochs = 100
      batch_size = 100
      # Drop items from dataset so that it's divisible by batch_size
      train_x = train_x[0:-1*(len(train_x) % batch_size)]
      train_y = train_y[0:-1*(len(train_y) % batch_size)]
      test_x = test_x[0:-1*(len(test_x) % batch_size)]
      test_y = test_y[0:-1*(len(test_y) % batch_size)]
      print('len(test_x) =', len(test_x))
      batches_per_epoch = int(len(train_x)/batch_size)
      sess = tf.InteractiveSession()
      model = cnn_cccccfffff()
      train_step = tf.train.AdamOptimizer(1e-4).minimize(model.loss)
      correct_prediction = tf.equal(tf.argmax(model.y_out,1), tf.argmax(model.y_,1))
      accuracy = tf.reduce_mean(tf.cast(correct_prediction, "float32"))
      saver = tf.train.Saver()
      sess.run(tf.global_variables_initializer())
      for i in range(num_epochs):
      for b in range(0, batches_per_epoch):
       batch = [train_x[b*batch_size:b*batch_size+batch_size], train_y[b*batch_size:b*batch_size+batch_size]]
      # --- normalize batch ---
       batch_ = [[],[]]
      for j in range(len(batch[0])):
       batch_[0].append(batch[0][j].astype(dtype=np.float32)/255.0)
       batch_[1].append(batch[1][j].astype(dtype=np.float32))
       batch = batch_
      # ------------------------
       train_step.run(feed_dict={model.x:batch[0], model.y_:batch[1], model.keep_prob_fc1:0.8, model.keep_prob_fc2:0.8, model.keep_prob_fc3:0.8, model.keep_prob_fc4:0.8})
       print('epoch', i, 'complete')
      if i % 5 == 0:
       test_error = 0.0
      for b in range(0, len(test_x), batch_size):
       batch = [test_x[b:b+batch_size], test_y[b:b+batch_size]]
      # --- normalize batch ---
       batch_ = [[],[]]
      for j in range(len(batch[0])):
       batch_[0].append(batch[0][j].astype(dtype=np.float32)/255.0)
       batch_[1].append(batch[1][j].astype(dtype=np.float32))
       batch = batch_
       test_error_ = model.loss.eval(feed_dict={model.x:batch[0], model.y_:batch[1],
       model.keep_prob_fc1:1.0, model.keep_prob_fc2:1.0,
       model.keep_prob_fc3:1.0, model.keep_prob_fc4:1.0})
      # y_out = model.y_out.eval(session=sess, feed_dict={model.x:batch[0] , 
      # model.keep_prob_fc1:1.0, model.keep_prob_fc2:1.0, 
      # model.keep_prob_fc3:1.0, model.keep_prob_fc4:1.0})
      # print("y out is ", y_out)
      # -----------------------
       test_error += test_error_
       test_error /= len(test_x)/batch_size
       test_accuracy = 1.0 - test_error
       print("test accuracy %g"%test_accuracy)
      filename = saver.save(sess, './cozmo_run_modelv2.ckpt')
  
 

自动控制:设定颜色,识别,给定控制方式;

人工智能:给定策略,不断学习,逐步提升。

不严谨,供参考。


资讯:

ROSCon Fr 2019,將ROSCon方法與法國研究界混合,建立了一個計劃委員會,並公開徵集意見書。計劃委員會收到了20份意見書。

經計劃委員會審查後,選出了20個演示文稿,演講時間從10分鐘到30分鐘不等(根據發言人提案)。選擇的演講涵蓋了廣泛的與ROS相關的主題,例如

  1. SNCF(法國國家鐵路公司)介紹ROS-Railways的演講;
  2. SNCF和Generation Robots之間的聯合演示,提出了一種檢測和跟踪軌道的新方法;
  3. 由Easymov引入RUST和ROS 2,
  4. LORIA用於動態像素伺服電機的roscontrol層;
  5. 介紹如何使用ROS來控制建築物;
  6. 一個演示如何使用ROS為您自己的個人家庭項目,如Anki機器人;
  7. 討論亞馬遜如何使用ROS 2在雲環境中部署機器人應用程序。
  8. 同樣在ROSCon和開發者大會的傳統中,半小時的節目也可用於閃電談話。主持人和觀眾都很有趣。

原文:

ROSCon Fr 2019, mixing the ROSCon method and the French research community, established a programme committee and made a public call for submissions. The programme committee received 20 submissions.

After review by the programme committee, the 20 presentations were selected and given presentation slots ranging from 10 minutes to 30 minutes (based on the speaker proposals). The presentations were selected covered a broad range of ROS-related topics, such as

  • a presentation from SNCF (French National railway company) introducing ROS-Railways;
  • a joint presentation between SNCF and Generation Robots to present a novel method to detect and follow rails;
  • the introduction of RUST with ROS 2 by Easymov,
  • a roscontrol layer for dynamixel servo motor by LORIA;
  • an introduction on how to use ROS to control buildings;
  • a demonstration on how you can use ROS for your own personal home projects such as rosfying an Anki robot;
  • a discussion of how Amazon is robustifying ROS 2 to deploy robots application in a cloud environment.
  • Also in the ROSCon and developer conference tradition, half an hour of the programme was made available for lightning talks. It was fun and interesting for both the presenters and the audience.

https://roscon.fr/

Omri Ben-Bassat ROS’n’Roll - How I ROSified my little Anki Vector home robot This presentation will introduce Vector robot by Anki and show how I ROSified it and what you can do with it using the open-source vector_ros package I built. We’ll learn more about Vector and what makes it such a great robot for entry-level robotics R&D. We’ll talk about the ROSification process itself and ROSication of robots in general. I’ll present the difficulties and dilemmas I had while working on this package and finally, we’ll see a small live demo of the robot tracking a red ball with ROS!

 

文章来源: zhangrelay.blog.csdn.net,作者:zhangrelay,版权归原作者所有,如需转载,请联系作者。

原文链接:zhangrelay.blog.csdn.net/article/details/93510762

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。