moflo 4.0.4 → 4.1.0

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.
Files changed (422) hide show
  1. package/.claude/agents/MIGRATION_SUMMARY.md +221 -221
  2. package/.claude/agents/analysis/analyze-code-quality.md +178 -178
  3. package/.claude/agents/analysis/code-analyzer.md +209 -209
  4. package/.claude/agents/analysis/code-review/analyze-code-quality.md +178 -178
  5. package/.claude/agents/architecture/system-design/arch-system-design.md +154 -154
  6. package/.claude/agents/base-template-generator.md +42 -42
  7. package/.claude/agents/consensus/byzantine-coordinator.md +62 -62
  8. package/.claude/agents/consensus/crdt-synchronizer.md +996 -996
  9. package/.claude/agents/consensus/gossip-coordinator.md +62 -62
  10. package/.claude/agents/consensus/performance-benchmarker.md +850 -850
  11. package/.claude/agents/consensus/quorum-manager.md +822 -822
  12. package/.claude/agents/consensus/raft-manager.md +62 -62
  13. package/.claude/agents/consensus/security-manager.md +621 -621
  14. package/.claude/agents/core/coder.md +265 -265
  15. package/.claude/agents/core/planner.md +167 -167
  16. package/.claude/agents/core/researcher.md +189 -189
  17. package/.claude/agents/core/reviewer.md +325 -325
  18. package/.claude/agents/core/tester.md +318 -318
  19. package/.claude/agents/custom/test-long-runner.md +44 -44
  20. package/.claude/agents/data/ml/data-ml-model.md +192 -192
  21. package/.claude/agents/development/backend/dev-backend-api.md +141 -141
  22. package/.claude/agents/development/dev-backend-api.md +344 -344
  23. package/.claude/agents/devops/ci-cd/ops-cicd-github.md +163 -163
  24. package/.claude/agents/documentation/api-docs/docs-api-openapi.md +173 -173
  25. package/.claude/agents/dual-mode/codex-coordinator.md +224 -224
  26. package/.claude/agents/dual-mode/codex-worker.md +211 -211
  27. package/.claude/agents/dual-mode/dual-orchestrator.md +291 -291
  28. package/.claude/agents/flow-nexus/app-store.md +87 -87
  29. package/.claude/agents/flow-nexus/authentication.md +68 -68
  30. package/.claude/agents/flow-nexus/challenges.md +80 -80
  31. package/.claude/agents/flow-nexus/neural-network.md +87 -87
  32. package/.claude/agents/flow-nexus/payments.md +82 -82
  33. package/.claude/agents/flow-nexus/sandbox.md +75 -75
  34. package/.claude/agents/flow-nexus/swarm.md +75 -75
  35. package/.claude/agents/flow-nexus/user-tools.md +95 -95
  36. package/.claude/agents/flow-nexus/workflow.md +83 -83
  37. package/.claude/agents/github/code-review-swarm.md +537 -537
  38. package/.claude/agents/github/github-modes.md +172 -172
  39. package/.claude/agents/github/issue-tracker.md +318 -318
  40. package/.claude/agents/github/multi-repo-swarm.md +552 -552
  41. package/.claude/agents/github/pr-manager.md +190 -190
  42. package/.claude/agents/github/project-board-sync.md +508 -508
  43. package/.claude/agents/github/release-manager.md +366 -366
  44. package/.claude/agents/github/release-swarm.md +582 -582
  45. package/.claude/agents/github/repo-architect.md +397 -397
  46. package/.claude/agents/github/swarm-issue.md +572 -572
  47. package/.claude/agents/github/swarm-pr.md +427 -427
  48. package/.claude/agents/github/sync-coordinator.md +451 -451
  49. package/.claude/agents/github/workflow-automation.md +634 -634
  50. package/.claude/agents/goal/agent.md +815 -815
  51. package/.claude/agents/goal/code-goal-planner.md +445 -445
  52. package/.claude/agents/goal/goal-planner.md +167 -167
  53. package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +129 -129
  54. package/.claude/agents/hive-mind/queen-coordinator.md +202 -202
  55. package/.claude/agents/hive-mind/scout-explorer.md +241 -241
  56. package/.claude/agents/hive-mind/swarm-memory-manager.md +192 -192
  57. package/.claude/agents/hive-mind/worker-specialist.md +216 -216
  58. package/.claude/agents/neural/safla-neural.md +73 -73
  59. package/.claude/agents/optimization/benchmark-suite.md +664 -664
  60. package/.claude/agents/optimization/load-balancer.md +430 -430
  61. package/.claude/agents/optimization/performance-monitor.md +671 -671
  62. package/.claude/agents/optimization/resource-allocator.md +673 -673
  63. package/.claude/agents/optimization/topology-optimizer.md +807 -807
  64. package/.claude/agents/payments/agentic-payments.md +126 -126
  65. package/.claude/agents/reasoning/agent.md +815 -815
  66. package/.claude/agents/reasoning/goal-planner.md +72 -72
  67. package/.claude/agents/sona/sona-learning-optimizer.md +74 -74
  68. package/.claude/agents/sparc/architecture.md +471 -471
  69. package/.claude/agents/sparc/pseudocode.md +317 -317
  70. package/.claude/agents/sparc/refinement.md +524 -524
  71. package/.claude/agents/sparc/specification.md +275 -275
  72. package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +224 -224
  73. package/.claude/agents/sublinear/consensus-coordinator.md +337 -337
  74. package/.claude/agents/sublinear/matrix-optimizer.md +184 -184
  75. package/.claude/agents/sublinear/pagerank-analyzer.md +298 -298
  76. package/.claude/agents/sublinear/performance-optimizer.md +367 -367
  77. package/.claude/agents/sublinear/trading-predictor.md +245 -245
  78. package/.claude/agents/swarm/adaptive-coordinator.md +395 -395
  79. package/.claude/agents/swarm/hierarchical-coordinator.md +326 -326
  80. package/.claude/agents/swarm/mesh-coordinator.md +391 -391
  81. package/.claude/agents/templates/automation-smart-agent.md +204 -204
  82. package/.claude/agents/templates/coordinator-swarm-init.md +104 -104
  83. package/.claude/agents/templates/github-pr-manager.md +176 -176
  84. package/.claude/agents/templates/implementer-sparc-coder.md +258 -258
  85. package/.claude/agents/templates/memory-coordinator.md +186 -186
  86. package/.claude/agents/templates/migration-plan.md +745 -745
  87. package/.claude/agents/templates/orchestrator-task.md +138 -138
  88. package/.claude/agents/templates/performance-analyzer.md +198 -198
  89. package/.claude/agents/templates/sparc-coordinator.md +182 -182
  90. package/.claude/agents/testing/production-validator.md +394 -394
  91. package/.claude/agents/testing/tdd-london-swarm.md +243 -243
  92. package/.claude/agents/testing/unit/tdd-london-swarm.md +243 -243
  93. package/.claude/agents/testing/validation/production-validator.md +394 -394
  94. package/.claude/agents/v3/v3-integration-architect.md +345 -345
  95. package/.claude/agents/v3/v3-memory-specialist.md +317 -317
  96. package/.claude/agents/v3/v3-performance-engineer.md +396 -396
  97. package/.claude/agents/v3/v3-queen-coordinator.md +97 -97
  98. package/.claude/agents/v3/v3-security-architect.md +173 -173
  99. package/.claude/commands/agents/README.md +10 -10
  100. package/.claude/commands/agents/agent-capabilities.md +21 -21
  101. package/.claude/commands/agents/agent-coordination.md +28 -28
  102. package/.claude/commands/agents/agent-spawning.md +28 -28
  103. package/.claude/commands/agents/agent-types.md +26 -26
  104. package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +53 -53
  105. package/.claude/commands/analysis/README.md +9 -9
  106. package/.claude/commands/analysis/bottleneck-detect.md +162 -162
  107. package/.claude/commands/analysis/performance-bottlenecks.md +58 -58
  108. package/.claude/commands/analysis/performance-report.md +25 -25
  109. package/.claude/commands/analysis/token-efficiency.md +44 -44
  110. package/.claude/commands/analysis/token-usage.md +25 -25
  111. package/.claude/commands/automation/README.md +9 -9
  112. package/.claude/commands/automation/auto-agent.md +122 -122
  113. package/.claude/commands/automation/self-healing.md +105 -105
  114. package/.claude/commands/automation/session-memory.md +89 -89
  115. package/.claude/commands/automation/smart-agents.md +72 -72
  116. package/.claude/commands/automation/smart-spawn.md +25 -25
  117. package/.claude/commands/automation/workflow-select.md +25 -25
  118. package/.claude/commands/claude-flow-help.md +103 -103
  119. package/.claude/commands/claude-flow-memory.md +107 -107
  120. package/.claude/commands/claude-flow-swarm.md +205 -205
  121. package/.claude/commands/coordination/README.md +9 -9
  122. package/.claude/commands/coordination/agent-spawn.md +25 -25
  123. package/.claude/commands/coordination/init.md +44 -44
  124. package/.claude/commands/coordination/orchestrate.md +43 -43
  125. package/.claude/commands/coordination/spawn.md +45 -45
  126. package/.claude/commands/coordination/swarm-init.md +85 -85
  127. package/.claude/commands/coordination/task-orchestrate.md +25 -25
  128. package/.claude/commands/flow-nexus/app-store.md +123 -123
  129. package/.claude/commands/flow-nexus/challenges.md +119 -119
  130. package/.claude/commands/flow-nexus/login-registration.md +64 -64
  131. package/.claude/commands/flow-nexus/neural-network.md +133 -133
  132. package/.claude/commands/flow-nexus/payments.md +115 -115
  133. package/.claude/commands/flow-nexus/sandbox.md +82 -82
  134. package/.claude/commands/flow-nexus/swarm.md +86 -86
  135. package/.claude/commands/flow-nexus/user-tools.md +151 -151
  136. package/.claude/commands/flow-nexus/workflow.md +114 -114
  137. package/.claude/commands/github/README.md +11 -11
  138. package/.claude/commands/github/code-review-swarm.md +513 -513
  139. package/.claude/commands/github/code-review.md +25 -25
  140. package/.claude/commands/github/github-modes.md +146 -146
  141. package/.claude/commands/github/github-swarm.md +121 -121
  142. package/.claude/commands/github/issue-tracker.md +291 -291
  143. package/.claude/commands/github/issue-triage.md +25 -25
  144. package/.claude/commands/github/multi-repo-swarm.md +518 -518
  145. package/.claude/commands/github/pr-enhance.md +26 -26
  146. package/.claude/commands/github/pr-manager.md +169 -169
  147. package/.claude/commands/github/project-board-sync.md +470 -470
  148. package/.claude/commands/github/release-manager.md +337 -337
  149. package/.claude/commands/github/release-swarm.md +543 -543
  150. package/.claude/commands/github/repo-analyze.md +25 -25
  151. package/.claude/commands/github/repo-architect.md +366 -366
  152. package/.claude/commands/github/swarm-issue.md +481 -481
  153. package/.claude/commands/github/swarm-pr.md +284 -284
  154. package/.claude/commands/github/sync-coordinator.md +300 -300
  155. package/.claude/commands/github/workflow-automation.md +441 -441
  156. package/.claude/commands/hive-mind/README.md +17 -17
  157. package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -8
  158. package/.claude/commands/hive-mind/hive-mind-init.md +18 -18
  159. package/.claude/commands/hive-mind/hive-mind-memory.md +8 -8
  160. package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -8
  161. package/.claude/commands/hive-mind/hive-mind-resume.md +8 -8
  162. package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -8
  163. package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -21
  164. package/.claude/commands/hive-mind/hive-mind-status.md +8 -8
  165. package/.claude/commands/hive-mind/hive-mind-stop.md +8 -8
  166. package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -8
  167. package/.claude/commands/hive-mind/hive-mind.md +27 -27
  168. package/.claude/commands/hooks/README.md +11 -11
  169. package/.claude/commands/hooks/overview.md +57 -57
  170. package/.claude/commands/hooks/post-edit.md +117 -117
  171. package/.claude/commands/hooks/post-task.md +112 -112
  172. package/.claude/commands/hooks/pre-edit.md +113 -113
  173. package/.claude/commands/hooks/pre-task.md +111 -111
  174. package/.claude/commands/hooks/session-end.md +118 -118
  175. package/.claude/commands/hooks/setup.md +102 -102
  176. package/.claude/commands/memory/README.md +9 -9
  177. package/.claude/commands/memory/memory-persist.md +25 -25
  178. package/.claude/commands/memory/memory-search.md +25 -25
  179. package/.claude/commands/memory/memory-usage.md +25 -25
  180. package/.claude/commands/memory/neural.md +47 -47
  181. package/.claude/commands/monitoring/README.md +9 -9
  182. package/.claude/commands/monitoring/agent-metrics.md +25 -25
  183. package/.claude/commands/monitoring/agents.md +44 -44
  184. package/.claude/commands/monitoring/real-time-view.md +25 -25
  185. package/.claude/commands/monitoring/status.md +46 -46
  186. package/.claude/commands/monitoring/swarm-monitor.md +25 -25
  187. package/.claude/commands/optimization/README.md +9 -9
  188. package/.claude/commands/optimization/auto-topology.md +61 -61
  189. package/.claude/commands/optimization/cache-manage.md +25 -25
  190. package/.claude/commands/optimization/parallel-execute.md +25 -25
  191. package/.claude/commands/optimization/parallel-execution.md +49 -49
  192. package/.claude/commands/optimization/topology-optimize.md +25 -25
  193. package/.claude/commands/pair/README.md +260 -260
  194. package/.claude/commands/pair/commands.md +545 -545
  195. package/.claude/commands/pair/config.md +509 -509
  196. package/.claude/commands/pair/examples.md +511 -511
  197. package/.claude/commands/pair/modes.md +347 -347
  198. package/.claude/commands/pair/session.md +406 -406
  199. package/.claude/commands/pair/start.md +208 -208
  200. package/.claude/commands/sparc/analyzer.md +51 -51
  201. package/.claude/commands/sparc/architect.md +53 -53
  202. package/.claude/commands/sparc/ask.md +97 -97
  203. package/.claude/commands/sparc/batch-executor.md +54 -54
  204. package/.claude/commands/sparc/code.md +89 -89
  205. package/.claude/commands/sparc/coder.md +54 -54
  206. package/.claude/commands/sparc/debug.md +83 -83
  207. package/.claude/commands/sparc/debugger.md +54 -54
  208. package/.claude/commands/sparc/designer.md +53 -53
  209. package/.claude/commands/sparc/devops.md +109 -109
  210. package/.claude/commands/sparc/docs-writer.md +80 -80
  211. package/.claude/commands/sparc/documenter.md +54 -54
  212. package/.claude/commands/sparc/innovator.md +54 -54
  213. package/.claude/commands/sparc/integration.md +83 -83
  214. package/.claude/commands/sparc/mcp.md +117 -117
  215. package/.claude/commands/sparc/memory-manager.md +54 -54
  216. package/.claude/commands/sparc/optimizer.md +54 -54
  217. package/.claude/commands/sparc/orchestrator.md +131 -131
  218. package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -83
  219. package/.claude/commands/sparc/refinement-optimization-mode.md +83 -83
  220. package/.claude/commands/sparc/researcher.md +54 -54
  221. package/.claude/commands/sparc/reviewer.md +54 -54
  222. package/.claude/commands/sparc/security-review.md +80 -80
  223. package/.claude/commands/sparc/sparc-modes.md +174 -174
  224. package/.claude/commands/sparc/sparc.md +111 -111
  225. package/.claude/commands/sparc/spec-pseudocode.md +80 -80
  226. package/.claude/commands/sparc/supabase-admin.md +348 -348
  227. package/.claude/commands/sparc/swarm-coordinator.md +54 -54
  228. package/.claude/commands/sparc/tdd.md +54 -54
  229. package/.claude/commands/sparc/tester.md +54 -54
  230. package/.claude/commands/sparc/tutorial.md +79 -79
  231. package/.claude/commands/sparc/workflow-manager.md +54 -54
  232. package/.claude/commands/sparc.md +166 -166
  233. package/.claude/commands/stream-chain/pipeline.md +120 -120
  234. package/.claude/commands/stream-chain/run.md +69 -69
  235. package/.claude/commands/swarm/README.md +15 -15
  236. package/.claude/commands/swarm/analysis.md +95 -95
  237. package/.claude/commands/swarm/development.md +96 -96
  238. package/.claude/commands/swarm/examples.md +168 -168
  239. package/.claude/commands/swarm/maintenance.md +102 -102
  240. package/.claude/commands/swarm/optimization.md +117 -117
  241. package/.claude/commands/swarm/research.md +136 -136
  242. package/.claude/commands/swarm/swarm-analysis.md +8 -8
  243. package/.claude/commands/swarm/swarm-background.md +8 -8
  244. package/.claude/commands/swarm/swarm-init.md +19 -19
  245. package/.claude/commands/swarm/swarm-modes.md +8 -8
  246. package/.claude/commands/swarm/swarm-monitor.md +8 -8
  247. package/.claude/commands/swarm/swarm-spawn.md +19 -19
  248. package/.claude/commands/swarm/swarm-status.md +8 -8
  249. package/.claude/commands/swarm/swarm-strategies.md +8 -8
  250. package/.claude/commands/swarm/swarm.md +27 -27
  251. package/.claude/commands/swarm/testing.md +131 -131
  252. package/.claude/commands/training/README.md +9 -9
  253. package/.claude/commands/training/model-update.md +25 -25
  254. package/.claude/commands/training/neural-patterns.md +73 -73
  255. package/.claude/commands/training/neural-train.md +25 -25
  256. package/.claude/commands/training/pattern-learn.md +25 -25
  257. package/.claude/commands/training/specialization.md +62 -62
  258. package/.claude/commands/truth/start.md +142 -142
  259. package/.claude/commands/verify/check.md +49 -49
  260. package/.claude/commands/verify/start.md +127 -127
  261. package/.claude/commands/workflows/README.md +9 -9
  262. package/.claude/commands/workflows/development.md +77 -77
  263. package/.claude/commands/workflows/research.md +62 -62
  264. package/.claude/commands/workflows/workflow-create.md +25 -25
  265. package/.claude/commands/workflows/workflow-execute.md +25 -25
  266. package/.claude/commands/workflows/workflow-export.md +25 -25
  267. package/.claude/config/v3-dependency-optimization.json +265 -265
  268. package/.claude/config/v3-performance-targets.json +250 -250
  269. package/.claude/helpers/README.md +96 -96
  270. package/.claude/helpers/aggressive-microcompact.mjs +36 -36
  271. package/.claude/helpers/auto-memory-hook.mjs +363 -363
  272. package/.claude/helpers/context-persistence-hook.mjs +1979 -1979
  273. package/.claude/helpers/github-safe.js +106 -106
  274. package/.claude/helpers/learning-service.mjs +1144 -1144
  275. package/.claude/helpers/metrics-db.mjs +488 -488
  276. package/.claude/helpers/patch-aggressive-prune.mjs +184 -184
  277. package/.claude/mcp.json +12 -12
  278. package/.claude/settings.json +2 -2
  279. package/.claude/skills/agentdb-advanced/SKILL.md +550 -550
  280. package/.claude/skills/agentdb-learning/SKILL.md +545 -545
  281. package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -339
  282. package/.claude/skills/agentdb-optimization/SKILL.md +509 -509
  283. package/.claude/skills/agentdb-vector-search/SKILL.md +339 -339
  284. package/.claude/skills/agentic-jujutsu/SKILL.md +645 -645
  285. package/.claude/skills/dual-mode/README.md +71 -71
  286. package/.claude/skills/dual-mode/dual-collect.md +103 -103
  287. package/.claude/skills/dual-mode/dual-coordinate.md +85 -85
  288. package/.claude/skills/dual-mode/dual-spawn.md +81 -81
  289. package/.claude/skills/flow-nexus-neural/SKILL.md +738 -738
  290. package/.claude/skills/flow-nexus-platform/SKILL.md +1157 -1157
  291. package/.claude/skills/flow-nexus-swarm/SKILL.md +610 -610
  292. package/.claude/skills/github-code-review/SKILL.md +1 -1
  293. package/.claude/skills/github-multi-repo/SKILL.md +2 -2
  294. package/.claude/skills/github-project-management/SKILL.md +1 -1
  295. package/.claude/skills/github-release-management/SKILL.md +2 -2
  296. package/.claude/skills/github-workflow-automation/SKILL.md +1 -1
  297. package/.claude/skills/hive-mind-advanced/SKILL.md +4 -4
  298. package/.claude/skills/hooks-automation/SKILL.md +1201 -1201
  299. package/.claude/skills/pair-programming/SKILL.md +1202 -1202
  300. package/.claude/skills/performance-analysis/SKILL.md +563 -563
  301. package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -446
  302. package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -201
  303. package/.claude/skills/skill-builder/SKILL.md +910 -910
  304. package/.claude/skills/sparc-methodology/SKILL.md +2 -2
  305. package/.claude/skills/stream-chain/SKILL.md +563 -563
  306. package/.claude/skills/swarm-advanced/SKILL.md +4 -4
  307. package/.claude/skills/swarm-orchestration/SKILL.md +179 -179
  308. package/.claude/skills/v3-cli-modernization/SKILL.md +871 -871
  309. package/.claude/skills/v3-core-implementation/SKILL.md +796 -796
  310. package/.claude/skills/v3-ddd-architecture/SKILL.md +441 -441
  311. package/.claude/skills/v3-integration-deep/SKILL.md +240 -240
  312. package/.claude/skills/v3-mcp-optimization/SKILL.md +776 -776
  313. package/.claude/skills/v3-memory-unification/SKILL.md +173 -173
  314. package/.claude/skills/v3-performance-optimization/SKILL.md +389 -389
  315. package/.claude/skills/v3-security-overhaul/SKILL.md +81 -81
  316. package/.claude/skills/v3-swarm-coordination/SKILL.md +339 -339
  317. package/.claude/skills/verification-quality/SKILL.md +649 -649
  318. package/.claude/skills/worker-benchmarks/skill.md +135 -135
  319. package/.claude/skills/worker-integration/skill.md +154 -154
  320. package/.claude/statusline.mjs +109 -109
  321. package/.claude-plugin/README.md +6 -6
  322. package/.claude-plugin/docs/INSTALLATION.md +4 -4
  323. package/.claude-plugin/docs/PLUGIN_SUMMARY.md +5 -5
  324. package/.claude-plugin/docs/QUICKSTART.md +1 -1
  325. package/.claude-plugin/docs/STRUCTURE.md +128 -128
  326. package/.claude-plugin/hooks/hooks.json +74 -74
  327. package/.claude-plugin/marketplace.json +5 -5
  328. package/.claude-plugin/plugin.json +4 -4
  329. package/README.md +148 -148
  330. package/bin/cli.js +12 -12
  331. package/bin/npx-repair.js +7 -7
  332. package/bin/npx-safe-launch.js +9 -9
  333. package/package.json +115 -114
  334. package/v3/@claude-flow/cli/README.md +5 -5
  335. package/v3/@claude-flow/cli/bin/cli.js +156 -156
  336. package/v3/@claude-flow/cli/bin/mcp-server.js +189 -189
  337. package/v3/@claude-flow/cli/dist/src/commands/analyze.d.ts +1 -1
  338. package/v3/@claude-flow/cli/dist/src/commands/analyze.js +1 -1
  339. package/v3/@claude-flow/cli/dist/src/commands/claims.d.ts +1 -1
  340. package/v3/@claude-flow/cli/dist/src/commands/claims.js +2 -2
  341. package/v3/@claude-flow/cli/dist/src/commands/completions.d.ts +1 -1
  342. package/v3/@claude-flow/cli/dist/src/commands/completions.js +1 -1
  343. package/v3/@claude-flow/cli/dist/src/commands/config.js +36 -2
  344. package/v3/@claude-flow/cli/dist/src/commands/daemon.js +54 -7
  345. package/v3/@claude-flow/cli/dist/src/commands/deployment.d.ts +1 -1
  346. package/v3/@claude-flow/cli/dist/src/commands/deployment.js +2 -2
  347. package/v3/@claude-flow/cli/dist/src/commands/doctor.d.ts +1 -1
  348. package/v3/@claude-flow/cli/dist/src/commands/doctor.js +1 -1
  349. package/v3/@claude-flow/cli/dist/src/commands/embeddings.d.ts +1 -1
  350. package/v3/@claude-flow/cli/dist/src/commands/embeddings.js +2 -2
  351. package/v3/@claude-flow/cli/dist/src/commands/hive-mind.js +90 -90
  352. package/v3/@claude-flow/cli/dist/src/commands/hooks.js +30 -112
  353. package/v3/@claude-flow/cli/dist/src/commands/init.js +6 -1
  354. package/v3/@claude-flow/cli/dist/src/commands/memory.js +30 -30
  355. package/v3/@claude-flow/cli/dist/src/commands/neural.d.ts +1 -1
  356. package/v3/@claude-flow/cli/dist/src/commands/neural.js +2 -2
  357. package/v3/@claude-flow/cli/dist/src/commands/orc.js +1 -0
  358. package/v3/@claude-flow/cli/dist/src/commands/performance.d.ts +1 -1
  359. package/v3/@claude-flow/cli/dist/src/commands/performance.js +2 -2
  360. package/v3/@claude-flow/cli/dist/src/commands/plugins.d.ts +1 -1
  361. package/v3/@claude-flow/cli/dist/src/commands/plugins.js +2 -2
  362. package/v3/@claude-flow/cli/dist/src/commands/providers.d.ts +1 -1
  363. package/v3/@claude-flow/cli/dist/src/commands/providers.js +2 -2
  364. package/v3/@claude-flow/cli/dist/src/commands/route.d.ts +1 -1
  365. package/v3/@claude-flow/cli/dist/src/commands/route.js +1 -1
  366. package/v3/@claude-flow/cli/dist/src/commands/ruvector/backup.js +23 -23
  367. package/v3/@claude-flow/cli/dist/src/commands/ruvector/benchmark.js +29 -29
  368. package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.d.ts +1 -1
  369. package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.js +1 -1
  370. package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.d.ts +1 -1
  371. package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.js +1 -1
  372. package/v3/@claude-flow/cli/dist/src/commands/ruvector/init.js +113 -113
  373. package/v3/@claude-flow/cli/dist/src/commands/ruvector/migrate.js +97 -97
  374. package/v3/@claude-flow/cli/dist/src/commands/ruvector/optimize.js +51 -51
  375. package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.d.ts +1 -1
  376. package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.js +2 -2
  377. package/v3/@claude-flow/cli/dist/src/commands/ruvector/status.js +36 -36
  378. package/v3/@claude-flow/cli/dist/src/commands/security.d.ts +1 -1
  379. package/v3/@claude-flow/cli/dist/src/commands/security.js +2 -2
  380. package/v3/@claude-flow/cli/dist/src/config/moflo-config.d.ts +13 -1
  381. package/v3/@claude-flow/cli/dist/src/config/moflo-config.js +93 -41
  382. package/v3/@claude-flow/cli/dist/src/index.d.ts +1 -1
  383. package/v3/@claude-flow/cli/dist/src/index.js +2 -2
  384. package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.js +2 -2
  385. package/v3/@claude-flow/cli/dist/src/init/executor.js +3 -3
  386. package/v3/@claude-flow/cli/dist/src/init/helpers-generator.js +640 -640
  387. package/v3/@claude-flow/cli/dist/src/init/moflo-init.d.ts +10 -0
  388. package/v3/@claude-flow/cli/dist/src/init/moflo-init.js +101 -20
  389. package/v3/@claude-flow/cli/dist/src/init/settings-generator.js +2 -2
  390. package/v3/@claude-flow/cli/dist/src/init/statusline-generator.js +783 -783
  391. package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.js +30 -13
  392. package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.d.ts +1 -1
  393. package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.js +1 -1
  394. package/v3/@claude-flow/cli/dist/src/memory/memory-bridge.js +61 -61
  395. package/v3/@claude-flow/cli/dist/src/memory/memory-initializer.js +2212 -2263
  396. package/v3/@claude-flow/cli/dist/src/runtime/headless.js +28 -28
  397. package/v3/@claude-flow/cli/dist/src/ruvector/flash-attention.d.ts +1 -1
  398. package/v3/@claude-flow/cli/dist/src/ruvector/flash-attention.js +1 -1
  399. package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.d.ts +1 -1
  400. package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.js +1 -1
  401. package/v3/@claude-flow/cli/dist/src/services/agent-router.d.ts +14 -0
  402. package/v3/@claude-flow/cli/dist/src/services/agent-router.js +86 -7
  403. package/v3/@claude-flow/cli/dist/src/services/headless-worker-executor.js +84 -84
  404. package/v3/@claude-flow/cli/dist/src/services/index.d.ts +1 -3
  405. package/v3/@claude-flow/cli/dist/src/services/index.js +1 -2
  406. package/v3/@claude-flow/cli/dist/src/services/learning-service.js +54 -54
  407. package/v3/@claude-flow/cli/dist/src/services/ruvector-training.d.ts +1 -1
  408. package/v3/@claude-flow/cli/dist/src/services/ruvector-training.js +1 -1
  409. package/v3/@claude-flow/cli/dist/src/services/worker-daemon.d.ts +24 -3
  410. package/v3/@claude-flow/cli/dist/src/services/worker-daemon.js +123 -12
  411. package/v3/@claude-flow/cli/dist/src/services/workflow-gate.d.ts +1 -0
  412. package/v3/@claude-flow/cli/dist/src/services/workflow-gate.js +20 -5
  413. package/v3/@claude-flow/cli/dist/src/suggest.d.ts +1 -1
  414. package/v3/@claude-flow/cli/dist/src/suggest.js +1 -1
  415. package/v3/@claude-flow/cli/dist/src/transfer/deploy-seraphine.js +23 -23
  416. package/v3/@claude-flow/cli/package.json +6 -6
  417. package/v3/@claude-flow/guidance/README.md +6 -6
  418. package/v3/@claude-flow/guidance/package.json +1 -1
  419. package/v3/@claude-flow/memory/README.md +1 -1
  420. package/v3/@claude-flow/shared/README.md +1 -1
  421. package/v3/@claude-flow/shared/package.json +42 -42
  422. package/v3/README.md +3 -3
