Bringing more realistic pedestrians movements into CARLA.
A part of Adversarial Cases for Autonomous Vehicles (ARCANE) project.
This project contains submodules when there was no other option of getting the code in (not pip-installable code). So to ensure that all models run correctly, clone with:
git clone --recurse-submodules https://github.com/wielgosz-info/carla-pedestrians.git
Copy .env.template
to .env
in the openpose
, pedestrians-common
, pedestrians-video-2-carla
, pedestrians-scenarios
folders and adjust the variables, especially the path to datasets (e.g. for dataset root VIDEO2CARLA_DATASETS_PATH=/datasets
the expected structure would be /datasets/JAAD
, /datasets/PIE
etc.).
Extract pedestrians skeletons from video clips with OpenPose using container specified in openpose/docker-compose.yml
:
cd openpose
docker-compose -f "docker-compose.yml" --env-file .env up -d --build
docker exec -it carla-pedestrians_openpose_1 /bin/bash
Inside container (after reviewing/modifying extract_poses_from_dataset.sh
):
cd /app
./extract_poses_from_dataset.sh
The generated files will be saved in the carla-pedestrians_outputs
Docker volume. By default the extract_poses.sh
scripts tries to use JAAD
dataset.
Run the CARLA server & the containers with our code. For convenience, there is a compose-up.sh
script provided,
that brings together the multiple docker-compose.yml
files from submodules and sets the common env variables.
When using NVIDIA GPU and some UNIX-like system, you can simply run:
./compose-up.sh
When using CPU, you need to specify PLATFORM=cpu
or modify the script.
Additionally, on MacOS when using Docker Desktop the default GROUP_ID and SHM_SIZE will not work,
so they need to be set manually. The resulting example command to run on MacOS is:
PLATFORM=cpu GROUP_ID=1000 SHM_SIZE=2147483648 ./compose-up.sh
For details about running each individual container, see the relevant README.md
files:
To quickly bring down all the containers in the carla-pedestrians
project, use:
docker-compose down --remove-orphans
Reference skeleton data in pedestrians-video-2-carla/src/pedestrians_video_2_carla/data/carla/files
are extracted form CARLA project Walkers *.uasset files.
If you use this repo please cite:
@misc{wielgosz2023carlabsp,
title={{CARLA-BSP}: a simulated dataset with pedestrians},
author={Maciej Wielgosz and Antonio M. López and Muhammad Naveed Riaz},
month={May},
year={2023},
eprint={2305.00204},
archivePrefix={arXiv},
primaryClass={cs.CV}
}
Our code is released under MIT License.
The most up-to-date third-party info can be found in the submodules repositories, but here is a non-exhaustive list:
This project uses (and is developed to work with) CARLA Simulator, which is released under MIT License.
This project uses videos and annotations from JAAD dataset, created by Amir Rasouli, Iuliia Kotseruba, and John K. Tsotsos, to extract pedestrians movements and attributes. The videos and annotations are released under MIT License.
This project uses OpenPose, created by Ginés Hidalgo, Zhe Cao, Tomas Simon, Shih-En Wei, Yaadhav Raaj, Hanbyul Joo, and Yaser Sheikh, to extract pedestrians skeletons from videos. OpenPose has its own licensing (basically, academic or non-profit organization noncommercial research use only).
This project uses software, models and datasets from Max-Planck Institute for Intelligent Systems, namely VPoser: Variational Human Pose Prior for Body Inverse Kinematics, Body Visualizer, Configer and Perceiving Systems Mesh Package, which have their own licenses (non-commercial scientific research purposes, see each repo for details). The models can be downloaded from "Expressive Body Capture: 3D Hands, Face, and Body from a Single Image" website. Required are the "SMPL-X with removed head bun" or other SMPL-based model that can be fed into BodyModel - right now our code utilizes only first 22 common SMPL basic joints. For VPoser, the "VPoser v2.0" model is used. Both downloaded models need to be put in pedestrians-video-2-carla/models
directory. If using other SMPL models, the defaults in pedestrians-video-2-carla/src/pedestrians_video_2_carla/data/smpl/constants.py
may need to be modified. SMPL-compatible datasets can be obtained from AMASS: Archive of Motion Capture As Surface Shapes. Each available dataset has its own license / citing requirements. During the development of this project, we mainly used CMU and Human Eva SMPL-X Gender Specific datasets.