Official code repositories often include many engineering details, which can be overwhelming for beginners. This repository aims to implement various models with as little code as possible using PyTorch, making it easier for learners to understand and reproduce results. Additionally, most tutorials lack a complete workflow, focusing only on the model without considering data loading and training. This makes it difficult for beginners to apply their knowledge in practice.
For each model, the typical directory structure is as follows:
<model name>/
βββ checkpoints/
βββ components/
βββ datasets/
βββ images/
βββ README.md
βββ data.py
βββ config.py
βββ train.ipynb
βββ inference.ipynb
- checkpoints/: Contains pre-trained model weights for direct use in
inference.ipynb
. Sometimes, pre-trained parameters from official repositories are loaded directly. - components/: Contains components necessary for model implementation.
- datasets/: Contains datasets required for training or inference validation, which may sometimes be downloaded to this directory via code.
- images/: Contains datasets required for training or inference validation, which may sometimes be downloaded to this directory via code.
- README.md: Introduces the implemented task and describes the implementation details.
- data.py: Defines
Dataset
,Dataloader
, or data preprocessing. - config.py: Defines hyperparameters needed for the experiment.
- train.ipynb: Clearly presents the process from data loading, preprocessing, to training and evaluation.
- inference.ipynb: Loads model parameters from the
checkpoints/
directory for inference.
This project uses the MIT License.