ma-agents 3.4.7 → 3.4.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.opencode/skills/.ma-agents.json +134 -134
- package/.opencode/skills/add-sprint/SKILL.md +207 -0
- package/.opencode/skills/add-sprint/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/add-to-sprint/SKILL.md +189 -0
- package/.opencode/skills/add-to-sprint/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/bmad-advanced-elicitation/SKILL.md +137 -0
- package/.opencode/skills/bmad-advanced-elicitation/methods.csv +51 -0
- package/.opencode/skills/bmad-agent-analyst/SKILL.md +56 -0
- package/.opencode/skills/bmad-agent-analyst/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-agent-architect/SKILL.md +52 -0
- package/.opencode/skills/bmad-agent-architect/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-agent-dev/SKILL.md +62 -0
- package/.opencode/skills/bmad-agent-dev/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-agent-pm/SKILL.md +57 -0
- package/.opencode/skills/bmad-agent-pm/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-agent-qa/SKILL.md +59 -0
- package/.opencode/skills/bmad-agent-qa/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-agent-quick-flow-solo-dev/SKILL.md +51 -0
- package/.opencode/skills/bmad-agent-quick-flow-solo-dev/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-agent-sm/SKILL.md +53 -0
- package/.opencode/skills/bmad-agent-sm/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-agent-tech-writer/SKILL.md +55 -0
- package/.opencode/skills/bmad-agent-tech-writer/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-agent-tech-writer/explain-concept.md +20 -0
- package/.opencode/skills/bmad-agent-tech-writer/mermaid-gen.md +20 -0
- package/.opencode/skills/bmad-agent-tech-writer/validate-doc.md +19 -0
- package/.opencode/skills/bmad-agent-tech-writer/write-document.md +20 -0
- package/.opencode/skills/bmad-agent-ux-designer/SKILL.md +53 -0
- package/.opencode/skills/bmad-agent-ux-designer/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-brainstorming/SKILL.md +6 -0
- package/.opencode/skills/bmad-brainstorming/brain-methods.csv +62 -0
- package/.opencode/skills/bmad-brainstorming/steps/step-01-session-setup.md +214 -0
- package/.opencode/skills/bmad-brainstorming/steps/step-01b-continue.md +124 -0
- package/.opencode/skills/bmad-brainstorming/steps/step-02a-user-selected.md +229 -0
- package/.opencode/skills/bmad-brainstorming/steps/step-02b-ai-recommended.md +239 -0
- package/.opencode/skills/bmad-brainstorming/steps/step-02c-random-selection.md +211 -0
- package/.opencode/skills/bmad-brainstorming/steps/step-02d-progressive-flow.md +266 -0
- package/.opencode/skills/bmad-brainstorming/steps/step-03-technique-execution.md +401 -0
- package/.opencode/skills/bmad-brainstorming/steps/step-04-idea-organization.md +305 -0
- package/.opencode/skills/bmad-brainstorming/template.md +15 -0
- package/.opencode/skills/bmad-brainstorming/workflow.md +53 -0
- package/.opencode/skills/bmad-check-implementation-readiness/SKILL.md +6 -0
- package/.opencode/skills/bmad-check-implementation-readiness/steps/step-01-document-discovery.md +179 -0
- package/.opencode/skills/bmad-check-implementation-readiness/steps/step-02-prd-analysis.md +168 -0
- package/.opencode/skills/bmad-check-implementation-readiness/steps/step-03-epic-coverage-validation.md +169 -0
- package/.opencode/skills/bmad-check-implementation-readiness/steps/step-04-ux-alignment.md +129 -0
- package/.opencode/skills/bmad-check-implementation-readiness/steps/step-05-epic-quality-review.md +241 -0
- package/.opencode/skills/bmad-check-implementation-readiness/steps/step-06-final-assessment.md +126 -0
- package/.opencode/skills/bmad-check-implementation-readiness/templates/readiness-report-template.md +4 -0
- package/.opencode/skills/bmad-check-implementation-readiness/workflow.md +49 -0
- package/.opencode/skills/bmad-cis-design-thinking/SKILL.md +6 -0
- package/.opencode/skills/bmad-cis-design-thinking/bmad-skill-manifest.yaml +1 -0
- package/.opencode/skills/bmad-cis-design-thinking/design-methods.csv +31 -0
- package/.opencode/skills/bmad-cis-design-thinking/template.md +111 -0
- package/.opencode/skills/bmad-cis-design-thinking/workflow.md +242 -0
- package/.opencode/skills/bmad-cis-innovation-strategy/SKILL.md +6 -0
- package/.opencode/skills/bmad-cis-innovation-strategy/bmad-skill-manifest.yaml +1 -0
- package/.opencode/skills/bmad-cis-innovation-strategy/innovation-frameworks.csv +31 -0
- package/.opencode/skills/bmad-cis-innovation-strategy/template.md +189 -0
- package/.opencode/skills/bmad-cis-innovation-strategy/workflow.md +315 -0
- package/.opencode/skills/bmad-cis-problem-solving/SKILL.md +6 -0
- package/.opencode/skills/bmad-cis-problem-solving/bmad-skill-manifest.yaml +1 -0
- package/.opencode/skills/bmad-cis-problem-solving/solving-methods.csv +31 -0
- package/.opencode/skills/bmad-cis-problem-solving/template.md +165 -0
- package/.opencode/skills/bmad-cis-problem-solving/workflow.md +291 -0
- package/.opencode/skills/bmad-cis-storytelling/SKILL.md +6 -0
- package/.opencode/skills/bmad-cis-storytelling/bmad-skill-manifest.yaml +1 -0
- package/.opencode/skills/bmad-cis-storytelling/story-types.csv +26 -0
- package/.opencode/skills/bmad-cis-storytelling/template.md +113 -0
- package/.opencode/skills/bmad-cis-storytelling/workflow.md +321 -0
- package/.opencode/skills/bmad-code-review/SKILL.md +6 -0
- package/.opencode/skills/bmad-code-review/steps/step-01-gather-context.md +62 -0
- package/.opencode/skills/bmad-code-review/steps/step-02-review.md +34 -0
- package/.opencode/skills/bmad-code-review/steps/step-03-triage.md +49 -0
- package/.opencode/skills/bmad-code-review/steps/step-04-present.md +129 -0
- package/.opencode/skills/bmad-code-review/workflow.md +55 -0
- package/.opencode/skills/bmad-correct-course/SKILL.md +6 -0
- package/.opencode/skills/bmad-correct-course/checklist.md +288 -0
- package/.opencode/skills/bmad-correct-course/workflow.md +267 -0
- package/.opencode/skills/bmad-create-architecture/SKILL.md +6 -0
- package/.opencode/skills/bmad-create-architecture/architecture-decision-template.md +12 -0
- package/.opencode/skills/bmad-create-architecture/data/domain-complexity.csv +13 -0
- package/.opencode/skills/bmad-create-architecture/data/project-types.csv +7 -0
- package/.opencode/skills/bmad-create-architecture/steps/step-01-init.md +153 -0
- package/.opencode/skills/bmad-create-architecture/steps/step-01b-continue.md +173 -0
- package/.opencode/skills/bmad-create-architecture/steps/step-02-context.md +224 -0
- package/.opencode/skills/bmad-create-architecture/steps/step-03-starter.md +329 -0
- package/.opencode/skills/bmad-create-architecture/steps/step-04-decisions.md +318 -0
- package/.opencode/skills/bmad-create-architecture/steps/step-05-patterns.md +359 -0
- package/.opencode/skills/bmad-create-architecture/steps/step-06-structure.md +379 -0
- package/.opencode/skills/bmad-create-architecture/steps/step-07-validation.md +359 -0
- package/.opencode/skills/bmad-create-architecture/steps/step-08-complete.md +76 -0
- package/.opencode/skills/bmad-create-architecture/workflow.md +38 -0
- package/.opencode/skills/bmad-create-epics-and-stories/SKILL.md +6 -0
- package/.opencode/skills/bmad-create-epics-and-stories/steps/step-01-validate-prerequisites.md +255 -0
- package/.opencode/skills/bmad-create-epics-and-stories/steps/step-02-design-epics.md +212 -0
- package/.opencode/skills/bmad-create-epics-and-stories/steps/step-03-create-stories.md +255 -0
- package/.opencode/skills/bmad-create-epics-and-stories/steps/step-04-final-validation.md +131 -0
- package/.opencode/skills/bmad-create-epics-and-stories/templates/epics-template.md +61 -0
- package/.opencode/skills/bmad-create-epics-and-stories/workflow.md +53 -0
- package/.opencode/skills/bmad-create-prd/SKILL.md +6 -0
- package/.opencode/skills/bmad-create-prd/data/domain-complexity.csv +15 -0
- package/.opencode/skills/bmad-create-prd/data/prd-purpose.md +197 -0
- package/.opencode/skills/bmad-create-prd/data/project-types.csv +11 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-01-init.md +178 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-01b-continue.md +161 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-02-discovery.md +208 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-02b-vision.md +142 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-02c-executive-summary.md +158 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-03-success.md +214 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-04-journeys.md +201 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-05-domain.md +194 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-06-innovation.md +211 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-07-project-type.md +222 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-08-scoping.md +216 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-09-functional.md +219 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-10-nonfunctional.md +230 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-11-polish.md +221 -0
- package/.opencode/skills/bmad-create-prd/steps-c/step-12-complete.md +115 -0
- package/.opencode/skills/bmad-create-prd/templates/prd-template.md +10 -0
- package/.opencode/skills/bmad-create-prd/workflow.md +62 -0
- package/.opencode/skills/bmad-create-story/SKILL.md +6 -0
- package/.opencode/skills/bmad-create-story/checklist.md +357 -0
- package/.opencode/skills/bmad-create-story/discover-inputs.md +88 -0
- package/.opencode/skills/bmad-create-story/template.md +49 -0
- package/.opencode/skills/bmad-create-story/workflow.md +380 -0
- package/.opencode/skills/bmad-create-ux-design/SKILL.md +6 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-01-init.md +135 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-01b-continue.md +127 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-02-discovery.md +190 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-03-core-experience.md +217 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-04-emotional-response.md +220 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-05-inspiration.md +235 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-06-design-system.md +253 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-07-defining-experience.md +255 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-08-visual-foundation.md +225 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-09-design-directions.md +225 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-10-user-journeys.md +242 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-11-component-strategy.md +249 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-12-ux-patterns.md +238 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-13-responsive-accessibility.md +265 -0
- package/.opencode/skills/bmad-create-ux-design/steps/step-14-complete.md +171 -0
- package/.opencode/skills/bmad-create-ux-design/ux-design-template.md +13 -0
- package/.opencode/skills/bmad-create-ux-design/workflow.md +36 -0
- package/.opencode/skills/bmad-dev-story/SKILL.md +6 -0
- package/.opencode/skills/bmad-dev-story/checklist.md +80 -0
- package/.opencode/skills/bmad-dev-story/workflow.md +450 -0
- package/.opencode/skills/bmad-distillator/SKILL.md +178 -0
- package/.opencode/skills/bmad-distillator/agents/distillate-compressor.md +116 -0
- package/.opencode/skills/bmad-distillator/agents/round-trip-reconstructor.md +68 -0
- package/.opencode/skills/bmad-distillator/resources/compression-rules.md +51 -0
- package/.opencode/skills/bmad-distillator/resources/distillate-format-reference.md +227 -0
- package/.opencode/skills/bmad-distillator/resources/splitting-strategy.md +78 -0
- package/.opencode/skills/bmad-distillator/scripts/analyze_sources.py +300 -0
- package/.opencode/skills/bmad-distillator/scripts/tests/test_analyze_sources.py +204 -0
- package/.opencode/skills/bmad-document-project/SKILL.md +6 -0
- package/.opencode/skills/bmad-document-project/checklist.md +245 -0
- package/.opencode/skills/bmad-document-project/documentation-requirements.csv +12 -0
- package/.opencode/skills/bmad-document-project/instructions.md +128 -0
- package/.opencode/skills/bmad-document-project/templates/deep-dive-template.md +345 -0
- package/.opencode/skills/bmad-document-project/templates/index-template.md +169 -0
- package/.opencode/skills/bmad-document-project/templates/project-overview-template.md +103 -0
- package/.opencode/skills/bmad-document-project/templates/project-scan-report-schema.json +160 -0
- package/.opencode/skills/bmad-document-project/templates/source-tree-template.md +135 -0
- package/.opencode/skills/bmad-document-project/workflow.md +27 -0
- package/.opencode/skills/bmad-document-project/workflows/deep-dive-instructions.md +299 -0
- package/.opencode/skills/bmad-document-project/workflows/deep-dive-workflow.md +34 -0
- package/.opencode/skills/bmad-document-project/workflows/full-scan-instructions.md +1107 -0
- package/.opencode/skills/bmad-document-project/workflows/full-scan-workflow.md +34 -0
- package/.opencode/skills/bmad-domain-research/SKILL.md +6 -0
- package/.opencode/skills/bmad-domain-research/domain-steps/step-01-init.md +137 -0
- package/.opencode/skills/bmad-domain-research/domain-steps/step-02-domain-analysis.md +229 -0
- package/.opencode/skills/bmad-domain-research/domain-steps/step-03-competitive-landscape.md +238 -0
- package/.opencode/skills/bmad-domain-research/domain-steps/step-04-regulatory-focus.md +206 -0
- package/.opencode/skills/bmad-domain-research/domain-steps/step-05-technical-trends.md +234 -0
- package/.opencode/skills/bmad-domain-research/domain-steps/step-06-research-synthesis.md +444 -0
- package/.opencode/skills/bmad-domain-research/research.template.md +29 -0
- package/.opencode/skills/bmad-domain-research/workflow.md +49 -0
- package/.opencode/skills/bmad-edit-prd/SKILL.md +6 -0
- package/.opencode/skills/bmad-edit-prd/steps-e/step-e-01-discovery.md +242 -0
- package/.opencode/skills/bmad-edit-prd/steps-e/step-e-01b-legacy-conversion.md +204 -0
- package/.opencode/skills/bmad-edit-prd/steps-e/step-e-02-review.md +245 -0
- package/.opencode/skills/bmad-edit-prd/steps-e/step-e-03-edit.md +250 -0
- package/.opencode/skills/bmad-edit-prd/steps-e/step-e-04-complete.md +165 -0
- package/.opencode/skills/bmad-edit-prd/workflow.md +63 -0
- package/.opencode/skills/bmad-editorial-review-prose/SKILL.md +86 -0
- package/.opencode/skills/bmad-editorial-review-structure/SKILL.md +179 -0
- package/.opencode/skills/bmad-generate-project-context/SKILL.md +6 -0
- package/.opencode/skills/bmad-generate-project-context/project-context-template.md +21 -0
- package/.opencode/skills/bmad-generate-project-context/steps/step-01-discover.md +186 -0
- package/.opencode/skills/bmad-generate-project-context/steps/step-02-generate.md +321 -0
- package/.opencode/skills/bmad-generate-project-context/steps/step-03-complete.md +278 -0
- package/.opencode/skills/bmad-generate-project-context/workflow.md +43 -0
- package/.opencode/skills/bmad-help/SKILL.md +73 -0
- package/.opencode/skills/bmad-index-docs/SKILL.md +66 -0
- package/.opencode/skills/bmad-init/SKILL.md +100 -0
- package/.opencode/skills/bmad-init/resources/core-module.yaml +25 -0
- package/.opencode/skills/bmad-init/scripts/bmad_init.py +593 -0
- package/.opencode/skills/bmad-init/scripts/tests/test_bmad_init.py +329 -0
- package/.opencode/skills/bmad-ma-agent-cyber/SKILL.md +49 -0
- package/.opencode/skills/bmad-ma-agent-cyber/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-ma-agent-devops/SKILL.md +49 -0
- package/.opencode/skills/bmad-ma-agent-devops/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-ma-agent-mil498/.gitkeep +0 -0
- package/.opencode/skills/bmad-ma-agent-mil498/SKILL.md +53 -0
- package/.opencode/skills/bmad-ma-agent-mil498/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-ma-agent-ml/.gitkeep +0 -0
- package/.opencode/skills/bmad-ma-agent-ml/SKILL.md +59 -0
- package/.opencode/skills/bmad-ma-agent-ml/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-ma-agent-sre/.gitkeep +0 -0
- package/.opencode/skills/bmad-ma-agent-sre/SKILL.md +49 -0
- package/.opencode/skills/bmad-ma-agent-sre/bmad-skill-manifest.yaml +11 -0
- package/.opencode/skills/bmad-market-research/SKILL.md +6 -0
- package/.opencode/skills/bmad-market-research/research.template.md +29 -0
- package/.opencode/skills/bmad-market-research/steps/step-01-init.md +184 -0
- package/.opencode/skills/bmad-market-research/steps/step-02-customer-behavior.md +239 -0
- package/.opencode/skills/bmad-market-research/steps/step-03-customer-pain-points.md +251 -0
- package/.opencode/skills/bmad-market-research/steps/step-04-customer-decisions.md +261 -0
- package/.opencode/skills/bmad-market-research/steps/step-05-competitive-analysis.md +173 -0
- package/.opencode/skills/bmad-market-research/steps/step-06-research-completion.md +478 -0
- package/.opencode/skills/bmad-market-research/workflow.md +49 -0
- package/.opencode/skills/bmad-party-mode/SKILL.md +6 -0
- package/.opencode/skills/bmad-party-mode/steps/step-01-agent-loading.md +138 -0
- package/.opencode/skills/bmad-party-mode/steps/step-02-discussion-orchestration.md +187 -0
- package/.opencode/skills/bmad-party-mode/steps/step-03-graceful-exit.md +167 -0
- package/.opencode/skills/bmad-party-mode/workflow.md +190 -0
- package/.opencode/skills/bmad-product-brief/SKILL.md +87 -0
- package/.opencode/skills/bmad-product-brief/agents/artifact-analyzer.md +60 -0
- package/.opencode/skills/bmad-product-brief/agents/opportunity-reviewer.md +44 -0
- package/.opencode/skills/bmad-product-brief/agents/skeptic-reviewer.md +44 -0
- package/.opencode/skills/bmad-product-brief/agents/web-researcher.md +49 -0
- package/.opencode/skills/bmad-product-brief/bmad-manifest.json +17 -0
- package/.opencode/skills/bmad-product-brief/prompts/contextual-discovery.md +57 -0
- package/.opencode/skills/bmad-product-brief/prompts/draft-and-review.md +86 -0
- package/.opencode/skills/bmad-product-brief/prompts/finalize.md +75 -0
- package/.opencode/skills/bmad-product-brief/prompts/guided-elicitation.md +70 -0
- package/.opencode/skills/bmad-product-brief/resources/brief-template.md +60 -0
- package/.opencode/skills/bmad-qa-generate-e2e-tests/SKILL.md +6 -0
- package/.opencode/skills/bmad-qa-generate-e2e-tests/checklist.md +33 -0
- package/.opencode/skills/bmad-qa-generate-e2e-tests/workflow.md +136 -0
- package/.opencode/skills/bmad-quick-dev/SKILL.md +6 -0
- package/.opencode/skills/bmad-quick-dev/spec-template.md +88 -0
- package/.opencode/skills/bmad-quick-dev/step-01-clarify-and-route.md +64 -0
- package/.opencode/skills/bmad-quick-dev/step-02-plan.md +35 -0
- package/.opencode/skills/bmad-quick-dev/step-03-implement.md +37 -0
- package/.opencode/skills/bmad-quick-dev/step-04-review.md +49 -0
- package/.opencode/skills/bmad-quick-dev/step-05-present.md +63 -0
- package/.opencode/skills/bmad-quick-dev/step-oneshot.md +49 -0
- package/.opencode/skills/bmad-quick-dev/workflow.md +79 -0
- package/.opencode/skills/bmad-retrospective/SKILL.md +6 -0
- package/.opencode/skills/bmad-retrospective/workflow.md +1479 -0
- package/.opencode/skills/bmad-review-adversarial-general/SKILL.md +37 -0
- package/.opencode/skills/bmad-review-edge-case-hunter/SKILL.md +67 -0
- package/.opencode/skills/bmad-shard-doc/SKILL.md +105 -0
- package/.opencode/skills/bmad-sprint-planning/SKILL.md +6 -0
- package/.opencode/skills/bmad-sprint-planning/checklist.md +33 -0
- package/.opencode/skills/bmad-sprint-planning/sprint-status-template.yaml +56 -0
- package/.opencode/skills/bmad-sprint-planning/workflow.md +263 -0
- package/.opencode/skills/bmad-sprint-status/SKILL.md +6 -0
- package/.opencode/skills/bmad-sprint-status/workflow.md +261 -0
- package/.opencode/skills/bmad-technical-research/SKILL.md +6 -0
- package/.opencode/skills/bmad-technical-research/research.template.md +29 -0
- package/.opencode/skills/bmad-technical-research/technical-steps/step-01-init.md +137 -0
- package/.opencode/skills/bmad-technical-research/technical-steps/step-02-technical-overview.md +239 -0
- package/.opencode/skills/bmad-technical-research/technical-steps/step-03-integration-patterns.md +248 -0
- package/.opencode/skills/bmad-technical-research/technical-steps/step-04-architectural-patterns.md +202 -0
- package/.opencode/skills/bmad-technical-research/technical-steps/step-05-implementation-research.md +233 -0
- package/.opencode/skills/bmad-technical-research/technical-steps/step-06-research-synthesis.md +487 -0
- package/.opencode/skills/bmad-technical-research/workflow.md +50 -0
- package/.opencode/skills/bmad-validate-prd/SKILL.md +6 -0
- package/.opencode/skills/bmad-validate-prd/data/domain-complexity.csv +15 -0
- package/.opencode/skills/bmad-validate-prd/data/prd-purpose.md +197 -0
- package/.opencode/skills/bmad-validate-prd/data/project-types.csv +11 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-01-discovery.md +221 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-02-format-detection.md +188 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-02b-parity-check.md +206 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-03-density-validation.md +171 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-04-brief-coverage-validation.md +211 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-05-measurability-validation.md +225 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-06-traceability-validation.md +214 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-07-implementation-leakage-validation.md +202 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-08-domain-compliance-validation.md +240 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-09-project-type-validation.md +260 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-10-smart-validation.md +206 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-11-holistic-quality-validation.md +261 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-12-completeness-validation.md +239 -0
- package/.opencode/skills/bmad-validate-prd/steps-v/step-v-13-report-complete.md +229 -0
- package/.opencode/skills/bmad-validate-prd/workflow.md +62 -0
- package/.opencode/skills/cleanup-done/.gitkeep +0 -0
- package/.opencode/skills/create-bug-story/.gitkeep +0 -0
- package/.opencode/skills/create-bug-story/SKILL.md +263 -0
- package/.opencode/skills/create-bug-story/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/cyber-generate-certs/.gitkeep +0 -0
- package/.opencode/skills/cyber-generate-certs/SKILL.md +27 -0
- package/.opencode/skills/cyber-generate-certs/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/cyber-immunity-estimation/.gitkeep +0 -0
- package/.opencode/skills/cyber-immunity-estimation/SKILL.md +29 -0
- package/.opencode/skills/cyber-immunity-estimation/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/cyber-security-audit/.gitkeep +0 -0
- package/.opencode/skills/cyber-security-audit/SKILL.md +27 -0
- package/.opencode/skills/cyber-security-audit/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/cyber-vault-secrets/.gitkeep +0 -0
- package/.opencode/skills/cyber-vault-secrets/SKILL.md +28 -0
- package/.opencode/skills/cyber-vault-secrets/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/cyber-verify-docker-users/.gitkeep +0 -0
- package/.opencode/skills/cyber-verify-docker-users/SKILL.md +23 -0
- package/.opencode/skills/cyber-verify-docker-users/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/cyber-verify-image-signature/.gitkeep +0 -0
- package/.opencode/skills/cyber-verify-image-signature/SKILL.md +22 -0
- package/.opencode/skills/cyber-verify-image-signature/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/cyber-vulnerability-scan/.gitkeep +0 -0
- package/.opencode/skills/cyber-vulnerability-scan/SKILL.md +28 -0
- package/.opencode/skills/cyber-vulnerability-scan/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/devops-configure-infrastructure/.gitkeep +0 -0
- package/.opencode/skills/devops-configure-infrastructure/SKILL.md +27 -0
- package/.opencode/skills/devops-configure-infrastructure/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/devops-disconnected-deployment/.gitkeep +0 -0
- package/.opencode/skills/devops-disconnected-deployment/SKILL.md +27 -0
- package/.opencode/skills/devops-disconnected-deployment/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/devops-docker-compose-setup/.gitkeep +0 -0
- package/.opencode/skills/devops-docker-compose-setup/SKILL.md +26 -0
- package/.opencode/skills/devops-docker-compose-setup/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/devops-manage-helm/.gitkeep +0 -0
- package/.opencode/skills/devops-manage-helm/SKILL.md +28 -0
- package/.opencode/skills/devops-manage-helm/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/devops-sign-docker-image/.gitkeep +0 -0
- package/.opencode/skills/devops-sign-docker-image/SKILL.md +24 -0
- package/.opencode/skills/devops-sign-docker-image/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/generate-backlog/.gitkeep +0 -0
- package/.opencode/skills/mil498-ocd/.gitkeep +0 -0
- package/.opencode/skills/mil498-ocd/SKILL.md +30 -0
- package/.opencode/skills/mil498-ocd/bmad-skill-manifest.yaml +5 -0
- package/.opencode/skills/mil498-ocd/prompts/01-discover-project-artifacts.md +26 -0
- package/.opencode/skills/mil498-ocd/prompts/02-load-template.md +10 -0
- package/.opencode/skills/mil498-ocd/prompts/03-generate-document.md +90 -0
- package/.opencode/skills/mil498-ocd/prompts/04-validate.md +14 -0
- package/.opencode/skills/mil498-ocd/prompts/05-review.md +15 -0
- package/.opencode/skills/mil498-ocd/prompts/06-save.md +15 -0
- package/.opencode/skills/mil498-ocd/template.md +169 -0
- package/.opencode/skills/mil498-sdd/.gitkeep +0 -0
- package/.opencode/skills/mil498-sdd/SKILL.md +30 -0
- package/.opencode/skills/mil498-sdd/bmad-skill-manifest.yaml +5 -0
- package/.opencode/skills/mil498-sdd/prompts/01-discover-project-artifacts.md +50 -0
- package/.opencode/skills/mil498-sdd/prompts/02-load-template.md +10 -0
- package/.opencode/skills/mil498-sdd/prompts/03-generate-document.md +98 -0
- package/.opencode/skills/mil498-sdd/prompts/04-validate.md +16 -0
- package/.opencode/skills/mil498-sdd/prompts/05-review.md +15 -0
- package/.opencode/skills/mil498-sdd/prompts/06-save.md +19 -0
- package/.opencode/skills/mil498-sdd/template.md +163 -0
- package/.opencode/skills/mil498-sdp/.gitkeep +0 -0
- package/.opencode/skills/mil498-sdp/SKILL.md +30 -0
- package/.opencode/skills/mil498-sdp/bmad-skill-manifest.yaml +5 -0
- package/.opencode/skills/mil498-sdp/prompts/01-discover-project-artifacts.md +32 -0
- package/.opencode/skills/mil498-sdp/prompts/02-load-template.md +10 -0
- package/.opencode/skills/mil498-sdp/prompts/03-generate-document.md +187 -0
- package/.opencode/skills/mil498-sdp/prompts/04-validate.md +13 -0
- package/.opencode/skills/mil498-sdp/prompts/05-review.md +15 -0
- package/.opencode/skills/mil498-sdp/prompts/06-save.md +14 -0
- package/.opencode/skills/mil498-sdp/template.md +307 -0
- package/.opencode/skills/mil498-srs/.gitkeep +0 -0
- package/.opencode/skills/mil498-srs/SKILL.md +30 -0
- package/.opencode/skills/mil498-srs/bmad-skill-manifest.yaml +5 -0
- package/.opencode/skills/mil498-srs/prompts/01-discover-project-artifacts.md +42 -0
- package/.opencode/skills/mil498-srs/prompts/02-load-template.md +10 -0
- package/.opencode/skills/mil498-srs/prompts/03-generate-document.md +100 -0
- package/.opencode/skills/mil498-srs/prompts/04-validate.md +16 -0
- package/.opencode/skills/mil498-srs/prompts/05-review.md +15 -0
- package/.opencode/skills/mil498-srs/prompts/06-save.md +18 -0
- package/.opencode/skills/mil498-srs/template.md +219 -0
- package/.opencode/skills/mil498-ssdd/.gitkeep +0 -0
- package/.opencode/skills/mil498-ssdd/SKILL.md +32 -0
- package/.opencode/skills/mil498-ssdd/bmad-skill-manifest.yaml +5 -0
- package/.opencode/skills/mil498-ssdd/prompts/01-discover-project-artifacts.md +32 -0
- package/.opencode/skills/mil498-ssdd/prompts/02-load-template.md +10 -0
- package/.opencode/skills/mil498-ssdd/prompts/03-csci-discovery-interview.md +43 -0
- package/.opencode/skills/mil498-ssdd/prompts/04-generate-document.md +96 -0
- package/.opencode/skills/mil498-ssdd/prompts/05-validate.md +14 -0
- package/.opencode/skills/mil498-ssdd/prompts/06-review.md +16 -0
- package/.opencode/skills/mil498-ssdd/prompts/07-save.md +16 -0
- package/.opencode/skills/mil498-ssdd/template.md +154 -0
- package/.opencode/skills/mil498-sss/.gitkeep +0 -0
- package/.opencode/skills/mil498-sss/SKILL.md +31 -0
- package/.opencode/skills/mil498-sss/bmad-skill-manifest.yaml +5 -0
- package/.opencode/skills/mil498-sss/prompts/01-discover-project-artifacts.md +31 -0
- package/.opencode/skills/mil498-sss/prompts/02-load-template.md +10 -0
- package/.opencode/skills/mil498-sss/prompts/03-generate-document.md +108 -0
- package/.opencode/skills/mil498-sss/prompts/04-validate.md +16 -0
- package/.opencode/skills/mil498-sss/prompts/05-review.md +15 -0
- package/.opencode/skills/mil498-sss/prompts/06-save.md +15 -0
- package/.opencode/skills/mil498-sss/template.md +225 -0
- package/.opencode/skills/mil498-std/.gitkeep +0 -0
- package/.opencode/skills/mil498-std/SKILL.md +30 -0
- package/.opencode/skills/mil498-std/bmad-skill-manifest.yaml +5 -0
- package/.opencode/skills/mil498-std/prompts/01-discover-project-artifacts.md +42 -0
- package/.opencode/skills/mil498-std/prompts/02-load-template.md +10 -0
- package/.opencode/skills/mil498-std/prompts/03-generate-document.md +117 -0
- package/.opencode/skills/mil498-std/prompts/04-validate.md +15 -0
- package/.opencode/skills/mil498-std/prompts/05-review.md +15 -0
- package/.opencode/skills/mil498-std/prompts/06-save.md +15 -0
- package/.opencode/skills/mil498-std/template.md +188 -0
- package/.opencode/skills/ml-advise/.gitkeep +0 -0
- package/.opencode/skills/ml-advise/SKILL.md +76 -0
- package/.opencode/skills/ml-advise/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-advise/skill.json +7 -0
- package/.opencode/skills/ml-analysis/.gitkeep +0 -0
- package/.opencode/skills/ml-analysis/SKILL.md +60 -0
- package/.opencode/skills/ml-analysis/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-analysis/skill.json +7 -0
- package/.opencode/skills/ml-architecture/.gitkeep +0 -0
- package/.opencode/skills/ml-architecture/SKILL.md +55 -0
- package/.opencode/skills/ml-architecture/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-architecture/skill.json +7 -0
- package/.opencode/skills/ml-detailed-design/.gitkeep +0 -0
- package/.opencode/skills/ml-detailed-design/SKILL.md +67 -0
- package/.opencode/skills/ml-detailed-design/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-detailed-design/skill.json +7 -0
- package/.opencode/skills/ml-eda/.gitkeep +0 -0
- package/.opencode/skills/ml-eda/SKILL.md +56 -0
- package/.opencode/skills/ml-eda/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-eda/scripts/baseline_classifier.py +522 -0
- package/.opencode/skills/ml-eda/scripts/class_weights_calculator.py +295 -0
- package/.opencode/skills/ml-eda/scripts/clustering_explorer.py +383 -0
- package/.opencode/skills/ml-eda/scripts/eda_analyzer.py +654 -0
- package/.opencode/skills/ml-eda/skill.json +7 -0
- package/.opencode/skills/ml-experiment/.gitkeep +0 -0
- package/.opencode/skills/ml-experiment/SKILL.md +74 -0
- package/.opencode/skills/ml-experiment/assets/advanced_trainer_configs.py +430 -0
- package/.opencode/skills/ml-experiment/assets/quick_trainer_setup.py +233 -0
- package/.opencode/skills/ml-experiment/assets/template_datamodule.py +219 -0
- package/.opencode/skills/ml-experiment/assets/template_gnn_module.py +341 -0
- package/.opencode/skills/ml-experiment/assets/template_lightning_module.py +158 -0
- package/.opencode/skills/ml-experiment/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-experiment/skill.json +7 -0
- package/.opencode/skills/ml-hparam/.gitkeep +0 -0
- package/.opencode/skills/ml-hparam/SKILL.md +81 -0
- package/.opencode/skills/ml-hparam/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-hparam/skill.json +7 -0
- package/.opencode/skills/ml-ideation/.gitkeep +0 -0
- package/.opencode/skills/ml-ideation/SKILL.md +50 -0
- package/.opencode/skills/ml-ideation/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-ideation/scripts/validate_ml_prd.py +287 -0
- package/.opencode/skills/ml-ideation/skill.json +7 -0
- package/.opencode/skills/ml-infra/.gitkeep +0 -0
- package/.opencode/skills/ml-infra/SKILL.md +58 -0
- package/.opencode/skills/ml-infra/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-infra/skill.json +7 -0
- package/.opencode/skills/ml-retrospective/.gitkeep +0 -0
- package/.opencode/skills/ml-retrospective/SKILL.md +63 -0
- package/.opencode/skills/ml-retrospective/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-retrospective/skill.json +7 -0
- package/.opencode/skills/ml-revision/.gitkeep +0 -0
- package/.opencode/skills/ml-revision/SKILL.md +82 -0
- package/.opencode/skills/ml-revision/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-revision/skill.json +7 -0
- package/.opencode/skills/ml-techspec/.gitkeep +0 -0
- package/.opencode/skills/ml-techspec/SKILL.md +80 -0
- package/.opencode/skills/ml-techspec/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/ml-techspec/skill.json +7 -0
- package/.opencode/skills/modify-sprint/.gitkeep +0 -0
- package/.opencode/skills/modify-sprint/SKILL.md +322 -0
- package/.opencode/skills/modify-sprint/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/prioritize-backlog/.gitkeep +0 -0
- package/.opencode/skills/project-context-expansion/.gitkeep +0 -0
- package/.opencode/skills/project-context-expansion/SKILL.md +238 -0
- package/.opencode/skills/project-context-expansion/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/remove-from-sprint/.gitkeep +0 -0
- package/.opencode/skills/sprint-status-view/.gitkeep +0 -0
- package/.opencode/skills/sprint-status-view/SKILL.md +263 -0
- package/.opencode/skills/sprint-status-view/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/sre-check-deployment-status/.gitkeep +0 -0
- package/.opencode/skills/sre-check-deployment-status/SKILL.md +32 -0
- package/.opencode/skills/sre-check-deployment-status/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/sre-check-secrets/.gitkeep +0 -0
- package/.opencode/skills/sre-check-secrets/SKILL.md +23 -0
- package/.opencode/skills/sre-check-secrets/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/sre-check-system-status/.gitkeep +0 -0
- package/.opencode/skills/sre-check-system-status/SKILL.md +27 -0
- package/.opencode/skills/sre-check-system-status/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/sre-day-2-ops/.gitkeep +0 -0
- package/.opencode/skills/sre-day-2-ops/SKILL.md +26 -0
- package/.opencode/skills/sre-day-2-ops/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/sre-deployment-strategies/.gitkeep +0 -0
- package/.opencode/skills/sre-deployment-strategies/SKILL.md +28 -0
- package/.opencode/skills/sre-deployment-strategies/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/sre-fix-deployments/.gitkeep +0 -0
- package/.opencode/skills/sre-fix-deployments/SKILL.md +25 -0
- package/.opencode/skills/sre-fix-deployments/bmad-skill-manifest.yaml +3 -0
- package/.opencode/skills/sre-gitops-status/.gitkeep +0 -0
- package/.opencode/skills/sre-gitops-status/SKILL.md +25 -0
- package/.opencode/skills/sre-gitops-status/bmad-skill-manifest.yaml +3 -0
- package/.roo/skills/.ma-agents.json +134 -134
- package/bin/cli.js +25 -10
- package/lib/agents.js +21 -51
- package/lib/bmad-extension/module-help.csv +4 -21
- package/lib/bmad-extension/skills/add-sprint/SKILL.md +40 -126
- package/lib/bmad-extension/skills/add-to-sprint/SKILL.md +142 -116
- package/lib/bmad-extension/skills/create-bug-story/SKILL.md +7 -75
- package/lib/bmad-extension/skills/modify-sprint/SKILL.md +0 -63
- package/lib/bmad-extension/skills/sprint-status-view/SKILL.md +138 -199
- package/lib/bmad-extension/workflows/add-sprint/workflow.md +39 -129
- package/lib/bmad-extension/workflows/add-to-sprint/workflow.md +205 -3
- package/lib/bmad-extension/workflows/modify-sprint/workflow.md +0 -5
- package/lib/bmad-extension/workflows/sprint-status-view/workflow.md +192 -3
- package/lib/installer.js +13 -5
- package/package.json +1 -1
- /package/{lib/bmad-extension/skills/cleanup-done → .opencode/skills/add-sprint}/.gitkeep +0 -0
- /package/{lib/bmad-extension/skills/generate-backlog → .opencode/skills/add-to-sprint}/.gitkeep +0 -0
- /package/{lib/bmad-extension/skills/prioritize-backlog → .opencode/skills/bmad-ma-agent-cyber}/.gitkeep +0 -0
- /package/{lib/bmad-extension/skills/remove-from-sprint → .opencode/skills/bmad-ma-agent-devops}/.gitkeep +0 -0
- /package/{lib/bmad-extension → .opencode}/skills/cleanup-done/SKILL.md +0 -0
- /package/{lib/bmad-extension → .opencode}/skills/cleanup-done/bmad-skill-manifest.yaml +0 -0
- /package/{lib/bmad-extension → .opencode}/skills/generate-backlog/SKILL.md +0 -0
- /package/{lib/bmad-extension → .opencode}/skills/generate-backlog/bmad-skill-manifest.yaml +0 -0
- /package/{lib/bmad-extension → .opencode}/skills/prioritize-backlog/SKILL.md +0 -0
- /package/{lib/bmad-extension → .opencode}/skills/prioritize-backlog/bmad-skill-manifest.yaml +0 -0
- /package/{lib/bmad-extension → .opencode}/skills/remove-from-sprint/SKILL.md +0 -0
- /package/{lib/bmad-extension → .opencode}/skills/remove-from-sprint/bmad-skill-manifest.yaml +0 -0
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
"""
|
|
2
|
+
quick_trainer_setup.py — BMAD DL Lifecycle
|
|
3
|
+
Ready-to-run Lightning Trainer configuration for standard DL training runs.
|
|
4
|
+
|
|
5
|
+
Covers: callbacks (early stopping, checkpointing, LR monitor),
|
|
6
|
+
loggers (CSV + optional TensorBoard/W&B), and hardware-aware device selection.
|
|
7
|
+
|
|
8
|
+
Usage:
|
|
9
|
+
python3 assets/quick_trainer_setup.py # prints recommended config
|
|
10
|
+
python3 assets/quick_trainer_setup.py --run # launches a training run (demo)
|
|
11
|
+
|
|
12
|
+
Or import and call build_trainer() in your training script:
|
|
13
|
+
|
|
14
|
+
from assets.quick_trainer_setup import build_trainer
|
|
15
|
+
from src.models.your_model import YourModel
|
|
16
|
+
from src.data.your_datamodule import YourDataModule
|
|
17
|
+
|
|
18
|
+
trainer = build_trainer(max_epochs=50, experiment_name="run_001")
|
|
19
|
+
model = YourModel(num_classes=2)
|
|
20
|
+
dm = YourDataModule(data_dir="data/")
|
|
21
|
+
trainer.fit(model, dm)
|
|
22
|
+
trainer.test(model, dm)
|
|
23
|
+
"""
|
|
24
|
+
|
|
25
|
+
from __future__ import annotations
|
|
26
|
+
|
|
27
|
+
import argparse
|
|
28
|
+
import sys
|
|
29
|
+
from pathlib import Path
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
# ── Lightning import ──────────────────────────────────────────────────────────
|
|
33
|
+
|
|
34
|
+
try:
|
|
35
|
+
import lightning as L
|
|
36
|
+
from lightning.pytorch.callbacks import (
|
|
37
|
+
EarlyStopping, ModelCheckpoint, LearningRateMonitor, RichProgressBar,
|
|
38
|
+
)
|
|
39
|
+
from lightning.pytorch.loggers import CSVLogger
|
|
40
|
+
LIGHTNING_PKG = "lightning"
|
|
41
|
+
except ImportError:
|
|
42
|
+
try:
|
|
43
|
+
import pytorch_lightning as L
|
|
44
|
+
from pytorch_lightning.callbacks import (
|
|
45
|
+
EarlyStopping, ModelCheckpoint, LearningRateMonitor,
|
|
46
|
+
)
|
|
47
|
+
from pytorch_lightning.loggers import CSVLogger
|
|
48
|
+
RichProgressBar = None
|
|
49
|
+
LIGHTNING_PKG = "pytorch_lightning"
|
|
50
|
+
except ImportError:
|
|
51
|
+
L = None # type: ignore
|
|
52
|
+
LIGHTNING_PKG = None
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
def _detect_accelerator() -> tuple[str, int]:
|
|
56
|
+
"""Return (accelerator, devices) based on available hardware, with explicit status output."""
|
|
57
|
+
try:
|
|
58
|
+
import torch
|
|
59
|
+
if torch.cuda.is_available():
|
|
60
|
+
device_name = torch.cuda.get_device_name(0)
|
|
61
|
+
vram_gb = torch.cuda.get_device_properties(0).total_memory / 1e9
|
|
62
|
+
print(f"GPU: {device_name} ({vram_gb:.1f} GB VRAM) — using CUDA")
|
|
63
|
+
return "gpu", torch.cuda.device_count()
|
|
64
|
+
if hasattr(torch.backends, "mps") and torch.backends.mps.is_available():
|
|
65
|
+
print("GPU: Apple MPS — using Metal Performance Shaders")
|
|
66
|
+
return "mps", 1
|
|
67
|
+
except ImportError:
|
|
68
|
+
pass
|
|
69
|
+
print("WARNING: No GPU detected — training will run on CPU and be significantly slower.")
|
|
70
|
+
print(" If you expected a GPU, check your CUDA installation and driver.")
|
|
71
|
+
return "cpu", 1
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
def build_trainer(
|
|
75
|
+
max_epochs: int = 50,
|
|
76
|
+
experiment_name: str = "experiment",
|
|
77
|
+
version: str | None = None,
|
|
78
|
+
log_dir: str | Path = "logs/",
|
|
79
|
+
monitor_metric: str = "val/loss",
|
|
80
|
+
monitor_mode: str = "min",
|
|
81
|
+
early_stopping_patience: int = 10,
|
|
82
|
+
gradient_clip_val: float = 1.0,
|
|
83
|
+
accumulate_grad_batches: int = 1,
|
|
84
|
+
precision: str = "16-mixed",
|
|
85
|
+
) -> "L.Trainer":
|
|
86
|
+
"""
|
|
87
|
+
Build a Lightning Trainer with standard callbacks and logging.
|
|
88
|
+
|
|
89
|
+
Args:
|
|
90
|
+
max_epochs: Maximum training epochs.
|
|
91
|
+
experiment_name: Name used for checkpoint dir and log subdir.
|
|
92
|
+
version: Run identifier appended to log path (e.g. "fold_0", "run_001").
|
|
93
|
+
Prevents different runs from overwriting each other's TensorBoard logs.
|
|
94
|
+
log_dir: Root directory for logs and checkpoints.
|
|
95
|
+
monitor_metric: Metric to monitor for early stopping and checkpointing.
|
|
96
|
+
monitor_mode: "min" (for loss) or "max" (for accuracy/F1).
|
|
97
|
+
early_stopping_patience: Stop after N epochs without improvement.
|
|
98
|
+
gradient_clip_val: Max gradient norm (0.0 to disable clipping).
|
|
99
|
+
accumulate_grad_batches: Simulate larger batch size via gradient accumulation.
|
|
100
|
+
precision: Training precision ("32", "16-mixed", "bf16-mixed").
|
|
101
|
+
|
|
102
|
+
Returns:
|
|
103
|
+
Configured Lightning Trainer.
|
|
104
|
+
"""
|
|
105
|
+
if L is None:
|
|
106
|
+
raise ImportError(
|
|
107
|
+
"PyTorch Lightning not installed.\n"
|
|
108
|
+
" pip install lightning (recommended)\n"
|
|
109
|
+
" or: pip install pytorch-lightning"
|
|
110
|
+
)
|
|
111
|
+
|
|
112
|
+
log_dir = Path(log_dir)
|
|
113
|
+
ckpt_dir = log_dir / "checkpoints" / experiment_name
|
|
114
|
+
ckpt_dir.mkdir(parents=True, exist_ok=True)
|
|
115
|
+
|
|
116
|
+
accelerator, devices = _detect_accelerator()
|
|
117
|
+
|
|
118
|
+
# ── Callbacks ─────────────────────────────────────────────────────────────
|
|
119
|
+
callbacks = [
|
|
120
|
+
ModelCheckpoint(
|
|
121
|
+
dirpath=ckpt_dir,
|
|
122
|
+
filename=f"{experiment_name}-{{epoch:02d}}-{{{monitor_metric}:.4f}}",
|
|
123
|
+
monitor=monitor_metric,
|
|
124
|
+
mode=monitor_mode,
|
|
125
|
+
save_top_k=3,
|
|
126
|
+
save_last=True,
|
|
127
|
+
verbose=True,
|
|
128
|
+
),
|
|
129
|
+
EarlyStopping(
|
|
130
|
+
monitor=monitor_metric,
|
|
131
|
+
mode=monitor_mode,
|
|
132
|
+
patience=early_stopping_patience,
|
|
133
|
+
verbose=True,
|
|
134
|
+
),
|
|
135
|
+
LearningRateMonitor(logging_interval="epoch"),
|
|
136
|
+
]
|
|
137
|
+
if RichProgressBar is not None:
|
|
138
|
+
callbacks.append(RichProgressBar())
|
|
139
|
+
|
|
140
|
+
# ── Loggers ───────────────────────────────────────────────────────────────
|
|
141
|
+
# TensorBoard is required — install with: uv add tensorboard
|
|
142
|
+
# version= keeps each fold/run in its own subdir so they never overwrite each other
|
|
143
|
+
if LIGHTNING_PKG == "lightning":
|
|
144
|
+
from lightning.pytorch.loggers import TensorBoardLogger
|
|
145
|
+
else:
|
|
146
|
+
from pytorch_lightning.loggers import TensorBoardLogger
|
|
147
|
+
|
|
148
|
+
tb_logger = TensorBoardLogger(save_dir=str(log_dir), name=experiment_name, version=version)
|
|
149
|
+
csv_logger = CSVLogger(save_dir=str(log_dir), name=experiment_name, version=version)
|
|
150
|
+
loggers = [tb_logger, csv_logger]
|
|
151
|
+
|
|
152
|
+
log_path = Path(log_dir) / experiment_name / (version or f"version_{tb_logger.version}")
|
|
153
|
+
print(f"Logs → {log_path}/ run: tensorboard --logdir={log_dir}")
|
|
154
|
+
|
|
155
|
+
# ── Precision ─────────────────────────────────────────────────────────────
|
|
156
|
+
# Fall back to 32-bit on CPU (mixed precision not supported)
|
|
157
|
+
if accelerator == "cpu" and precision != "32":
|
|
158
|
+
precision = "32"
|
|
159
|
+
|
|
160
|
+
trainer = L.Trainer(
|
|
161
|
+
max_epochs=max_epochs,
|
|
162
|
+
accelerator=accelerator,
|
|
163
|
+
devices=devices,
|
|
164
|
+
precision=precision,
|
|
165
|
+
gradient_clip_val=gradient_clip_val if gradient_clip_val > 0 else None,
|
|
166
|
+
accumulate_grad_batches=accumulate_grad_batches,
|
|
167
|
+
callbacks=callbacks,
|
|
168
|
+
logger=loggers,
|
|
169
|
+
log_every_n_steps=10,
|
|
170
|
+
deterministic=False, # set True for full reproducibility (slower)
|
|
171
|
+
)
|
|
172
|
+
|
|
173
|
+
return trainer
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
def print_config(max_epochs: int, experiment_name: str, log_dir: str) -> None:
|
|
177
|
+
accelerator, devices = _detect_accelerator()
|
|
178
|
+
print(f"""
|
|
179
|
+
┌─────────────────────────────────────────────────────┐
|
|
180
|
+
│ BMAD DL — Quick Trainer Configuration │
|
|
181
|
+
├─────────────────────────────────────────────────────┤
|
|
182
|
+
│ Lightning package : {LIGHTNING_PKG or 'NOT INSTALLED':<30} │
|
|
183
|
+
│ Hardware : {accelerator.upper()} ({devices} device(s)){'':<19} │
|
|
184
|
+
│ Max epochs : {max_epochs:<30} │
|
|
185
|
+
│ Experiment name : {experiment_name:<30} │
|
|
186
|
+
│ Log directory : {log_dir:<30} │
|
|
187
|
+
├─────────────────────────────────────────────────────┤
|
|
188
|
+
│ Callbacks active: │
|
|
189
|
+
│ ✓ ModelCheckpoint (top-3 + last) │
|
|
190
|
+
│ ✓ EarlyStopping (patience=10) │
|
|
191
|
+
│ ✓ LearningRateMonitor │
|
|
192
|
+
│ ✓ RichProgressBar (if available) │
|
|
193
|
+
│ Loggers active: │
|
|
194
|
+
│ ✓ CSVLogger │
|
|
195
|
+
│ ✓ TensorBoardLogger (if tensorboard installed) │
|
|
196
|
+
└─────────────────────────────────────────────────────┘
|
|
197
|
+
|
|
198
|
+
Quick start in your training script:
|
|
199
|
+
|
|
200
|
+
from assets.quick_trainer_setup import build_trainer
|
|
201
|
+
trainer = build_trainer(max_epochs=50, experiment_name="run_001")
|
|
202
|
+
trainer.fit(model, datamodule)
|
|
203
|
+
trainer.test(model, datamodule)
|
|
204
|
+
|
|
205
|
+
After training, parse results with:
|
|
206
|
+
|
|
207
|
+
python3 scripts/parse_training_logs.py \\
|
|
208
|
+
logs/{experiment_name}/version_0/metrics.csv \\
|
|
209
|
+
docs/prd/01_PRD.md
|
|
210
|
+
""")
|
|
211
|
+
|
|
212
|
+
|
|
213
|
+
def main() -> int:
|
|
214
|
+
parser = argparse.ArgumentParser(description="Quick Trainer Setup — BMAD DL Lifecycle")
|
|
215
|
+
parser.add_argument("--run", action="store_true", help="Launch a demo training run")
|
|
216
|
+
parser.add_argument("--max-epochs", type=int, default=50)
|
|
217
|
+
parser.add_argument("--experiment-name", type=str, default="run_001")
|
|
218
|
+
parser.add_argument("--log-dir", type=str, default="logs/")
|
|
219
|
+
args = parser.parse_args()
|
|
220
|
+
|
|
221
|
+
if args.run:
|
|
222
|
+
if L is None:
|
|
223
|
+
print("Error: PyTorch Lightning not installed.", file=sys.stderr)
|
|
224
|
+
return 2
|
|
225
|
+
print("Demo run requires a model and datamodule. See module docstring.")
|
|
226
|
+
return 1
|
|
227
|
+
|
|
228
|
+
print_config(args.max_epochs, args.experiment_name, args.log_dir)
|
|
229
|
+
return 0
|
|
230
|
+
|
|
231
|
+
|
|
232
|
+
if __name__ == "__main__":
|
|
233
|
+
sys.exit(main())
|
|
@@ -0,0 +1,219 @@
|
|
|
1
|
+
"""
|
|
2
|
+
template_datamodule.py — BMAD DL Lifecycle
|
|
3
|
+
PyTorch Lightning LightningDataModule template.
|
|
4
|
+
|
|
5
|
+
Handles train/val/test dataset loading, transforms, and DataLoader creation
|
|
6
|
+
in a clean, reproducible, and Lightning-compatible way.
|
|
7
|
+
|
|
8
|
+
Usage:
|
|
9
|
+
Copy to src/data/your_datamodule.py and implement the TODO sections.
|
|
10
|
+
Then pass it directly to the Trainer — no manual DataLoaders needed.
|
|
11
|
+
"""
|
|
12
|
+
|
|
13
|
+
from __future__ import annotations
|
|
14
|
+
|
|
15
|
+
from pathlib import Path
|
|
16
|
+
from typing import Optional
|
|
17
|
+
|
|
18
|
+
import torch
|
|
19
|
+
from torch.utils.data import DataLoader, Dataset, random_split
|
|
20
|
+
|
|
21
|
+
try:
|
|
22
|
+
import lightning as L
|
|
23
|
+
LightningDataModule = L.LightningDataModule
|
|
24
|
+
except ImportError:
|
|
25
|
+
try:
|
|
26
|
+
import pytorch_lightning as pl
|
|
27
|
+
LightningDataModule = pl.LightningDataModule
|
|
28
|
+
except ImportError:
|
|
29
|
+
raise ImportError("Install PyTorch Lightning: pip install lightning")
|
|
30
|
+
|
|
31
|
+
try:
|
|
32
|
+
from torchvision import transforms
|
|
33
|
+
HAS_TORCHVISION = True
|
|
34
|
+
except ImportError:
|
|
35
|
+
HAS_TORCHVISION = False
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
# ── TODO: Define or import your Dataset ───────────────────────────────────────
|
|
39
|
+
# Replace this stub with your actual Dataset class.
|
|
40
|
+
|
|
41
|
+
class YourDataset(Dataset):
|
|
42
|
+
"""
|
|
43
|
+
Stub dataset — replace with your implementation.
|
|
44
|
+
|
|
45
|
+
Expected output per __getitem__: (input_tensor, label_tensor)
|
|
46
|
+
"""
|
|
47
|
+
|
|
48
|
+
def __init__(self, data_dir: Path, split: str = "train", transform=None):
|
|
49
|
+
self.data_dir = data_dir
|
|
50
|
+
self.split = split
|
|
51
|
+
self.transform = transform
|
|
52
|
+
|
|
53
|
+
# TODO: load file list, annotations, CSV rows, etc.
|
|
54
|
+
self.samples: list = [] # list of (path_or_data, label)
|
|
55
|
+
|
|
56
|
+
def __len__(self) -> int:
|
|
57
|
+
return len(self.samples)
|
|
58
|
+
|
|
59
|
+
def __getitem__(self, idx: int):
|
|
60
|
+
sample, label = self.samples[idx]
|
|
61
|
+
# TODO: load image/array/features from `sample`
|
|
62
|
+
# x = Image.open(sample).convert("RGB")
|
|
63
|
+
# if self.transform:
|
|
64
|
+
# x = self.transform(x)
|
|
65
|
+
# return x, label
|
|
66
|
+
raise NotImplementedError("Implement __getitem__ in your Dataset")
|
|
67
|
+
|
|
68
|
+
# ── END TODO ──────────────────────────────────────────────────────────────────
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
class YourDataModule(LightningDataModule):
|
|
72
|
+
"""
|
|
73
|
+
Template LightningDataModule.
|
|
74
|
+
|
|
75
|
+
Replace 'YourDataModule' with a descriptive name (e.g. DefectDataModule).
|
|
76
|
+
|
|
77
|
+
Args:
|
|
78
|
+
data_dir: Root directory of your dataset.
|
|
79
|
+
batch_size: Batch size for all DataLoaders.
|
|
80
|
+
num_workers: Number of worker processes for data loading.
|
|
81
|
+
val_split: Fraction of training data to use for validation
|
|
82
|
+
(only used when no explicit val/ directory exists).
|
|
83
|
+
seed: Random seed for reproducibility.
|
|
84
|
+
image_size: (H, W) for image resizing — set None to skip.
|
|
85
|
+
"""
|
|
86
|
+
|
|
87
|
+
def __init__(
|
|
88
|
+
self,
|
|
89
|
+
data_dir: str | Path = "data/",
|
|
90
|
+
batch_size: int = 32,
|
|
91
|
+
num_workers: int = 4,
|
|
92
|
+
val_split: float = 0.15,
|
|
93
|
+
seed: int = 42,
|
|
94
|
+
image_size: tuple[int, int] | None = (224, 224),
|
|
95
|
+
):
|
|
96
|
+
super().__init__()
|
|
97
|
+
self.save_hyperparameters()
|
|
98
|
+
self.data_dir = Path(data_dir)
|
|
99
|
+
|
|
100
|
+
# Built in setup()
|
|
101
|
+
self.train_dataset: Optional[Dataset] = None
|
|
102
|
+
self.val_dataset: Optional[Dataset] = None
|
|
103
|
+
self.test_dataset: Optional[Dataset] = None
|
|
104
|
+
|
|
105
|
+
# ── Transforms ────────────────────────────────────────────────────────────
|
|
106
|
+
|
|
107
|
+
def _train_transform(self):
|
|
108
|
+
"""
|
|
109
|
+
TODO: Define augmentation pipeline for training.
|
|
110
|
+
"""
|
|
111
|
+
if not HAS_TORCHVISION:
|
|
112
|
+
return None
|
|
113
|
+
steps = []
|
|
114
|
+
if self.hparams.image_size:
|
|
115
|
+
steps.append(transforms.Resize(self.hparams.image_size))
|
|
116
|
+
steps += [
|
|
117
|
+
transforms.RandomHorizontalFlip(),
|
|
118
|
+
transforms.RandomRotation(10),
|
|
119
|
+
transforms.ColorJitter(brightness=0.2, contrast=0.2),
|
|
120
|
+
transforms.ToTensor(),
|
|
121
|
+
transforms.Normalize(mean=[0.485, 0.456, 0.406],
|
|
122
|
+
std=[0.229, 0.224, 0.225]),
|
|
123
|
+
]
|
|
124
|
+
return transforms.Compose(steps)
|
|
125
|
+
|
|
126
|
+
def _eval_transform(self):
|
|
127
|
+
"""
|
|
128
|
+
TODO: Define deterministic transform for val/test (no augmentation).
|
|
129
|
+
"""
|
|
130
|
+
if not HAS_TORCHVISION:
|
|
131
|
+
return None
|
|
132
|
+
steps = []
|
|
133
|
+
if self.hparams.image_size:
|
|
134
|
+
steps.append(transforms.Resize(self.hparams.image_size))
|
|
135
|
+
steps += [
|
|
136
|
+
transforms.ToTensor(),
|
|
137
|
+
transforms.Normalize(mean=[0.485, 0.456, 0.406],
|
|
138
|
+
std=[0.229, 0.224, 0.225]),
|
|
139
|
+
]
|
|
140
|
+
return transforms.Compose(steps)
|
|
141
|
+
|
|
142
|
+
# ── Setup ─────────────────────────────────────────────────────────────────
|
|
143
|
+
|
|
144
|
+
def setup(self, stage: Optional[str] = None) -> None:
|
|
145
|
+
"""
|
|
146
|
+
Called by Lightning before fit/test. Initializes dataset splits.
|
|
147
|
+
|
|
148
|
+
stage: "fit" (train+val), "test", "predict", or None (all).
|
|
149
|
+
"""
|
|
150
|
+
# TODO: Adjust split detection logic for your directory layout.
|
|
151
|
+
# Option A — explicit split directories: data/train/, data/val/, data/test/
|
|
152
|
+
has_split_dirs = (
|
|
153
|
+
(self.data_dir / "train").exists() and
|
|
154
|
+
(self.data_dir / "val").exists()
|
|
155
|
+
)
|
|
156
|
+
|
|
157
|
+
if stage in (None, "fit"):
|
|
158
|
+
if has_split_dirs:
|
|
159
|
+
self.train_dataset = YourDataset(
|
|
160
|
+
self.data_dir / "train", split="train",
|
|
161
|
+
transform=self._train_transform(),
|
|
162
|
+
)
|
|
163
|
+
self.val_dataset = YourDataset(
|
|
164
|
+
self.data_dir / "val", split="val",
|
|
165
|
+
transform=self._eval_transform(),
|
|
166
|
+
)
|
|
167
|
+
else:
|
|
168
|
+
# Option B — random split from single dataset directory
|
|
169
|
+
full_dataset = YourDataset(
|
|
170
|
+
self.data_dir, split="train",
|
|
171
|
+
transform=self._train_transform(),
|
|
172
|
+
)
|
|
173
|
+
val_size = int(len(full_dataset) * self.hparams.val_split)
|
|
174
|
+
train_size = len(full_dataset) - val_size
|
|
175
|
+
self.train_dataset, self.val_dataset = random_split(
|
|
176
|
+
full_dataset,
|
|
177
|
+
[train_size, val_size],
|
|
178
|
+
generator=torch.Generator().manual_seed(self.hparams.seed),
|
|
179
|
+
)
|
|
180
|
+
|
|
181
|
+
if stage in (None, "test"):
|
|
182
|
+
test_dir = self.data_dir / "test"
|
|
183
|
+
if test_dir.exists():
|
|
184
|
+
self.test_dataset = YourDataset(
|
|
185
|
+
test_dir, split="test",
|
|
186
|
+
transform=self._eval_transform(),
|
|
187
|
+
)
|
|
188
|
+
|
|
189
|
+
# ── DataLoaders ───────────────────────────────────────────────────────────
|
|
190
|
+
|
|
191
|
+
def train_dataloader(self) -> DataLoader:
|
|
192
|
+
return DataLoader(
|
|
193
|
+
self.train_dataset,
|
|
194
|
+
batch_size=self.hparams.batch_size,
|
|
195
|
+
shuffle=True,
|
|
196
|
+
num_workers=self.hparams.num_workers,
|
|
197
|
+
pin_memory=True,
|
|
198
|
+
drop_last=True,
|
|
199
|
+
)
|
|
200
|
+
|
|
201
|
+
def val_dataloader(self) -> DataLoader:
|
|
202
|
+
return DataLoader(
|
|
203
|
+
self.val_dataset,
|
|
204
|
+
batch_size=self.hparams.batch_size,
|
|
205
|
+
shuffle=False,
|
|
206
|
+
num_workers=self.hparams.num_workers,
|
|
207
|
+
pin_memory=True,
|
|
208
|
+
)
|
|
209
|
+
|
|
210
|
+
def test_dataloader(self) -> DataLoader:
|
|
211
|
+
if self.test_dataset is None:
|
|
212
|
+
raise RuntimeError("No test dataset found. Check data_dir/test/ exists.")
|
|
213
|
+
return DataLoader(
|
|
214
|
+
self.test_dataset,
|
|
215
|
+
batch_size=self.hparams.batch_size,
|
|
216
|
+
shuffle=False,
|
|
217
|
+
num_workers=self.hparams.num_workers,
|
|
218
|
+
pin_memory=True,
|
|
219
|
+
)
|