Forked from ASRF offical code. This repo is the a implementation of replacing original MSTCN backbone with ASFormer.
GTEA, 50Salads, Breakfast
You can download features and G.T. of these datasets from this repository.
Or you can extract their features by yourself using this repository
- Python >= 3.7
- pytorch => 1.0
- torchvision
- pandas
- numpy
- Pillow
- PyYAML
You can download packages using requirements.txt.
pip install -r requirements.txtroot ── csv/
      ├─ libs/
      ├─ imgs/
      ├─ result/
      ├─ utils/
      ├─ dataset ─── 50salads/...
      │           ├─ breakfast/...
      │           └─ gtea ─── features/
      │                    ├─ groundTruth/
      │                    ├─ splits/
      │                    └─ mapping.txt
      ├.gitignore
      ├ README.md
      ├ requirements.txt
      ├ save_pred.py
      ├ train.py
      └ evaluate.py
- csvdirectory contains csv files which are necessary for training and testing.
- An image in imgsis one from PascalVOC. This is used for an color palette to visualize outputs.
- Experimental results are stored in resultsdirectory.
- Scripts in utilsare directly irrelevant withtrain.pyandevaluate.pybut necessary for converting labels, generating configurations, visualization and so on.
- Scripts in libsare necessary for training and evaluation. e.g.) models, loss functions, dataset class and so on.
- The datasets downloaded from this repository are stored in dataset. You can put them in another directory, but need to specify the path in configuration files.
- train.pyis a script for training networks.
- eval.pyis a script for evaluation.
- save_pred.pyis for saving predictions from models.
Please also check scripts/experiment.sh, which runs all the following experimental codes.
- 
First of all, please download features and G.T. of these datasets from this repository. 
- 
Features and groundTruth labels need to be converted to numpy array. This repository does not provide boundary groundtruth labels, so you have to generate them, too. Please run the following command. [DATASET_DIR]is the path to your dataset directory.python utils/generate_gt_array.py --dataset_dir [DATASET_DIR] python utils/generate_boundary_array.py --dataset_dir [DATASET_DIR] 
- 
In this implementation, csv files are used for keeping information of training or test data. You can run the below command to generate csv files, but we suggest to use the csv files provided in the repo. python utils/make_csv_files.py --dataset_dir [DATASET_DIR] 
- 
You can automatically generate experiment configuration files by running the following command. This command generates directories and configuration files in root_dir. However, we suggest to use the config files provided in the repo.python utils/make_config.py --root_dir ./result/50salads --dataset 50salads --split 1 2 3 4 5 python utils/make_config.py --root_dir ./result/gtea --dataset gtea --split 1 2 3 4 python utils/make_config.py --root_dir ./result/breakfast --dataset breakfast --split 1 2 3 4 If you want to add other configurations, please add command-line options like: python utils/make_config.py --root_dir ./result/50salads --dataset 50salads --split 1 2 3 4 5 --learning_rate 0.1 0.01 0.001 0.0001 Please see libs/config.pyabout configurations.
- 
You can train and evaluate models specifying a configuration file generated in the above process like, we train 80 epochs for 50salads dataset in the config.yaml. python train.py ./result/50salads/dataset-50salads_split-1/config.yaml python evaluate.py ./result/50salads/dataset-50salads_split-1/config.yaml test
- 
You can also save model predictions as numpy array by running: python save_pred.py ./result/50salads/dataset-50salads_split-1/config.yaml test
- 
If you want to visualize the saved model predictions, please run: python utils/convert_arr2img.py ./result/50salads/dataset-50salads_split1/predictions 
This repository is released under the MIT License.
@inproceedings{chinayi_ASformer,
author={Fangqiu Yi and Hongyu Wen and Tingting Jiang},
booktitle={The British Machine Vision Conference (BMVC)},
title={ASFormer: Transformer for Action Segmentation},
year={2021},
}
- Yuchi Ishikawa, Seito Kasai, Yoshimitsu Aoki, Hirokatsu Kataoka, "Alleviating Over-segmentation Errors by Detecting Action Boundaries" in WACV 2021.
- Colin Lea et al., "Temporal Convolutional Networks for Action Segmentation and Detection", in CVPR2017 (paper)
- Yazan Abu Farha et al., "MS-TCN: Multi-Stage Temporal Convolutional Network for Action Segmentation", in CVPR2019 (paper, code)