Skip to content

nidelson/bmad-module-bcp

Repository files navigation

BCP — Business Complexity Points Scorer

BMAD Module BMAD Version GitHub release Module: MIT Rule: CC BY-NC-ND 4.0

Estimativa por complexidade, não por chute.

Pontue cada story pelo framework Business Complexity Points (BCP) da CI&T. O estimated_hours sai do score × baseline da categoria — recalibrado com horas reais do seu time.

🌐 English 🇺🇸 · este é o manual canônico (PT-BR, default).

⚠️ Documentação canônica em PT-BR. O README.en.md é uma vitrine mínima que aponta para cá. Política completa: ADR 0001.


O problema

Estimativa por "feeling" não escala e não audita. Dois desenvolvedores olham a mesma story e cravam 8h e 40h — sem critério compartilhado, sem rastro de como chegaram lá, sem como melhorar na próxima.

O Business Complexity Points (BCP) — framework publicado pela CI&T — troca o chute por uma régua: 10 elementos de complexidade, cada um dimensionado em 5 tamanhos (XS/S/M/L/XL), pontos Fibonacci. O score total vira horas via um fator h_per_bcp por categoria que o próprio módulo recalibra com horas reais.

O que você ganha

  • Score reproduzível — mesma story, mesma régua, mesmo total. Critério explícito no frontmatter.
  • estimated_hours derivado — horas saem do score × baseline da categoria, não de opinião.
  • Baseline que aprende — recalibração FIFO com horas reais; cada categoria sai do seed depois de N amostras.
  • Trilha de auditoria — todo rescore entra em bcp.history (cap 50), com motivo do delta.
  • Acopla limpo com o PULSE — BCP estima, PULSE mede eficiência. Zero import cruzado, degradação graciosa.

Quick start

Instale o módulo num projeto BMAD (requer BMAD ≥ 6.6.0):

npx bmad-method install --custom-source github:nidelson/bmad-module-bcp

Depois, dentro do projeto:

/bmad-bcp-setup            # configura, semeia o baseline, registra o customize hook
/bmad-bcp-rule-card        # consulta a régua (10 elementos × 5 tamanhos)
/bmad-bcp-score <story>    # pontua uma story e deriva estimated_hours

setup é o consentimento: ao instalar, você autoriza o BCP a ser dono do estimated_hours (o valor original da Amelia é preservado uma única vez em estimated_hours_pre_bcp). Para desligar isso, responda "Não" na pergunta bcp_overwrite_estimated_hours do setup.

Skills inclusas

Comando Faz Depende de
/bmad-bcp-setup Instala, configura, semeia baseline, registra o customize hook
/bmad-bcp-rule-card Renderiza a régua BCP + atribuição CC BY-NC-ND
/bmad-bcp-score Pontua uma story, deriva estimated_hours setup
/bmad-bcp-score-batch Pontua várias stories em lote (retroativo) score
/bmad-bcp-rescore Repontua story já pontuada (+ history + horas) score
/bmad-bcp-recalibrate Recalibra h_per_bcp por categoria com horas reais score
/bmad-bcp-backfill-baseline Mata o cold-start do baseline com o histórico do squad recalibrate
/bmad-bcp-agent-bruno Coach de complexidade (agente facilitador opcional) setup

Bruno — seu coach de complexidade

/bmad-bcp-agent-bruno ativa o Bruno, agente facilitador opcional. Lema: "Régua antes de régua." Ele conduz o scoring elemento a elemento, questiona tamanhos inflados e explica a régua — útil para times entrando no BCP. Não é obrigatório: as skills score/rescore rodam sem ele.

Como funciona

  1. Régua imutável. bcp-rule.yaml é a régua da CI&T transcrita verbatim (CC BY-NC-ND — conteúdo não pode ser alterado; só hints editoriais são mutáveis).
  2. Score. Cada elemento aplicável recebe um tamanho; o tamanho mapeia para pontos Fibonacci (XS=1, S=2, M=3, L=5, XL=8). total = soma do breakdown.
  3. Horas. estimated_hours = total × h_per_bcp(categoria). O fator vem do bcp-baseline.yaml.
  4. Aprendizado. recalibrate alimenta horas reais numa janela FIFO por categoria; ao atingir min_samples, a categoria sai do seed (is_seed: false) e passa a usar a média móvel.

Baseline e recalibração

Parâmetro Default Significado
bcp_baseline_seed 4.13 Horas por BCP no cold start (referência CI&T 2014)
bcp_baseline_min_samples 5 Amostras antes de uma categoria sair do seed
bcp_baseline_rolling_window 10 Tamanho da janela FIFO de recalibração

O baseline vive em {output_folder}/implementation-artifacts/bcp-baseline.yaml. Squad com histórico? /bmad-bcp-backfill-baseline <glob> pontua o passado e calibra sem esperar o acúmulo natural.

Configuração

Setup grava as respostas via o sistema de config em quatro camadas do BMAD. Principais variáveis:

Variável Default Efeito
bcp_overwrite_estimated_hours yes BCP é dono de estimated_hours (preserva _pre_bcp)
bcp_non_interactive_default yes Auto-score direto; dry-run só em divergência
bcp_confidence_threshold 0.75 Acima disso, pula o dry-run review
bcp_estimation_basis bcp Rótulo gravado em estimated_hours_basis
bcp_data_folder {output_folder}/implementation-artifacts Onde baseline e artefatos ficam

Para mudar de forma durável: re-rodar o installer ou usar as camadas _bmad/custom/. Nunca editar _bmad/config.toml direto (installer-owned, regenerado a cada install).

Integração com o PULSE

BCP e PULSE são frouxamente acoplados, mediados por schema — nenhum importa o outro. BCP escreve o bloco bcp.* e o estimated_hours; PULSE lê estimated_hours de forma agnóstica ao escritor e mede eficiência de IA. Nenhum ajuste no PULSE é necessário.

  • BCP escreve: estimated_hours, estimated_hours_pre_bcp, estimated_hours_basis, bcp.*, bcp.history.
  • BCP nunca escreve: pulse_metrics.
  • Se o PULSE estiver ausente, o BCP funciona sozinho. Se o BCP estiver ausente, o PULSE usa a estimativa da Amelia.

Contrato completo: docs/integration/pulse.md. Hook no fluxo de criação de story: docs/integration/bmad-create-story.md.

Licença

Split intencional e load-bearing:

  • Código do módulo — MIT (LICENSE).
  • Régua BCP embarcada (skills/bmad-bcp-rule-card/assets/bcp-rule.yaml) — obra da CI&T, CC BY-NC-ND 4.0. O conteúdo da régua é imutável (ND). Ver ATTRIBUTION.md — aceite da atribuição é pré-requisito de uso, não rodapé.

Requisitos

  • BMAD ≥ 6.6.0 (gate verificado no setup via manifest.yaml).
  • Python 3.11+ (stdlib apenas; scripts rodam sem venv/pip).
  • Opcional: módulo irmão PULSE para medição de eficiência.

Dúvidas e sugestões: https://github.com/nidelson/bmad-module-bcp

About

Estime histórias por complexidade, não por chute. Módulo BMAD do framework Business Complexity Points (BCP) da CI&T: pontos → horas que aprendem conforme seu time acelera na era do AI coding, com coach embarcado.

Topics

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors