moflo 4.9.20 → 4.9.22

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 (240) hide show
  1. package/.claude/agents/analysis/analyze-code-quality.md +0 -121
  2. package/.claude/agents/analysis/code-analyzer.md +5 -26
  3. package/.claude/agents/architecture/system-design/arch-system-design.md +0 -119
  4. package/.claude/agents/base-template-generator.md +0 -1
  5. package/.claude/agents/core/coder.md +0 -22
  6. package/.claude/agents/core/planner.md +0 -16
  7. package/.claude/agents/core/researcher.md +0 -16
  8. package/.claude/agents/core/reviewer.md +0 -17
  9. package/.claude/agents/core/tester.md +0 -19
  10. package/.claude/agents/custom/test-long-runner.md +0 -2
  11. package/.claude/agents/development/dev-backend-api.md +0 -167
  12. package/.claude/agents/development/dev-database.md +43 -0
  13. package/.claude/agents/development/dev-frontend.md +42 -0
  14. package/.claude/agents/devops/ci-cd/ops-cicd-github.md +0 -112
  15. package/.claude/agents/documentation/api-docs/docs-api-openapi.md +0 -111
  16. package/.claude/agents/security/security-auditor.md +45 -0
  17. package/.claude/guidance/shipped/moflo-agent-rules.md +172 -0
  18. package/.claude/guidance/shipped/moflo-claude-swarm-cohesion.md +73 -265
  19. package/.claude/guidance/shipped/moflo-cli-reference.md +6 -6
  20. package/.claude/guidance/shipped/moflo-core-guidance.md +66 -184
  21. package/.claude/guidance/shipped/moflo-cross-platform.md +1 -1
  22. package/.claude/guidance/shipped/moflo-error-handling.md +3 -3
  23. package/.claude/guidance/shipped/moflo-guidance-rules.md +17 -7
  24. package/.claude/guidance/shipped/moflo-memory-strategy.md +76 -182
  25. package/.claude/guidance/shipped/moflo-memorydb-maintenance.md +6 -8
  26. package/.claude/guidance/shipped/moflo-settings-injection.md +7 -9
  27. package/.claude/guidance/shipped/moflo-source-hygiene.md +5 -5
  28. package/.claude/guidance/shipped/moflo-spell-connectors.md +3 -4
  29. package/.claude/guidance/shipped/moflo-spell-custom-steps.md +3 -4
  30. package/.claude/guidance/shipped/moflo-spell-engine.md +40 -162
  31. package/.claude/guidance/shipped/moflo-spell-runner.md +134 -0
  32. package/.claude/guidance/shipped/moflo-spell-sandboxing.md +10 -57
  33. package/.claude/guidance/shipped/moflo-spell-troubleshooting.md +149 -0
  34. package/.claude/guidance/shipped/moflo-subagents.md +43 -114
  35. package/.claude/guidance/shipped/moflo-task-icons.md +4 -4
  36. package/.claude/guidance/shipped/moflo-user-facing-language.md +3 -3
  37. package/.claude/guidance/shipped/moflo-verbose-command-filtering.md +3 -3
  38. package/.claude/guidance/shipped/moflo-yaml-reference.md +4 -5
  39. package/.claude/helpers/gate.cjs +192 -15
  40. package/.claude/helpers/prompt-hook.mjs +4 -38
  41. package/.claude/helpers/simplify-classify.cjs +32 -11
  42. package/.claude/helpers/subagent-bootstrap.json +1 -1
  43. package/.claude/helpers/subagent-start.cjs +1 -1
  44. package/.claude/skills/connector-builder/SKILL.md +42 -429
  45. package/.claude/skills/connector-builder/templates/connector.md +189 -0
  46. package/.claude/skills/connector-builder/templates/step-command.md +176 -0
  47. package/.claude/skills/eldar/SKILL.md +7 -7
  48. package/.claude/skills/fl/SKILL.md +3 -3
  49. package/.claude/skills/fl/execution-modes.md +39 -16
  50. package/.claude/skills/fl/phases.md +3 -3
  51. package/.claude/skills/{simplify → flo-simplify}/SKILL.md +11 -11
  52. package/.claude/skills/guidance/SKILL.md +17 -9
  53. package/.claude/skills/memory-patterns/SKILL.md +1 -1
  54. package/.claude/skills/publish/SKILL.md +121 -36
  55. package/.claude/skills/reset-epic/SKILL.md +2 -2
  56. package/.claude/skills/spell-builder/SKILL.md +39 -226
  57. package/.claude/skills/spell-builder/architecture.md +1 -1
  58. package/.claude/skills/spell-builder/permissions.md +107 -0
  59. package/.claude/skills/spell-builder/preflight.md +101 -0
  60. package/.claude/skills/spell-schedule/SKILL.md +2 -3
  61. package/bin/gate.cjs +192 -15
  62. package/bin/lib/retired-files.mjs +146 -0
  63. package/bin/prompt-hook.mjs +4 -38
  64. package/bin/session-start-launcher.mjs +120 -1
  65. package/bin/setup-project.mjs +63 -69
  66. package/bin/simplify-classify.cjs +32 -11
  67. package/dist/src/cli/appliance/rvfa-builder.js +1 -1
  68. package/dist/src/cli/commands/agent.js +3 -9
  69. package/dist/src/cli/commands/doctor-checks-deep.js +4 -0
  70. package/dist/src/cli/commands/hooks.js +1 -3
  71. package/dist/src/cli/commands/index.js +2 -0
  72. package/dist/src/cli/commands/retire.js +111 -0
  73. package/dist/src/cli/hooks/reasoningbank/index.js +7 -7
  74. package/dist/src/cli/init/claudemd-generator.js +30 -33
  75. package/dist/src/cli/init/executor.js +53 -69
  76. package/dist/src/cli/init/helpers-generator.js +165 -52
  77. package/dist/src/cli/init/moflo-init.js +41 -114
  78. package/dist/src/cli/init/settings-generator.js +44 -14
  79. package/dist/src/cli/mcp-tools/agent-tools.js +9 -27
  80. package/dist/src/cli/mcp-tools/hooks-tools.js +23 -21
  81. package/dist/src/cli/memory/controllers/semantic-router.js +18 -12
  82. package/dist/src/cli/memory/sona-optimizer.js +6 -6
  83. package/dist/src/cli/neural/domain/services/learning-service.js +3 -3
  84. package/dist/src/cli/services/agent-router.js +2 -5
  85. package/dist/src/cli/services/hook-block-hash.js +11 -2
  86. package/dist/src/cli/services/hook-wiring.js +86 -3
  87. package/dist/src/cli/services/subagent-bootstrap.js +1 -1
  88. package/dist/src/cli/shared/events/example-usage.js +6 -6
  89. package/dist/src/cli/shared/hooks/task-hooks.js +8 -8
  90. package/dist/src/cli/version.js +1 -1
  91. package/package.json +3 -2
  92. package/retired-files.json +1989 -0
  93. package/scripts/post-install-bootstrap.mjs +19 -0
  94. package/src/cli/data/model-registry.json +2 -2
  95. package/.claude/agents/consensus/byzantine-coordinator.md +0 -63
  96. package/.claude/agents/consensus/crdt-synchronizer.md +0 -997
  97. package/.claude/agents/consensus/gossip-coordinator.md +0 -63
  98. package/.claude/agents/consensus/performance-benchmarker.md +0 -851
  99. package/.claude/agents/consensus/quorum-manager.md +0 -823
  100. package/.claude/agents/consensus/raft-manager.md +0 -63
  101. package/.claude/agents/consensus/security-manager.md +0 -622
  102. package/.claude/agents/data/ml/data-ml-model.md +0 -193
  103. package/.claude/agents/github/code-review-swarm.md +0 -538
  104. package/.claude/agents/github/github-modes.md +0 -172
  105. package/.claude/agents/github/issue-tracker.md +0 -311
  106. package/.claude/agents/github/multi-repo-swarm.md +0 -551
  107. package/.claude/agents/github/pr-manager.md +0 -183
  108. package/.claude/agents/github/project-board-sync.md +0 -508
  109. package/.claude/agents/github/release-manager.md +0 -360
  110. package/.claude/agents/github/release-swarm.md +0 -580
  111. package/.claude/agents/github/repo-architect.md +0 -391
  112. package/.claude/agents/github/swarm-issue.md +0 -566
  113. package/.claude/agents/github/swarm-pr.md +0 -414
  114. package/.claude/agents/github/sync-coordinator.md +0 -426
  115. package/.claude/agents/github/workflow-automation.md +0 -606
  116. package/.claude/agents/goal/code-goal-planner.md +0 -440
  117. package/.claude/agents/goal/goal-planner.md +0 -168
  118. package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +0 -127
  119. package/.claude/agents/hive-mind/queen-coordinator.md +0 -198
  120. package/.claude/agents/hive-mind/scout-explorer.md +0 -233
  121. package/.claude/agents/hive-mind/swarm-memory-manager.md +0 -184
  122. package/.claude/agents/hive-mind/worker-specialist.md +0 -208
  123. package/.claude/agents/neural/safla-neural.md +0 -73
  124. package/.claude/agents/optimization/benchmark-suite.md +0 -665
  125. package/.claude/agents/optimization/load-balancer.md +0 -431
  126. package/.claude/agents/optimization/performance-monitor.md +0 -672
  127. package/.claude/agents/optimization/resource-allocator.md +0 -674
  128. package/.claude/agents/optimization/topology-optimizer.md +0 -808
  129. package/.claude/agents/reasoning/goal-planner.md +0 -67
  130. package/.claude/agents/sona/sona-learning-optimizer.md +0 -74
  131. package/.claude/agents/sparc/architecture.md +0 -472
  132. package/.claude/agents/sparc/pseudocode.md +0 -318
  133. package/.claude/agents/sparc/refinement.md +0 -525
  134. package/.claude/agents/sparc/specification.md +0 -276
  135. package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +0 -225
  136. package/.claude/agents/swarm/adaptive-coordinator.md +0 -391
  137. package/.claude/agents/swarm/hierarchical-coordinator.md +0 -321
  138. package/.claude/agents/swarm/mesh-coordinator.md +0 -383
  139. package/.claude/agents/testing/production-validator.md +0 -395
  140. package/.claude/agents/testing/tdd-london-swarm.md +0 -244
  141. package/.claude/agents/v3/adr-architect.md +0 -184
  142. package/.claude/agents/v3/aidefence-guardian.md +0 -277
  143. package/.claude/agents/v3/claims-authorizer.md +0 -208
  144. package/.claude/agents/v3/collective-intelligence-coordinator.md +0 -988
  145. package/.claude/agents/v3/ddd-domain-expert.md +0 -220
  146. package/.claude/agents/v3/injection-analyst.md +0 -232
  147. package/.claude/agents/v3/memory-specialist.md +0 -987
  148. package/.claude/agents/v3/performance-engineer.md +0 -1225
  149. package/.claude/agents/v3/pii-detector.md +0 -146
  150. package/.claude/agents/v3/reasoningbank-learner.md +0 -213
  151. package/.claude/agents/v3/security-architect-aidefence.md +0 -405
  152. package/.claude/agents/v3/security-architect.md +0 -865
  153. package/.claude/agents/v3/security-auditor.md +0 -771
  154. package/.claude/agents/v3/sparc-orchestrator.md +0 -182
  155. package/.claude/agents/v3/swarm-memory-manager.md +0 -142
  156. package/.claude/agents/v3/v3-integration-architect.md +0 -205
  157. package/.claude/commands/claude-flow-help.md +0 -103
  158. package/.claude/commands/claude-flow-memory.md +0 -107
  159. package/.claude/commands/claude-flow-swarm.md +0 -205
  160. package/.claude/commands/github/README.md +0 -11
  161. package/.claude/commands/github/code-review-swarm.md +0 -514
  162. package/.claude/commands/github/code-review.md +0 -25
  163. package/.claude/commands/github/github-modes.md +0 -146
  164. package/.claude/commands/github/github-swarm.md +0 -113
  165. package/.claude/commands/github/issue-tracker.md +0 -284
  166. package/.claude/commands/github/issue-triage.md +0 -25
  167. package/.claude/commands/github/multi-repo-swarm.md +0 -519
  168. package/.claude/commands/github/pr-enhance.md +0 -26
  169. package/.claude/commands/github/pr-manager.md +0 -164
  170. package/.claude/commands/github/project-board-sync.md +0 -471
  171. package/.claude/commands/github/release-manager.md +0 -332
  172. package/.claude/commands/github/release-swarm.md +0 -544
  173. package/.claude/commands/github/repo-analyze.md +0 -25
  174. package/.claude/commands/github/repo-architect.md +0 -361
  175. package/.claude/commands/github/swarm-issue.md +0 -482
  176. package/.claude/commands/github/swarm-pr.md +0 -285
  177. package/.claude/commands/github/sync-coordinator.md +0 -294
  178. package/.claude/commands/github/workflow-automation.md +0 -442
  179. package/.claude/commands/hooks/README.md +0 -11
  180. package/.claude/commands/hooks/overview.md +0 -58
  181. package/.claude/commands/hooks/post-edit.md +0 -117
  182. package/.claude/commands/hooks/post-task.md +0 -112
  183. package/.claude/commands/hooks/pre-edit.md +0 -113
  184. package/.claude/commands/hooks/pre-task.md +0 -111
  185. package/.claude/commands/hooks/session-end.md +0 -118
  186. package/.claude/commands/hooks/setup.md +0 -103
  187. package/.claude/commands/simplify.md +0 -101
  188. package/.claude/commands/sparc/analyzer.md +0 -42
  189. package/.claude/commands/sparc/architect.md +0 -43
  190. package/.claude/commands/sparc/ask.md +0 -86
  191. package/.claude/commands/sparc/batch-executor.md +0 -44
  192. package/.claude/commands/sparc/code.md +0 -78
  193. package/.claude/commands/sparc/coder.md +0 -44
  194. package/.claude/commands/sparc/debug.md +0 -72
  195. package/.claude/commands/sparc/debugger.md +0 -44
  196. package/.claude/commands/sparc/designer.md +0 -43
  197. package/.claude/commands/sparc/devops.md +0 -98
  198. package/.claude/commands/sparc/docs-writer.md +0 -69
  199. package/.claude/commands/sparc/documenter.md +0 -44
  200. package/.claude/commands/sparc/innovator.md +0 -44
  201. package/.claude/commands/sparc/integration.md +0 -72
  202. package/.claude/commands/sparc/mcp.md +0 -106
  203. package/.claude/commands/sparc/memory-manager.md +0 -44
  204. package/.claude/commands/sparc/optimizer.md +0 -44
  205. package/.claude/commands/sparc/orchestrator.md +0 -116
  206. package/.claude/commands/sparc/post-deployment-monitoring-mode.md +0 -72
  207. package/.claude/commands/sparc/refinement-optimization-mode.md +0 -72
  208. package/.claude/commands/sparc/researcher.md +0 -44
  209. package/.claude/commands/sparc/reviewer.md +0 -44
  210. package/.claude/commands/sparc/security-review.md +0 -69
  211. package/.claude/commands/sparc/sparc-modes.md +0 -139
  212. package/.claude/commands/sparc/sparc.md +0 -99
  213. package/.claude/commands/sparc/spec-pseudocode.md +0 -69
  214. package/.claude/commands/sparc/spell-manager.md +0 -44
  215. package/.claude/commands/sparc/supabase-admin.md +0 -337
  216. package/.claude/commands/sparc/swarm-coordinator.md +0 -44
  217. package/.claude/commands/sparc/tdd.md +0 -44
  218. package/.claude/commands/sparc/tester.md +0 -44
  219. package/.claude/commands/sparc/tutorial.md +0 -68
  220. package/.claude/commands/sparc.md +0 -151
  221. package/.claude/guidance/shipped/moflo-session-start.md +0 -154
  222. package/.claude/guidance/shipped/moflo-spell-engine-architecture.md +0 -145
  223. package/.claude/skills/browser/SKILL.md +0 -204
  224. package/.claude/skills/github-code-review/SKILL.md +0 -1140
  225. package/.claude/skills/github-multi-repo/SKILL.md +0 -866
  226. package/.claude/skills/github-project-management/SKILL.md +0 -1272
  227. package/.claude/skills/github-release-management/SKILL.md +0 -1074
  228. package/.claude/skills/github-workflow-automation/SKILL.md +0 -1060
  229. package/.claude/skills/hive-mind-advanced/SKILL.md +0 -712
  230. package/.claude/skills/hooks-automation/SKILL.md +0 -1193
  231. package/.claude/skills/pair-programming/SKILL.md +0 -1202
  232. package/.claude/skills/performance-analysis/SKILL.md +0 -563
  233. package/.claude/skills/skill-builder/SKILL.md +0 -910
  234. package/.claude/skills/sparc-methodology/SKILL.md +0 -904
  235. package/.claude/skills/stream-chain/SKILL.md +0 -563
  236. package/.claude/skills/swarm-advanced/SKILL.md +0 -811
  237. package/.claude/skills/swarm-orchestration/SKILL.md +0 -179
  238. package/.claude/skills/verification-quality/SKILL.md +0 -649
  239. package/.claude/skills/worker-benchmarks/skill.md +0 -135
  240. package/.claude/skills/worker-integration/skill.md +0 -154
