@cogitator-ai/self-modifying 0.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 (143) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +714 -0
  3. package/dist/architecture-evolution/capability-analyzer.d.ts +32 -0
  4. package/dist/architecture-evolution/capability-analyzer.d.ts.map +1 -0
  5. package/dist/architecture-evolution/capability-analyzer.js +264 -0
  6. package/dist/architecture-evolution/capability-analyzer.js.map +1 -0
  7. package/dist/architecture-evolution/evolution-strategy.d.ts +29 -0
  8. package/dist/architecture-evolution/evolution-strategy.d.ts.map +1 -0
  9. package/dist/architecture-evolution/evolution-strategy.js +176 -0
  10. package/dist/architecture-evolution/evolution-strategy.js.map +1 -0
  11. package/dist/architecture-evolution/index.d.ts +5 -0
  12. package/dist/architecture-evolution/index.d.ts.map +1 -0
  13. package/dist/architecture-evolution/index.js +5 -0
  14. package/dist/architecture-evolution/index.js.map +1 -0
  15. package/dist/architecture-evolution/parameter-optimizer.d.ts +67 -0
  16. package/dist/architecture-evolution/parameter-optimizer.d.ts.map +1 -0
  17. package/dist/architecture-evolution/parameter-optimizer.js +341 -0
  18. package/dist/architecture-evolution/parameter-optimizer.js.map +1 -0
  19. package/dist/architecture-evolution/prompts.d.ts +33 -0
  20. package/dist/architecture-evolution/prompts.d.ts.map +1 -0
  21. package/dist/architecture-evolution/prompts.js +169 -0
  22. package/dist/architecture-evolution/prompts.js.map +1 -0
  23. package/dist/constraints/index.d.ts +4 -0
  24. package/dist/constraints/index.d.ts.map +1 -0
  25. package/dist/constraints/index.js +4 -0
  26. package/dist/constraints/index.js.map +1 -0
  27. package/dist/constraints/modification-validator.d.ts +26 -0
  28. package/dist/constraints/modification-validator.d.ts.map +1 -0
  29. package/dist/constraints/modification-validator.js +313 -0
  30. package/dist/constraints/modification-validator.js.map +1 -0
  31. package/dist/constraints/rollback-manager.d.ts +52 -0
  32. package/dist/constraints/rollback-manager.d.ts.map +1 -0
  33. package/dist/constraints/rollback-manager.js +113 -0
  34. package/dist/constraints/rollback-manager.js.map +1 -0
  35. package/dist/constraints/safety-constraints.d.ts +11 -0
  36. package/dist/constraints/safety-constraints.d.ts.map +1 -0
  37. package/dist/constraints/safety-constraints.js +78 -0
  38. package/dist/constraints/safety-constraints.js.map +1 -0
  39. package/dist/events/event-emitter.d.ts +12 -0
  40. package/dist/events/event-emitter.d.ts.map +1 -0
  41. package/dist/events/event-emitter.js +43 -0
  42. package/dist/events/event-emitter.js.map +1 -0
  43. package/dist/events/index.d.ts +2 -0
  44. package/dist/events/index.d.ts.map +1 -0
  45. package/dist/events/index.js +2 -0
  46. package/dist/events/index.js.map +1 -0
  47. package/dist/index.d.ts +8 -0
  48. package/dist/index.d.ts.map +1 -0
  49. package/dist/index.js +7 -0
  50. package/dist/index.js.map +1 -0
  51. package/dist/meta-reasoning/index.d.ts +5 -0
  52. package/dist/meta-reasoning/index.d.ts.map +1 -0
  53. package/dist/meta-reasoning/index.js +5 -0
  54. package/dist/meta-reasoning/index.js.map +1 -0
  55. package/dist/meta-reasoning/meta-reasoner.d.ts +53 -0
  56. package/dist/meta-reasoning/meta-reasoner.d.ts.map +1 -0
  57. package/dist/meta-reasoning/meta-reasoner.js +261 -0
  58. package/dist/meta-reasoning/meta-reasoner.js.map +1 -0
  59. package/dist/meta-reasoning/observation-collector.d.ts +37 -0
  60. package/dist/meta-reasoning/observation-collector.d.ts.map +1 -0
  61. package/dist/meta-reasoning/observation-collector.js +123 -0
  62. package/dist/meta-reasoning/observation-collector.js.map +1 -0
  63. package/dist/meta-reasoning/prompts.d.ts +31 -0
  64. package/dist/meta-reasoning/prompts.d.ts.map +1 -0
  65. package/dist/meta-reasoning/prompts.js +96 -0
  66. package/dist/meta-reasoning/prompts.js.map +1 -0
  67. package/dist/meta-reasoning/strategy-selector.d.ts +27 -0
  68. package/dist/meta-reasoning/strategy-selector.d.ts.map +1 -0
  69. package/dist/meta-reasoning/strategy-selector.js +138 -0
  70. package/dist/meta-reasoning/strategy-selector.js.map +1 -0
  71. package/dist/self-modifying-agent.d.ts +61 -0
  72. package/dist/self-modifying-agent.d.ts.map +1 -0
  73. package/dist/self-modifying-agent.js +449 -0
  74. package/dist/self-modifying-agent.js.map +1 -0
  75. package/dist/tool-generation/gap-analyzer.d.ts +25 -0
  76. package/dist/tool-generation/gap-analyzer.d.ts.map +1 -0
  77. package/dist/tool-generation/gap-analyzer.js +153 -0
  78. package/dist/tool-generation/gap-analyzer.js.map +1 -0
  79. package/dist/tool-generation/generated-tool-store.d.ts +51 -0
  80. package/dist/tool-generation/generated-tool-store.d.ts.map +1 -0
  81. package/dist/tool-generation/generated-tool-store.js +195 -0
  82. package/dist/tool-generation/generated-tool-store.js.map +1 -0
  83. package/dist/tool-generation/index.d.ts +7 -0
  84. package/dist/tool-generation/index.d.ts.map +1 -0
  85. package/dist/tool-generation/index.js +7 -0
  86. package/dist/tool-generation/index.js.map +1 -0
  87. package/dist/tool-generation/prompts.d.ts +28 -0
  88. package/dist/tool-generation/prompts.d.ts.map +1 -0
  89. package/dist/tool-generation/prompts.js +269 -0
  90. package/dist/tool-generation/prompts.js.map +1 -0
  91. package/dist/tool-generation/tool-generator.d.ts +29 -0
  92. package/dist/tool-generation/tool-generator.d.ts.map +1 -0
  93. package/dist/tool-generation/tool-generator.js +169 -0
  94. package/dist/tool-generation/tool-generator.js.map +1 -0
  95. package/dist/tool-generation/tool-sandbox.d.ts +31 -0
  96. package/dist/tool-generation/tool-sandbox.d.ts.map +1 -0
  97. package/dist/tool-generation/tool-sandbox.js +240 -0
  98. package/dist/tool-generation/tool-sandbox.js.map +1 -0
  99. package/dist/tool-generation/tool-validator.d.ts +32 -0
  100. package/dist/tool-generation/tool-validator.d.ts.map +1 -0
  101. package/dist/tool-generation/tool-validator.js +304 -0
  102. package/dist/tool-generation/tool-validator.js.map +1 -0
  103. package/dist/utils/index.d.ts +2 -0
  104. package/dist/utils/index.d.ts.map +1 -0
  105. package/dist/utils/index.js +2 -0
  106. package/dist/utils/index.js.map +1 -0
  107. package/dist/utils/llm-helper.d.ts +6 -0
  108. package/dist/utils/llm-helper.d.ts.map +1 -0
  109. package/dist/utils/llm-helper.js +18 -0
  110. package/dist/utils/llm-helper.js.map +1 -0
  111. package/package.json +61 -0
  112. package/src/__tests__/architecture-evolution.test.ts +368 -0
  113. package/src/__tests__/constraints.test.ts +266 -0
  114. package/src/__tests__/index.test.ts +99 -0
  115. package/src/__tests__/meta-reasoning.test.ts +343 -0
  116. package/src/__tests__/tool-generation.test.ts +455 -0
  117. package/src/architecture-evolution/capability-analyzer.ts +337 -0
  118. package/src/architecture-evolution/evolution-strategy.ts +224 -0
  119. package/src/architecture-evolution/index.ts +26 -0
  120. package/src/architecture-evolution/parameter-optimizer.ts +489 -0
  121. package/src/architecture-evolution/prompts.ts +216 -0
  122. package/src/constraints/index.ts +23 -0
  123. package/src/constraints/modification-validator.ts +402 -0
  124. package/src/constraints/rollback-manager.ts +173 -0
  125. package/src/constraints/safety-constraints.ts +103 -0
  126. package/src/events/event-emitter.ts +62 -0
  127. package/src/events/index.ts +1 -0
  128. package/src/index.ts +112 -0
  129. package/src/meta-reasoning/index.ts +24 -0
  130. package/src/meta-reasoning/meta-reasoner.ts +381 -0
  131. package/src/meta-reasoning/observation-collector.ts +161 -0
  132. package/src/meta-reasoning/prompts.ts +131 -0
  133. package/src/meta-reasoning/strategy-selector.ts +179 -0
  134. package/src/self-modifying-agent.ts +585 -0
  135. package/src/tool-generation/gap-analyzer.ts +234 -0
  136. package/src/tool-generation/generated-tool-store.ts +268 -0
  137. package/src/tool-generation/index.ts +19 -0
  138. package/src/tool-generation/prompts.ts +308 -0
  139. package/src/tool-generation/tool-generator.ts +243 -0
  140. package/src/tool-generation/tool-sandbox.ts +332 -0
  141. package/src/tool-generation/tool-validator.ts +365 -0
  142. package/src/utils/index.ts +1 -0
  143. package/src/utils/llm-helper.ts +24 -0
@@ -0,0 +1,32 @@
1
+ import type { Tool, LLMBackend, TaskProfile } from '@cogitator-ai/types';
2
+ export interface CapabilityAnalyzerOptions {
3
+ llm?: LLMBackend;
4
+ enableLLMAnalysis?: boolean;
5
+ }
6
+ export declare class CapabilityAnalyzer {
7
+ private readonly llm?;
8
+ private readonly enableLLMAnalysis;
9
+ private readonly profileCache;
10
+ private readonly cacheTTL;
11
+ constructor(options?: CapabilityAnalyzerOptions);
12
+ analyzeTask(taskDescription: string, context?: {
13
+ availableTools?: Tool[];
14
+ previousTasks?: string[];
15
+ constraints?: {
16
+ maxCost?: number;
17
+ maxLatency?: number;
18
+ };
19
+ }): Promise<TaskProfile>;
20
+ private analyzWithLLM;
21
+ private analyzeHeuristically;
22
+ private detectDomain;
23
+ private detectComplexity;
24
+ private analyzeToolRequirements;
25
+ private estimateTokens;
26
+ private estimateReasoningDepth;
27
+ private estimateAccuracyRequirement;
28
+ private detectTimeConstraint;
29
+ private buildCacheKey;
30
+ clearCache(): void;
31
+ }
32
+ //# sourceMappingURL=capability-analyzer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"capability-analyzer.d.ts","sourceRoot":"","sources":["../../src/architecture-evolution/capability-analyzer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGzE,MAAM,WAAW,yBAAyB;IACxC,GAAG,CAAC,EAAE,UAAU,CAAC;IACjB,iBAAiB,CAAC,EAAE,OAAO,CAAC;CAC7B;AA6CD,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAa;IAClC,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAU;IAC5C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAkE;IAC/F,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;gBAEtB,OAAO,GAAE,yBAA8B;IAK7C,WAAW,CACf,eAAe,EAAE,MAAM,EACvB,OAAO,CAAC,EAAE;QACR,cAAc,CAAC,EAAE,IAAI,EAAE,CAAC;QACxB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;QACzB,WAAW,CAAC,EAAE;YAAE,OAAO,CAAC,EAAE,MAAM,CAAC;YAAC,UAAU,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC;KACzD,GACA,OAAO,CAAC,WAAW,CAAC;YA0BT,aAAa;IAqD3B,OAAO,CAAC,oBAAoB;IAyB5B,OAAO,CAAC,YAAY;IAsBpB,OAAO,CAAC,gBAAgB;IAgBxB,OAAO,CAAC,uBAAuB;IAoC/B,OAAO,CAAC,cAAc;IAgBtB,OAAO,CAAC,sBAAsB;IAuB9B,OAAO,CAAC,2BAA2B;IAyBnC,OAAO,CAAC,oBAAoB;IAkB5B,OAAO,CAAC,aAAa;IAIrB,UAAU,IAAI,IAAI;CAGnB"}
@@ -0,0 +1,264 @@
1
+ import { buildTaskProfilePrompt, parseTaskProfileResponse } from './prompts';
2
+ const DOMAIN_KEYWORDS = {
3
+ coding: [
4
+ 'code', 'program', 'function', 'class', 'debug', 'implement', 'refactor',
5
+ 'typescript', 'javascript', 'python', 'api', 'database', 'sql', 'algorithm',
6
+ 'data structure', 'compile', 'syntax', 'bug', 'error', 'test', 'unit test',
7
+ ],
8
+ reasoning: [
9
+ 'analyze', 'reason', 'logic', 'deduce', 'infer', 'solve', 'problem',
10
+ 'strategy', 'plan', 'decision', 'evaluate', 'compare', 'trade-off',
11
+ 'optimize', 'proof', 'argument', 'conclusion', 'hypothesis',
12
+ ],
13
+ creative: [
14
+ 'create', 'imagine', 'story', 'poem', 'write', 'design', 'brainstorm',
15
+ 'innovative', 'novel', 'artistic', 'compose', 'invent', 'original',
16
+ 'creative', 'fiction', 'narrative', 'metaphor', 'style',
17
+ ],
18
+ factual: [
19
+ 'what is', 'define', 'explain', 'describe', 'list', 'fact', 'information',
20
+ 'history', 'science', 'data', 'statistic', 'research', 'study', 'source',
21
+ 'reference', 'accurate', 'true', 'correct',
22
+ ],
23
+ conversational: [
24
+ 'chat', 'talk', 'hello', 'hi', 'thanks', 'please', 'help', 'assist',
25
+ 'question', 'answer', 'discuss', 'conversation', 'opinion',
26
+ ],
27
+ };
28
+ const COMPLEXITY_INDICATORS = {
29
+ trivial: ['simple', 'quick', 'easy', 'basic', 'straightforward'],
30
+ simple: ['explain', 'define', 'list', 'describe', 'show'],
31
+ moderate: ['compare', 'analyze', 'summarize', 'evaluate', 'implement'],
32
+ complex: ['design', 'architect', 'optimize', 'comprehensive', 'detailed'],
33
+ extreme: ['novel', 'research', 'breakthrough', 'state-of-the-art', 'cutting-edge'],
34
+ };
35
+ export class CapabilityAnalyzer {
36
+ llm;
37
+ enableLLMAnalysis;
38
+ profileCache = new Map();
39
+ cacheTTL = 60000;
40
+ constructor(options = {}) {
41
+ this.llm = options.llm;
42
+ this.enableLLMAnalysis = options.enableLLMAnalysis ?? false;
43
+ }
44
+ async analyzeTask(taskDescription, context) {
45
+ const cacheKey = this.buildCacheKey(taskDescription);
46
+ const cached = this.profileCache.get(cacheKey);
47
+ if (cached && Date.now() - cached.timestamp < this.cacheTTL) {
48
+ return cached.profile;
49
+ }
50
+ let profile;
51
+ if (this.llm && this.enableLLMAnalysis) {
52
+ profile = await this.analyzWithLLM(taskDescription, context);
53
+ }
54
+ else {
55
+ profile = this.analyzeHeuristically(taskDescription, context?.availableTools);
56
+ }
57
+ this.profileCache.set(cacheKey, { profile, timestamp: Date.now() });
58
+ if (this.profileCache.size > 100) {
59
+ const entries = Array.from(this.profileCache.entries());
60
+ entries.sort((a, b) => a[1].timestamp - b[1].timestamp);
61
+ entries.slice(0, 20).forEach(([key]) => this.profileCache.delete(key));
62
+ }
63
+ return profile;
64
+ }
65
+ async analyzWithLLM(taskDescription, context) {
66
+ const llm = this.llm;
67
+ if (!llm) {
68
+ return this.analyzeHeuristically(taskDescription, context?.availableTools);
69
+ }
70
+ try {
71
+ const prompt = buildTaskProfilePrompt(taskDescription, {
72
+ previousTasks: context?.previousTasks,
73
+ constraints: context?.constraints,
74
+ });
75
+ const response = llm.complete
76
+ ? await llm.complete({
77
+ messages: [
78
+ {
79
+ role: 'system',
80
+ content: 'You are a task analysis expert. Analyze tasks and determine their characteristics.',
81
+ },
82
+ { role: 'user', content: prompt },
83
+ ],
84
+ temperature: 0.2,
85
+ })
86
+ : await llm.chat({
87
+ model: 'default',
88
+ messages: [
89
+ {
90
+ role: 'system',
91
+ content: 'You are a task analysis expert. Analyze tasks and determine their characteristics.',
92
+ },
93
+ { role: 'user', content: prompt },
94
+ ],
95
+ temperature: 0.2,
96
+ });
97
+ const parsed = parseTaskProfileResponse(response.content);
98
+ if (parsed) {
99
+ return parsed;
100
+ }
101
+ }
102
+ catch {
103
+ }
104
+ return this.analyzeHeuristically(taskDescription, context?.availableTools);
105
+ }
106
+ analyzeHeuristically(taskDescription, availableTools) {
107
+ const lowerTask = taskDescription.toLowerCase();
108
+ const words = lowerTask.split(/\s+/);
109
+ const wordCount = words.length;
110
+ const domain = this.detectDomain(lowerTask);
111
+ const complexity = this.detectComplexity(lowerTask, wordCount);
112
+ const toolAnalysis = this.analyzeToolRequirements(lowerTask, availableTools);
113
+ return {
114
+ complexity,
115
+ domain,
116
+ estimatedTokens: this.estimateTokens(wordCount, complexity),
117
+ requiresTools: toolAnalysis.requiresTools,
118
+ toolIntensity: toolAnalysis.intensity,
119
+ reasoningDepth: this.estimateReasoningDepth(complexity, domain),
120
+ creativityLevel: domain === 'creative' ? 'high' : complexity === 'trivial' ? 'low' : 'moderate',
121
+ accuracyRequirement: this.estimateAccuracyRequirement(domain, lowerTask),
122
+ timeConstraint: this.detectTimeConstraint(lowerTask),
123
+ };
124
+ }
125
+ detectDomain(task) {
126
+ const scores = {
127
+ coding: 0,
128
+ reasoning: 0,
129
+ creative: 0,
130
+ factual: 0,
131
+ conversational: 0,
132
+ };
133
+ for (const [domain, keywords] of Object.entries(DOMAIN_KEYWORDS)) {
134
+ for (const keyword of keywords) {
135
+ if (task.includes(keyword)) {
136
+ scores[domain] += keyword.length > 5 ? 2 : 1;
137
+ }
138
+ }
139
+ }
140
+ const maxDomain = Object.entries(scores).reduce((a, b) => (b[1] > a[1] ? b : a));
141
+ if (maxDomain[1] === 0)
142
+ return 'general';
143
+ return maxDomain[0];
144
+ }
145
+ detectComplexity(task, wordCount) {
146
+ for (const [level, indicators] of Object.entries(COMPLEXITY_INDICATORS).reverse()) {
147
+ for (const indicator of indicators) {
148
+ if (task.includes(indicator)) {
149
+ return level;
150
+ }
151
+ }
152
+ }
153
+ if (wordCount < 10)
154
+ return 'trivial';
155
+ if (wordCount < 30)
156
+ return 'simple';
157
+ if (wordCount < 100)
158
+ return 'moderate';
159
+ if (wordCount < 300)
160
+ return 'complex';
161
+ return 'extreme';
162
+ }
163
+ analyzeToolRequirements(task, availableTools) {
164
+ const toolIndicators = [
165
+ 'calculate', 'search', 'fetch', 'query', 'lookup', 'find',
166
+ 'execute', 'run', 'call', 'invoke', 'use tool',
167
+ ];
168
+ let toolMentions = 0;
169
+ for (const indicator of toolIndicators) {
170
+ if (task.includes(indicator)) {
171
+ toolMentions++;
172
+ }
173
+ }
174
+ if (availableTools?.length) {
175
+ for (const tool of availableTools) {
176
+ if (task.includes(tool.name.toLowerCase())) {
177
+ toolMentions += 2;
178
+ }
179
+ }
180
+ }
181
+ if (toolMentions === 0) {
182
+ return { requiresTools: false, intensity: 'none' };
183
+ }
184
+ if (toolMentions <= 2) {
185
+ return { requiresTools: true, intensity: 'light' };
186
+ }
187
+ if (toolMentions <= 5) {
188
+ return { requiresTools: true, intensity: 'moderate' };
189
+ }
190
+ return { requiresTools: true, intensity: 'heavy' };
191
+ }
192
+ estimateTokens(wordCount, complexity) {
193
+ const baseMultiplier = {
194
+ trivial: 2,
195
+ simple: 3,
196
+ moderate: 5,
197
+ complex: 8,
198
+ extreme: 12,
199
+ expert: 15,
200
+ };
201
+ return Math.min(wordCount * baseMultiplier[complexity] + 200, 32000);
202
+ }
203
+ estimateReasoningDepth(complexity, domain) {
204
+ if (domain === 'reasoning') {
205
+ return complexity === 'trivial' ? 'moderate' : complexity === 'simple' ? 'deep' : 'exhaustive';
206
+ }
207
+ switch (complexity) {
208
+ case 'trivial':
209
+ return 'shallow';
210
+ case 'simple':
211
+ return 'shallow';
212
+ case 'moderate':
213
+ return 'moderate';
214
+ case 'complex':
215
+ return 'deep';
216
+ case 'extreme':
217
+ case 'expert':
218
+ return 'exhaustive';
219
+ }
220
+ }
221
+ estimateAccuracyRequirement(domain, task) {
222
+ if (domain === 'coding' || domain === 'factual') {
223
+ return 'high';
224
+ }
225
+ const criticalIndicators = ['critical', 'exact', 'precise', 'must be correct', 'no errors'];
226
+ for (const indicator of criticalIndicators) {
227
+ if (task.includes(indicator)) {
228
+ return 'critical';
229
+ }
230
+ }
231
+ const approximateIndicators = ['rough', 'approximate', 'estimate', 'about', 'roughly'];
232
+ for (const indicator of approximateIndicators) {
233
+ if (task.includes(indicator)) {
234
+ return 'approximate';
235
+ }
236
+ }
237
+ return 'moderate';
238
+ }
239
+ detectTimeConstraint(task) {
240
+ const strictIndicators = ['urgent', 'asap', 'immediately', 'right now', 'hurry'];
241
+ const moderateIndicators = ['soon', 'quickly', 'fast', 'today'];
242
+ const relaxedIndicators = ['when possible', 'eventually', 'no rush'];
243
+ for (const indicator of strictIndicators) {
244
+ if (task.includes(indicator))
245
+ return 'strict';
246
+ }
247
+ for (const indicator of moderateIndicators) {
248
+ if (task.includes(indicator))
249
+ return 'moderate';
250
+ }
251
+ for (const indicator of relaxedIndicators) {
252
+ if (task.includes(indicator))
253
+ return 'relaxed';
254
+ }
255
+ return 'none';
256
+ }
257
+ buildCacheKey(task) {
258
+ return task.slice(0, 200).toLowerCase().replace(/\s+/g, ' ').trim();
259
+ }
260
+ clearCache() {
261
+ this.profileCache.clear();
262
+ }
263
+ }
264
+ //# sourceMappingURL=capability-analyzer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"capability-analyzer.js","sourceRoot":"","sources":["../../src/architecture-evolution/capability-analyzer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ import type { EvolutionCandidate, EvolutionStrategy as IEvolutionStrategy } from '@cogitator-ai/types';
2
+ export interface EvolutionStrategyOptions {
3
+ strategy: IEvolutionStrategy;
4
+ explorationBonus?: number;
5
+ }
6
+ export interface SelectionResult {
7
+ candidate: EvolutionCandidate;
8
+ score: number;
9
+ isExploration: boolean;
10
+ reasoning: string;
11
+ }
12
+ export declare class EvolutionStrategy {
13
+ private readonly strategy;
14
+ private readonly explorationBonus;
15
+ private totalSelections;
16
+ constructor(options: EvolutionStrategyOptions);
17
+ select(candidates: EvolutionCandidate[]): SelectionResult;
18
+ private epsilonGreedy;
19
+ private upperConfidenceBound;
20
+ private thompsonSampling;
21
+ private sampleBeta;
22
+ private sampleGamma;
23
+ private sampleNormal;
24
+ updateCandidate(candidate: EvolutionCandidate, reward: number): void;
25
+ getExplorationRate(): number;
26
+ shouldExploreMore(candidates: EvolutionCandidate[]): boolean;
27
+ reset(): void;
28
+ }
29
+ //# sourceMappingURL=evolution-strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evolution-strategy.d.ts","sourceRoot":"","sources":["../../src/architecture-evolution/evolution-strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,iBAAiB,IAAI,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAEvG,MAAM,WAAW,wBAAwB;IACvC,QAAQ,EAAE,kBAAkB,CAAC;IAC7B,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,eAAe;IAC9B,SAAS,EAAE,kBAAkB,CAAC;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,EAAE,OAAO,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAqB;IAC9C,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;IAC1C,OAAO,CAAC,eAAe,CAAK;gBAEhB,OAAO,EAAE,wBAAwB;IAK7C,MAAM,CAAC,UAAU,EAAE,kBAAkB,EAAE,GAAG,eAAe;IA4BzD,OAAO,CAAC,aAAa;IAkCrB,OAAO,CAAC,oBAAoB;IA2B5B,OAAO,CAAC,gBAAgB;IAyBxB,OAAO,CAAC,UAAU;IAMlB,OAAO,CAAC,WAAW;IA8BnB,OAAO,CAAC,YAAY;IAMpB,eAAe,CAAC,SAAS,EAAE,kBAAkB,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAQpE,kBAAkB,IAAI,MAAM;IAe5B,iBAAiB,CAAC,UAAU,EAAE,kBAAkB,EAAE,GAAG,OAAO;IAiB5D,KAAK,IAAI,IAAI;CAGd"}
@@ -0,0 +1,176 @@
1
+ export class EvolutionStrategy {
2
+ strategy;
3
+ explorationBonus;
4
+ totalSelections = 0;
5
+ constructor(options) {
6
+ this.strategy = options.strategy;
7
+ this.explorationBonus = options.explorationBonus ?? 2.0;
8
+ }
9
+ select(candidates) {
10
+ if (candidates.length === 0) {
11
+ throw new Error('No candidates to select from');
12
+ }
13
+ if (candidates.length === 1) {
14
+ return {
15
+ candidate: candidates[0],
16
+ score: candidates[0].score,
17
+ isExploration: false,
18
+ reasoning: 'Only one candidate available',
19
+ };
20
+ }
21
+ this.totalSelections++;
22
+ switch (this.strategy.type) {
23
+ case 'epsilon_greedy':
24
+ return this.epsilonGreedy(candidates);
25
+ case 'ucb':
26
+ return this.upperConfidenceBound(candidates);
27
+ case 'thompson_sampling':
28
+ return this.thompsonSampling(candidates);
29
+ default:
30
+ return this.epsilonGreedy(candidates);
31
+ }
32
+ }
33
+ epsilonGreedy(candidates) {
34
+ const epsilon = this.strategy.epsilon ?? 0.1;
35
+ const isExploration = Math.random() < epsilon;
36
+ if (isExploration) {
37
+ const unexplored = candidates.filter((c) => c.evaluationCount === 0);
38
+ if (unexplored.length > 0) {
39
+ const candidate = unexplored[Math.floor(Math.random() * unexplored.length)];
40
+ return {
41
+ candidate,
42
+ score: 0,
43
+ isExploration: true,
44
+ reasoning: `Epsilon-greedy exploration: selected unexplored candidate ${candidate.id}`,
45
+ };
46
+ }
47
+ const candidate = candidates[Math.floor(Math.random() * candidates.length)];
48
+ return {
49
+ candidate,
50
+ score: candidate.score,
51
+ isExploration: true,
52
+ reasoning: `Epsilon-greedy exploration: randomly selected ${candidate.id}`,
53
+ };
54
+ }
55
+ const best = candidates.reduce((a, b) => (b.score > a.score ? b : a));
56
+ return {
57
+ candidate: best,
58
+ score: best.score,
59
+ isExploration: false,
60
+ reasoning: `Epsilon-greedy exploitation: selected best scoring ${best.id} (score: ${best.score.toFixed(3)})`,
61
+ };
62
+ }
63
+ upperConfidenceBound(candidates) {
64
+ const c = this.strategy.explorationConstant ?? this.explorationBonus;
65
+ const ucbScores = candidates.map((candidate) => {
66
+ if (candidate.evaluationCount === 0) {
67
+ return { candidate, ucb: Infinity, isExploration: true };
68
+ }
69
+ const exploitation = candidate.score;
70
+ const exploration = c * Math.sqrt(Math.log(this.totalSelections + 1) / candidate.evaluationCount);
71
+ const ucb = exploitation + exploration;
72
+ return { candidate, ucb, isExploration: exploration > exploitation };
73
+ });
74
+ const best = ucbScores.reduce((a, b) => (b.ucb > a.ucb ? b : a));
75
+ return {
76
+ candidate: best.candidate,
77
+ score: best.ucb === Infinity ? 0 : best.ucb,
78
+ isExploration: best.isExploration,
79
+ reasoning: best.ucb === Infinity
80
+ ? `UCB: selected unexplored candidate ${best.candidate.id}`
81
+ : `UCB: selected ${best.candidate.id} with UCB score ${best.ucb.toFixed(3)} (base: ${best.candidate.score.toFixed(3)}, exploration bonus)`,
82
+ };
83
+ }
84
+ thompsonSampling(candidates) {
85
+ const samples = candidates.map((candidate) => {
86
+ const alpha = candidate.evaluationCount > 0
87
+ ? candidate.score * candidate.evaluationCount + 1
88
+ : 1;
89
+ const beta = candidate.evaluationCount > 0
90
+ ? (1 - candidate.score) * candidate.evaluationCount + 1
91
+ : 1;
92
+ const sample = this.sampleBeta(alpha, beta);
93
+ return { candidate, sample };
94
+ });
95
+ const best = samples.reduce((a, b) => (b.sample > a.sample ? b : a));
96
+ const isExploration = best.candidate.evaluationCount < 3;
97
+ return {
98
+ candidate: best.candidate,
99
+ score: best.sample,
100
+ isExploration,
101
+ reasoning: `Thompson sampling: selected ${best.candidate.id} with sample ${best.sample.toFixed(3)} (evals: ${best.candidate.evaluationCount})`,
102
+ };
103
+ }
104
+ sampleBeta(alpha, beta) {
105
+ const gammaA = this.sampleGamma(alpha);
106
+ const gammaB = this.sampleGamma(beta);
107
+ return gammaA / (gammaA + gammaB);
108
+ }
109
+ sampleGamma(shape) {
110
+ if (shape < 1) {
111
+ return this.sampleGamma(shape + 1) * Math.pow(Math.random(), 1 / shape);
112
+ }
113
+ const d = shape - 1 / 3;
114
+ const c = 1 / Math.sqrt(9 * d);
115
+ while (true) {
116
+ let x;
117
+ let v;
118
+ do {
119
+ x = this.sampleNormal();
120
+ v = 1 + c * x;
121
+ } while (v <= 0);
122
+ v = v * v * v;
123
+ const u = Math.random();
124
+ if (u < 1 - 0.0331 * (x * x) * (x * x)) {
125
+ return d * v;
126
+ }
127
+ if (Math.log(u) < 0.5 * x * x + d * (1 - v + Math.log(v))) {
128
+ return d * v;
129
+ }
130
+ }
131
+ }
132
+ sampleNormal() {
133
+ const u1 = Math.random();
134
+ const u2 = Math.random();
135
+ return Math.sqrt(-2 * Math.log(u1)) * Math.cos(2 * Math.PI * u2);
136
+ }
137
+ updateCandidate(candidate, reward) {
138
+ const oldScore = candidate.score;
139
+ const oldCount = candidate.evaluationCount;
140
+ candidate.evaluationCount++;
141
+ candidate.score = (oldScore * oldCount + reward) / candidate.evaluationCount;
142
+ }
143
+ getExplorationRate() {
144
+ if (this.totalSelections === 0)
145
+ return 1;
146
+ switch (this.strategy.type) {
147
+ case 'epsilon_greedy':
148
+ return this.strategy.epsilon ?? 0.1;
149
+ case 'ucb':
150
+ return Math.min(1, (this.strategy.explorationConstant ?? 2) / Math.sqrt(this.totalSelections));
151
+ case 'thompson_sampling':
152
+ return 0.5;
153
+ default:
154
+ return 0.1;
155
+ }
156
+ }
157
+ shouldExploreMore(candidates) {
158
+ const unexploredCount = candidates.filter((c) => c.evaluationCount === 0).length;
159
+ if (unexploredCount > 0)
160
+ return true;
161
+ const avgEvaluations = candidates.reduce((sum, c) => sum + c.evaluationCount, 0) / candidates.length;
162
+ if (avgEvaluations < 5)
163
+ return true;
164
+ const scores = candidates.map((c) => c.score);
165
+ const maxScore = Math.max(...scores);
166
+ const minScore = Math.min(...scores);
167
+ const scoreRange = maxScore - minScore;
168
+ if (scoreRange > 0.3)
169
+ return true;
170
+ return false;
171
+ }
172
+ reset() {
173
+ this.totalSelections = 0;
174
+ }
175
+ }
176
+ //# sourceMappingURL=evolution-strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evolution-strategy.js","sourceRoot":"","sources":["../../src/architecture-evolution/evolution-strategy.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export { CapabilityAnalyzer, type CapabilityAnalyzerOptions, } from './capability-analyzer';
2
+ export { EvolutionStrategy, type EvolutionStrategyOptions, type SelectionResult, } from './evolution-strategy';
3
+ export { ParameterOptimizer, type ParameterOptimizerOptions, type OptimizationResult, } from './parameter-optimizer';
4
+ export { buildTaskProfilePrompt, buildCandidateGenerationPrompt, buildPerformanceAnalysisPrompt, parseTaskProfileResponse, parseCandidateGenerationResponse, parsePerformanceAnalysisResponse, ARCHITECTURE_ANALYSIS_SYSTEM_PROMPT, } from './prompts';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/architecture-evolution/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,KAAK,yBAAyB,GAC/B,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EACL,iBAAiB,EACjB,KAAK,wBAAwB,EAC7B,KAAK,eAAe,GACrB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EACL,kBAAkB,EAClB,KAAK,yBAAyB,EAC9B,KAAK,kBAAkB,GACxB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EACL,sBAAsB,EACtB,8BAA8B,EAC9B,8BAA8B,EAC9B,wBAAwB,EACxB,gCAAgC,EAChC,gCAAgC,EAChC,mCAAmC,GACpC,MAAM,WAAW,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { CapabilityAnalyzer, } from './capability-analyzer';
2
+ export { EvolutionStrategy, } from './evolution-strategy';
3
+ export { ParameterOptimizer, } from './parameter-optimizer';
4
+ export { buildTaskProfilePrompt, buildCandidateGenerationPrompt, buildPerformanceAnalysisPrompt, parseTaskProfileResponse, parseCandidateGenerationResponse, parsePerformanceAnalysisResponse, ARCHITECTURE_ANALYSIS_SYSTEM_PROMPT, } from './prompts';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/architecture-evolution/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,GAEnB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EACL,iBAAiB,GAGlB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EACL,kBAAkB,GAGnB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EACL,sBAAsB,EACtB,8BAA8B,EAC9B,8BAA8B,EAC9B,wBAAwB,EACxB,gCAAgC,EAChC,gCAAgC,EAChC,mCAAmC,GACpC,MAAM,WAAW,CAAC"}
@@ -0,0 +1,67 @@
1
+ import type { LLMBackend, TaskProfile, ArchitectureConfig, EvolutionCandidate, ArchitectureEvolutionConfig, EvolutionMetrics } from '@cogitator-ai/types';
2
+ export interface ParameterOptimizerOptions {
3
+ llm: LLMBackend;
4
+ config: ArchitectureEvolutionConfig;
5
+ baseConfig: ArchitectureConfig;
6
+ }
7
+ export interface OptimizationResult {
8
+ recommendedConfig: ArchitectureConfig;
9
+ candidate: EvolutionCandidate | null;
10
+ metrics: EvolutionMetrics;
11
+ shouldAdopt: boolean;
12
+ confidence: number;
13
+ reasoning: string;
14
+ }
15
+ interface HistoricalRecord {
16
+ taskProfile: TaskProfile;
17
+ config: Partial<ArchitectureConfig>;
18
+ score: number;
19
+ metrics: Record<string, number>;
20
+ timestamp: number;
21
+ }
22
+ export declare class ParameterOptimizer {
23
+ private readonly llm;
24
+ private readonly config;
25
+ private readonly baseConfig;
26
+ private readonly capabilityAnalyzer;
27
+ private readonly evolutionStrategy;
28
+ private candidates;
29
+ private history;
30
+ private currentGeneration;
31
+ private readonly maxHistorySize;
32
+ constructor(options: ParameterOptimizerOptions);
33
+ optimize(taskDescription: string): Promise<OptimizationResult>;
34
+ recordOutcome(candidateId: string, taskProfile: TaskProfile, metrics: {
35
+ successRate: number;
36
+ latency: number;
37
+ tokenUsage: number;
38
+ qualityScore: number;
39
+ }): Promise<void>;
40
+ private generateInitialCandidates;
41
+ private createBaselineCandidate;
42
+ private evolve;
43
+ private generateOffspring;
44
+ private mutateConfig;
45
+ private crossover;
46
+ private calculateReward;
47
+ private shouldEvolve;
48
+ private getLastEvolutionTime;
49
+ private getRelevantHistory;
50
+ private mergeConfigs;
51
+ private calculateMetrics;
52
+ private calculateDiversity;
53
+ private configDistance;
54
+ private calculateConvergenceRate;
55
+ private calculateVariance;
56
+ analyzePerformance(): Promise<{
57
+ recommendation: string;
58
+ confidence: number;
59
+ analysis: string;
60
+ } | null>;
61
+ private callLLM;
62
+ getCandidates(): EvolutionCandidate[];
63
+ getHistory(): HistoricalRecord[];
64
+ reset(): void;
65
+ }
66
+ export {};
67
+ //# sourceMappingURL=parameter-optimizer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parameter-optimizer.d.ts","sourceRoot":"","sources":["../../src/architecture-evolution/parameter-optimizer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,UAAU,EACV,WAAW,EACX,kBAAkB,EAClB,kBAAkB,EAClB,2BAA2B,EAC3B,gBAAgB,EACjB,MAAM,qBAAqB,CAAC;AAU7B,MAAM,WAAW,yBAAyB;IACxC,GAAG,EAAE,UAAU,CAAC;IAChB,MAAM,EAAE,2BAA2B,CAAC;IACpC,UAAU,EAAE,kBAAkB,CAAC;CAChC;AAED,MAAM,WAAW,kBAAkB;IACjC,iBAAiB,EAAE,kBAAkB,CAAC;IACtC,SAAS,EAAE,kBAAkB,GAAG,IAAI,CAAC;IACrC,OAAO,EAAE,gBAAgB,CAAC;IAC1B,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,UAAU,gBAAgB;IACxB,WAAW,EAAE,WAAW,CAAC;IACzB,MAAM,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;IACpC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAa;IACjC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA8B;IACrD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAqB;IAChD,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAqB;IACxD,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAoB;IAEtD,OAAO,CAAC,UAAU,CAA4B;IAC9C,OAAO,CAAC,OAAO,CAA0B;IACzC,OAAO,CAAC,iBAAiB,CAAK;IAC9B,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAO;gBAE1B,OAAO,EAAE,yBAAyB;IAgBxC,QAAQ,CAAC,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAqB9D,aAAa,CACjB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,WAAW,EACxB,OAAO,EAAE;QACP,WAAW,EAAE,MAAM,CAAC;QACpB,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,EAAE,MAAM,CAAC;QACnB,YAAY,EAAE,MAAM,CAAC;KACtB,GACA,OAAO,CAAC,IAAI,CAAC;YA6BF,yBAAyB;IA8BvC,OAAO,CAAC,uBAAuB;YAajB,MAAM;YA6BN,iBAAiB;IAqC/B,OAAO,CAAC,YAAY;IAoBpB,OAAO,CAAC,SAAS;IAoBjB,OAAO,CAAC,eAAe;IA0BvB,OAAO,CAAC,YAAY;IAepB,OAAO,CAAC,oBAAoB;IAO5B,OAAO,CAAC,kBAAkB;IAM1B,OAAO,CAAC,YAAY;IAYpB,OAAO,CAAC,gBAAgB;IA4BxB,OAAO,CAAC,kBAAkB;IAgB1B,OAAO,CAAC,cAAc;IAsBtB,OAAO,CAAC,wBAAwB;IAShC,OAAO,CAAC,iBAAiB;IAOnB,kBAAkB,IAAI,OAAO,CAAC;QAClC,cAAc,EAAE,MAAM,CAAC;QACvB,UAAU,EAAE,MAAM,CAAC;QACnB,QAAQ,EAAE,MAAM,CAAC;KAClB,GAAG,IAAI,CAAC;YAoCK,OAAO;IAUrB,aAAa,IAAI,kBAAkB,EAAE;IAIrC,UAAU,IAAI,gBAAgB,EAAE;IAIhC,KAAK,IAAI,IAAI;CAMd"}