choreo repository

Repository Summary

Checkout URI https://github.com/yijiangh/Choreo.git
VCS Type git
VCS Version kinetic-devel
Last Updated 2019-07-15
Dev Status DEVELOPED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

README

drawing

CHOREO: A robotic sequence and motion planning framework for spatial extrusion of 3D trusses

Build Status

With Choreo, you will be able to print the following cool structures (and many more!) with ease:

voronoi_extrusion

Check out the the full workflow of Choreo here:

choreo_workflow

Currently, Choreo only supports ROS-kinetic on Ubuntu 16.04.

Note: To increase the flexibility and usability of Choreo, we decided to shift our development and maintenance efforts to pychoreo, a python implementation based on the pybullet simulation engine. This python version implements exactly the same algorithm as its ROS counterpart, but is more flexible and usable (but of course, with some compromise on the computational efficiency). pychoreo is supported on all major platforms: Windows(!), OSX, Linux and has all the core components as the ROS version: collision checking, IKfast, motion planner, stiffness checker, all of which is ROS-free.

       

Installation

If you are new to Linux or ROS, you might find links in the references section handy.

Build from source

| Name | Description | Install | — | — | — | | ROS-kinetic | base ROS system on Ubuntu 16.04 | follow instruction here | | python_catkin_tools | catkin build tool | ```sudo apt-get install python-catkin-tools

| [wstool] | workspace version control | 
```sudo apt install python-wstool
``` |
| [moveit!] | The Moveit! motion planning framework | 
```sudo apt-get install ros-kinetic-moveit
``` |
| [moveit visual tools] | visualization aids in rviz | 
```sudo apt-get install ros-kinetic-moveit-visual-tools
``` |

- Cd into the 'src' directory of your catkin workspace (
```~/catkin_ws/src
``` in my case) and run the following:
  
```bash
  wstool init .
  wstool merge https://github.com/yijiangh/Choreo/raw/kinetic-devel/choreo.rosinstall
  wstool update
  rosdep install --from-paths . --ignore-src
  
  • Finally, build Choreo from src:
  cd ~/catkin_ws (your catkin workspace root)
  catkin build
  source devel/setup.bash
  

Docker image

Coming soon.

Quick start demo

Start playing with robotic spatial extrusion on a KUKA KR6R900 robot:

roslaunch framefab_kr6_r900_support kr6_r900_choreo.launch

KR6R900_demo

Or on an ABB robot mounted on a linear track:

roslaunch framefab_irb6600_support irb6600_choreo.launch

ABB_demo

For a video demo on the topology optimized beam (details in the paper):

large_topopt

First set up your print model by clicking the Parameters button and set up model file path in Model Input (you might need to set up the robot start pose too). Save it and click Next. Some test models for spatial extrusion can be found here.

More detailed instruction coming soon.

Code API

Coming soon.

Publications

If you use this work, please consider citing as follows:

@article{huang2018automated, title={Automated sequence and motion planning for robotic spatial extrusion of 3D trusses}, author={Huang, Yijiang and Garrett, Caelan R and Mueller, Caitlin T}, journal={Construction Robotics}, volume={2}, number={1-4}, pages={15–39}, year={2018}, publisher={Springer} }

Algorithms behind Choreo:

  • Automated sequence and motion planning for robotic spatial extrusion of 3D trusses, Constr Robot (2018) 2:15-39, Arxiv-1810.00998

Applications of Choreo:

  • Robotic extrusion of architectural structures with nonstandard topology, RobArch 2018, paper link
  • Spatial extrusion of Topology Optimized 3D Trusses, IASS 2018, paper link

Bugs & Feature Requests

Please report bugs and request features using the Issue Tracker.

References

If you are new to Linux: You may find it helpful to first do a quick tutorial on common command line tools for linux. A good one is here.

For researchers and developers who wants to dive deep into the system implementation but not familiar to ROS, you may find the official ROS tutorial here useful.

CONTRIBUTING

No CONTRIBUTING.md found.