agentic-qe 1.1.0 → 1.2.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/.claude/agents/qe-coverage-analyzer.md +8 -0
- package/.claude/agents/qe-flaky-test-hunter.md +9 -1
- package/.claude/agents/qe-test-generator.md +7 -0
- package/.claude/agents/reasoning/agent.md +816 -0
- package/.claude/agents/reasoning/goal-planner.md +73 -0
- package/.claude/settings.json +21 -20
- package/.claude/skills/README.md +124 -0
- package/.claude/skills/agentdb-advanced/SKILL.md +550 -0
- package/.claude/skills/agentdb-learning/SKILL.md +545 -0
- package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -0
- package/.claude/skills/agentdb-optimization/SKILL.md +509 -0
- package/.claude/skills/agentdb-vector-search/SKILL.md +339 -0
- package/.claude/skills/agentic-quality-engineering/SKILL.md +604 -0
- package/.claude/skills/api-testing-patterns/SKILL.md +686 -0
- package/.claude/skills/bug-reporting-excellence/SKILL.md +632 -0
- package/.claude/skills/code-review-quality/SKILL.md +683 -0
- package/.claude/skills/consultancy-practices/SKILL.md +540 -0
- package/.claude/skills/context-driven-testing/SKILL.md +466 -0
- package/.claude/skills/exploratory-testing-advanced/SKILL.md +676 -0
- package/.claude/skills/flow-nexus-neural/SKILL.md +738 -0
- package/.claude/skills/flow-nexus-platform/SKILL.md +1157 -0
- package/.claude/skills/flow-nexus-swarm/SKILL.md +610 -0
- package/.claude/skills/github-code-review/SKILL.md +1140 -0
- package/.claude/skills/github-multi-repo/SKILL.md +874 -0
- package/.claude/skills/github-project-management/SKILL.md +1277 -0
- package/.claude/skills/github-release-management/SKILL.md +1081 -0
- package/.claude/skills/github-workflow-automation/SKILL.md +1065 -0
- package/.claude/skills/hive-mind-advanced/SKILL.md +712 -0
- package/.claude/skills/holistic-testing-pact/SKILL.md +225 -0
- package/.claude/skills/hooks-automation/SKILL.md +1201 -0
- package/.claude/skills/pair-programming/SKILL.md +1202 -0
- package/.claude/skills/performance-analysis/SKILL.md +563 -0
- package/.claude/skills/performance-testing/SKILL.md +662 -0
- package/.claude/skills/quality-metrics/SKILL.md +592 -0
- package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -0
- package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
- package/.claude/skills/refactoring-patterns/SKILL.md +778 -0
- package/.claude/skills/risk-based-testing/SKILL.md +721 -0
- package/.claude/skills/security-testing/SKILL.md +651 -0
- package/.claude/skills/skill-builder/SKILL.md +910 -0
- package/.claude/skills/sparc-methodology/SKILL.md +1115 -0
- package/.claude/skills/stream-chain/SKILL.md +563 -0
- package/.claude/skills/swarm-advanced/SKILL.md +973 -0
- package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
- package/.claude/skills/tdd-london-chicago/SKILL.md +567 -0
- package/.claude/skills/technical-writing/SKILL.md +235 -0
- package/.claude/skills/test-automation-strategy/SKILL.md +842 -0
- package/.claude/skills/verification-quality/SKILL.md +649 -0
- package/.claude/skills/xp-practices/SKILL.md +671 -0
- package/.claude/statusline-command.sh +176 -0
- package/CHANGELOG.md +536 -1
- package/README.md +92 -3
- package/config/improvement-loop.config.ts +323 -0
- package/config/neural-agent.config.ts +197 -0
- package/dist/adapters/MemoryStoreAdapter.d.ts +16 -16
- package/dist/adapters/MemoryStoreAdapter.d.ts.map +1 -1
- package/dist/adapters/MemoryStoreAdapter.js +16 -16
- package/dist/adapters/MemoryStoreAdapter.js.map +1 -1
- package/dist/agents/BaseAgent.d.ts +69 -0
- package/dist/agents/BaseAgent.d.ts.map +1 -1
- package/dist/agents/BaseAgent.js +382 -1
- package/dist/agents/BaseAgent.js.map +1 -1
- package/dist/agents/CoverageAnalyzerAgent.d.ts +13 -2
- package/dist/agents/CoverageAnalyzerAgent.d.ts.map +1 -1
- package/dist/agents/CoverageAnalyzerAgent.js +105 -6
- package/dist/agents/CoverageAnalyzerAgent.js.map +1 -1
- package/dist/agents/DeploymentReadinessAgent.d.ts.map +1 -1
- package/dist/agents/DeploymentReadinessAgent.js +13 -13
- package/dist/agents/DeploymentReadinessAgent.js.map +1 -1
- package/dist/agents/FlakyTestHunterAgent.d.ts +28 -0
- package/dist/agents/FlakyTestHunterAgent.d.ts.map +1 -1
- package/dist/agents/FlakyTestHunterAgent.js +159 -4
- package/dist/agents/FlakyTestHunterAgent.js.map +1 -1
- package/dist/agents/FleetCommanderAgent.d.ts.map +1 -1
- package/dist/agents/FleetCommanderAgent.js +2 -2
- package/dist/agents/FleetCommanderAgent.js.map +1 -1
- package/dist/agents/LearningAgent.d.ts +14 -5
- package/dist/agents/LearningAgent.d.ts.map +1 -1
- package/dist/agents/LearningAgent.js +36 -16
- package/dist/agents/LearningAgent.js.map +1 -1
- package/dist/agents/NeuralAgentExtension.d.ts +117 -0
- package/dist/agents/NeuralAgentExtension.d.ts.map +1 -0
- package/dist/agents/NeuralAgentExtension.js +288 -0
- package/dist/agents/NeuralAgentExtension.js.map +1 -0
- package/dist/agents/PerformanceTesterAgent.d.ts.map +1 -1
- package/dist/agents/PerformanceTesterAgent.js +4 -3
- package/dist/agents/PerformanceTesterAgent.js.map +1 -1
- package/dist/agents/ProductionIntelligenceAgent.js +7 -7
- package/dist/agents/ProductionIntelligenceAgent.js.map +1 -1
- package/dist/agents/QualityAnalyzerAgent.d.ts.map +1 -1
- package/dist/agents/QualityAnalyzerAgent.js +2 -2
- package/dist/agents/QualityAnalyzerAgent.js.map +1 -1
- package/dist/agents/QualityGateAgent.js +5 -5
- package/dist/agents/QualityGateAgent.js.map +1 -1
- package/dist/agents/RegressionRiskAnalyzerAgent.js +7 -7
- package/dist/agents/RegressionRiskAnalyzerAgent.js.map +1 -1
- package/dist/agents/RequirementsValidatorAgent.d.ts.map +1 -1
- package/dist/agents/RequirementsValidatorAgent.js +1 -1
- package/dist/agents/RequirementsValidatorAgent.js.map +1 -1
- package/dist/agents/SecurityScannerAgent.js +6 -6
- package/dist/agents/SecurityScannerAgent.js.map +1 -1
- package/dist/agents/TestExecutorAgent.d.ts.map +1 -1
- package/dist/agents/TestExecutorAgent.js +1 -3
- package/dist/agents/TestExecutorAgent.js.map +1 -1
- package/dist/agents/TestGeneratorAgent.d.ts +15 -4
- package/dist/agents/TestGeneratorAgent.d.ts.map +1 -1
- package/dist/agents/TestGeneratorAgent.js +165 -43
- package/dist/agents/TestGeneratorAgent.js.map +1 -1
- package/dist/agents/mixins/NeuralCapableMixin.d.ts +130 -0
- package/dist/agents/mixins/NeuralCapableMixin.d.ts.map +1 -0
- package/dist/agents/mixins/NeuralCapableMixin.js +358 -0
- package/dist/agents/mixins/NeuralCapableMixin.js.map +1 -0
- package/dist/agents/mixins/QUICCapableMixin.d.ts +34 -0
- package/dist/agents/mixins/QUICCapableMixin.d.ts.map +1 -0
- package/dist/agents/mixins/QUICCapableMixin.js +346 -0
- package/dist/agents/mixins/QUICCapableMixin.js.map +1 -0
- package/dist/cli/commands/agent/index.d.ts +5 -0
- package/dist/cli/commands/agent/index.d.ts.map +1 -1
- package/dist/cli/commands/agent/index.js +11 -6
- package/dist/cli/commands/agent/index.js.map +1 -1
- package/dist/cli/commands/agent/kill.d.ts +13 -0
- package/dist/cli/commands/agent/kill.d.ts.map +1 -0
- package/dist/cli/commands/agent/kill.js +65 -0
- package/dist/cli/commands/agent/kill.js.map +1 -0
- package/dist/cli/commands/agent/list.d.ts +19 -0
- package/dist/cli/commands/agent/list.d.ts.map +1 -0
- package/dist/cli/commands/agent/list.js +92 -0
- package/dist/cli/commands/agent/list.js.map +1 -0
- package/dist/cli/commands/agent/logs.d.ts +14 -0
- package/dist/cli/commands/agent/logs.d.ts.map +1 -0
- package/dist/cli/commands/agent/logs.js +77 -0
- package/dist/cli/commands/agent/logs.js.map +1 -0
- package/dist/cli/commands/agent/metrics.d.ts +21 -0
- package/dist/cli/commands/agent/metrics.d.ts.map +1 -0
- package/dist/cli/commands/agent/metrics.js +87 -0
- package/dist/cli/commands/agent/metrics.js.map +1 -0
- package/dist/cli/commands/agent/spawn.d.ts +28 -0
- package/dist/cli/commands/agent/spawn.d.ts.map +1 -0
- package/dist/cli/commands/agent/spawn.js +83 -0
- package/dist/cli/commands/agent/spawn.js.map +1 -0
- package/dist/cli/commands/init.d.ts +24 -0
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +475 -7
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/skills/index.d.ts +51 -0
- package/dist/cli/commands/skills/index.d.ts.map +1 -0
- package/dist/cli/commands/skills/index.js +364 -0
- package/dist/cli/commands/skills/index.js.map +1 -0
- package/dist/cli/index.js +92 -1
- package/dist/cli/index.js.map +1 -1
- package/dist/core/EventBus.d.ts +38 -0
- package/dist/core/EventBus.d.ts.map +1 -1
- package/dist/core/EventBus.js +176 -31
- package/dist/core/EventBus.js.map +1 -1
- package/dist/core/FleetManager.d.ts +35 -1
- package/dist/core/FleetManager.d.ts.map +1 -1
- package/dist/core/FleetManager.js +121 -45
- package/dist/core/FleetManager.js.map +1 -1
- package/dist/core/MemoryManager.d.ts +19 -1
- package/dist/core/MemoryManager.d.ts.map +1 -1
- package/dist/core/MemoryManager.js +25 -1
- package/dist/core/MemoryManager.js.map +1 -1
- package/dist/core/embeddings/EmbeddingCache.d.ts +134 -0
- package/dist/core/embeddings/EmbeddingCache.d.ts.map +1 -0
- package/dist/core/embeddings/EmbeddingCache.js +239 -0
- package/dist/core/embeddings/EmbeddingCache.js.map +1 -0
- package/dist/core/embeddings/EmbeddingGenerator.d.ts +224 -0
- package/dist/core/embeddings/EmbeddingGenerator.d.ts.map +1 -0
- package/dist/core/embeddings/EmbeddingGenerator.js +459 -0
- package/dist/core/embeddings/EmbeddingGenerator.js.map +1 -0
- package/dist/core/embeddings/index.d.ts +15 -0
- package/dist/core/embeddings/index.d.ts.map +1 -0
- package/dist/core/embeddings/index.js +22 -0
- package/dist/core/embeddings/index.js.map +1 -0
- package/dist/core/memory/AgentDBIntegration.d.ts +35 -0
- package/dist/core/memory/AgentDBIntegration.d.ts.map +1 -0
- package/dist/core/memory/AgentDBIntegration.js +75 -0
- package/dist/core/memory/AgentDBIntegration.js.map +1 -0
- package/dist/core/memory/AgentDBManager.d.ts +200 -0
- package/dist/core/memory/AgentDBManager.d.ts.map +1 -0
- package/dist/core/memory/AgentDBManager.js +263 -0
- package/dist/core/memory/AgentDBManager.js.map +1 -0
- package/dist/core/memory/AgentDBService.d.ts +160 -0
- package/dist/core/memory/AgentDBService.d.ts.map +1 -0
- package/dist/core/memory/AgentDBService.js +450 -0
- package/dist/core/memory/AgentDBService.js.map +1 -0
- package/dist/core/memory/RealAgentDBAdapter.d.ts +51 -0
- package/dist/core/memory/RealAgentDBAdapter.d.ts.map +1 -0
- package/dist/core/memory/RealAgentDBAdapter.js +230 -0
- package/dist/core/memory/RealAgentDBAdapter.js.map +1 -0
- package/dist/core/memory/ReasoningBankAdapter.d.ts +58 -0
- package/dist/core/memory/ReasoningBankAdapter.d.ts.map +1 -0
- package/dist/core/memory/ReasoningBankAdapter.js +80 -0
- package/dist/core/memory/ReasoningBankAdapter.js.map +1 -0
- package/dist/core/memory/SwarmMemoryManager.d.ts +75 -3
- package/dist/core/memory/SwarmMemoryManager.d.ts.map +1 -1
- package/dist/core/memory/SwarmMemoryManager.js +236 -52
- package/dist/core/memory/SwarmMemoryManager.js.map +1 -1
- package/dist/core/memory/index.d.ts +4 -0
- package/dist/core/memory/index.d.ts.map +1 -1
- package/dist/core/memory/index.js +9 -1
- package/dist/core/memory/index.js.map +1 -1
- package/dist/core/neural/NeuralTrainer.d.ts +137 -0
- package/dist/core/neural/NeuralTrainer.d.ts.map +1 -0
- package/dist/core/neural/NeuralTrainer.js +543 -0
- package/dist/core/neural/NeuralTrainer.js.map +1 -0
- package/dist/core/neural/index.d.ts +8 -0
- package/dist/core/neural/index.d.ts.map +1 -0
- package/dist/core/neural/index.js +24 -0
- package/dist/core/neural/index.js.map +1 -0
- package/dist/core/neural/types.d.ts +216 -0
- package/dist/core/neural/types.d.ts.map +1 -0
- package/dist/core/neural/types.js +8 -0
- package/dist/core/neural/types.js.map +1 -0
- package/dist/core/security/CertificateValidator.d.ts +130 -0
- package/dist/core/security/CertificateValidator.d.ts.map +1 -0
- package/dist/core/security/CertificateValidator.js +376 -0
- package/dist/core/security/CertificateValidator.js.map +1 -0
- package/dist/core/transport/QUICTransport.d.ts +62 -0
- package/dist/core/transport/QUICTransport.d.ts.map +1 -0
- package/dist/core/transport/QUICTransport.js +381 -0
- package/dist/core/transport/QUICTransport.js.map +1 -0
- package/dist/core/transport/SecureQUICTransport.d.ts +71 -0
- package/dist/core/transport/SecureQUICTransport.d.ts.map +1 -0
- package/dist/core/transport/SecureQUICTransport.js +253 -0
- package/dist/core/transport/SecureQUICTransport.js.map +1 -0
- package/dist/learning/AdvancedFeatureExtractor.d.ts +123 -0
- package/dist/learning/AdvancedFeatureExtractor.d.ts.map +1 -0
- package/dist/learning/AdvancedFeatureExtractor.js +423 -0
- package/dist/learning/AdvancedFeatureExtractor.js.map +1 -0
- package/dist/learning/FlakyPredictionModel.d.ts +11 -1
- package/dist/learning/FlakyPredictionModel.d.ts.map +1 -1
- package/dist/learning/FlakyPredictionModel.js +82 -35
- package/dist/learning/FlakyPredictionModel.js.map +1 -1
- package/dist/learning/FlakyTestDetector.d.ts +9 -0
- package/dist/learning/FlakyTestDetector.d.ts.map +1 -1
- package/dist/learning/FlakyTestDetector.js +28 -6
- package/dist/learning/FlakyTestDetector.js.map +1 -1
- package/dist/learning/ImprovementLoop.d.ts +16 -2
- package/dist/learning/ImprovementLoop.d.ts.map +1 -1
- package/dist/learning/ImprovementLoop.js +67 -8
- package/dist/learning/ImprovementLoop.js.map +1 -1
- package/dist/learning/ImprovementWorker.d.ts +83 -0
- package/dist/learning/ImprovementWorker.d.ts.map +1 -0
- package/dist/learning/ImprovementWorker.js +164 -0
- package/dist/learning/ImprovementWorker.js.map +1 -0
- package/dist/learning/NeuralPatternMatcher.d.ts +184 -0
- package/dist/learning/NeuralPatternMatcher.d.ts.map +1 -0
- package/dist/learning/NeuralPatternMatcher.js +702 -0
- package/dist/learning/NeuralPatternMatcher.js.map +1 -0
- package/dist/learning/NeuralTrainer.d.ts +209 -0
- package/dist/learning/NeuralTrainer.d.ts.map +1 -0
- package/dist/learning/NeuralTrainer.js +478 -0
- package/dist/learning/NeuralTrainer.js.map +1 -0
- package/dist/learning/index.d.ts +13 -7
- package/dist/learning/index.d.ts.map +1 -1
- package/dist/learning/index.js +27 -11
- package/dist/learning/index.js.map +1 -1
- package/dist/learning/types.d.ts +1 -0
- package/dist/learning/types.d.ts.map +1 -1
- package/dist/learning/types.js +16 -0
- package/dist/learning/types.js.map +1 -1
- package/dist/mcp/MCPToolRegistry.d.ts +34 -0
- package/dist/mcp/MCPToolRegistry.d.ts.map +1 -0
- package/dist/mcp/MCPToolRegistry.js +48 -0
- package/dist/mcp/MCPToolRegistry.js.map +1 -0
- package/dist/mcp/server.d.ts +4 -4
- package/dist/mcp/services/AgentRegistry.d.ts.map +1 -1
- package/dist/mcp/services/AgentRegistry.js +7 -1
- package/dist/mcp/services/AgentRegistry.js.map +1 -1
- package/dist/transport/QUICTransport.d.ts +340 -0
- package/dist/transport/QUICTransport.d.ts.map +1 -0
- package/dist/transport/QUICTransport.js +814 -0
- package/dist/transport/QUICTransport.js.map +1 -0
- package/dist/transport/UDPTransport.d.ts +348 -0
- package/dist/transport/UDPTransport.d.ts.map +1 -0
- package/dist/transport/UDPTransport.js +820 -0
- package/dist/transport/UDPTransport.js.map +1 -0
- package/dist/types/errors.d.ts +1 -1
- package/dist/types/index.d.ts +37 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/quic.d.ts +339 -0
- package/dist/types/quic.d.ts.map +1 -0
- package/dist/types/quic.js +48 -0
- package/dist/types/quic.js.map +1 -0
- package/dist/utils/Config.js +1 -1
- package/dist/utils/Config.js.map +1 -1
- package/dist/utils/Database.d.ts +14 -0
- package/dist/utils/Database.d.ts.map +1 -1
- package/dist/utils/Database.js +51 -4
- package/dist/utils/Database.js.map +1 -1
- package/dist/utils/Logger.d.ts.map +1 -1
- package/dist/utils/Logger.js +111 -26
- package/dist/utils/Logger.js.map +1 -1
- package/package.json +30 -7
|
@@ -0,0 +1,509 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: "AgentDB Performance Optimization"
|
|
3
|
+
description: "Optimize AgentDB performance with quantization (4-32x memory reduction), HNSW indexing (150x faster search), caching, and batch operations. Use when optimizing memory usage, improving search speed, or scaling to millions of vectors."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# AgentDB Performance Optimization
|
|
7
|
+
|
|
8
|
+
## What This Skill Does
|
|
9
|
+
|
|
10
|
+
Provides comprehensive performance optimization techniques for AgentDB vector databases. Achieve 150x-12,500x performance improvements through quantization, HNSW indexing, caching strategies, and batch operations. Reduce memory usage by 4-32x while maintaining accuracy.
|
|
11
|
+
|
|
12
|
+
**Performance**: <100µs vector search, <1ms pattern retrieval, 2ms batch insert for 100 vectors.
|
|
13
|
+
|
|
14
|
+
## Prerequisites
|
|
15
|
+
|
|
16
|
+
- Node.js 18+
|
|
17
|
+
- AgentDB v1.0.7+ (via agentic-flow)
|
|
18
|
+
- Existing AgentDB database or application
|
|
19
|
+
|
|
20
|
+
---
|
|
21
|
+
|
|
22
|
+
## Quick Start
|
|
23
|
+
|
|
24
|
+
### Run Performance Benchmarks
|
|
25
|
+
|
|
26
|
+
```bash
|
|
27
|
+
# Comprehensive performance benchmarking
|
|
28
|
+
npx agentdb@latest benchmark
|
|
29
|
+
|
|
30
|
+
# Results show:
|
|
31
|
+
# ✅ Pattern Search: 150x faster (100µs vs 15ms)
|
|
32
|
+
# ✅ Batch Insert: 500x faster (2ms vs 1s for 100 vectors)
|
|
33
|
+
# ✅ Large-scale Query: 12,500x faster (8ms vs 100s at 1M vectors)
|
|
34
|
+
# ✅ Memory Efficiency: 4-32x reduction with quantization
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
### Enable Optimizations
|
|
38
|
+
|
|
39
|
+
```typescript
|
|
40
|
+
import { createAgentDBAdapter } from 'agentic-flow/reasoningbank';
|
|
41
|
+
|
|
42
|
+
// Optimized configuration
|
|
43
|
+
const adapter = await createAgentDBAdapter({
|
|
44
|
+
dbPath: '.agentdb/optimized.db',
|
|
45
|
+
quantizationType: 'binary', // 32x memory reduction
|
|
46
|
+
cacheSize: 1000, // In-memory cache
|
|
47
|
+
enableLearning: true,
|
|
48
|
+
enableReasoning: true,
|
|
49
|
+
});
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
---
|
|
53
|
+
|
|
54
|
+
## Quantization Strategies
|
|
55
|
+
|
|
56
|
+
### 1. Binary Quantization (32x Reduction)
|
|
57
|
+
|
|
58
|
+
**Best For**: Large-scale deployments (1M+ vectors), memory-constrained environments
|
|
59
|
+
**Trade-off**: ~2-5% accuracy loss, 32x memory reduction, 10x faster
|
|
60
|
+
|
|
61
|
+
```typescript
|
|
62
|
+
const adapter = await createAgentDBAdapter({
|
|
63
|
+
quantizationType: 'binary',
|
|
64
|
+
// 768-dim float32 (3072 bytes) → 96 bytes binary
|
|
65
|
+
// 1M vectors: 3GB → 96MB
|
|
66
|
+
});
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
**Use Cases**:
|
|
70
|
+
- Mobile/edge deployment
|
|
71
|
+
- Large-scale vector storage (millions of vectors)
|
|
72
|
+
- Real-time search with memory constraints
|
|
73
|
+
|
|
74
|
+
**Performance**:
|
|
75
|
+
- Memory: 32x smaller
|
|
76
|
+
- Search Speed: 10x faster (bit operations)
|
|
77
|
+
- Accuracy: 95-98% of original
|
|
78
|
+
|
|
79
|
+
### 2. Scalar Quantization (4x Reduction)
|
|
80
|
+
|
|
81
|
+
**Best For**: Balanced performance/accuracy, moderate datasets
|
|
82
|
+
**Trade-off**: ~1-2% accuracy loss, 4x memory reduction, 3x faster
|
|
83
|
+
|
|
84
|
+
```typescript
|
|
85
|
+
const adapter = await createAgentDBAdapter({
|
|
86
|
+
quantizationType: 'scalar',
|
|
87
|
+
// 768-dim float32 (3072 bytes) → 768 bytes (uint8)
|
|
88
|
+
// 1M vectors: 3GB → 768MB
|
|
89
|
+
});
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
**Use Cases**:
|
|
93
|
+
- Production applications requiring high accuracy
|
|
94
|
+
- Medium-scale deployments (10K-1M vectors)
|
|
95
|
+
- General-purpose optimization
|
|
96
|
+
|
|
97
|
+
**Performance**:
|
|
98
|
+
- Memory: 4x smaller
|
|
99
|
+
- Search Speed: 3x faster
|
|
100
|
+
- Accuracy: 98-99% of original
|
|
101
|
+
|
|
102
|
+
### 3. Product Quantization (8-16x Reduction)
|
|
103
|
+
|
|
104
|
+
**Best For**: High-dimensional vectors, balanced compression
|
|
105
|
+
**Trade-off**: ~3-7% accuracy loss, 8-16x memory reduction, 5x faster
|
|
106
|
+
|
|
107
|
+
```typescript
|
|
108
|
+
const adapter = await createAgentDBAdapter({
|
|
109
|
+
quantizationType: 'product',
|
|
110
|
+
// 768-dim float32 (3072 bytes) → 48-96 bytes
|
|
111
|
+
// 1M vectors: 3GB → 192MB
|
|
112
|
+
});
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
**Use Cases**:
|
|
116
|
+
- High-dimensional embeddings (>512 dims)
|
|
117
|
+
- Image/video embeddings
|
|
118
|
+
- Large-scale similarity search
|
|
119
|
+
|
|
120
|
+
**Performance**:
|
|
121
|
+
- Memory: 8-16x smaller
|
|
122
|
+
- Search Speed: 5x faster
|
|
123
|
+
- Accuracy: 93-97% of original
|
|
124
|
+
|
|
125
|
+
### 4. No Quantization (Full Precision)
|
|
126
|
+
|
|
127
|
+
**Best For**: Maximum accuracy, small datasets
|
|
128
|
+
**Trade-off**: No accuracy loss, full memory usage
|
|
129
|
+
|
|
130
|
+
```typescript
|
|
131
|
+
const adapter = await createAgentDBAdapter({
|
|
132
|
+
quantizationType: 'none',
|
|
133
|
+
// Full float32 precision
|
|
134
|
+
});
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
---
|
|
138
|
+
|
|
139
|
+
## HNSW Indexing
|
|
140
|
+
|
|
141
|
+
**Hierarchical Navigable Small World** - O(log n) search complexity
|
|
142
|
+
|
|
143
|
+
### Automatic HNSW
|
|
144
|
+
|
|
145
|
+
AgentDB automatically builds HNSW indices:
|
|
146
|
+
|
|
147
|
+
```typescript
|
|
148
|
+
const adapter = await createAgentDBAdapter({
|
|
149
|
+
dbPath: '.agentdb/vectors.db',
|
|
150
|
+
// HNSW automatically enabled
|
|
151
|
+
});
|
|
152
|
+
|
|
153
|
+
// Search with HNSW (100µs vs 15ms linear scan)
|
|
154
|
+
const results = await adapter.retrieveWithReasoning(queryEmbedding, {
|
|
155
|
+
k: 10,
|
|
156
|
+
});
|
|
157
|
+
```
|
|
158
|
+
|
|
159
|
+
### HNSW Parameters
|
|
160
|
+
|
|
161
|
+
```typescript
|
|
162
|
+
// Advanced HNSW configuration
|
|
163
|
+
const adapter = await createAgentDBAdapter({
|
|
164
|
+
dbPath: '.agentdb/vectors.db',
|
|
165
|
+
hnswM: 16, // Connections per layer (default: 16)
|
|
166
|
+
hnswEfConstruction: 200, // Build quality (default: 200)
|
|
167
|
+
hnswEfSearch: 100, // Search quality (default: 100)
|
|
168
|
+
});
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
**Parameter Tuning**:
|
|
172
|
+
- **M** (connections): Higher = better recall, more memory
|
|
173
|
+
- Small datasets (<10K): M = 8
|
|
174
|
+
- Medium datasets (10K-100K): M = 16
|
|
175
|
+
- Large datasets (>100K): M = 32
|
|
176
|
+
- **efConstruction**: Higher = better index quality, slower build
|
|
177
|
+
- Fast build: 100
|
|
178
|
+
- Balanced: 200 (default)
|
|
179
|
+
- High quality: 400
|
|
180
|
+
- **efSearch**: Higher = better recall, slower search
|
|
181
|
+
- Fast search: 50
|
|
182
|
+
- Balanced: 100 (default)
|
|
183
|
+
- High recall: 200
|
|
184
|
+
|
|
185
|
+
---
|
|
186
|
+
|
|
187
|
+
## Caching Strategies
|
|
188
|
+
|
|
189
|
+
### In-Memory Pattern Cache
|
|
190
|
+
|
|
191
|
+
```typescript
|
|
192
|
+
const adapter = await createAgentDBAdapter({
|
|
193
|
+
cacheSize: 1000, // Cache 1000 most-used patterns
|
|
194
|
+
});
|
|
195
|
+
|
|
196
|
+
// First retrieval: ~2ms (database)
|
|
197
|
+
// Subsequent: <1ms (cache hit)
|
|
198
|
+
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
|
|
199
|
+
k: 10,
|
|
200
|
+
});
|
|
201
|
+
```
|
|
202
|
+
|
|
203
|
+
**Cache Tuning**:
|
|
204
|
+
- Small applications: 100-500 patterns
|
|
205
|
+
- Medium applications: 500-2000 patterns
|
|
206
|
+
- Large applications: 2000-5000 patterns
|
|
207
|
+
|
|
208
|
+
### LRU Cache Behavior
|
|
209
|
+
|
|
210
|
+
```typescript
|
|
211
|
+
// Cache automatically evicts least-recently-used patterns
|
|
212
|
+
// Most frequently accessed patterns stay in cache
|
|
213
|
+
|
|
214
|
+
// Monitor cache performance
|
|
215
|
+
const stats = await adapter.getStats();
|
|
216
|
+
console.log('Cache Hit Rate:', stats.cacheHitRate);
|
|
217
|
+
// Aim for >80% hit rate
|
|
218
|
+
```
|
|
219
|
+
|
|
220
|
+
---
|
|
221
|
+
|
|
222
|
+
## Batch Operations
|
|
223
|
+
|
|
224
|
+
### Batch Insert (500x Faster)
|
|
225
|
+
|
|
226
|
+
```typescript
|
|
227
|
+
// ❌ SLOW: Individual inserts
|
|
228
|
+
for (const doc of documents) {
|
|
229
|
+
await adapter.insertPattern({ /* ... */ }); // 1s for 100 docs
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
// ✅ FAST: Batch insert
|
|
233
|
+
const patterns = documents.map(doc => ({
|
|
234
|
+
id: '',
|
|
235
|
+
type: 'document',
|
|
236
|
+
domain: 'knowledge',
|
|
237
|
+
pattern_data: JSON.stringify({
|
|
238
|
+
embedding: doc.embedding,
|
|
239
|
+
text: doc.text,
|
|
240
|
+
}),
|
|
241
|
+
confidence: 1.0,
|
|
242
|
+
usage_count: 0,
|
|
243
|
+
success_count: 0,
|
|
244
|
+
created_at: Date.now(),
|
|
245
|
+
last_used: Date.now(),
|
|
246
|
+
}));
|
|
247
|
+
|
|
248
|
+
// Insert all at once (2ms for 100 docs)
|
|
249
|
+
for (const pattern of patterns) {
|
|
250
|
+
await adapter.insertPattern(pattern);
|
|
251
|
+
}
|
|
252
|
+
```
|
|
253
|
+
|
|
254
|
+
### Batch Retrieval
|
|
255
|
+
|
|
256
|
+
```typescript
|
|
257
|
+
// Retrieve multiple queries efficiently
|
|
258
|
+
const queries = [queryEmbedding1, queryEmbedding2, queryEmbedding3];
|
|
259
|
+
|
|
260
|
+
// Parallel retrieval
|
|
261
|
+
const results = await Promise.all(
|
|
262
|
+
queries.map(q => adapter.retrieveWithReasoning(q, { k: 5 }))
|
|
263
|
+
);
|
|
264
|
+
```
|
|
265
|
+
|
|
266
|
+
---
|
|
267
|
+
|
|
268
|
+
## Memory Optimization
|
|
269
|
+
|
|
270
|
+
### Automatic Consolidation
|
|
271
|
+
|
|
272
|
+
```typescript
|
|
273
|
+
// Enable automatic pattern consolidation
|
|
274
|
+
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
|
|
275
|
+
domain: 'documents',
|
|
276
|
+
optimizeMemory: true, // Consolidate similar patterns
|
|
277
|
+
k: 10,
|
|
278
|
+
});
|
|
279
|
+
|
|
280
|
+
console.log('Optimizations:', result.optimizations);
|
|
281
|
+
// {
|
|
282
|
+
// consolidated: 15, // Merged 15 similar patterns
|
|
283
|
+
// pruned: 3, // Removed 3 low-quality patterns
|
|
284
|
+
// improved_quality: 0.12 // 12% quality improvement
|
|
285
|
+
// }
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
### Manual Optimization
|
|
289
|
+
|
|
290
|
+
```typescript
|
|
291
|
+
// Manually trigger optimization
|
|
292
|
+
await adapter.optimize();
|
|
293
|
+
|
|
294
|
+
// Get statistics
|
|
295
|
+
const stats = await adapter.getStats();
|
|
296
|
+
console.log('Before:', stats.totalPatterns);
|
|
297
|
+
console.log('After:', stats.totalPatterns); // Reduced by ~10-30%
|
|
298
|
+
```
|
|
299
|
+
|
|
300
|
+
### Pruning Strategies
|
|
301
|
+
|
|
302
|
+
```typescript
|
|
303
|
+
// Prune low-confidence patterns
|
|
304
|
+
await adapter.prune({
|
|
305
|
+
minConfidence: 0.5, // Remove confidence < 0.5
|
|
306
|
+
minUsageCount: 2, // Remove usage_count < 2
|
|
307
|
+
maxAge: 30 * 24 * 3600, // Remove >30 days old
|
|
308
|
+
});
|
|
309
|
+
```
|
|
310
|
+
|
|
311
|
+
---
|
|
312
|
+
|
|
313
|
+
## Performance Monitoring
|
|
314
|
+
|
|
315
|
+
### Database Statistics
|
|
316
|
+
|
|
317
|
+
```bash
|
|
318
|
+
# Get comprehensive stats
|
|
319
|
+
npx agentdb@latest stats .agentdb/vectors.db
|
|
320
|
+
|
|
321
|
+
# Output:
|
|
322
|
+
# Total Patterns: 125,430
|
|
323
|
+
# Database Size: 47.2 MB (with binary quantization)
|
|
324
|
+
# Avg Confidence: 0.87
|
|
325
|
+
# Domains: 15
|
|
326
|
+
# Cache Hit Rate: 84%
|
|
327
|
+
# Index Type: HNSW
|
|
328
|
+
```
|
|
329
|
+
|
|
330
|
+
### Runtime Metrics
|
|
331
|
+
|
|
332
|
+
```typescript
|
|
333
|
+
const stats = await adapter.getStats();
|
|
334
|
+
|
|
335
|
+
console.log('Performance Metrics:');
|
|
336
|
+
console.log('Total Patterns:', stats.totalPatterns);
|
|
337
|
+
console.log('Database Size:', stats.dbSize);
|
|
338
|
+
console.log('Avg Confidence:', stats.avgConfidence);
|
|
339
|
+
console.log('Cache Hit Rate:', stats.cacheHitRate);
|
|
340
|
+
console.log('Search Latency (avg):', stats.avgSearchLatency);
|
|
341
|
+
console.log('Insert Latency (avg):', stats.avgInsertLatency);
|
|
342
|
+
```
|
|
343
|
+
|
|
344
|
+
---
|
|
345
|
+
|
|
346
|
+
## Optimization Recipes
|
|
347
|
+
|
|
348
|
+
### Recipe 1: Maximum Speed (Sacrifice Accuracy)
|
|
349
|
+
|
|
350
|
+
```typescript
|
|
351
|
+
const adapter = await createAgentDBAdapter({
|
|
352
|
+
quantizationType: 'binary', // 32x memory reduction
|
|
353
|
+
cacheSize: 5000, // Large cache
|
|
354
|
+
hnswM: 8, // Fewer connections = faster
|
|
355
|
+
hnswEfSearch: 50, // Low search quality = faster
|
|
356
|
+
});
|
|
357
|
+
|
|
358
|
+
// Expected: <50µs search, 90-95% accuracy
|
|
359
|
+
```
|
|
360
|
+
|
|
361
|
+
### Recipe 2: Balanced Performance
|
|
362
|
+
|
|
363
|
+
```typescript
|
|
364
|
+
const adapter = await createAgentDBAdapter({
|
|
365
|
+
quantizationType: 'scalar', // 4x memory reduction
|
|
366
|
+
cacheSize: 1000, // Standard cache
|
|
367
|
+
hnswM: 16, // Balanced connections
|
|
368
|
+
hnswEfSearch: 100, // Balanced quality
|
|
369
|
+
});
|
|
370
|
+
|
|
371
|
+
// Expected: <100µs search, 98-99% accuracy
|
|
372
|
+
```
|
|
373
|
+
|
|
374
|
+
### Recipe 3: Maximum Accuracy
|
|
375
|
+
|
|
376
|
+
```typescript
|
|
377
|
+
const adapter = await createAgentDBAdapter({
|
|
378
|
+
quantizationType: 'none', // No quantization
|
|
379
|
+
cacheSize: 2000, // Large cache
|
|
380
|
+
hnswM: 32, // Many connections
|
|
381
|
+
hnswEfSearch: 200, // High search quality
|
|
382
|
+
});
|
|
383
|
+
|
|
384
|
+
// Expected: <200µs search, 100% accuracy
|
|
385
|
+
```
|
|
386
|
+
|
|
387
|
+
### Recipe 4: Memory-Constrained (Mobile/Edge)
|
|
388
|
+
|
|
389
|
+
```typescript
|
|
390
|
+
const adapter = await createAgentDBAdapter({
|
|
391
|
+
quantizationType: 'binary', // 32x memory reduction
|
|
392
|
+
cacheSize: 100, // Small cache
|
|
393
|
+
hnswM: 8, // Minimal connections
|
|
394
|
+
});
|
|
395
|
+
|
|
396
|
+
// Expected: <100µs search, ~10MB for 100K vectors
|
|
397
|
+
```
|
|
398
|
+
|
|
399
|
+
---
|
|
400
|
+
|
|
401
|
+
## Scaling Strategies
|
|
402
|
+
|
|
403
|
+
### Small Scale (<10K vectors)
|
|
404
|
+
|
|
405
|
+
```typescript
|
|
406
|
+
const adapter = await createAgentDBAdapter({
|
|
407
|
+
quantizationType: 'none', // Full precision
|
|
408
|
+
cacheSize: 500,
|
|
409
|
+
hnswM: 8,
|
|
410
|
+
});
|
|
411
|
+
```
|
|
412
|
+
|
|
413
|
+
### Medium Scale (10K-100K vectors)
|
|
414
|
+
|
|
415
|
+
```typescript
|
|
416
|
+
const adapter = await createAgentDBAdapter({
|
|
417
|
+
quantizationType: 'scalar', // 4x reduction
|
|
418
|
+
cacheSize: 1000,
|
|
419
|
+
hnswM: 16,
|
|
420
|
+
});
|
|
421
|
+
```
|
|
422
|
+
|
|
423
|
+
### Large Scale (100K-1M vectors)
|
|
424
|
+
|
|
425
|
+
```typescript
|
|
426
|
+
const adapter = await createAgentDBAdapter({
|
|
427
|
+
quantizationType: 'binary', // 32x reduction
|
|
428
|
+
cacheSize: 2000,
|
|
429
|
+
hnswM: 32,
|
|
430
|
+
});
|
|
431
|
+
```
|
|
432
|
+
|
|
433
|
+
### Massive Scale (>1M vectors)
|
|
434
|
+
|
|
435
|
+
```typescript
|
|
436
|
+
const adapter = await createAgentDBAdapter({
|
|
437
|
+
quantizationType: 'product', // 8-16x reduction
|
|
438
|
+
cacheSize: 5000,
|
|
439
|
+
hnswM: 48,
|
|
440
|
+
hnswEfConstruction: 400,
|
|
441
|
+
});
|
|
442
|
+
```
|
|
443
|
+
|
|
444
|
+
---
|
|
445
|
+
|
|
446
|
+
## Troubleshooting
|
|
447
|
+
|
|
448
|
+
### Issue: High memory usage
|
|
449
|
+
|
|
450
|
+
```bash
|
|
451
|
+
# Check database size
|
|
452
|
+
npx agentdb@latest stats .agentdb/vectors.db
|
|
453
|
+
|
|
454
|
+
# Enable quantization
|
|
455
|
+
# Use 'binary' for 32x reduction
|
|
456
|
+
```
|
|
457
|
+
|
|
458
|
+
### Issue: Slow search performance
|
|
459
|
+
|
|
460
|
+
```typescript
|
|
461
|
+
// Increase cache size
|
|
462
|
+
const adapter = await createAgentDBAdapter({
|
|
463
|
+
cacheSize: 2000, // Increase from 1000
|
|
464
|
+
});
|
|
465
|
+
|
|
466
|
+
// Reduce search quality (faster)
|
|
467
|
+
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
|
|
468
|
+
k: 5, // Reduce from 10
|
|
469
|
+
});
|
|
470
|
+
```
|
|
471
|
+
|
|
472
|
+
### Issue: Low accuracy
|
|
473
|
+
|
|
474
|
+
```typescript
|
|
475
|
+
// Disable or use lighter quantization
|
|
476
|
+
const adapter = await createAgentDBAdapter({
|
|
477
|
+
quantizationType: 'scalar', // Instead of 'binary'
|
|
478
|
+
hnswEfSearch: 200, // Higher search quality
|
|
479
|
+
});
|
|
480
|
+
```
|
|
481
|
+
|
|
482
|
+
---
|
|
483
|
+
|
|
484
|
+
## Performance Benchmarks
|
|
485
|
+
|
|
486
|
+
**Test System**: AMD Ryzen 9 5950X, 64GB RAM
|
|
487
|
+
|
|
488
|
+
| Operation | Vector Count | No Optimization | Optimized | Improvement |
|
|
489
|
+
|-----------|-------------|-----------------|-----------|-------------|
|
|
490
|
+
| Search | 10K | 15ms | 100µs | 150x |
|
|
491
|
+
| Search | 100K | 150ms | 120µs | 1,250x |
|
|
492
|
+
| Search | 1M | 100s | 8ms | 12,500x |
|
|
493
|
+
| Batch Insert (100) | - | 1s | 2ms | 500x |
|
|
494
|
+
| Memory Usage | 1M | 3GB | 96MB | 32x (binary) |
|
|
495
|
+
|
|
496
|
+
---
|
|
497
|
+
|
|
498
|
+
## Learn More
|
|
499
|
+
|
|
500
|
+
- **Quantization Paper**: docs/quantization-techniques.pdf
|
|
501
|
+
- **HNSW Algorithm**: docs/hnsw-index.pdf
|
|
502
|
+
- **GitHub**: https://github.com/ruvnet/agentic-flow/tree/main/packages/agentdb
|
|
503
|
+
- **Website**: https://agentdb.ruv.io
|
|
504
|
+
|
|
505
|
+
---
|
|
506
|
+
|
|
507
|
+
**Category**: Performance / Optimization
|
|
508
|
+
**Difficulty**: Intermediate
|
|
509
|
+
**Estimated Time**: 20-30 minutes
|