@@ -1,431 +0,0 @@
1
- ---
2
- name: Load Balancing Coordinator
3
- type: agent
4
- category: optimization
5
- description: Dynamic task distribution, work-stealing algorithms and adaptive load balancing
6
- ---
7
-
8
- # Load Balancing Coordinator Agent
9
-
10
- ## Agent Profile
11
- - **Name**: Load Balancing Coordinator
12
- - **Type**: Performance Optimization Agent
13
- - **Specialization**: Dynamic task distribution and resource allocation
14
- - **Performance Focus**: Work-stealing algorithms and adaptive load balancing
15
-
16
- ## Core Capabilities
17
-
18
- ### 1. Work-Stealing Algorithms
19
- ```javascript
20
- // Advanced work-stealing implementation
21
- const workStealingScheduler = {
22
- // Distributed queue system
23
- globalQueue: new PriorityQueue(),
24
- localQueues: new Map(), // agent-id -> local queue
25
-
26
- // Work-stealing algorithm
27
- async stealWork(requestingAgentId) {
28
- const victims = this.getVictimCandidates(requestingAgentId);
29
-
30
- for (const victim of victims) {
31
- const stolenTasks = await this.attemptSteal(victim, requestingAgentId);
32
- if (stolenTasks.length > 0) {
33
- return stolenTasks;
34
- }
35
- }
36
-
37
- // Fallback to global queue
38
- return await this.getFromGlobalQueue(requestingAgentId);
39
- },
40
-
41
- // Victim selection strategy
42
- getVictimCandidates(requestingAgent) {
43
- return Array.from(this.localQueues.entries())
44
- .filter(([agentId, queue]) =>
45
- agentId !== requestingAgent &&
46
- queue.size() > this.stealThreshold
47
- )
48
- .sort((a, b) => b[1].size() - a[1].size()) // Heaviest first
49
- .map(([agentId]) => agentId);
50
- }
51
- };
52
- ```
53
-
54
- ### 2. Dynamic Load Balancing
55
- ```javascript
56
- // Real-time load balancing system
57
- const loadBalancer = {
58
- // Agent capacity tracking
59
- agentCapacities: new Map(),
60
- currentLoads: new Map(),
61
- performanceMetrics: new Map(),
62
-
63
- // Dynamic load balancing
64
- async balanceLoad() {
65
- const agents = await this.getActiveAgents();
66
- const loadDistribution = this.calculateLoadDistribution(agents);
67
-
68
- // Identify overloaded and underloaded agents
69
- const { overloaded, underloaded } = this.categorizeAgents(loadDistribution);
70
-
71
- // Migrate tasks from overloaded to underloaded agents
72
- for (const overloadedAgent of overloaded) {
73
- const candidateTasks = await this.getMovableTasks(overloadedAgent.id);
74
- const targetAgent = this.selectTargetAgent(underloaded, candidateTasks);
75
-
76
- if (targetAgent) {
77
- await this.migrateTasks(candidateTasks, overloadedAgent.id, targetAgent.id);
78
- }
79
- }
80
- },
81
-
82
- // Weighted Fair Queuing implementation
83
- async scheduleWithWFQ(tasks) {
84
- const weights = await this.calculateAgentWeights();
85
- const virtualTimes = new Map();
86
-
87
- return tasks.sort((a, b) => {
88
- const aFinishTime = this.calculateFinishTime(a, weights, virtualTimes);
89
- const bFinishTime = this.calculateFinishTime(b, weights, virtualTimes);
90
- return aFinishTime - bFinishTime;
91
- });
92
- }
93
- };
94
- ```
95
-
96
- ### 3. Queue Management & Prioritization
97
- ```javascript
98
- // Advanced queue management system
99
- class PriorityTaskQueue {
100
- constructor() {
101
- this.queues = {
102
- critical: new PriorityQueue((a, b) => a.deadline - b.deadline),
103
- high: new PriorityQueue((a, b) => a.priority - b.priority),
104
- normal: new WeightedRoundRobinQueue(),
105
- low: new FairShareQueue()
106
- };
107
-
108
- this.schedulingWeights = {
109
- critical: 0.4,
110
- high: 0.3,
111
- normal: 0.2,
112
- low: 0.1
113
- };
114
- }
115
-
116
- // Multi-level feedback queue scheduling
117
- async scheduleNext() {
118
- // Critical tasks always first
119
- if (!this.queues.critical.isEmpty()) {
120
- return this.queues.critical.dequeue();
121
- }
122
-
123
- // Use weighted scheduling for other levels
124
- const random = Math.random();
125
- let cumulative = 0;
126
-
127
- for (const [level, weight] of Object.entries(this.schedulingWeights)) {
128
- cumulative += weight;
129
- if (random <= cumulative && !this.queues[level].isEmpty()) {
130
- return this.queues[level].dequeue();
131
- }
132
- }
133
-
134
- return null;
135
- }
136
-
137
- // Adaptive priority adjustment
138
- adjustPriorities() {
139
- const now = Date.now();
140
-
141
- // Age-based priority boosting
142
- for (const queue of Object.values(this.queues)) {
143
- queue.forEach(task => {
144
- const age = now - task.submissionTime;
145
- if (age > this.agingThreshold) {
146
- task.priority += this.agingBoost;
147
- }
148
- });
149
- }
150
- }
151
- }
152
- ```
153
-
154
- ### 4. Resource Allocation Optimization
155
- ```javascript
156
- // Intelligent resource allocation
157
- const resourceAllocator = {
158
- // Multi-objective optimization
159
- async optimizeAllocation(agents, tasks, constraints) {
160
- const objectives = [
161
- this.minimizeLatency,
162
- this.maximizeUtilization,
163
- this.balanceLoad,
164
- this.minimizeCost
165
- ];
166
-
167
- // Genetic algorithm for multi-objective optimization
168
- const population = this.generateInitialPopulation(agents, tasks);
169
-
170
- for (let generation = 0; generation < this.maxGenerations; generation++) {
171
- const fitness = population.map(individual =>
172
- this.evaluateMultiObjectiveFitness(individual, objectives)
173
- );
174
-
175
- const selected = this.selectParents(population, fitness);
176
- const offspring = this.crossoverAndMutate(selected);
177
- population.splice(0, population.length, ...offspring);
178
- }
179
-
180
- return this.getBestSolution(population, objectives);
181
- },
182
-
183
- // Constraint-based allocation
184
- async allocateWithConstraints(resources, demands, constraints) {
185
- const solver = new ConstraintSolver();
186
-
187
- // Define variables
188
- const allocation = new Map();
189
- for (const [agentId, capacity] of resources) {
190
- allocation.set(agentId, solver.createVariable(0, capacity));
191
- }
192
-
193
- // Add constraints
194
- constraints.forEach(constraint => solver.addConstraint(constraint));
195
-
196
- // Objective: maximize utilization while respecting constraints
197
- const objective = this.createUtilizationObjective(allocation);
198
- solver.setObjective(objective, 'maximize');
199
-
200
- return await solver.solve();
201
- }
202
- };
203
- ```
204
-
205
- ## MCP Integration Hooks
206
-
207
- ### Performance Monitoring Integration
208
- ```javascript
209
- // MCP performance tools integration
210
- const mcpIntegration = {
211
- // Real-time metrics collection
212
- async collectMetrics() {
213
- const metrics = await mcp.performance_report({ format: 'json' });
214
- const bottlenecks = await mcp.bottleneck_analyze({});
215
- const tokenUsage = await mcp.token_usage({});
216
-
217
- return {
218
- performance: metrics,
219
- bottlenecks: bottlenecks,
220
- tokenConsumption: tokenUsage,
221
- timestamp: Date.now()
222
- };
223
- },
224
-
225
- // Load balancing coordination
226
- async coordinateLoadBalancing(swarmId) {
227
- const agents = await mcp.agent_list({ swarmId });
228
- const metrics = await mcp.agent_metrics({});
229
-
230
- // Implement load balancing based on agent metrics
231
- const rebalancing = this.calculateRebalancing(agents, metrics);
232
-
233
- if (rebalancing.required) {
234
- await mcp.load_balance({
235
- swarmId,
236
- tasks: rebalancing.taskMigrations
237
- });
238
- }
239
-
240
- return rebalancing;
241
- },
242
-
243
- // Topology optimization
244
- async optimizeTopology(swarmId) {
245
- const currentTopology = await mcp.swarm_status({ swarmId });
246
- const optimizedTopology = await this.calculateOptimalTopology(currentTopology);
247
-
248
- if (optimizedTopology.improvement > 0.1) { // 10% improvement threshold
249
- await mcp.topology_optimize({ swarmId });
250
- return optimizedTopology;
251
- }
252
-
253
- return null;
254
- }
255
- };
256
- ```
257
-
258
- ## Advanced Scheduling Algorithms
259
-
260
- ### 1. Earliest Deadline First (EDF)
261
- ```javascript
262
- class EDFScheduler {
263
- schedule(tasks) {
264
- return tasks.sort((a, b) => a.deadline - b.deadline);
265
- }
266
-
267
- // Admission control for real-time tasks
268
- admissionControl(newTask, existingTasks) {
269
- const totalUtilization = [...existingTasks, newTask]
270
- .reduce((sum, task) => sum + (task.executionTime / task.period), 0);
271
-
272
- return totalUtilization <= 1.0; // Liu & Layland bound
273
- }
274
- }
275
- ```
276
-
277
- ### 2. Completely Fair Scheduler (CFS)
278
- ```javascript
279
- class CFSScheduler {
280
- constructor() {
281
- this.virtualRuntime = new Map();
282
- this.weights = new Map();
283
- this.rbtree = new RedBlackTree();
284
- }
285
-
286
- schedule() {
287
- const nextTask = this.rbtree.minimum();
288
- if (nextTask) {
289
- this.updateVirtualRuntime(nextTask);
290
- return nextTask;
291
- }
292
- return null;
293
- }
294
-
295
- updateVirtualRuntime(task) {
296
- const weight = this.weights.get(task.id) || 1;
297
- const runtime = this.virtualRuntime.get(task.id) || 0;
298
- this.virtualRuntime.set(task.id, runtime + (1000 / weight)); // Nice value scaling
299
- }
300
- }
301
- ```
302
-
303
- ## Performance Optimization Features
304
-
305
- ### Circuit Breaker Pattern
306
- ```javascript
307
- class CircuitBreaker {
308
- constructor(threshold = 5, timeout = 60000) {
309
- this.failureThreshold = threshold;
310
- this.timeout = timeout;
311
- this.failureCount = 0;
312
- this.lastFailureTime = null;
313
- this.state = 'CLOSED'; // CLOSED, OPEN, HALF_OPEN
314
- }
315
-
316
- async execute(operation) {
317
- if (this.state === 'OPEN') {
318
- if (Date.now() - this.lastFailureTime > this.timeout) {
319
- this.state = 'HALF_OPEN';
320
- } else {
321
- throw new Error('Circuit breaker is OPEN');
322
- }
323
- }
324
-
325
- try {
326
- const result = await operation();
327
- this.onSuccess();
328
- return result;
329
- } catch (error) {
330
- this.onFailure();
331
- throw error;
332
- }
333
- }
334
-
335
- onSuccess() {
336
- this.failureCount = 0;
337
- this.state = 'CLOSED';
338
- }
339
-
340
- onFailure() {
341
- this.failureCount++;
342
- this.lastFailureTime = Date.now();
343
-
344
- if (this.failureCount >= this.failureThreshold) {
345
- this.state = 'OPEN';
346
- }
347
- }
348
- }
349
- ```
350
-
351
- ## Operational Commands
352
-
353
- ### Load Balancing Commands
354
- ```bash
355
- # Initialize load balancer
356
- npx claude-flow agent spawn load-balancer --type coordinator
357
-
358
- # Start load balancing
359
- npx claude-flow load-balance --swarm-id <id> --strategy adaptive
360
-
361
- # Monitor load distribution
362
- npx claude-flow agent-metrics --type load-balancer
363
-
364
- # Adjust balancing parameters
365
- npx claude-flow config-manage --action update --config '{"stealThreshold": 5, "agingBoost": 10}'
366
- ```
367
-
368
- ### Performance Monitoring
369
- ```bash
370
- # Real-time load monitoring
371
- npx claude-flow performance-report --format detailed
372
-
373
- # Bottleneck analysis
374
- npx claude-flow bottleneck-analyze --component swarm-coordination
375
-
376
- # Resource utilization tracking
377
- npx claude-flow metrics-collect --components ["load-balancer", "task-queue"]
378
- ```
379
-
380
- ## Integration Points
381
-
382
- ### With Other Optimization Agents
383
- - **Performance Monitor**: Provides real-time metrics for load balancing decisions
384
- - **Topology Optimizer**: Coordinates topology changes based on load patterns
385
- - **Resource Allocator**: Optimizes resource distribution across the swarm
386
-
387
- ### With Swarm Infrastructure
388
- - **Task Orchestrator**: Receives load-balanced task assignments
389
- - **Agent Coordinator**: Provides agent capacity and availability information
390
- - **Memory System**: Stores load balancing history and patterns
391
-
392
- ## Performance Metrics
393
-
394
- ### Key Performance Indicators
395
- - **Load Distribution Variance**: Measure of load balance across agents
396
- - **Task Migration Rate**: Frequency of work-stealing operations
397
- - **Queue Latency**: Average time tasks spend in queues
398
- - **Utilization Efficiency**: Percentage of optimal resource utilization
399
- - **Fairness Index**: Measure of fair resource allocation
400
-
401
- ### Benchmarking
402
- ```javascript
403
- // Load balancer benchmarking suite
404
- const benchmarks = {
405
- async throughputTest(taskCount, agentCount) {
406
- const startTime = performance.now();
407
- await this.distributeAndExecute(taskCount, agentCount);
408
- const endTime = performance.now();
409
-
410
- return {
411
- throughput: taskCount / ((endTime - startTime) / 1000),
412
- averageLatency: (endTime - startTime) / taskCount
413
- };
414
- },
415
-
416
- async loadBalanceEfficiency(tasks, agents) {
417
- const distribution = await this.distributeLoad(tasks, agents);
418
- const idealLoad = tasks.length / agents.length;
419
-
420
- const variance = distribution.reduce((sum, load) =>
421
- sum + Math.pow(load - idealLoad, 2), 0) / agents.length;
422
-
423
- return {
424
- efficiency: 1 / (1 + variance),
425
- loadVariance: variance
426
- };
427
- }
428
- };
429
- ```
430
-
431
- This Load Balancing Coordinator agent provides comprehensive task distribution optimization with advanced algorithms, real-time monitoring, and adaptive resource allocation capabilities for high-performance swarm coordination.