Phenology/Code/Supervised_learning/resnet/specs/1-phenology-classifier/tasks.md
2025-11-06 14:16:49 +01:00

97 lines
4.1 KiB
Markdown

# Tasks: ResNet Phenology Classifier
**Input**: Design documents from `/specs/1-phenology-classifier/`
**Prerequisites**: plan.md (required), spec.md (required for user stories), research.md, data-model.md, contracts/
**Tests**: Included as per constitution testing standards.
**Organization**: Tasks are grouped by user story to enable independent implementation and testing of each story.
## Format: `[ID] [P?] [Story] Description`
- **[P]**: Can run in parallel (different files, no dependencies)
- **[Story]**: Which user story this task belongs to (e.g., US1, US2, US3)
- Include exact file paths in descriptions
## Path Conventions
- **Single project**: `src/`, `tests/` at repository root
## Dependencies
- US1 (Train Model) must complete before US2 (Evaluate) and US3 (Classify)
- US2 and US3 can run in parallel after US1
## Parallel Execution Examples
- Setup tasks: T001-T005 can run in parallel
- US1 tasks: T010-T015 can run in parallel except for training which depends on data loading
- US2 and US3: Can run in parallel after US1 completion
## Implementation Strategy
- MVP: Complete US1 for basic training capability
- Incremental: Add US2 for evaluation, then US3 for inference
- Each user story delivers independently testable value
## Phase 1: Setup (Shared Infrastructure)
**Purpose**: Project initialization and basic structure
- [x] T001 Create project directory structure per plan.md
- [x] T002 Create requirements.txt with PyTorch, torchvision, pandas, scikit-learn
- [x] T003 Create data/ directory and subdirectories for images and labels
- [x] T004 Create models/ directory for saved models
- [x] T005 Create src/__init__.py and basic module structure
## Phase 2: Foundational (Blocking Prerequisites)
**Purpose**: Core components needed by all user stories
- [x] T006 [P] Implement data loader in src/data_loader.py for CSV labels and image loading
- [x] T007 [P] Define ResNet50 model in src/model.py with classification head
- [x] T008 [P] Create utils.py with preprocessing and helper functions
- [x] T009 [P] Set up test framework with pytest configuration
- [x] T010 [P] Create unit tests for data loader in tests/test_data_loader.py
## Phase 3: US1 - Train ResNet Model
**Purpose**: Enable model training on labeled datasets
**Independent Test**: Train on subset and verify model learns (accuracy improves)
- [x] T011 [P] [US1] Implement training script in src/train.py with data loading and ResNet training loop
- [x] T012 [P] [US1] Add model saving functionality to train.py
- [x] T013 [P] [US1] Implement data augmentation in utils.py for training
- [x] T014 [P] [US1] Create unit tests for training components in tests/test_train.py
- [x] T015 [US1] Integrate training pipeline and test end-to-end training
## Phase 4: US2 - Evaluate Model Performance
**Purpose**: Provide evaluation metrics for trained models
**Independent Test**: Run evaluation on test set and verify metrics output
- [x] T016 [P] [US2] Implement evaluation script in src/evaluate.py with accuracy and F1-score calculation
- [x] T017 [P] [US2] Add per-class metrics and confusion matrix in evaluate.py
- [x] T018 [P] [US2] Create unit tests for evaluation in tests/test_evaluate.py
- [x] T019 [US2] Integrate evaluation and test on trained model
## Phase 5: US3 - Classify New Images
**Purpose**: Enable inference on new plant images
**Independent Test**: Classify sample image and verify output format
- [x] T020 [P] [US3] Implement inference script in src/inference.py for single image classification
- [x] T021 [P] [US3] Create API endpoint in src/api.py using FastAPI for /classify POST
- [x] T022 [P] [US3] Add input validation and error handling in api.py
- [x] T023 [P] [US3] Create unit tests for inference in tests/test_inference.py
- [x] T024 [US3] Integrate API and test classification endpoint
## Final Phase: Polish & Cross-Cutting Concerns
**Purpose**: Quality assurance and production readiness
- [x] T025 Add logging and monitoring to all scripts
- [x] T026 Implement CI/CD pipeline with linting and testing
- [x] T027 Add comprehensive documentation and README updates
- [x] T028 Performance optimization and memory management
- [x] T029 Final integration testing and validation