Differentiable Task Graph Learning: Procedural Activity Representation and Online Mistake Detection from Egocentric Videos
Luigi Seminara, Giovanni Maria Farinella, Antonino Furnari
NeurIPS (spotlight), 2024
arXiv pre-print | Project page
- [October, 2024] We release the Differentiable Task Graph Learning codebase, checkpoints and features.
- [September, 2024] Differentiable Task Graph Learning is accepted in NeurIPS 2024 as spotlight.
- Baselines [LINK]
- Direct Optimization (DO) Model [LINK]
- Task Graph Transformer (TGT) Model [LINK]
- Video Understanding [LINK]
- Online Mistake Detection [LINK]
- Guide for all experiments [LINK]
- Guide for set up Assembly101-O and EPIC-Tent-O [Assembly101-O | EPIC-Tent-O]
- Repository Structure
- Environment configuration
- Data and format
- Qualitative results
- Contact
- Acknowledgements
- Citation
- Authors
Differentiable-Task-Graph-Learning
├── assets
├── configs
│ ├── Baselines
│ ├── CaptainCook4D-DO
│ └── CaptainCook4D-TGT-text
├── data
│ ├── assembly101
│ ├── captaincook4d
│ │ └── ground_truth_task_graphs
│ └── epic-tent
├── lib
└── task-graph-learning
├── DO
├── TGT
├── baselines
├── online-mistake-detection
├── utils
└── video_understanding
assets/
: This folder contains static resources such as images, logos, or visualizations used in the project (for presentations or documentation purposes).configs/
: This directory contains various configuration files, divided into subcategories:Baseline/
: Configurations for baseline methods.CaptainCook4D-DO/
: Configuration files for using CaptainCook4D datasets with the Direct Optimization (DO) model.CaptainCook4D-TGT-text/
: Configuration files for using CaptainCook4D dataset with the Task Graph Transformer (TGT) model based on text embeddings.
data/
: Houses the datasets used in the project.assembly101/
: A subdirectory dedicated to the Assembly101-O dataset.captaincook4d/
: A subdirectory dedicated to the CaptainCook4D dataset.ground_truth_task_graphs/
: Contains ground truth task graphs.
epic-tent/
: A subdirectory dedicated to the EPIC-Tent-O dataset.
lib/
: Contains external libraries, utilities, and custom modules that the project depends on for task graph learning.task-graph-learning/
: Contains all the scripts for run experiments and a guide on how to run them [LINK]DO/
: Contains the scripts to use the Direct Optimization (DO) method for task graph learning.TGT/
: Contains the scripts to use the Task Graph Transformer (TGT) approach for task graph learning.baselines/
: Contains the scripts to use the baselines for task graph generation.online-mistake-detection
: Contains the scripts for online mistake detection experiments.utils/
: Contains scripts for evaluation.video_understanding/
: Contains scripts for video understanding experiments.
The code was tested with Python 3.9. Run the following commands to configurate a new conda environment:
conda create -n tgml python=3.9
conda activate tgml
python -m pip install -e ./lib
conda install -c conda-forge pygraphviz
The specified versions of PyTorch and its associated libraries are recommended for optimal compatibility and performance:
- PyTorch: 2.0.1
- Torchvision: 0.15.2
- Torchaudio: 2.0.2
- PyTorch with CUDA: Version 11.7
These packages can be installed using the following command:
conda install pytorch==2.0.1 torchvision==0.15.2 torchaudio==2.0.2 pytorch-cuda=11.7 -c pytorch -c nvidia
While these versions are recommended, newer versions of these libraries may also be compatible with the project. If you choose to use alternative versions, please ensure they do not introduce any compatibility issues.
In the ./data directory, you will find the CaptainCook4D data that we have defined for our task. This data is provided in compliance with the license defined by the original authors. Our split differs from those defined by the original authors of the paper, as we have only included annotations that do not contain errors. For more information about the original dataset, please visit the official CaptainCook4D repository.
The proposed methods can be used with other datasets that follow the following JSON structure:
{
"annotations": {
"1_14": { // Unique identifier for a specific recording session [MANDATORY]
"recording_id": "1_14", // Identifier for the recording (e.g., video file) [OPTIONAL]
"activity_id": 1, // Numeric ID of the activity being performed [OPTIONAL]
"activity_name": "Microwave Egg Sandwich", // Name of the activity being performed [MANDATORY]
"person_id": 1, // ID of the person performing the task [OPTIONAL]
"environment": 5, // Numeric code representing the environment (e.g., kitchen type) [OPTIONAL]
"scenario": "microwaveeggsandwich", // Scenario name as a string (used for taxonomy linking) [MANDATORY]
"segments": [
{
"step_id": 12, // Step number within the activity [MANDATORY]
"start_time": 0.799, // Start time of the segment (in seconds) [MANDATORY]
"end_time": 87.74, // End time of the segment (in seconds) [MANDATORY]
"description": "Cut - Cut the English muffin into two pieces with a knife", // Text description of the action being performed [MANDATORY]
"has_errors": false, // Boolean flag indicating whether this segment contains any errors [OPTIONAL]
"step_name": "Cut - Cut the English muffin into two pieces with a knife" // Name of the action or step being performed [MANDATORY]
},
...
]
}
...
},
"taxonomy": {
"microwaveeggsandwich": { // Category or task label for the scenario
"1": { // This is the same of the "id"
"name": "Pour - Pour 1 egg into the ramekin cup", // Name of the step in the taxonomy [MANDATORY]
"id": 1, // Unique ID of this step [MANDATORY]
"is_leafnode": true, // Boolean flag indicating if this step is a leaf node (i.e., has no substeps) [OPTIONAL]
"parent_id": null, // ID of the parent step (null if no parent) [OPTIONAL]
"parent_name": null // Name of the parent step (null if no parent) [OPTIONAL]
},
...
}
}
}
NOTE: Fields marked MANDATORY are required for the proposed methods to work, while fields marked OPTIONAL can be absent without affecting the functionality of the code.
The figure reports the generated task graphs of the procedure called "Dressed Up Meatballs". On the left there is the ground truth task graph, while on the right the generated using the Direct Optimization model. These graphs must be interpreted from the bottom up, reflecting the bottom-up nature of dependency edges. Other qualitative results are reported in the supplementary material of the paper.
Ground Truth | Generated |
---|---|
The figure shows a success (left) and failure (right) case on EPIC-Tent. Past key-steps' colors match nodes' colors. On the left, the current key-step "Pickup/Open Stakebag" is correctly evaluated as a mistake because the step "Pickup/Place Ventcover" is a precondition of the current key-step, but it is not included among the previous key-steps. On the right, "Pickup/Open Supportbag" is incorrectly evaluated as mistake because the step "Spread Tent" is precondition of the current key-step, but it is not included among the previous key-steps. This is due to the fact that our method wrongly predicted "Spread Tent" as a pre-condition of "Pickup/Open Supportbag", probably due to the two actions often occurring in this order.
This repository is created and maintained by Luigi. Technical questions and discussions are encouraged via GitHub issues, as this allows everyone interested in the work to benefit from the shared information. However, you can always reach us directly via email.
This research is supported in part by the PNRR PhD scholarship "Digital Innovation: Models, Systems and Applications" DM 118/2023, by the project Future Artificial Intelligence Research (FAIR) – PNRR MUR Cod. PE0000013 - CUP: E63C22001940006, and by the Research Program PIAno di inCEntivi per la Ricerca di Ateneo 2020/2022 — Linea di Intervento 3 "Starting Grant" EVIPORES Project - University of Catania.
We thank the authors of PREGO and in particular Alessandro Flaborea and Guido Maria D'Amely di Melendugno for sharing the code to replicate experiments in the PREGO benchmark.
Visit PREGO repository for more details.
If you use the code/models hosted in this repository, please cite the following paper:
@article{seminara2024differentiable,
title={Differentiable Task Graph Learning: Procedural Activity Representation and Online Mistake Detection from Egocentric Videos},
author={Seminara, Luigi and Farinella, Giovanni Maria and Furnari, Antonino},
journal={arXiv preprint arXiv:2406.01486},
year={2024}
}
Please, refer to the paper for more technical details.