Skip to content

Latest commit

 

History

History
224 lines (176 loc) · 13.3 KB

File metadata and controls

224 lines (176 loc) · 13.3 KB

Differentiable Task Graph Learning: Procedural Activity Representation and Online Mistake Detection from Egocentric Videos

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

Stargazers Forks Issues

LinkedIn X

python pytorch

📢 News

  • [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.

🎯 What's inside?

  • 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

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.

Environment configuration

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.

Data and format

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.

Qualitative results

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
First Image Second Image

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.

OMD

Contact

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.

Acknowledgements

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.

Citation

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.

Authors

Authors