@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.
- package/LICENSE +21 -0
- package/README.md +714 -0
- package/dist/architecture-evolution/capability-analyzer.d.ts +32 -0
- package/dist/architecture-evolution/capability-analyzer.d.ts.map +1 -0
- package/dist/architecture-evolution/capability-analyzer.js +264 -0
- package/dist/architecture-evolution/capability-analyzer.js.map +1 -0
- package/dist/architecture-evolution/evolution-strategy.d.ts +29 -0
- package/dist/architecture-evolution/evolution-strategy.d.ts.map +1 -0
- package/dist/architecture-evolution/evolution-strategy.js +176 -0
- package/dist/architecture-evolution/evolution-strategy.js.map +1 -0
- package/dist/architecture-evolution/index.d.ts +5 -0
- package/dist/architecture-evolution/index.d.ts.map +1 -0
- package/dist/architecture-evolution/index.js +5 -0
- package/dist/architecture-evolution/index.js.map +1 -0
- package/dist/architecture-evolution/parameter-optimizer.d.ts +67 -0
- package/dist/architecture-evolution/parameter-optimizer.d.ts.map +1 -0
- package/dist/architecture-evolution/parameter-optimizer.js +341 -0
- package/dist/architecture-evolution/parameter-optimizer.js.map +1 -0
- package/dist/architecture-evolution/prompts.d.ts +33 -0
- package/dist/architecture-evolution/prompts.d.ts.map +1 -0
- package/dist/architecture-evolution/prompts.js +169 -0
- package/dist/architecture-evolution/prompts.js.map +1 -0
- package/dist/constraints/index.d.ts +4 -0
- package/dist/constraints/index.d.ts.map +1 -0
- package/dist/constraints/index.js +4 -0
- package/dist/constraints/index.js.map +1 -0
- package/dist/constraints/modification-validator.d.ts +26 -0
- package/dist/constraints/modification-validator.d.ts.map +1 -0
- package/dist/constraints/modification-validator.js +313 -0
- package/dist/constraints/modification-validator.js.map +1 -0
- package/dist/constraints/rollback-manager.d.ts +52 -0
- package/dist/constraints/rollback-manager.d.ts.map +1 -0
- package/dist/constraints/rollback-manager.js +113 -0
- package/dist/constraints/rollback-manager.js.map +1 -0
- package/dist/constraints/safety-constraints.d.ts +11 -0
- package/dist/constraints/safety-constraints.d.ts.map +1 -0
- package/dist/constraints/safety-constraints.js +78 -0
- package/dist/constraints/safety-constraints.js.map +1 -0
- package/dist/events/event-emitter.d.ts +12 -0
- package/dist/events/event-emitter.d.ts.map +1 -0
- package/dist/events/event-emitter.js +43 -0
- package/dist/events/event-emitter.js.map +1 -0
- package/dist/events/index.d.ts +2 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +2 -0
- package/dist/events/index.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/meta-reasoning/index.d.ts +5 -0
- package/dist/meta-reasoning/index.d.ts.map +1 -0
- package/dist/meta-reasoning/index.js +5 -0
- package/dist/meta-reasoning/index.js.map +1 -0
- package/dist/meta-reasoning/meta-reasoner.d.ts +53 -0
- package/dist/meta-reasoning/meta-reasoner.d.ts.map +1 -0
- package/dist/meta-reasoning/meta-reasoner.js +261 -0
- package/dist/meta-reasoning/meta-reasoner.js.map +1 -0
- package/dist/meta-reasoning/observation-collector.d.ts +37 -0
- package/dist/meta-reasoning/observation-collector.d.ts.map +1 -0
- package/dist/meta-reasoning/observation-collector.js +123 -0
- package/dist/meta-reasoning/observation-collector.js.map +1 -0
- package/dist/meta-reasoning/prompts.d.ts +31 -0
- package/dist/meta-reasoning/prompts.d.ts.map +1 -0
- package/dist/meta-reasoning/prompts.js +96 -0
- package/dist/meta-reasoning/prompts.js.map +1 -0
- package/dist/meta-reasoning/strategy-selector.d.ts +27 -0
- package/dist/meta-reasoning/strategy-selector.d.ts.map +1 -0
- package/dist/meta-reasoning/strategy-selector.js +138 -0
- package/dist/meta-reasoning/strategy-selector.js.map +1 -0
- package/dist/self-modifying-agent.d.ts +61 -0
- package/dist/self-modifying-agent.d.ts.map +1 -0
- package/dist/self-modifying-agent.js +449 -0
- package/dist/self-modifying-agent.js.map +1 -0
- package/dist/tool-generation/gap-analyzer.d.ts +25 -0
- package/dist/tool-generation/gap-analyzer.d.ts.map +1 -0
- package/dist/tool-generation/gap-analyzer.js +153 -0
- package/dist/tool-generation/gap-analyzer.js.map +1 -0
- package/dist/tool-generation/generated-tool-store.d.ts +51 -0
- package/dist/tool-generation/generated-tool-store.d.ts.map +1 -0
- package/dist/tool-generation/generated-tool-store.js +195 -0
- package/dist/tool-generation/generated-tool-store.js.map +1 -0
- package/dist/tool-generation/index.d.ts +7 -0
- package/dist/tool-generation/index.d.ts.map +1 -0
- package/dist/tool-generation/index.js +7 -0
- package/dist/tool-generation/index.js.map +1 -0
- package/dist/tool-generation/prompts.d.ts +28 -0
- package/dist/tool-generation/prompts.d.ts.map +1 -0
- package/dist/tool-generation/prompts.js +269 -0
- package/dist/tool-generation/prompts.js.map +1 -0
- package/dist/tool-generation/tool-generator.d.ts +29 -0
- package/dist/tool-generation/tool-generator.d.ts.map +1 -0
- package/dist/tool-generation/tool-generator.js +169 -0
- package/dist/tool-generation/tool-generator.js.map +1 -0
- package/dist/tool-generation/tool-sandbox.d.ts +31 -0
- package/dist/tool-generation/tool-sandbox.d.ts.map +1 -0
- package/dist/tool-generation/tool-sandbox.js +240 -0
- package/dist/tool-generation/tool-sandbox.js.map +1 -0
- package/dist/tool-generation/tool-validator.d.ts +32 -0
- package/dist/tool-generation/tool-validator.d.ts.map +1 -0
- package/dist/tool-generation/tool-validator.js +304 -0
- package/dist/tool-generation/tool-validator.js.map +1 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +2 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/llm-helper.d.ts +6 -0
- package/dist/utils/llm-helper.d.ts.map +1 -0
- package/dist/utils/llm-helper.js +18 -0
- package/dist/utils/llm-helper.js.map +1 -0
- package/package.json +61 -0
- package/src/__tests__/architecture-evolution.test.ts +368 -0
- package/src/__tests__/constraints.test.ts +266 -0
- package/src/__tests__/index.test.ts +99 -0
- package/src/__tests__/meta-reasoning.test.ts +343 -0
- package/src/__tests__/tool-generation.test.ts +455 -0
- package/src/architecture-evolution/capability-analyzer.ts +337 -0
- package/src/architecture-evolution/evolution-strategy.ts +224 -0
- package/src/architecture-evolution/index.ts +26 -0
- package/src/architecture-evolution/parameter-optimizer.ts +489 -0
- package/src/architecture-evolution/prompts.ts +216 -0
- package/src/constraints/index.ts +23 -0
- package/src/constraints/modification-validator.ts +402 -0
- package/src/constraints/rollback-manager.ts +173 -0
- package/src/constraints/safety-constraints.ts +103 -0
- package/src/events/event-emitter.ts +62 -0
- package/src/events/index.ts +1 -0
- package/src/index.ts +112 -0
- package/src/meta-reasoning/index.ts +24 -0
- package/src/meta-reasoning/meta-reasoner.ts +381 -0
- package/src/meta-reasoning/observation-collector.ts +161 -0
- package/src/meta-reasoning/prompts.ts +131 -0
- package/src/meta-reasoning/strategy-selector.ts +179 -0
- package/src/self-modifying-agent.ts +585 -0
- package/src/tool-generation/gap-analyzer.ts +234 -0
- package/src/tool-generation/generated-tool-store.ts +268 -0
- package/src/tool-generation/index.ts +19 -0
- package/src/tool-generation/prompts.ts +308 -0
- package/src/tool-generation/tool-generator.ts +243 -0
- package/src/tool-generation/tool-sandbox.ts +332 -0
- package/src/tool-generation/tool-validator.ts +365 -0
- package/src/utils/index.ts +1 -0
- 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"}
|