@@ -1,672 +1,672 @@
1
- ---
2
- name: Performance Monitor
3
- type: agent
4
- category: optimization
5
- description: Real-time metrics collection, bottleneck analysis, SLA monitoring and anomaly detection
6
- ---
7
-
8
- # Performance Monitor Agent
9
-
10
- ## Agent Profile
11
- - **Name**: Performance Monitor
12
- - **Type**: Performance Optimization Agent
13
- - **Specialization**: Real-time metrics collection and bottleneck analysis
14
- - **Performance Focus**: SLA monitoring, resource tracking, and anomaly detection
15
-
16
- ## Core Capabilities
17
-
18
- ### 1. Real-Time Metrics Collection
19
- ```javascript
20
- // Advanced metrics collection system
21
- class MetricsCollector {
22
- constructor() {
23
- this.collectors = new Map();
24
- this.aggregators = new Map();
25
- this.streams = new Map();
26
- this.alertThresholds = new Map();
27
- }
28
-
29
- // Multi-dimensional metrics collection
30
- async collectMetrics() {
31
- const metrics = {
32
- // System metrics
33
- system: await this.collectSystemMetrics(),
34
-
35
- // Agent-specific metrics
36
- agents: await this.collectAgentMetrics(),
37
-
38
- // Swarm coordination metrics
39
- coordination: await this.collectCoordinationMetrics(),
40
-
41
- // Task execution metrics
42
- tasks: await this.collectTaskMetrics(),
43
-
44
- // Resource utilization metrics
45
- resources: await this.collectResourceMetrics(),
46
-
47
- // Network and communication metrics
48
- network: await this.collectNetworkMetrics()
49
- };
50
-
51
- // Real-time processing and analysis
52
- await this.processMetrics(metrics);
53
- return metrics;
54
- }
55
-
56
- // System-level metrics
57
- async collectSystemMetrics() {
58
- return {
59
- cpu: {
60
- usage: await this.getCPUUsage(),
61
- loadAverage: await this.getLoadAverage(),
62
- coreUtilization: await this.getCoreUtilization()
63
- },
64
- memory: {
65
- usage: await this.getMemoryUsage(),
66
- available: await this.getAvailableMemory(),
67
- pressure: await this.getMemoryPressure()
68
- },
69
- io: {
70
- diskUsage: await this.getDiskUsage(),
71
- diskIO: await this.getDiskIOStats(),
72
- networkIO: await this.getNetworkIOStats()
73
- },
74
- processes: {
75
- count: await this.getProcessCount(),
76
- threads: await this.getThreadCount(),
77
- handles: await this.getHandleCount()
78
- }
79
- };
80
- }
81
-
82
- // Agent performance metrics
83
- async collectAgentMetrics() {
84
- const agents = await mcp.agent_list({});
85
- const agentMetrics = new Map();
86
-
87
- for (const agent of agents) {
88
- const metrics = await mcp.agent_metrics({ agentId: agent.id });
89
- agentMetrics.set(agent.id, {
90
- ...metrics,
91
- efficiency: this.calculateEfficiency(metrics),
92
- responsiveness: this.calculateResponsiveness(metrics),
93
- reliability: this.calculateReliability(metrics)
94
- });
95
- }
96
-
97
- return agentMetrics;
98
- }
99
- }
100
- ```
101
-
102
- ### 2. Bottleneck Detection & Analysis
103
- ```javascript
104
- // Intelligent bottleneck detection
105
- class BottleneckAnalyzer {
106
- constructor() {
107
- this.detectors = [
108
- new CPUBottleneckDetector(),
109
- new MemoryBottleneckDetector(),
110
- new IOBottleneckDetector(),
111
- new NetworkBottleneckDetector(),
112
- new CoordinationBottleneckDetector(),
113
- new TaskQueueBottleneckDetector()
114
- ];
115
-
116
- this.patterns = new Map();
117
- this.history = new CircularBuffer(1000);
118
- }
119
-
120
- // Multi-layer bottleneck analysis
121
- async analyzeBottlenecks(metrics) {
122
- const bottlenecks = [];
123
-
124
- // Parallel detection across all layers
125
- const detectionPromises = this.detectors.map(detector =>
126
- detector.detect(metrics)
127
- );
128
-
129
- const results = await Promise.all(detectionPromises);
130
-
131
- // Correlate and prioritize bottlenecks
132
- for (const result of results) {
133
- if (result.detected) {
134
- bottlenecks.push({
135
- type: result.type,
136
- severity: result.severity,
137
- component: result.component,
138
- rootCause: result.rootCause,
139
- impact: result.impact,
140
- recommendations: result.recommendations,
141
- timestamp: Date.now()
142
- });
143
- }
144
- }
145
-
146
- // Pattern recognition for recurring bottlenecks
147
- await this.updatePatterns(bottlenecks);
148
-
149
- return this.prioritizeBottlenecks(bottlenecks);
150
- }
151
-
152
- // Advanced pattern recognition
153
- async updatePatterns(bottlenecks) {
154
- for (const bottleneck of bottlenecks) {
155
- const signature = this.createBottleneckSignature(bottleneck);
156
-
157
- if (this.patterns.has(signature)) {
158
- const pattern = this.patterns.get(signature);
159
- pattern.frequency++;
160
- pattern.lastOccurrence = Date.now();
161
- pattern.averageInterval = this.calculateAverageInterval(pattern);
162
- } else {
163
- this.patterns.set(signature, {
164
- signature,
165
- frequency: 1,
166
- firstOccurrence: Date.now(),
167
- lastOccurrence: Date.now(),
168
- averageInterval: 0,
169
- predictedNext: null
170
- });
171
- }
172
- }
173
- }
174
- }
175
- ```
176
-
177
- ### 3. SLA Monitoring & Alerting
178
- ```javascript
179
- // Service Level Agreement monitoring
180
- class SLAMonitor {
181
- constructor() {
182
- this.slaDefinitions = new Map();
183
- this.violations = new Map();
184
- this.alertChannels = new Set();
185
- this.escalationRules = new Map();
186
- }
187
-
188
- // Define SLA metrics and thresholds
189
- defineSLA(service, slaConfig) {
190
- this.slaDefinitions.set(service, {
191
- availability: slaConfig.availability || 99.9, // percentage
192
- responseTime: slaConfig.responseTime || 1000, // milliseconds
193
- throughput: slaConfig.throughput || 100, // requests per second
194
- errorRate: slaConfig.errorRate || 0.1, // percentage
195
- recoveryTime: slaConfig.recoveryTime || 300, // seconds
196
-
197
- // Time windows for measurements
198
- measurementWindow: slaConfig.measurementWindow || 300, // seconds
199
- evaluationInterval: slaConfig.evaluationInterval || 60, // seconds
200
-
201
- // Alerting configuration
202
- alertThresholds: slaConfig.alertThresholds || {
203
- warning: 0.8, // 80% of SLA threshold
204
- critical: 0.9, // 90% of SLA threshold
205
- breach: 1.0 // 100% of SLA threshold
206
- }
207
- });
208
- }
209
-
210
- // Continuous SLA monitoring
211
- async monitorSLA() {
212
- const violations = [];
213
-
214
- for (const [service, sla] of this.slaDefinitions) {
215
- const metrics = await this.getServiceMetrics(service);
216
- const evaluation = this.evaluateSLA(service, sla, metrics);
217
-
218
- if (evaluation.violated) {
219
- violations.push(evaluation);
220
- await this.handleViolation(service, evaluation);
221
- }
222
- }
223
-
224
- return violations;
225
- }
226
-
227
- // SLA evaluation logic
228
- evaluateSLA(service, sla, metrics) {
229
- const evaluation = {
230
- service,
231
- timestamp: Date.now(),
232
- violated: false,
233
- violations: []
234
- };
235
-
236
- // Availability check
237
- if (metrics.availability < sla.availability) {
238
- evaluation.violations.push({
239
- metric: 'availability',
240
- expected: sla.availability,
241
- actual: metrics.availability,
242
- severity: this.calculateSeverity(metrics.availability, sla.availability, sla.alertThresholds)
243
- });
244
- evaluation.violated = true;
245
- }
246
-
247
- // Response time check
248
- if (metrics.responseTime > sla.responseTime) {
249
- evaluation.violations.push({
250
- metric: 'responseTime',
251
- expected: sla.responseTime,
252
- actual: metrics.responseTime,
253
- severity: this.calculateSeverity(metrics.responseTime, sla.responseTime, sla.alertThresholds)
254
- });
255
- evaluation.violated = true;
256
- }
257
-
258
- // Additional SLA checks...
259
-
260
- return evaluation;
261
- }
262
- }
263
- ```
264
-
265
- ### 4. Resource Utilization Tracking
266
- ```javascript
267
- // Comprehensive resource tracking
268
- class ResourceTracker {
269
- constructor() {
270
- this.trackers = {
271
- cpu: new CPUTracker(),
272
- memory: new MemoryTracker(),
273
- disk: new DiskTracker(),
274
- network: new NetworkTracker(),
275
- gpu: new GPUTracker(),
276
- agents: new AgentResourceTracker()
277
- };
278
-
279
- this.forecaster = new ResourceForecaster();
280
- this.optimizer = new ResourceOptimizer();
281
- }
282
-
283
- // Real-time resource tracking
284
- async trackResources() {
285
- const resources = {};
286
-
287
- // Parallel resource collection
288
- const trackingPromises = Object.entries(this.trackers).map(
289
- async ([type, tracker]) => [type, await tracker.collect()]
290
- );
291
-
292
- const results = await Promise.all(trackingPromises);
293
-
294
- for (const [type, data] of results) {
295
- resources[type] = {
296
- ...data,
297
- utilization: this.calculateUtilization(data),
298
- efficiency: this.calculateEfficiency(data),
299
- trend: this.calculateTrend(type, data),
300
- forecast: await this.forecaster.forecast(type, data)
301
- };
302
- }
303
-
304
- return resources;
305
- }
306
-
307
- // Resource utilization analysis
308
- calculateUtilization(resourceData) {
309
- return {
310
- current: resourceData.used / resourceData.total,
311
- peak: resourceData.peak / resourceData.total,
312
- average: resourceData.average / resourceData.total,
313
- percentiles: {
314
- p50: resourceData.p50 / resourceData.total,
315
- p90: resourceData.p90 / resourceData.total,
316
- p95: resourceData.p95 / resourceData.total,
317
- p99: resourceData.p99 / resourceData.total
318
- }
319
- };
320
- }
321
-
322
- // Predictive resource forecasting
323
- async forecastResourceNeeds(timeHorizon = 3600) { // 1 hour default
324
- const currentResources = await this.trackResources();
325
- const forecasts = {};
326
-
327
- for (const [type, data] of Object.entries(currentResources)) {
328
- forecasts[type] = await this.forecaster.forecast(type, data, timeHorizon);
329
- }
330
-
331
- return {
332
- timeHorizon,
333
- forecasts,
334
- recommendations: await this.optimizer.generateRecommendations(forecasts),
335
- confidence: this.calculateForecastConfidence(forecasts)
336
- };
337
- }
338
- }
339
- ```
340
-
341
- ## MCP Integration Hooks
342
-
343
- ### Performance Data Collection
344
- ```javascript
345
- // Comprehensive MCP integration
346
- const performanceIntegration = {
347
- // Real-time performance monitoring
348
- async startMonitoring(config = {}) {
349
- const monitoringTasks = [
350
- this.monitorSwarmHealth(),
351
- this.monitorAgentPerformance(),
352
- this.monitorResourceUtilization(),
353
- this.monitorBottlenecks(),
354
- this.monitorSLACompliance()
355
- ];
356
-
357
- // Start all monitoring tasks concurrently
358
- const monitors = await Promise.all(monitoringTasks);
359
-
360
- return {
361
- swarmHealthMonitor: monitors[0],
362
- agentPerformanceMonitor: monitors[1],
363
- resourceMonitor: monitors[2],
364
- bottleneckMonitor: monitors[3],
365
- slaMonitor: monitors[4]
366
- };
367
- },
368
-
369
- // Swarm health monitoring
370
- async monitorSwarmHealth() {
371
- const healthMetrics = await mcp.health_check({
372
- components: ['swarm', 'coordination', 'communication']
373
- });
374
-
375
- return {
376
- status: healthMetrics.overall,
377
- components: healthMetrics.components,
378
- issues: healthMetrics.issues,
379
- recommendations: healthMetrics.recommendations
380
- };
381
- },
382
-
383
- // Agent performance monitoring
384
- async monitorAgentPerformance() {
385
- const agents = await mcp.agent_list({});
386
- const performanceData = new Map();
387
-
388
- for (const agent of agents) {
389
- const metrics = await mcp.agent_metrics({ agentId: agent.id });
390
- const performance = await mcp.performance_report({
391
- format: 'detailed',
392
- timeframe: '24h'
393
- });
394
-
395
- performanceData.set(agent.id, {
396
- ...metrics,
397
- performance,
398
- efficiency: this.calculateAgentEfficiency(metrics, performance),
399
- bottlenecks: await mcp.bottleneck_analyze({ component: agent.id })
400
- });
401
- }
402
-
403
- return performanceData;
404
- },
405
-
406
- // Bottleneck monitoring and analysis
407
- async monitorBottlenecks() {
408
- const bottlenecks = await mcp.bottleneck_analyze({});
409
-
410
- // Enhanced bottleneck analysis
411
- const analysis = {
412
- detected: bottlenecks.length > 0,
413
- count: bottlenecks.length,
414
- severity: this.calculateOverallSeverity(bottlenecks),
415
- categories: this.categorizeBottlenecks(bottlenecks),
416
- trends: await this.analyzeBottleneckTrends(bottlenecks),
417
- predictions: await this.predictBottlenecks(bottlenecks)
418
- };
419
-
420
- return analysis;
421
- }
422
- };
423
- ```
424
-
425
- ### Anomaly Detection
426
- ```javascript
427
- // Advanced anomaly detection system
428
- class AnomalyDetector {
429
- constructor() {
430
- this.models = {
431
- statistical: new StatisticalAnomalyDetector(),
432
- machine_learning: new MLAnomalyDetector(),
433
- time_series: new TimeSeriesAnomalyDetector(),
434
- behavioral: new BehavioralAnomalyDetector()
435
- };
436
-
437
- this.ensemble = new EnsembleDetector(this.models);
438
- }
439
-
440
- // Multi-model anomaly detection
441
- async detectAnomalies(metrics) {
442
- const anomalies = [];
443
-
444
- // Parallel detection across all models
445
- const detectionPromises = Object.entries(this.models).map(
446
- async ([modelType, model]) => {
447
- const detected = await model.detect(metrics);
448
- return { modelType, detected };
449
- }
450
- );
451
-
452
- const results = await Promise.all(detectionPromises);
453
-
454
- // Ensemble voting for final decision
455
- const ensembleResult = await this.ensemble.vote(results);
456
-
457
- return {
458
- anomalies: ensembleResult.anomalies,
459
- confidence: ensembleResult.confidence,
460
- consensus: ensembleResult.consensus,
461
- individualResults: results
462
- };
463
- }
464
-
465
- // Statistical anomaly detection
466
- detectStatisticalAnomalies(data) {
467
- const mean = this.calculateMean(data);
468
- const stdDev = this.calculateStandardDeviation(data, mean);
469
- const threshold = 3 * stdDev; // 3-sigma rule
470
-
471
- return data.filter(point => Math.abs(point - mean) > threshold)
472
- .map(point => ({
473
- value: point,
474
- type: 'statistical',
475
- deviation: Math.abs(point - mean) / stdDev,
476
- probability: this.calculateProbability(point, mean, stdDev)
477
- }));
478
- }
479
-
480
- // Time series anomaly detection
481
- async detectTimeSeriesAnomalies(timeSeries) {
482
- // LSTM-based anomaly detection
483
- const model = await this.loadTimeSeriesModel();
484
- const predictions = await model.predict(timeSeries);
485
-
486
- const anomalies = [];
487
- for (let i = 0; i < timeSeries.length; i++) {
488
- const error = Math.abs(timeSeries[i] - predictions[i]);
489
- const threshold = this.calculateDynamicThreshold(timeSeries, i);
490
-
491
- if (error > threshold) {
492
- anomalies.push({
493
- timestamp: i,
494
- actual: timeSeries[i],
495
- predicted: predictions[i],
496
- error: error,
497
- type: 'time_series'
498
- });
499
- }
500
- }
501
-
502
- return anomalies;
503
- }
504
- }
505
- ```
506
-
507
- ## Dashboard Integration
508
-
509
- ### Real-Time Performance Dashboard
510
- ```javascript
511
- // Dashboard data provider
512
- class DashboardProvider {
513
- constructor() {
514
- this.updateInterval = 1000; // 1 second updates
515
- this.subscribers = new Set();
516
- this.dataBuffer = new CircularBuffer(1000);
517
- }
518
-
519
- // Real-time dashboard data
520
- async provideDashboardData() {
521
- const dashboardData = {
522
- // High-level metrics
523
- overview: {
524
- swarmHealth: await this.getSwarmHealthScore(),
525
- activeAgents: await this.getActiveAgentCount(),
526
- totalTasks: await this.getTotalTaskCount(),
527
- averageResponseTime: await this.getAverageResponseTime()
528
- },
529
-
530
- // Performance metrics
531
- performance: {
532
- throughput: await this.getCurrentThroughput(),
533
- latency: await this.getCurrentLatency(),
534
- errorRate: await this.getCurrentErrorRate(),
535
- utilization: await this.getResourceUtilization()
536
- },
537
-
538
- // Real-time charts data
539
- timeSeries: {
540
- cpu: this.getCPUTimeSeries(),
541
- memory: this.getMemoryTimeSeries(),
542
- network: this.getNetworkTimeSeries(),
543
- tasks: this.getTaskTimeSeries()
544
- },
545
-
546
- // Alerts and notifications
547
- alerts: await this.getActiveAlerts(),
548
- notifications: await this.getRecentNotifications(),
549
-
550
- // Agent status
551
- agents: await this.getAgentStatusSummary(),
552
-
553
- timestamp: Date.now()
554
- };
555
-
556
- // Broadcast to subscribers
557
- this.broadcast(dashboardData);
558
-
559
- return dashboardData;
560
- }
561
-
562
- // WebSocket subscription management
563
- subscribe(callback) {
564
- this.subscribers.add(callback);
565
- return () => this.subscribers.delete(callback);
566
- }
567
-
568
- broadcast(data) {
569
- this.subscribers.forEach(callback => {
570
- try {
571
- callback(data);
572
- } catch (error) {
573
- console.error('Dashboard subscriber error:', error);
574
- }
575
- });
576
- }
577
- }
578
- ```
579
-
580
- ## Operational Commands
581
-
582
- ### Monitoring Commands
583
- ```bash
584
- # Start comprehensive monitoring
585
- npx claude-flow performance-report --format detailed --timeframe 24h
586
-
587
- # Real-time bottleneck analysis
588
- npx claude-flow bottleneck-analyze --component swarm-coordination
589
-
590
- # Health check all components
591
- npx claude-flow health-check --components ["swarm", "agents", "coordination"]
592
-
593
- # Collect specific metrics
594
- npx claude-flow metrics-collect --components ["cpu", "memory", "network"]
595
-
596
- # Monitor SLA compliance
597
- npx claude-flow sla-monitor --service swarm-coordination --threshold 99.9
598
- ```
599
-
600
- ### Alert Configuration
601
- ```bash
602
- # Configure performance alerts
603
- npx claude-flow alert-config --metric cpu_usage --threshold 80 --severity warning
604
-
605
- # Set up anomaly detection
606
- npx claude-flow anomaly-setup --models ["statistical", "ml", "time_series"]
607
-
608
- # Configure notification channels
609
- npx claude-flow notification-config --channels ["slack", "email", "webhook"]
610
- ```
611
-
612
- ## Integration Points
613
-
614
- ### With Other Optimization Agents
615
- - **Load Balancer**: Provides performance data for load balancing decisions
616
- - **Topology Optimizer**: Supplies network and coordination metrics
617
- - **Resource Manager**: Shares resource utilization and forecasting data
618
-
619
- ### With Swarm Infrastructure
620
- - **Task Orchestrator**: Monitors task execution performance
621
- - **Agent Coordinator**: Tracks agent health and performance
622
- - **Memory System**: Stores historical performance data and patterns
623
-
624
- ## Performance Analytics
625
-
626
- ### Key Metrics Dashboard
627
- ```javascript
628
- // Performance analytics engine
629
- const analytics = {
630
- // Key Performance Indicators
631
- calculateKPIs(metrics) {
632
- return {
633
- // Availability metrics
634
- uptime: this.calculateUptime(metrics),
635
- availability: this.calculateAvailability(metrics),
636
-
637
- // Performance metrics
638
- responseTime: {
639
- average: this.calculateAverage(metrics.responseTimes),
640
- p50: this.calculatePercentile(metrics.responseTimes, 50),
641
- p90: this.calculatePercentile(metrics.responseTimes, 90),
642
- p95: this.calculatePercentile(metrics.responseTimes, 95),
643
- p99: this.calculatePercentile(metrics.responseTimes, 99)
644
- },
645
-
646
- // Throughput metrics
647
- throughput: this.calculateThroughput(metrics),
648
-
649
- // Error metrics
650
- errorRate: this.calculateErrorRate(metrics),
651
-
652
- // Resource efficiency
653
- resourceEfficiency: this.calculateResourceEfficiency(metrics),
654
-
655
- // Cost metrics
656
- costEfficiency: this.calculateCostEfficiency(metrics)
657
- };
658
- },
659
-
660
- // Trend analysis
661
- analyzeTrends(historicalData, timeWindow = '7d') {
662
- return {
663
- performance: this.calculatePerformanceTrend(historicalData, timeWindow),
664
- efficiency: this.calculateEfficiencyTrend(historicalData, timeWindow),
665
- reliability: this.calculateReliabilityTrend(historicalData, timeWindow),
666
- capacity: this.calculateCapacityTrend(historicalData, timeWindow)
667
- };
668
- }
669
- };
670
- ```
671
-
1
+ ---
2
+ name: Performance Monitor
3
+ type: agent
4
+ category: optimization
5
+ description: Real-time metrics collection, bottleneck analysis, SLA monitoring and anomaly detection
6
+ ---
7
+
8
+ # Performance Monitor Agent
9
+
10
+ ## Agent Profile
11
+ - **Name**: Performance Monitor
12
+ - **Type**: Performance Optimization Agent
13
+ - **Specialization**: Real-time metrics collection and bottleneck analysis
14
+ - **Performance Focus**: SLA monitoring, resource tracking, and anomaly detection
15
+
16
+ ## Core Capabilities
17
+
18
+ ### 1. Real-Time Metrics Collection
19
+ ```javascript
20
+ // Advanced metrics collection system
21
+ class MetricsCollector {
22
+ constructor() {
23
+ this.collectors = new Map();
24
+ this.aggregators = new Map();
25
+ this.streams = new Map();
26
+ this.alertThresholds = new Map();
27
+ }
28
+
29
+ // Multi-dimensional metrics collection
30
+ async collectMetrics() {
31
+ const metrics = {
32
+ // System metrics
33
+ system: await this.collectSystemMetrics(),
34
+
35
+ // Agent-specific metrics
36
+ agents: await this.collectAgentMetrics(),
37
+
38
+ // Swarm coordination metrics
39
+ coordination: await this.collectCoordinationMetrics(),
40
+
41
+ // Task execution metrics
42
+ tasks: await this.collectTaskMetrics(),
43
+
44
+ // Resource utilization metrics
45
+ resources: await this.collectResourceMetrics(),
46
+
47
+ // Network and communication metrics
48
+ network: await this.collectNetworkMetrics()
49
+ };
50
+
51
+ // Real-time processing and analysis
52
+ await this.processMetrics(metrics);
53
+ return metrics;
54
+ }
55
+
56
+ // System-level metrics
57
+ async collectSystemMetrics() {
58
+ return {
59
+ cpu: {
60
+ usage: await this.getCPUUsage(),
61
+ loadAverage: await this.getLoadAverage(),
62
+ coreUtilization: await this.getCoreUtilization()
63
+ },
64
+ memory: {
65
+ usage: await this.getMemoryUsage(),
66
+ available: await this.getAvailableMemory(),
67
+ pressure: await this.getMemoryPressure()
68
+ },
69
+ io: {
70
+ diskUsage: await this.getDiskUsage(),
71
+ diskIO: await this.getDiskIOStats(),
72
+ networkIO: await this.getNetworkIOStats()
73
+ },
74
+ processes: {
75
+ count: await this.getProcessCount(),
76
+ threads: await this.getThreadCount(),
77
+ handles: await this.getHandleCount()
78
+ }
79
+ };
80
+ }
81
+
82
+ // Agent performance metrics
83
+ async collectAgentMetrics() {
84
+ const agents = await mcp.agent_list({});
85
+ const agentMetrics = new Map();
86
+
87
+ for (const agent of agents) {
88
+ const metrics = await mcp.agent_metrics({ agentId: agent.id });
89
+ agentMetrics.set(agent.id, {
90
+ ...metrics,
91
+ efficiency: this.calculateEfficiency(metrics),
92
+ responsiveness: this.calculateResponsiveness(metrics),
93
+ reliability: this.calculateReliability(metrics)
94
+ });
95
+ }
96
+
97
+ return agentMetrics;
98
+ }
99
+ }
100
+ ```
101
+
102
+ ### 2. Bottleneck Detection & Analysis
103
+ ```javascript
104
+ // Intelligent bottleneck detection
105
+ class BottleneckAnalyzer {
106
+ constructor() {
107
+ this.detectors = [
108
+ new CPUBottleneckDetector(),
109
+ new MemoryBottleneckDetector(),
110
+ new IOBottleneckDetector(),
111
+ new NetworkBottleneckDetector(),
112
+ new CoordinationBottleneckDetector(),
113
+ new TaskQueueBottleneckDetector()
114
+ ];
115
+
116
+ this.patterns = new Map();
117
+ this.history = new CircularBuffer(1000);
118
+ }
119
+
120
+ // Multi-layer bottleneck analysis
121
+ async analyzeBottlenecks(metrics) {
122
+ const bottlenecks = [];
123
+
124
+ // Parallel detection across all layers
125
+ const detectionPromises = this.detectors.map(detector =>
126
+ detector.detect(metrics)
127
+ );
128
+
129
+ const results = await Promise.all(detectionPromises);
130
+
131
+ // Correlate and prioritize bottlenecks
132
+ for (const result of results) {
133
+ if (result.detected) {
134
+ bottlenecks.push({
135
+ type: result.type,
136
+ severity: result.severity,
137
+ component: result.component,
138
+ rootCause: result.rootCause,
139
+ impact: result.impact,
140
+ recommendations: result.recommendations,
141
+ timestamp: Date.now()
142
+ });
143
+ }
144
+ }
145
+
146
+ // Pattern recognition for recurring bottlenecks
147
+ await this.updatePatterns(bottlenecks);
148
+
149
+ return this.prioritizeBottlenecks(bottlenecks);
150
+ }
151
+
152
+ // Advanced pattern recognition
153
+ async updatePatterns(bottlenecks) {
154
+ for (const bottleneck of bottlenecks) {
155
+ const signature = this.createBottleneckSignature(bottleneck);
156
+
157
+ if (this.patterns.has(signature)) {
158
+ const pattern = this.patterns.get(signature);
159
+ pattern.frequency++;
160
+ pattern.lastOccurrence = Date.now();
161
+ pattern.averageInterval = this.calculateAverageInterval(pattern);
162
+ } else {
163
+ this.patterns.set(signature, {
164
+ signature,
165
+ frequency: 1,
166
+ firstOccurrence: Date.now(),
167
+ lastOccurrence: Date.now(),
168
+ averageInterval: 0,
169
+ predictedNext: null
170
+ });
171
+ }
172
+ }
173
+ }
174
+ }
175
+ ```
176
+
177
+ ### 3. SLA Monitoring & Alerting
178
+ ```javascript
179
+ // Service Level Agreement monitoring
180
+ class SLAMonitor {
181
+ constructor() {
182
+ this.slaDefinitions = new Map();
183
+ this.violations = new Map();
184
+ this.alertChannels = new Set();
185
+ this.escalationRules = new Map();
186
+ }
187
+
188
+ // Define SLA metrics and thresholds
189
+ defineSLA(service, slaConfig) {
190
+ this.slaDefinitions.set(service, {
191
+ availability: slaConfig.availability || 99.9, // percentage
192
+ responseTime: slaConfig.responseTime || 1000, // milliseconds
193
+ throughput: slaConfig.throughput || 100, // requests per second
194
+ errorRate: slaConfig.errorRate || 0.1, // percentage
195
+ recoveryTime: slaConfig.recoveryTime || 300, // seconds
196
+
197
+ // Time windows for measurements
198
+ measurementWindow: slaConfig.measurementWindow || 300, // seconds
199
+ evaluationInterval: slaConfig.evaluationInterval || 60, // seconds
200
+
201
+ // Alerting configuration
202
+ alertThresholds: slaConfig.alertThresholds || {
203
+ warning: 0.8, // 80% of SLA threshold
204
+ critical: 0.9, // 90% of SLA threshold
205
+ breach: 1.0 // 100% of SLA threshold
206
+ }
207
+ });
208
+ }
209
+
210
+ // Continuous SLA monitoring
211
+ async monitorSLA() {
212
+ const violations = [];
213
+
214
+ for (const [service, sla] of this.slaDefinitions) {
215
+ const metrics = await this.getServiceMetrics(service);
216
+ const evaluation = this.evaluateSLA(service, sla, metrics);
217
+
218
+ if (evaluation.violated) {
219
+ violations.push(evaluation);
220
+ await this.handleViolation(service, evaluation);
221
+ }
222
+ }
223
+
224
+ return violations;
225
+ }
226
+
227
+ // SLA evaluation logic
228
+ evaluateSLA(service, sla, metrics) {
229
+ const evaluation = {
230
+ service,
231
+ timestamp: Date.now(),
232
+ violated: false,
233
+ violations: []
234
+ };
235
+
236
+ // Availability check
237
+ if (metrics.availability < sla.availability) {
238
+ evaluation.violations.push({
239
+ metric: 'availability',
240
+ expected: sla.availability,
241
+ actual: metrics.availability,
242
+ severity: this.calculateSeverity(metrics.availability, sla.availability, sla.alertThresholds)
243
+ });
244
+ evaluation.violated = true;
245
+ }
246
+
247
+ // Response time check
248
+ if (metrics.responseTime > sla.responseTime) {
249
+ evaluation.violations.push({
250
+ metric: 'responseTime',
251
+ expected: sla.responseTime,
252
+ actual: metrics.responseTime,
253
+ severity: this.calculateSeverity(metrics.responseTime, sla.responseTime, sla.alertThresholds)
254
+ });
255
+ evaluation.violated = true;
256
+ }
257
+
258
+ // Additional SLA checks...
259
+
260
+ return evaluation;
261
+ }
262
+ }
263
+ ```
264
+
265
+ ### 4. Resource Utilization Tracking
266
+ ```javascript
267
+ // Comprehensive resource tracking
268
+ class ResourceTracker {
269
+ constructor() {
270
+ this.trackers = {
271
+ cpu: new CPUTracker(),
272
+ memory: new MemoryTracker(),
273
+ disk: new DiskTracker(),
274
+ network: new NetworkTracker(),
275
+ gpu: new GPUTracker(),
276
+ agents: new AgentResourceTracker()
277
+ };
278
+
279
+ this.forecaster = new ResourceForecaster();
280
+ this.optimizer = new ResourceOptimizer();
281
+ }
282
+
283
+ // Real-time resource tracking
284
+ async trackResources() {
285
+ const resources = {};
286
+
287
+ // Parallel resource collection
288
+ const trackingPromises = Object.entries(this.trackers).map(
289
+ async ([type, tracker]) => [type, await tracker.collect()]
290
+ );
291
+
292
+ const results = await Promise.all(trackingPromises);
293
+
294
+ for (const [type, data] of results) {
295
+ resources[type] = {
296
+ ...data,
297
+ utilization: this.calculateUtilization(data),
298
+ efficiency: this.calculateEfficiency(data),
299
+ trend: this.calculateTrend(type, data),
300
+ forecast: await this.forecaster.forecast(type, data)
301
+ };
302
+ }
303
+
304
+ return resources;
305
+ }
306
+
307
+ // Resource utilization analysis
308
+ calculateUtilization(resourceData) {
309
+ return {
310
+ current: resourceData.used / resourceData.total,
311
+ peak: resourceData.peak / resourceData.total,
312
+ average: resourceData.average / resourceData.total,
313
+ percentiles: {
314
+ p50: resourceData.p50 / resourceData.total,
315
+ p90: resourceData.p90 / resourceData.total,
316
+ p95: resourceData.p95 / resourceData.total,
317
+ p99: resourceData.p99 / resourceData.total
318
+ }
319
+ };
320
+ }
321
+
322
+ // Predictive resource forecasting
323
+ async forecastResourceNeeds(timeHorizon = 3600) { // 1 hour default
324
+ const currentResources = await this.trackResources();
325
+ const forecasts = {};
326
+
327
+ for (const [type, data] of Object.entries(currentResources)) {
328
+ forecasts[type] = await this.forecaster.forecast(type, data, timeHorizon);
329
+ }
330
+
331
+ return {
332
+ timeHorizon,
333
+ forecasts,
334
+ recommendations: await this.optimizer.generateRecommendations(forecasts),
335
+ confidence: this.calculateForecastConfidence(forecasts)
336
+ };
337
+ }
338
+ }
339
+ ```
340
+
341
+ ## MCP Integration Hooks
342
+
343
+ ### Performance Data Collection
344
+ ```javascript
345
+ // Comprehensive MCP integration
346
+ const performanceIntegration = {
347
+ // Real-time performance monitoring
348
+ async startMonitoring(config = {}) {
349
+ const monitoringTasks = [
350
+ this.monitorSwarmHealth(),
351
+ this.monitorAgentPerformance(),
352
+ this.monitorResourceUtilization(),
353
+ this.monitorBottlenecks(),
354
+ this.monitorSLACompliance()
355
+ ];
356
+
357
+ // Start all monitoring tasks concurrently
358
+ const monitors = await Promise.all(monitoringTasks);
359
+
360
+ return {
361
+ swarmHealthMonitor: monitors[0],
362
+ agentPerformanceMonitor: monitors[1],
363
+ resourceMonitor: monitors[2],
364
+ bottleneckMonitor: monitors[3],
365
+ slaMonitor: monitors[4]
366
+ };
367
+ },
368
+
369
+ // Swarm health monitoring
370
+ async monitorSwarmHealth() {
371
+ const healthMetrics = await mcp.health_check({
372
+ components: ['swarm', 'coordination', 'communication']
373
+ });
374
+
375
+ return {
376
+ status: healthMetrics.overall,
377
+ components: healthMetrics.components,
378
+ issues: healthMetrics.issues,
379
+ recommendations: healthMetrics.recommendations
380
+ };
381
+ },
382
+
383
+ // Agent performance monitoring
384
+ async monitorAgentPerformance() {
385
+ const agents = await mcp.agent_list({});
386
+ const performanceData = new Map();
387
+
388
+ for (const agent of agents) {
389
+ const metrics = await mcp.agent_metrics({ agentId: agent.id });
390
+ const performance = await mcp.performance_report({
391
+ format: 'detailed',
392
+ timeframe: '24h'
393
+ });
394
+
395
+ performanceData.set(agent.id, {
396
+ ...metrics,
397
+ performance,
398
+ efficiency: this.calculateAgentEfficiency(metrics, performance),
399
+ bottlenecks: await mcp.bottleneck_analyze({ component: agent.id })
400
+ });
401
+ }
402
+
403
+ return performanceData;
404
+ },
405
+
406
+ // Bottleneck monitoring and analysis
407
+ async monitorBottlenecks() {
408
+ const bottlenecks = await mcp.bottleneck_analyze({});
409
+
410
+ // Enhanced bottleneck analysis
411
+ const analysis = {
412
+ detected: bottlenecks.length > 0,
413
+ count: bottlenecks.length,
414
+ severity: this.calculateOverallSeverity(bottlenecks),
415
+ categories: this.categorizeBottlenecks(bottlenecks),
416
+ trends: await this.analyzeBottleneckTrends(bottlenecks),
417
+ predictions: await this.predictBottlenecks(bottlenecks)
418
+ };
419
+
420
+ return analysis;
421
+ }
422
+ };
423
+ ```
424
+
425
+ ### Anomaly Detection
426
+ ```javascript
427
+ // Advanced anomaly detection system
428
+ class AnomalyDetector {
429
+ constructor() {
430
+ this.models = {
431
+ statistical: new StatisticalAnomalyDetector(),
432
+ machine_learning: new MLAnomalyDetector(),
433
+ time_series: new TimeSeriesAnomalyDetector(),
434
+ behavioral: new BehavioralAnomalyDetector()
435
+ };
436
+
437
+ this.ensemble = new EnsembleDetector(this.models);
438
+ }
439
+
440
+ // Multi-model anomaly detection
441
+ async detectAnomalies(metrics) {
442
+ const anomalies = [];
443
+
444
+ // Parallel detection across all models
445
+ const detectionPromises = Object.entries(this.models).map(
446
+ async ([modelType, model]) => {
447
+ const detected = await model.detect(metrics);
448
+ return { modelType, detected };
449
+ }
450
+ );
451
+
452
+ const results = await Promise.all(detectionPromises);
453
+
454
+ // Ensemble voting for final decision
455
+ const ensembleResult = await this.ensemble.vote(results);
456
+
457
+ return {
458
+ anomalies: ensembleResult.anomalies,
459
+ confidence: ensembleResult.confidence,
460
+ consensus: ensembleResult.consensus,
461
+ individualResults: results
462
+ };
463
+ }
464
+
465
+ // Statistical anomaly detection
466
+ detectStatisticalAnomalies(data) {
467
+ const mean = this.calculateMean(data);
468
+ const stdDev = this.calculateStandardDeviation(data, mean);
469
+ const threshold = 3 * stdDev; // 3-sigma rule
470
+
471
+ return data.filter(point => Math.abs(point - mean) > threshold)
472
+ .map(point => ({
473
+ value: point,
474
+ type: 'statistical',
475
+ deviation: Math.abs(point - mean) / stdDev,
476
+ probability: this.calculateProbability(point, mean, stdDev)
477
+ }));
478
+ }
479
+
480
+ // Time series anomaly detection
481
+ async detectTimeSeriesAnomalies(timeSeries) {
482
+ // LSTM-based anomaly detection
483
+ const model = await this.loadTimeSeriesModel();
484
+ const predictions = await model.predict(timeSeries);
485
+
486
+ const anomalies = [];
487
+ for (let i = 0; i < timeSeries.length; i++) {
488
+ const error = Math.abs(timeSeries[i] - predictions[i]);
489
+ const threshold = this.calculateDynamicThreshold(timeSeries, i);
490
+
491
+ if (error > threshold) {
492
+ anomalies.push({
493
+ timestamp: i,
494
+ actual: timeSeries[i],
495
+ predicted: predictions[i],
496
+ error: error,
497
+ type: 'time_series'
498
+ });
499
+ }
500
+ }
501
+
502
+ return anomalies;
503
+ }
504
+ }
505
+ ```
506
+
507
+ ## Dashboard Integration
508
+
509
+ ### Real-Time Performance Dashboard
510
+ ```javascript
511
+ // Dashboard data provider
512
+ class DashboardProvider {
513
+ constructor() {
514
+ this.updateInterval = 1000; // 1 second updates
515
+ this.subscribers = new Set();
516
+ this.dataBuffer = new CircularBuffer(1000);
517
+ }
518
+
519
+ // Real-time dashboard data
520
+ async provideDashboardData() {
521
+ const dashboardData = {
522
+ // High-level metrics
523
+ overview: {
524
+ swarmHealth: await this.getSwarmHealthScore(),
525
+ activeAgents: await this.getActiveAgentCount(),
526
+ totalTasks: await this.getTotalTaskCount(),
527
+ averageResponseTime: await this.getAverageResponseTime()
528
+ },
529
+
530
+ // Performance metrics
531
+ performance: {
532
+ throughput: await this.getCurrentThroughput(),
533
+ latency: await this.getCurrentLatency(),
534
+ errorRate: await this.getCurrentErrorRate(),
535
+ utilization: await this.getResourceUtilization()
536
+ },
537
+
538
+ // Real-time charts data
539
+ timeSeries: {
540
+ cpu: this.getCPUTimeSeries(),
541
+ memory: this.getMemoryTimeSeries(),
542
+ network: this.getNetworkTimeSeries(),
543
+ tasks: this.getTaskTimeSeries()
544
+ },
545
+
546
+ // Alerts and notifications
547
+ alerts: await this.getActiveAlerts(),
548
+ notifications: await this.getRecentNotifications(),
549
+
550
+ // Agent status
551
+ agents: await this.getAgentStatusSummary(),
552
+
553
+ timestamp: Date.now()
554
+ };
555
+
556
+ // Broadcast to subscribers
557
+ this.broadcast(dashboardData);
558
+
559
+ return dashboardData;
560
+ }
561
+
562
+ // WebSocket subscription management
563
+ subscribe(callback) {
564
+ this.subscribers.add(callback);
565
+ return () => this.subscribers.delete(callback);
566
+ }
567
+
568
+ broadcast(data) {
569
+ this.subscribers.forEach(callback => {
570
+ try {
571
+ callback(data);
572
+ } catch (error) {
573
+ console.error('Dashboard subscriber error:', error);
574
+ }
575
+ });
576
+ }
577
+ }
578
+ ```
579
+
580
+ ## Operational Commands
581
+
582
+ ### Monitoring Commands
583
+ ```bash
584
+ # Start comprehensive monitoring
585
+ npx claude-flow performance-report --format detailed --timeframe 24h
586
+
587
+ # Real-time bottleneck analysis
588
+ npx claude-flow bottleneck-analyze --component swarm-coordination
589
+
590
+ # Health check all components
591
+ npx claude-flow health-check --components ["swarm", "agents", "coordination"]
592
+
593
+ # Collect specific metrics
594
+ npx claude-flow metrics-collect --components ["cpu", "memory", "network"]
595
+
596
+ # Monitor SLA compliance
597
+ npx claude-flow sla-monitor --service swarm-coordination --threshold 99.9
598
+ ```
599
+
600
+ ### Alert Configuration
601
+ ```bash
602
+ # Configure performance alerts
603
+ npx claude-flow alert-config --metric cpu_usage --threshold 80 --severity warning
604
+
605
+ # Set up anomaly detection
606
+ npx claude-flow anomaly-setup --models ["statistical", "ml", "time_series"]
607
+
608
+ # Configure notification channels
609
+ npx claude-flow notification-config --channels ["slack", "email", "webhook"]
610
+ ```
611
+
612
+ ## Integration Points
613
+
614
+ ### With Other Optimization Agents
615
+ - **Load Balancer**: Provides performance data for load balancing decisions
616
+ - **Topology Optimizer**: Supplies network and coordination metrics
617
+ - **Resource Manager**: Shares resource utilization and forecasting data
618
+
619
+ ### With Swarm Infrastructure
620
+ - **Task Orchestrator**: Monitors task execution performance
621
+ - **Agent Coordinator**: Tracks agent health and performance
622
+ - **Memory System**: Stores historical performance data and patterns
623
+
624
+ ## Performance Analytics
625
+
626
+ ### Key Metrics Dashboard
627
+ ```javascript
628
+ // Performance analytics engine
629
+ const analytics = {
630
+ // Key Performance Indicators
631
+ calculateKPIs(metrics) {
632
+ return {
633
+ // Availability metrics
634
+ uptime: this.calculateUptime(metrics),
635
+ availability: this.calculateAvailability(metrics),
636
+
637
+ // Performance metrics
638
+ responseTime: {
639
+ average: this.calculateAverage(metrics.responseTimes),
640
+ p50: this.calculatePercentile(metrics.responseTimes, 50),
641
+ p90: this.calculatePercentile(metrics.responseTimes, 90),
642
+ p95: this.calculatePercentile(metrics.responseTimes, 95),
643
+ p99: this.calculatePercentile(metrics.responseTimes, 99)
644
+ },
645
+
646
+ // Throughput metrics
647
+ throughput: this.calculateThroughput(metrics),
648
+
649
+ // Error metrics
650
+ errorRate: this.calculateErrorRate(metrics),
651
+
652
+ // Resource efficiency
653
+ resourceEfficiency: this.calculateResourceEfficiency(metrics),
654
+
655
+ // Cost metrics
656
+ costEfficiency: this.calculateCostEfficiency(metrics)
657
+ };
658
+ },
659
+
660
+ // Trend analysis
661
+ analyzeTrends(historicalData, timeWindow = '7d') {
662
+ return {
663
+ performance: this.calculatePerformanceTrend(historicalData, timeWindow),
664
+ efficiency: this.calculateEfficiencyTrend(historicalData, timeWindow),
665
+ reliability: this.calculateReliabilityTrend(historicalData, timeWindow),
666
+ capacity: this.calculateCapacityTrend(historicalData, timeWindow)
667
+ };
668
+ }
669
+ };
670
+ ```
671
+
672
672
  This Performance Monitor agent provides comprehensive real-time monitoring, bottleneck detection, SLA compliance tracking, and advanced analytics for optimal swarm performance management.