This is the code for the RSS 2020 paper "VisuoSpatial Foresight for Multi-Step, Multi-Task Fabric Manipulation" (arXiv, project website). It contains all code except for the physical experiments with the surgical robot, which is here. If you find the code useful, please consider citing the paper:
@inproceedings{fabric_vsf_2020,
    author = {Ryan Hoque and Daniel Seita and Ashwin Balakrishna and Aditya Ganapathi and Ajay Tanwani and Nawid Jamali and Katsu Yamane and Soshi Iba and Ken Goldberg},
    title = {{VisuoSpatial Foresight for Multi-Step, Multi-Task Fabric Manipulation}},
    booktitle = {Robotics: Science and Systems (RSS)},
    Year = {2020}
}
This repository is built off the gym-cloth repository, an RL environment wrapped around a fabric simulator. The repository includes code for fabric manipulation with VSF (see the project website here), primarily in the vismpc/ directory. The most relevant files for Visual MPC are scripts/run.py, cfg/sim.yaml, gym_cloth/envs/cloth_env.py, and vismpc/mpc.py. See vismpc/README.md for detailed instructions.
Instructions for gym-cloth in general are below:
This creates a gym environment based on our cloth simulator. The path directory
is structured following standard gym conventions, and we also include our
.pyx files here for Cython compilation.
Platforms tested:
- Mac OS X (renderer working)
- Ubuntu 16.04 (renderer not working, unfortunately)
- Ubuntu 18.04 (renderer working)
Python versions tested:
- Python 2.7
- Python 3.6
The code is hopefully agnostic to Python 2 or 3, however we strongly recommend using Python 3. We have not done any serious Python 2 testing for many months.
- 
Make a new virtualenv. For example, if you're using Python 2 and you put your environments in a directory ~/Envs:virtualenv --python=python2 ~/Envs/py2-clothsim
- 
Run pip install -r requirements.txt.
- 
Run python setup.py install. This should automatically "cythonize" the Python.pyxfiles and allow you to runfrom gym_cloth import ...regarless of current directory. You will need to re-run this command after making any changes ingym_cloth/orvismpc/, for example:python setup.py install ; python scripts/run.py
To visualize the simulator in real time, you will need to install the OpenGL renderer,
which is currently an independent C++ program. However this won't be possible if running
Visual MPC on a remote server. In this case, there are other ways to inspect results
(see vismpc/README.md).
These instructions have been tested on Mac OS X and Ubuntu 18.04. For some
reason, we have not been able to get this working for Ubuntu 16.04. For Ubuntu 18.04, you
might need sudo access for make -j4 install.
- Navigate to render/ext/libzmq. Run
mkdir build
cd build
cmake ..
make -j4 install
- Navigate to render/ext/cppzmq. Again run
mkdir build
cd build
cmake ..
make -j4 install
- Navigate to render. Run
mkdir build
cd build
cmake ..
make
Finally you should have an executable clothsim in render/build. To test
that it is working, go to render/build and run ./clothsim on the command
line. You should see an empty window appear. There should be no segmentation
faults. Occasionally I have seen it fail on installed machines, but normally
rebooting fixes it.
To activate the renderer, set init: render_opengl to True in your cfg file.
Notes:
- 
If you make changes to width,height, orrender_portincfg/env_config.yaml, please also updatenum_width_points,num_height_points, andrender_portrespectively inrender/scene/pinned2.json.
- 
It's easier to change the viewing angle by directly adjusting values in clothSimulator.cpp, rather than with the mouse and GUI. When you adjust the camera angles, be sure to re-compile the renderer using the instructions above. You only need to re-compilerender, not the other two.