2024-09-05
Spannende Neuigkeiten! FREA wird von CoRL 2024 für eine mündliche Präsentation angenommen ??!2024-08-10
Entdecken Sie unsere Projektseite, jetzt live hier?!2024-08-10
Codes sind jetzt verfügbar!2024-06-05
Unser Artikel ist auf Arxiv verfügbar?!Dieses Repository enthält die Implementierung des Papiers.
FREA: Machbarkeitsgesteuerte Generierung sicherheitskritischer Szenarien mit angemessener Adversarialität
Keyu Chen 1 , Yuheng Lei 2 , Hao Cheng 1 , Haoran Wu 1 , Wenchao Sun 1 , Sifa Zheng 1
1 School of Vehicle and Mobility, Tsinghua University 2 The University of Hong Kong
Wenn Sie unsere Arbeit nützlich finden, geben Sie uns bitte einen Stern?!
? FREA berücksichtigt die Machbarkeit als Leitfaden zur Generierung kontroverser, aber AV-tauglicher und sicherheitskritischer Szenarien.
Empfohlenes System: Ubuntu 20.04 oder 22.04
Schritt 1: Carla installieren (0.9.13 empfohlen)
Schritt 2: Conda-Umgebung einrichten
conda create -n frea python=3.8
conda activate frea
Schritt 3: Klonen Sie dieses Git-Repo in einen geeigneten Ordner
git clone [email protected]:CurryChen77/FREA.git
Schritt 4: Geben Sie den Repo-Stammordner ein und installieren Sie die Pakete:
cd FREA
pip install -r requirements.txt
pip install -e .
# Launch CARLA
./CarlaUE4.sh -prefernvidia -RenderOffScreen -carla-port=2000
# Launch in another terminal
python scripts/run.py --agent_cfg expert.yaml --scenario_cfg standard_train.yaml --mode collect_feasibility_data
# Merge data
python frea/feasibility/unify_offline_data.py
Um den Offline-Datensatz in unserem Paper zu verwenden, laden Sie ihn hier herunter und legen Sie ihn in den feasibility
.
# Train optimal feasible value function of AV
python train_feasibility.py
# Launch CARLA
./CarlaUE4.sh -prefernvidia -RenderOffScreen -carla-port=2000
# Train FREA
python scripts/run.py --agent_cfg expert.yaml --scenario_cfg fppo_adv_train.yaml --mode train_scenario
# Launch CARLA
./CarlaUE4.sh -prefernvidia -RenderOffScreen -carla-port=2000
# Train FPPO-RS
python scripts/run.py --agent_cfg expert.yaml --scenario_cfg fppo_rs_train.yaml --mode train_scenario
# Launch CARLA
./CarlaUE4.sh -prefernvidia -RenderOffScreen -carla-port=2000
# Train PPO
python scripts/run.py --agent_cfg expert.yaml --scenario_cfg ppo_train.yaml --mode train_scenario
# Launch CARLA
./CarlaUE4.sh -prefernvidia -RenderOffScreen -carla-port=2000
# Train FREA
python scripts/run.py --agent_cfg ppo.yaml --scenario_cfg fppo_adv_train.yaml --mode train_agent
# Launch CARLA
./CarlaUE4.sh -prefernvidia -RenderOffScreen -carla-port=2000
# Train FREA
python scripts/run.py --agent_cfg ppo.yaml --scenario_cfg standard_train.yaml --mode train_agent
# Launch CARLA
./CarlaUE4.sh -prefernvidia -windowed -carla-port=2000
# Evaluation FREA
python scripts/run.py --agent_cfg expert.yaml --scenario_cfg FPPO_adv_eval.yaml --mode eval --eval_mode analysis
# Launch CARLA
./CarlaUE4.sh -prefernvidia -windowed -carla-port=2000
# Evaluation FREA
python scripts/run.py --agent_cfg expert.yaml --scenario_cfg FPPO_adv_eval.yaml --mode eval --eval_mode render
Stellen Sie sicher, dass die Auswertung abgeschlossen ist und das Ergebnis im Ordner gespeichert ist.
# Process the recorded data
python eval_analysis/process_data/process_all_data.py
# Plot the evaluation result
python eval_analysis/plot_data/plot_evaluation_result.py
# Launch CARLA
./CarlaUE4.sh -prefernvidia -windowed -carla-port=2000
# Set world spectator
python scripts/run.py --agent_cfg expert.yaml --scenario_cfg standard_eval.yaml --mode eval -sp
# Launch CARLA
./CarlaUE4.sh -prefernvidia -windowed -carla-port=2000
# Visualize AV route
python scripts/run.py --agent_cfg expert.yaml --scenario_cfg standard_eval.yaml --mode eval -viz_route
# Launch CARLA
./CarlaUE4.sh -prefernvidia -windowed -carla-port=2000
# Visualize BEV map
python scripts/run.py --agent_cfg expert.yaml --scenario_cfg FPPO_adv_eval.yaml --mode eval --eval_mode render
Wenn Sie unser Papier nützlich finden, zitieren Sie uns bitte über:
@inproceedings{
chen2024frea,
title={{FREA}: Feasibility-Guided Generation of Safety-Critical Scenarios with Reasonable Adversariality},
author={Keyu Chen and Yuheng Lei and Hao Cheng and Haoran Wu and Wenchao Sun and Sifa Zheng},
booktitle={8th Annual Conference on Robot Learning},
year={2024},
url={https://openreview.net/forum?id=3bcujpPikC}
}
Diese Implementierung basiert auf Code aus mehreren Repositorys. Wir danken den Autoren herzlich für ihre großartige Arbeit.