@winspan/claude-forge 3.1.0 → 3.5.2
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/README.md +2 -2
- package/dist/ai/base-provider.d.ts.map +1 -0
- package/dist/ai/base-provider.js.map +1 -0
- package/dist/ai/factory.d.ts.map +1 -0
- package/dist/ai/factory.js.map +1 -0
- package/dist/{ai-gateway → ai}/index.d.ts +2 -2
- package/dist/ai/index.d.ts.map +1 -0
- package/dist/ai/index.js.map +1 -0
- package/dist/ai/model-selector.d.ts.map +1 -0
- package/dist/ai/model-selector.js.map +1 -0
- package/dist/ai/ollama-provider.d.ts.map +1 -0
- package/dist/ai/ollama-provider.js.map +1 -0
- package/dist/ai/openai-provider.d.ts.map +1 -0
- package/dist/ai/openai-provider.js.map +1 -0
- package/dist/ai/rate-limiter.d.ts.map +1 -0
- package/dist/ai/rate-limiter.js.map +1 -0
- package/dist/ai/response-cache.d.ts.map +1 -0
- package/dist/ai/response-cache.js.map +1 -0
- package/dist/ai/token-budget.d.ts.map +1 -0
- package/dist/ai/token-budget.js.map +1 -0
- package/dist/ai/types.d.ts.map +1 -0
- package/dist/ai/types.js.map +1 -0
- package/dist/autopilot/index.d.ts +0 -1
- package/dist/autopilot/index.d.ts.map +1 -1
- package/dist/autopilot/index.js +0 -1
- package/dist/autopilot/index.js.map +1 -1
- package/dist/autopilot/issue-tracker.d.ts +1 -1
- package/dist/autopilot/issue-tracker.d.ts.map +1 -1
- package/dist/autopilot/issue-tracker.js +1 -1
- package/dist/autopilot/issue-tracker.js.map +1 -1
- package/dist/autopilot/phase-gap-detector.d.ts +1 -1
- package/dist/autopilot/phase-gap-detector.d.ts.map +1 -1
- package/dist/autopilot/phase-gap-detector.js +1 -1
- package/dist/autopilot/phase-gap-detector.js.map +1 -1
- package/dist/autopilot/quality-gate.d.ts +2 -2
- package/dist/autopilot/quality-gate.d.ts.map +1 -1
- package/dist/autopilot/quality-gate.js +2 -2
- package/dist/autopilot/quality-gate.js.map +1 -1
- package/dist/autopilot/rule-distiller.d.ts +1 -1
- package/dist/autopilot/rule-distiller.d.ts.map +1 -1
- package/dist/autopilot/task-completion-detector.d.ts +2 -2
- package/dist/autopilot/task-completion-detector.d.ts.map +1 -1
- package/dist/claudemd/index.d.ts +1 -1
- package/dist/claudemd/index.d.ts.map +1 -1
- package/dist/claudemd/writer.js +1 -1
- package/dist/claudemd/writer.js.map +1 -1
- package/dist/cli/commands/pipeline.d.ts.map +1 -1
- package/dist/cli/commands/pipeline.js +3 -13
- package/dist/cli/commands/pipeline.js.map +1 -1
- package/dist/convention/convention-distiller.d.ts +1 -1
- package/dist/convention/convention-distiller.d.ts.map +1 -1
- package/dist/convention/convention-evolver.d.ts +1 -1
- package/dist/convention/convention-evolver.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-autopilot.d.ts +3 -3
- package/dist/daemon/engine-registry/init-autopilot.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-autopilot.js +7 -8
- package/dist/daemon/engine-registry/init-autopilot.js.map +1 -1
- package/dist/daemon/engine-registry/init-distill.d.ts +1 -1
- package/dist/daemon/engine-registry/init-distill.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-pipeline.d.ts +1 -1
- package/dist/daemon/engine-registry/init-pipeline.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-resume.d.ts +1 -1
- package/dist/daemon/engine-registry/init-resume.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-skill-registry.d.ts +1 -1
- package/dist/daemon/engine-registry/init-skill-registry.d.ts.map +1 -1
- package/dist/daemon/engine-registry.d.ts +1 -1
- package/dist/daemon/engine-registry.d.ts.map +1 -1
- package/dist/daemon/engine-registry.js +6 -6
- package/dist/daemon/engine-registry.js.map +1 -1
- package/dist/daemon/handler-context.d.ts +6 -6
- package/dist/daemon/handler-context.d.ts.map +1 -1
- package/dist/daemon/handlers/context-builder.js +1 -1
- package/dist/daemon/handlers/context-builder.js.map +1 -1
- package/dist/daemon/handlers/orchestration-context.d.ts +1 -1
- package/dist/daemon/handlers/orchestration-context.d.ts.map +1 -1
- package/dist/daemon/handlers/post-tool-use-handler.js +4 -4
- package/dist/daemon/handlers/post-tool-use-handler.js.map +1 -1
- package/dist/daemon/handlers/session-cleanup.d.ts.map +1 -1
- package/dist/daemon/handlers/session-cleanup.js +2 -16
- package/dist/daemon/handlers/session-cleanup.js.map +1 -1
- package/dist/daemon/handlers/stages/06-engine-check.js +1 -1
- package/dist/daemon/handlers/stages/06-engine-check.js.map +1 -1
- package/dist/daemon/handlers/stages/09-pipeline-active.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/09-pipeline-active.js +0 -7
- package/dist/daemon/handlers/stages/09-pipeline-active.js.map +1 -1
- package/dist/daemon/handlers/stages/11-intent-analysis.d.ts +1 -1
- package/dist/daemon/handlers/stages/11-intent-analysis.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/11-intent-analysis.js +12 -6
- package/dist/daemon/handlers/stages/11-intent-analysis.js.map +1 -1
- package/dist/daemon/handlers/stages/18-complex-task.js +1 -1
- package/dist/daemon/handlers/stages/18-complex-task.js.map +1 -1
- package/dist/daemon/handlers/stages/19-moderate-task.js +2 -2
- package/dist/daemon/handlers/stages/19-moderate-task.js.map +1 -1
- package/dist/daemon/handlers/stop-handler.js +3 -3
- package/dist/daemon/handlers/stop-handler.js.map +1 -1
- package/dist/daemon/handlers/user-prompt-handler.js +1 -1
- package/dist/daemon/handlers/user-prompt-handler.js.map +1 -1
- package/dist/daemon/index.js +3 -3
- package/dist/daemon/index.js.map +1 -1
- package/dist/distill/index.d.ts +1 -1
- package/dist/distill/index.d.ts.map +1 -1
- package/dist/distill/tree-index.d.ts +1 -1
- package/dist/distill/tree-index.d.ts.map +1 -1
- package/dist/distill/trigger.js +1 -1
- package/dist/distill/trigger.js.map +1 -1
- package/dist/distill/writer.d.ts +1 -1
- package/dist/distill/writer.d.ts.map +1 -1
- package/dist/goal/goal-classifier.d.ts +38 -0
- package/dist/goal/goal-classifier.d.ts.map +1 -0
- package/dist/{autopilot/intent-engine.js → goal/goal-classifier.js} +187 -297
- package/dist/goal/goal-classifier.js.map +1 -0
- package/dist/goal/goal-decomposer.d.ts +32 -0
- package/dist/goal/goal-decomposer.d.ts.map +1 -0
- package/dist/{pipeline/analyzer.js → goal/goal-decomposer.js} +45 -112
- package/dist/goal/goal-decomposer.js.map +1 -0
- package/dist/goal/goal-planner.d.ts +16 -0
- package/dist/goal/goal-planner.d.ts.map +1 -0
- package/dist/goal/goal-planner.js +90 -0
- package/dist/goal/goal-planner.js.map +1 -0
- package/dist/goal/goal-types.d.ts +62 -0
- package/dist/goal/goal-types.d.ts.map +1 -0
- package/dist/goal/goal-types.js +8 -0
- package/dist/goal/goal-types.js.map +1 -0
- package/dist/goal/index.d.ts +5 -0
- package/dist/goal/index.d.ts.map +1 -0
- package/dist/goal/index.js +4 -0
- package/dist/goal/index.js.map +1 -0
- package/dist/pipeline/artifact-generator.d.ts +1 -1
- package/dist/pipeline/artifact-generator.d.ts.map +1 -1
- package/dist/pipeline/artifact-generator.js +0 -1
- package/dist/pipeline/artifact-generator.js.map +1 -1
- package/dist/pipeline/dynamic-node-executor.d.ts +3 -29
- package/dist/pipeline/dynamic-node-executor.d.ts.map +1 -1
- package/dist/pipeline/dynamic-node-executor.js +49 -115
- package/dist/pipeline/dynamic-node-executor.js.map +1 -1
- package/dist/pipeline/execution-plan.d.ts +1 -1
- package/dist/pipeline/execution-plan.d.ts.map +1 -1
- package/dist/pipeline/index.d.ts +5 -13
- package/dist/pipeline/index.d.ts.map +1 -1
- package/dist/pipeline/index.js +23 -63
- package/dist/pipeline/index.js.map +1 -1
- package/dist/pipeline/node-runtime.d.ts +41 -0
- package/dist/pipeline/node-runtime.d.ts.map +1 -0
- package/dist/pipeline/node-runtime.js +73 -0
- package/dist/pipeline/node-runtime.js.map +1 -0
- package/dist/pipeline/semantic-validator.d.ts +1 -1
- package/dist/pipeline/semantic-validator.d.ts.map +1 -1
- package/dist/pipeline/step-orchestrator.d.ts +1 -1
- package/dist/pipeline/step-orchestrator.d.ts.map +1 -1
- package/dist/pipeline/store.d.ts +18 -48
- package/dist/pipeline/store.d.ts.map +1 -1
- package/dist/pipeline/store.js +101 -424
- package/dist/pipeline/store.js.map +1 -1
- package/dist/pipeline/template-router.d.ts +1 -1
- package/dist/pipeline/template-router.d.ts.map +1 -1
- package/dist/pipeline/types.d.ts +3 -3
- package/dist/pipeline/types.d.ts.map +1 -1
- package/dist/pipeline/types.js +1 -1
- package/dist/pipeline/types.js.map +1 -1
- package/dist/resume/context-gen.d.ts +1 -1
- package/dist/resume/context-gen.d.ts.map +1 -1
- package/dist/resume/index.d.ts +1 -1
- package/dist/resume/index.d.ts.map +1 -1
- package/dist/retrospective/index.d.ts +1 -1
- package/dist/retrospective/index.d.ts.map +1 -1
- package/dist/retrospective/pattern-learner.d.ts +1 -1
- package/dist/retrospective/pattern-learner.d.ts.map +1 -1
- package/dist/skill-registry/collector.d.ts +1 -1
- package/dist/skill-registry/collector.d.ts.map +1 -1
- package/dist/skill-registry/evolver/community-distiller.d.ts +1 -1
- package/dist/skill-registry/evolver/community-distiller.d.ts.map +1 -1
- package/dist/skill-registry/evolver/generation-engine.d.ts +1 -1
- package/dist/skill-registry/evolver/generation-engine.d.ts.map +1 -1
- package/dist/skill-registry/evolver/index.d.ts +1 -1
- package/dist/skill-registry/evolver/index.d.ts.map +1 -1
- package/dist/skill-registry/evolver/keyword-evolver.d.ts +1 -1
- package/dist/skill-registry/evolver/keyword-evolver.d.ts.map +1 -1
- package/dist/skill-registry/evolver/official-evolver.d.ts +1 -1
- package/dist/skill-registry/evolver/official-evolver.d.ts.map +1 -1
- package/dist/skill-registry/evolver/optimization-engine.d.ts +1 -1
- package/dist/skill-registry/evolver/optimization-engine.d.ts.map +1 -1
- package/dist/skill-registry/evolver/repair-engine.d.ts +1 -1
- package/dist/skill-registry/evolver/repair-engine.d.ts.map +1 -1
- package/dist/skill-registry/index.d.ts +1 -1
- package/dist/skill-registry/index.d.ts.map +1 -1
- package/dist/skill-registry/official-sync/skill-definitions.d.ts.map +1 -1
- package/dist/skill-registry/official-sync/skill-definitions.js +675 -0
- package/dist/skill-registry/official-sync/skill-definitions.js.map +1 -1
- package/dist/skill-registry/orchestrator.d.ts +1 -1
- package/dist/skill-registry/orchestrator.d.ts.map +1 -1
- package/dist/skill-registry/pattern-evolver.d.ts +1 -1
- package/dist/skill-registry/pattern-evolver.d.ts.map +1 -1
- package/dist/skill-registry/project-learner.d.ts +1 -1
- package/dist/skill-registry/project-learner.d.ts.map +1 -1
- package/dist/{core/types.d.ts → types/core-types.d.ts} +1 -1
- package/dist/types/core-types.d.ts.map +1 -0
- package/dist/{core/types.js → types/core-types.js} +1 -1
- package/dist/types/core-types.js.map +1 -0
- package/dist/utils/cache-registry.d.ts.map +1 -0
- package/dist/utils/cache-registry.js.map +1 -0
- package/dist/utils/circuit-breaker.js +1 -1
- package/dist/utils/circuit-breaker.js.map +1 -1
- package/dist/utils/claude-api.d.ts +3 -3
- package/dist/utils/claude-api.d.ts.map +1 -1
- package/dist/utils/claude-api.js +2 -2
- package/dist/utils/claude-api.js.map +1 -1
- package/dist/utils/error-handler.d.ts +0 -4
- package/dist/utils/error-handler.d.ts.map +1 -1
- package/dist/utils/error-handler.js +0 -20
- package/dist/utils/error-handler.js.map +1 -1
- package/dist/utils/pending-prompt-sink.d.ts.map +1 -0
- package/dist/utils/pending-prompt-sink.js.map +1 -0
- package/dist/web/routes/pipelines.d.ts.map +1 -1
- package/dist/web/routes/pipelines.js +68 -12
- package/dist/web/routes/pipelines.js.map +1 -1
- package/dist/web/routes/quality.d.ts +1 -1
- package/dist/web/routes/quality.d.ts.map +1 -1
- package/dist/web/server.d.ts +1 -1
- package/dist/web/server.d.ts.map +1 -1
- package/dist/web-static/assets/{index-DABYEmUB.js → index-3iTzJKjz.js} +1 -1
- package/dist/web-static/index.html +1 -1
- package/package.json +1 -1
- package/dist/ai-gateway/index.d.ts.map +0 -1
- package/dist/ai-gateway/index.js.map +0 -1
- package/dist/ai-gateway/model-selector.d.ts.map +0 -1
- package/dist/ai-gateway/model-selector.js.map +0 -1
- package/dist/ai-gateway/rate-limiter.d.ts.map +0 -1
- package/dist/ai-gateway/rate-limiter.js.map +0 -1
- package/dist/ai-gateway/response-cache.d.ts.map +0 -1
- package/dist/ai-gateway/response-cache.js.map +0 -1
- package/dist/ai-gateway/token-budget.d.ts.map +0 -1
- package/dist/ai-gateway/token-budget.js.map +0 -1
- package/dist/ai-provider/base-provider.d.ts.map +0 -1
- package/dist/ai-provider/base-provider.js.map +0 -1
- package/dist/ai-provider/factory.d.ts.map +0 -1
- package/dist/ai-provider/factory.js.map +0 -1
- package/dist/ai-provider/index.d.ts +0 -7
- package/dist/ai-provider/index.d.ts.map +0 -1
- package/dist/ai-provider/index.js +0 -6
- package/dist/ai-provider/index.js.map +0 -1
- package/dist/ai-provider/ollama-provider.d.ts.map +0 -1
- package/dist/ai-provider/ollama-provider.js.map +0 -1
- package/dist/ai-provider/openai-provider.d.ts.map +0 -1
- package/dist/ai-provider/openai-provider.js.map +0 -1
- package/dist/ai-provider/types.d.ts.map +0 -1
- package/dist/ai-provider/types.js.map +0 -1
- package/dist/autopilot/intent-engine.d.ts +0 -100
- package/dist/autopilot/intent-engine.d.ts.map +0 -1
- package/dist/autopilot/intent-engine.js.map +0 -1
- package/dist/autopilot/knowledge-engine.d.ts +0 -67
- package/dist/autopilot/knowledge-engine.d.ts.map +0 -1
- package/dist/autopilot/knowledge-engine.js +0 -262
- package/dist/autopilot/knowledge-engine.js.map +0 -1
- package/dist/core/cache-registry.d.ts.map +0 -1
- package/dist/core/cache-registry.js.map +0 -1
- package/dist/core/pending-prompt-sink.d.ts.map +0 -1
- package/dist/core/pending-prompt-sink.js.map +0 -1
- package/dist/core/types.d.ts.map +0 -1
- package/dist/core/types.js.map +0 -1
- package/dist/doc-sync/index.d.ts +0 -29
- package/dist/doc-sync/index.d.ts.map +0 -1
- package/dist/doc-sync/index.js +0 -276
- package/dist/doc-sync/index.js.map +0 -1
- package/dist/pipeline/aggregator.d.ts +0 -161
- package/dist/pipeline/aggregator.d.ts.map +0 -1
- package/dist/pipeline/aggregator.js +0 -261
- package/dist/pipeline/aggregator.js.map +0 -1
- package/dist/pipeline/analyzer.d.ts +0 -46
- package/dist/pipeline/analyzer.d.ts.map +0 -1
- package/dist/pipeline/analyzer.js.map +0 -1
- package/dist/pipeline/artifact-enforcement.d.ts +0 -74
- package/dist/pipeline/artifact-enforcement.d.ts.map +0 -1
- package/dist/pipeline/artifact-enforcement.js +0 -187
- package/dist/pipeline/artifact-enforcement.js.map +0 -1
- package/dist/pipeline/artifact-rules.d.ts +0 -39
- package/dist/pipeline/artifact-rules.d.ts.map +0 -1
- package/dist/pipeline/artifact-rules.js +0 -104
- package/dist/pipeline/artifact-rules.js.map +0 -1
- package/dist/pipeline/checkpoint.d.ts +0 -38
- package/dist/pipeline/checkpoint.d.ts.map +0 -1
- package/dist/pipeline/checkpoint.js +0 -132
- package/dist/pipeline/checkpoint.js.map +0 -1
- package/dist/pipeline/dynamic-aggregator.d.ts +0 -83
- package/dist/pipeline/dynamic-aggregator.d.ts.map +0 -1
- package/dist/pipeline/dynamic-aggregator.js +0 -303
- package/dist/pipeline/dynamic-aggregator.js.map +0 -1
- package/dist/pipeline/event-sourced-engine.d.ts +0 -77
- package/dist/pipeline/event-sourced-engine.d.ts.map +0 -1
- package/dist/pipeline/event-sourced-engine.js +0 -267
- package/dist/pipeline/event-sourced-engine.js.map +0 -1
- package/dist/pipeline/event-store.d.ts +0 -58
- package/dist/pipeline/event-store.d.ts.map +0 -1
- package/dist/pipeline/event-store.js +0 -184
- package/dist/pipeline/event-store.js.map +0 -1
- package/dist/pipeline/events.d.ts +0 -308
- package/dist/pipeline/events.d.ts.map +0 -1
- package/dist/pipeline/events.js +0 -49
- package/dist/pipeline/events.js.map +0 -1
- package/dist/pipeline/execution-plan-builder.d.ts +0 -20
- package/dist/pipeline/execution-plan-builder.d.ts.map +0 -1
- package/dist/pipeline/execution-plan-builder.js +0 -100
- package/dist/pipeline/execution-plan-builder.js.map +0 -1
- package/dist/pipeline/optimized-aggregator.d.ts +0 -36
- package/dist/pipeline/optimized-aggregator.d.ts.map +0 -1
- package/dist/pipeline/optimized-aggregator.js +0 -93
- package/dist/pipeline/optimized-aggregator.js.map +0 -1
- package/dist/pipeline/progress-tracker.d.ts +0 -29
- package/dist/pipeline/progress-tracker.d.ts.map +0 -1
- package/dist/pipeline/progress-tracker.js +0 -99
- package/dist/pipeline/progress-tracker.js.map +0 -1
- package/dist/pipeline/snapshot-store.d.ts +0 -45
- package/dist/pipeline/snapshot-store.d.ts.map +0 -1
- package/dist/pipeline/snapshot-store.js +0 -89
- package/dist/pipeline/snapshot-store.js.map +0 -1
- package/dist/pipeline/state-machine-types.d.ts +0 -157
- package/dist/pipeline/state-machine-types.d.ts.map +0 -1
- package/dist/pipeline/state-machine-types.js +0 -2
- package/dist/pipeline/state-machine-types.js.map +0 -1
- package/dist/pipeline/state-machine.d.ts +0 -44
- package/dist/pipeline/state-machine.d.ts.map +0 -1
- package/dist/pipeline/state-machine.js +0 -206
- package/dist/pipeline/state-machine.js.map +0 -1
- package/dist/pipeline/state-query.d.ts +0 -71
- package/dist/pipeline/state-query.d.ts.map +0 -1
- package/dist/pipeline/state-query.js +0 -213
- package/dist/pipeline/state-query.js.map +0 -1
- package/dist/pipeline/transitions.d.ts +0 -28
- package/dist/pipeline/transitions.d.ts.map +0 -1
- package/dist/pipeline/transitions.js +0 -336
- package/dist/pipeline/transitions.js.map +0 -1
- package/dist/strategy/bandit.d.ts +0 -51
- package/dist/strategy/bandit.d.ts.map +0 -1
- package/dist/strategy/bandit.js +0 -116
- package/dist/strategy/bandit.js.map +0 -1
- /package/dist/{ai-provider → ai}/base-provider.d.ts +0 -0
- /package/dist/{ai-provider → ai}/base-provider.js +0 -0
- /package/dist/{ai-provider → ai}/factory.d.ts +0 -0
- /package/dist/{ai-provider → ai}/factory.js +0 -0
- /package/dist/{ai-gateway → ai}/index.js +0 -0
- /package/dist/{ai-gateway → ai}/model-selector.d.ts +0 -0
- /package/dist/{ai-gateway → ai}/model-selector.js +0 -0
- /package/dist/{ai-provider → ai}/ollama-provider.d.ts +0 -0
- /package/dist/{ai-provider → ai}/ollama-provider.js +0 -0
- /package/dist/{ai-provider → ai}/openai-provider.d.ts +0 -0
- /package/dist/{ai-provider → ai}/openai-provider.js +0 -0
- /package/dist/{ai-gateway → ai}/rate-limiter.d.ts +0 -0
- /package/dist/{ai-gateway → ai}/rate-limiter.js +0 -0
- /package/dist/{ai-gateway → ai}/response-cache.d.ts +0 -0
- /package/dist/{ai-gateway → ai}/response-cache.js +0 -0
- /package/dist/{ai-gateway → ai}/token-budget.d.ts +0 -0
- /package/dist/{ai-gateway → ai}/token-budget.js +0 -0
- /package/dist/{ai-provider → ai}/types.d.ts +0 -0
- /package/dist/{ai-provider → ai}/types.js +0 -0
- /package/dist/{core → utils}/cache-registry.d.ts +0 -0
- /package/dist/{core → utils}/cache-registry.js +0 -0
- /package/dist/{core → utils}/pending-prompt-sink.d.ts +0 -0
- /package/dist/{core → utils}/pending-prompt-sink.js +0 -0
package/dist/strategy/bandit.js
DELETED
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ThompsonSampler — 多臂老虎机策略选择器
|
|
3
|
-
*
|
|
4
|
-
* 使用 Thompson Sampling(Beta 分布采样)在多个候选 Pattern 中选择最优策略。
|
|
5
|
-
* 每个 arm 维护 Beta(alpha, beta) 分布参数:
|
|
6
|
-
* alpha = 成功次数 + 1(先验:1)
|
|
7
|
-
* beta = 失败次数 + 1(先验:1)
|
|
8
|
-
*
|
|
9
|
-
* 从 effectiveness_score 和 adoption_count 推导初始参数:
|
|
10
|
-
* alpha = effectiveness_score * adoption_count + 1
|
|
11
|
-
* beta = (1 - effectiveness_score) * adoption_count + 1
|
|
12
|
-
*/
|
|
13
|
-
import { BANDIT } from '../constants.js';
|
|
14
|
-
export class ThompsonSampler {
|
|
15
|
-
/**
|
|
16
|
-
* 从候选 arms 中采样选出最优 arm ID。
|
|
17
|
-
* 若 arms 为空返回 null;若只有一个直接返回。
|
|
18
|
-
*
|
|
19
|
-
* v5 改进:
|
|
20
|
-
* - 冷启动:新 Pattern (adoptionCount=0) 给予乐观初始值
|
|
21
|
-
* - 时间衰减:历史数据根据最后使用时间衰减
|
|
22
|
-
*/
|
|
23
|
-
sample(arms) {
|
|
24
|
-
if (arms.length === 0)
|
|
25
|
-
return null;
|
|
26
|
-
if (arms.length === 1)
|
|
27
|
-
return arms[0].id;
|
|
28
|
-
let bestId = arms[0].id;
|
|
29
|
-
let bestSample = -1;
|
|
30
|
-
for (const arm of arms) {
|
|
31
|
-
const { alpha, beta } = this.deriveParams(arm);
|
|
32
|
-
const s = this.sampleBeta(alpha, beta);
|
|
33
|
-
if (s > bestSample) {
|
|
34
|
-
bestSample = s;
|
|
35
|
-
bestId = arm.id;
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
return bestId;
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* v5 新增:从 arm 推导 Beta 分布参数
|
|
42
|
-
* - 冷启动:adoptionCount=0 时给予乐观初始值 (alpha=2, beta=1)
|
|
43
|
-
* - 时间衰减:根据 lastUsed 计算衰减系数,半衰期 30 天
|
|
44
|
-
*/
|
|
45
|
-
deriveParams(arm) {
|
|
46
|
-
const n = arm.adoptionCount;
|
|
47
|
-
const score = arm.effectivenessScore;
|
|
48
|
-
// 冷启动:新 Pattern 给予乐观初始值
|
|
49
|
-
if (n === 0) {
|
|
50
|
-
return { alpha: 2, beta: 1 }; // 期望成功率 = 2/(2+1) ≈ 0.67
|
|
51
|
-
}
|
|
52
|
-
// 时间衰减:计算距离最后使用的天数
|
|
53
|
-
let decay = 1.0;
|
|
54
|
-
if (arm.lastUsed) {
|
|
55
|
-
try {
|
|
56
|
-
const lastUsedDate = new Date(arm.lastUsed);
|
|
57
|
-
const now = new Date();
|
|
58
|
-
const daysSince = (now.getTime() - lastUsedDate.getTime()) / (1000 * 60 * 60 * 24);
|
|
59
|
-
// 半衰期 30 天:decay = exp(-days / BANDIT.DECAY_HALF_LIFE_DAYS)
|
|
60
|
-
decay = Math.exp(-daysSince / BANDIT.DECAY_HALF_LIFE_DAYS);
|
|
61
|
-
}
|
|
62
|
-
catch {
|
|
63
|
-
// 解析失败,不衰减
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
// 应用衰减后的有效采用次数
|
|
67
|
-
const effectiveN = n * decay;
|
|
68
|
-
return {
|
|
69
|
-
alpha: score * effectiveN + 1,
|
|
70
|
-
beta: (1 - score) * effectiveN + 1,
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Beta 分布采样(Johnk 方法近似)
|
|
75
|
-
* 对于 alpha, beta > 0 的 Beta 分布,返回 [0, 1] 内的随机样本。
|
|
76
|
-
*/
|
|
77
|
-
sampleBeta(alpha, beta) {
|
|
78
|
-
// 使用 Gamma 分布近似:Beta(a,b) = Gamma(a) / (Gamma(a) + Gamma(b))
|
|
79
|
-
const x = this.sampleGamma(alpha);
|
|
80
|
-
const y = this.sampleGamma(beta);
|
|
81
|
-
return x / (x + y);
|
|
82
|
-
}
|
|
83
|
-
/**
|
|
84
|
-
* Gamma 分布采样(Marsaglia-Tsang 方法)
|
|
85
|
-
* shape > 0,scale = 1
|
|
86
|
-
*/
|
|
87
|
-
sampleGamma(shape) {
|
|
88
|
-
if (shape < 1) {
|
|
89
|
-
// 利用 Gamma(shape) = Gamma(shape+1) * U^(1/shape)
|
|
90
|
-
return this.sampleGamma(shape + 1) * Math.pow(Math.random(), 1 / shape);
|
|
91
|
-
}
|
|
92
|
-
const d = shape - 1 / 3;
|
|
93
|
-
const c = 1 / Math.sqrt(9 * d);
|
|
94
|
-
for (;;) {
|
|
95
|
-
let x;
|
|
96
|
-
let v;
|
|
97
|
-
do {
|
|
98
|
-
x = this.randomNormal();
|
|
99
|
-
v = 1 + c * x;
|
|
100
|
-
} while (v <= 0);
|
|
101
|
-
v = v * v * v;
|
|
102
|
-
const u = Math.random();
|
|
103
|
-
if (u < 1 - 0.0331 * (x * x) * (x * x))
|
|
104
|
-
return d * v;
|
|
105
|
-
if (Math.log(u) < 0.5 * x * x + d * (1 - v + Math.log(v)))
|
|
106
|
-
return d * v;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
/** Box-Muller 正态分布采样 */
|
|
110
|
-
randomNormal() {
|
|
111
|
-
const u1 = Math.random();
|
|
112
|
-
const u2 = Math.random();
|
|
113
|
-
return Math.sqrt(-2 * Math.log(u1 + 1e-10)) * Math.cos(2 * Math.PI * u2);
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
//# sourceMappingURL=bandit.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bandit.js","sourceRoot":"","sources":["../../src/strategy/bandit.ts"],"names":[],"mappings":"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"}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|