@mytechtoday/augment-extensions 0.2.0 → 0.5.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/README.md +614 -39
- package/augment-extensions/coding-standards/bash/README.md +196 -0
- package/augment-extensions/coding-standards/bash/module.json +163 -0
- package/augment-extensions/coding-standards/bash/rules/naming-conventions.md +336 -0
- package/augment-extensions/coding-standards/bash/rules/universal-standards.md +289 -0
- package/augment-extensions/coding-standards/css/README.md +40 -0
- package/augment-extensions/coding-standards/css/examples/css-examples.css +550 -0
- package/augment-extensions/coding-standards/css/module.json +44 -0
- package/augment-extensions/coding-standards/css/rules/css-modern-features.md +448 -0
- package/augment-extensions/coding-standards/css/rules/css-standards.md +492 -0
- package/augment-extensions/coding-standards/html/README.md +40 -0
- package/augment-extensions/coding-standards/html/examples/html-examples.html +267 -0
- package/augment-extensions/coding-standards/html/examples/responsive-layout.html +505 -0
- package/augment-extensions/coding-standards/html/module.json +44 -0
- package/augment-extensions/coding-standards/html/rules/html-standards.md +349 -0
- package/augment-extensions/coding-standards/html-css-js/README.md +194 -0
- package/augment-extensions/coding-standards/html-css-js/examples/async-examples.js +487 -0
- package/augment-extensions/coding-standards/html-css-js/examples/css-examples.css +550 -0
- package/augment-extensions/coding-standards/html-css-js/examples/dom-examples.js +667 -0
- package/augment-extensions/coding-standards/html-css-js/examples/html-examples.html +267 -0
- package/augment-extensions/coding-standards/html-css-js/examples/javascript-examples.js +612 -0
- package/augment-extensions/coding-standards/html-css-js/examples/responsive-layout.html +505 -0
- package/augment-extensions/coding-standards/html-css-js/module.json +48 -0
- package/augment-extensions/coding-standards/html-css-js/rules/async-patterns.md +515 -0
- package/augment-extensions/coding-standards/html-css-js/rules/css-modern-features.md +448 -0
- package/augment-extensions/coding-standards/html-css-js/rules/css-standards.md +492 -0
- package/augment-extensions/coding-standards/html-css-js/rules/dom-manipulation.md +439 -0
- package/augment-extensions/coding-standards/html-css-js/rules/html-standards.md +349 -0
- package/augment-extensions/coding-standards/html-css-js/rules/javascript-standards.md +486 -0
- package/augment-extensions/coding-standards/html-css-js/rules/performance.md +463 -0
- package/augment-extensions/coding-standards/html-css-js/rules/tooling.md +543 -0
- package/augment-extensions/coding-standards/js/README.md +46 -0
- package/augment-extensions/coding-standards/js/examples/async-examples.js +487 -0
- package/augment-extensions/coding-standards/js/examples/dom-examples.js +667 -0
- package/augment-extensions/coding-standards/js/examples/javascript-examples.js +612 -0
- package/augment-extensions/coding-standards/js/module.json +49 -0
- package/augment-extensions/coding-standards/js/rules/async-patterns.md +515 -0
- package/augment-extensions/coding-standards/js/rules/dom-manipulation.md +439 -0
- package/augment-extensions/coding-standards/js/rules/javascript-standards.md +486 -0
- package/augment-extensions/coding-standards/js/rules/performance.md +463 -0
- package/augment-extensions/coding-standards/js/rules/tooling.md +543 -0
- package/augment-extensions/coding-standards/php/README.md +248 -0
- package/augment-extensions/coding-standards/php/examples/api-endpoint-example.php +204 -0
- package/augment-extensions/coding-standards/php/examples/cli-command-example.php +206 -0
- package/augment-extensions/coding-standards/php/examples/legacy-refactoring-example.php +234 -0
- package/augment-extensions/coding-standards/php/examples/web-application-example.php +211 -0
- package/augment-extensions/coding-standards/php/examples/woocommerce-extension-example.php +215 -0
- package/augment-extensions/coding-standards/php/examples/wordpress-plugin-example.php +189 -0
- package/augment-extensions/coding-standards/php/module.json +166 -0
- package/augment-extensions/coding-standards/php/rules/api-development.md +480 -0
- package/augment-extensions/coding-standards/php/rules/category-configuration.md +332 -0
- package/augment-extensions/coding-standards/php/rules/cli-tools.md +472 -0
- package/augment-extensions/coding-standards/php/rules/cms-integration.md +561 -0
- package/augment-extensions/coding-standards/php/rules/code-quality.md +402 -0
- package/augment-extensions/coding-standards/php/rules/documentation.md +425 -0
- package/augment-extensions/coding-standards/php/rules/ecommerce.md +627 -0
- package/augment-extensions/coding-standards/php/rules/error-handling.md +336 -0
- package/augment-extensions/coding-standards/php/rules/legacy-migration.md +677 -0
- package/augment-extensions/coding-standards/php/rules/naming-conventions.md +279 -0
- package/augment-extensions/coding-standards/php/rules/performance.md +392 -0
- package/augment-extensions/coding-standards/php/rules/psr-standards.md +186 -0
- package/augment-extensions/coding-standards/php/rules/security.md +358 -0
- package/augment-extensions/coding-standards/php/rules/testing.md +403 -0
- package/augment-extensions/coding-standards/php/rules/type-declarations.md +331 -0
- package/augment-extensions/coding-standards/php/rules/web-applications.md +426 -0
- package/augment-extensions/coding-standards/powershell/README.md +154 -0
- package/augment-extensions/coding-standards/powershell/examples/admin-example.ps1 +272 -0
- package/augment-extensions/coding-standards/powershell/examples/automation-example.ps1 +173 -0
- package/augment-extensions/coding-standards/powershell/examples/cloud-example.ps1 +243 -0
- package/augment-extensions/coding-standards/powershell/examples/cross-platform-example.ps1 +297 -0
- package/augment-extensions/coding-standards/powershell/examples/dsc-example.ps1 +224 -0
- package/augment-extensions/coding-standards/powershell/examples/legacy-migration-example.ps1 +340 -0
- package/augment-extensions/coding-standards/powershell/examples/module-example.psm1 +255 -0
- package/augment-extensions/coding-standards/powershell/module.json +165 -0
- package/augment-extensions/coding-standards/powershell/rules/administrative-tools.md +439 -0
- package/augment-extensions/coding-standards/powershell/rules/automation-scripts.md +240 -0
- package/augment-extensions/coding-standards/powershell/rules/cloud-orchestration.md +384 -0
- package/augment-extensions/coding-standards/powershell/rules/configuration-schema.md +383 -0
- package/augment-extensions/coding-standards/powershell/rules/cross-platform-scripts.md +482 -0
- package/augment-extensions/coding-standards/powershell/rules/dsc-configurations.md +296 -0
- package/augment-extensions/coding-standards/powershell/rules/error-handling.md +314 -0
- package/augment-extensions/coding-standards/powershell/rules/legacy-migrations.md +466 -0
- package/augment-extensions/coding-standards/powershell/rules/modules-functions.md +244 -0
- package/augment-extensions/coding-standards/powershell/rules/naming-conventions.md +266 -0
- package/augment-extensions/coding-standards/powershell/rules/performance-optimization.md +209 -0
- package/augment-extensions/coding-standards/powershell/rules/security-practices.md +314 -0
- package/augment-extensions/coding-standards/powershell/rules/testing-guidelines.md +268 -0
- package/augment-extensions/coding-standards/powershell/rules/universal-standards.md +197 -0
- package/augment-extensions/coding-standards/python/README.md +12 -8
- package/augment-extensions/coding-standards/python/examples/best-practices.py +373 -0
- package/augment-extensions/coding-standards/python/module.json +8 -4
- package/augment-extensions/coding-standards/python/rules/async-patterns.md +884 -0
- package/augment-extensions/coding-standards/python/rules/documentation.md +831 -0
- package/augment-extensions/coding-standards/python/rules/error-handling.md +855 -68
- package/augment-extensions/coding-standards/python/rules/testing.md +409 -0
- package/augment-extensions/coding-standards/python/rules/tooling.md +446 -0
- package/augment-extensions/coding-standards/python/rules/type-hints.md +115 -50
- package/augment-extensions/collections/html-css-js/README.md +82 -0
- package/augment-extensions/collections/html-css-js/collection.json +41 -0
- package/augment-extensions/domain-rules/database/README.md +161 -0
- package/augment-extensions/domain-rules/database/examples/flat-database-example.md +793 -0
- package/augment-extensions/domain-rules/database/examples/hybrid-database-example.md +1132 -0
- package/augment-extensions/domain-rules/database/examples/nosql-document-example.md +868 -0
- package/augment-extensions/domain-rules/database/examples/nosql-graph-example.md +805 -0
- package/augment-extensions/domain-rules/database/examples/relational-schema-example.md +621 -0
- package/augment-extensions/domain-rules/database/examples/vector-database-example.md +965 -0
- package/augment-extensions/domain-rules/database/module.json +28 -0
- package/augment-extensions/domain-rules/database/rules/flat-databases.md +624 -0
- package/augment-extensions/domain-rules/database/rules/nosql-databases.md +588 -0
- package/augment-extensions/domain-rules/database/rules/nosql-document-stores.md +856 -0
- package/augment-extensions/domain-rules/database/rules/nosql-graph-databases.md +778 -0
- package/augment-extensions/domain-rules/database/rules/nosql-key-value-stores.md +963 -0
- package/augment-extensions/domain-rules/database/rules/performance-optimization.md +1076 -0
- package/augment-extensions/domain-rules/database/rules/relational-databases.md +697 -0
- package/augment-extensions/domain-rules/database/rules/relational-indexing.md +671 -0
- package/augment-extensions/domain-rules/database/rules/relational-query-optimization.md +607 -0
- package/augment-extensions/domain-rules/database/rules/relational-schema-design.md +907 -0
- package/augment-extensions/domain-rules/database/rules/relational-transactions.md +783 -0
- package/augment-extensions/domain-rules/database/rules/security-standards.md +980 -0
- package/augment-extensions/domain-rules/database/rules/universal-best-practices.md +485 -0
- package/augment-extensions/domain-rules/database/rules/vector-databases.md +521 -0
- package/augment-extensions/domain-rules/database/rules/vector-embeddings.md +858 -0
- package/augment-extensions/domain-rules/database/rules/vector-indexing.md +934 -0
- package/augment-extensions/domain-rules/design/color/themes/catppuccin-latte/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/catppuccin-latte/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/catppuccin-mocha/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/catppuccin-mocha/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/dracula/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/dracula/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/gruvbox-dark/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/gruvbox-dark/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/gruvbox-light/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/gruvbox-light/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/high-contrast/README.md +27 -0
- package/augment-extensions/domain-rules/design/color/themes/high-contrast/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/monokai/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/monokai/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/nord/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/nord/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/one-dark/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/one-dark/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/one-light/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/one-light/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/solarized-dark/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/solarized-dark/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/solarized-light/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/solarized-light/module.json +26 -0
- package/augment-extensions/domain-rules/design/color/themes/tokyo-night/README.md +23 -0
- package/augment-extensions/domain-rules/design/color/themes/tokyo-night/module.json +26 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/README.md +136 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/SCHEMA-VALIDATION-REPORT.md +216 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/brand-kit-example.yaml +292 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/campaign-brief-example.yaml +389 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/content-calendar-example.yaml +643 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/email-newsletter-example.md +376 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/landing-page-example.md +934 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/ppc-ad-copy-example.md +301 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/seo-blog-post-example.md +347 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/examples/social-media-campaign-example.md +606 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/module.json +50 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/affiliate-influencer-marketing.md +593 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/asset-management.md +418 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/brand-consistency.md +210 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/content-marketing.md +337 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/conversion-optimization.md +455 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/direct-sales.md +499 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/email-marketing.md +439 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/legal-compliance.md +227 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/ppc-advertising.md +569 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/seo-optimization.md +470 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/social-media-marketing.md +414 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/rules/universal-marketing.md +177 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/asset-inventory.schema.json +247 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/brand-kit.schema.json +326 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/campaign-brief.schema.json +342 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/color-palette.schema.json +223 -0
- package/augment-extensions/domain-rules/marketing-standards/seo-sales-marketing/schemas/content-template.schema.json +383 -0
- package/augment-extensions/domain-rules/mcp/README.md +150 -0
- package/augment-extensions/domain-rules/mcp/examples/compressed-example.md +522 -0
- package/augment-extensions/domain-rules/mcp/examples/graph-augmented-example.md +520 -0
- package/augment-extensions/domain-rules/mcp/examples/hybrid-example.md +570 -0
- package/augment-extensions/domain-rules/mcp/examples/state-based-example.md +427 -0
- package/augment-extensions/domain-rules/mcp/examples/token-based-example.md +435 -0
- package/augment-extensions/domain-rules/mcp/examples/vector-based-example.md +502 -0
- package/augment-extensions/domain-rules/mcp/module.json +49 -0
- package/augment-extensions/domain-rules/mcp/rules/compressed-mcp.md +595 -0
- package/augment-extensions/domain-rules/mcp/rules/configuration.md +345 -0
- package/augment-extensions/domain-rules/mcp/rules/graph-augmented-mcp.md +687 -0
- package/augment-extensions/domain-rules/mcp/rules/hybrid-mcp.md +636 -0
- package/augment-extensions/domain-rules/mcp/rules/state-based-mcp.md +484 -0
- package/augment-extensions/domain-rules/mcp/rules/testing-validation.md +360 -0
- package/augment-extensions/domain-rules/mcp/rules/token-based-mcp.md +393 -0
- package/augment-extensions/domain-rules/mcp/rules/universal-rules.md +194 -0
- package/augment-extensions/domain-rules/mcp/rules/vector-based-mcp.md +625 -0
- package/augment-extensions/workflows/beads/module.json +4 -3
- package/augment-extensions/workflows/beads-integration/IMPLEMENTATION-STATUS.md +145 -0
- package/augment-extensions/workflows/beads-integration/README.md +143 -0
- package/augment-extensions/workflows/beads-integration/config/defaults.json +32 -0
- package/augment-extensions/workflows/beads-integration/config/schema.json +140 -0
- package/augment-extensions/workflows/beads-integration/examples/basic-task-generation.md +293 -0
- package/augment-extensions/workflows/beads-integration/module.json +75 -0
- package/augment-extensions/workflows/beads-integration/rules/core-rules.md +219 -0
- package/augment-extensions/workflows/beads-integration/rules/effectiveness-standards.md +256 -0
- package/augment-extensions/workflows/beads-integration/rules/task-generation.md +607 -0
- package/augment-extensions/workflows/database/README.md +195 -0
- package/augment-extensions/workflows/database/ai-prompt-testing.md +295 -0
- package/augment-extensions/workflows/database/examples/migration-example.md +498 -0
- package/augment-extensions/workflows/database/examples/optimization-example.md +496 -0
- package/augment-extensions/workflows/database/examples/schema-design-example.md +444 -0
- package/augment-extensions/workflows/database/module.json +42 -0
- package/augment-extensions/workflows/database/rules/data-migration.md +249 -0
- package/augment-extensions/workflows/database/rules/documentation-standards.md +339 -0
- package/augment-extensions/workflows/database/rules/migration-workflow.md +352 -0
- package/augment-extensions/workflows/database/rules/optimization-workflow.md +435 -0
- package/augment-extensions/workflows/database/rules/schema-design-workflow.md +535 -0
- package/augment-extensions/workflows/database/rules/testing-patterns.md +305 -0
- package/augment-extensions/workflows/database/rules/workflow.md +458 -0
- package/augment-extensions/workflows/openspec/module.json +4 -3
- package/augment-extensions/writing-standards/screenplay/README.md +300 -0
- package/augment-extensions/writing-standards/screenplay/_templates/README.md +121 -0
- package/augment-extensions/writing-standards/screenplay/_templates/genre-template.md +153 -0
- package/augment-extensions/writing-standards/screenplay/_templates/style-template.md +243 -0
- package/augment-extensions/writing-standards/screenplay/_templates/theme-template.md +213 -0
- package/augment-extensions/writing-standards/screenplay/examples/aaa-hollywood-scene.fountain +164 -0
- package/augment-extensions/writing-standards/screenplay/examples/beat-sheet-example.yaml +95 -0
- package/augment-extensions/writing-standards/screenplay/examples/character-profile-example.yaml +116 -0
- package/augment-extensions/writing-standards/screenplay/examples/commercial-30sec.fountain +151 -0
- package/augment-extensions/writing-standards/screenplay/examples/independent-monologue.fountain +67 -0
- package/augment-extensions/writing-standards/screenplay/examples/news-segment.fountain +142 -0
- package/augment-extensions/writing-standards/screenplay/examples/plot-outline-example.yaml +184 -0
- package/augment-extensions/writing-standards/screenplay/examples/tv-episode-teaser.fountain +204 -0
- package/augment-extensions/writing-standards/screenplay/genres/README.md +181 -0
- package/augment-extensions/writing-standards/screenplay/genres/examples/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/genres/module.json +70 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/action.md +399 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/adventure.md +407 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/animation.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/biographical.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/comedy.md +401 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/documentary.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/drama.md +409 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/fantasy.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/historical.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/horror.md +268 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/musical.md +294 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/mystery.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/noir.md +294 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/romance.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/sci-fi.md +289 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/superhero.md +293 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/thriller.md +294 -0
- package/augment-extensions/writing-standards/screenplay/genres/rules/western.md +293 -0
- package/augment-extensions/writing-standards/screenplay/module.json +124 -0
- package/augment-extensions/writing-standards/screenplay/rules/aaa-hollywood-films.md +339 -0
- package/augment-extensions/writing-standards/screenplay/rules/ai-integration-testing.md +329 -0
- package/augment-extensions/writing-standards/screenplay/rules/character-development.md +169 -0
- package/augment-extensions/writing-standards/screenplay/rules/commercials.md +437 -0
- package/augment-extensions/writing-standards/screenplay/rules/dialogue-writing.md +263 -0
- package/augment-extensions/writing-standards/screenplay/rules/diversity-inclusion.md +261 -0
- package/augment-extensions/writing-standards/screenplay/rules/examples-guide.md +315 -0
- package/augment-extensions/writing-standards/screenplay/rules/formatting-validation.md +413 -0
- package/augment-extensions/writing-standards/screenplay/rules/fountain-format.md +372 -0
- package/augment-extensions/writing-standards/screenplay/rules/independent-films.md +374 -0
- package/augment-extensions/writing-standards/screenplay/rules/live-tv-productions.md +443 -0
- package/augment-extensions/writing-standards/screenplay/rules/narrative-structures.md +207 -0
- package/augment-extensions/writing-standards/screenplay/rules/news-broadcasts.md +444 -0
- package/augment-extensions/writing-standards/screenplay/rules/pacing-timing.md +331 -0
- package/augment-extensions/writing-standards/screenplay/rules/quality-review-checklist.md +334 -0
- package/augment-extensions/writing-standards/screenplay/rules/quick-reference.md +299 -0
- package/augment-extensions/writing-standards/screenplay/rules/screen-continuity.md +263 -0
- package/augment-extensions/writing-standards/screenplay/rules/streaming-content.md +412 -0
- package/augment-extensions/writing-standards/screenplay/rules/trope-management.md +370 -0
- package/augment-extensions/writing-standards/screenplay/rules/tv-series.md +374 -0
- package/augment-extensions/writing-standards/screenplay/rules/universal-formatting.md +339 -0
- package/augment-extensions/writing-standards/screenplay/rules/vscode-integration.md +277 -0
- package/augment-extensions/writing-standards/screenplay/rules/web-content.md +393 -0
- package/augment-extensions/writing-standards/screenplay/schemas/beat-sheet.json +332 -0
- package/augment-extensions/writing-standards/screenplay/schemas/character-profile.json +247 -0
- package/augment-extensions/writing-standards/screenplay/schemas/feature-selection.json +200 -0
- package/augment-extensions/writing-standards/screenplay/schemas/plot-outline.json +233 -0
- package/augment-extensions/writing-standards/screenplay/schemas/screenplay-config.json +245 -0
- package/augment-extensions/writing-standards/screenplay/schemas/trope-inventory.json +221 -0
- package/augment-extensions/writing-standards/screenplay/styles/README.md +159 -0
- package/augment-extensions/writing-standards/screenplay/styles/examples/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/styles/examples/style-applications.md +1449 -0
- package/augment-extensions/writing-standards/screenplay/styles/module.json +64 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/dialogue-centric.md +520 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/ensemble.md +499 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/epic.md +497 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/experimental.md +492 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/flashback.md +509 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/linear.md +490 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/minimalist.md +499 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/non-linear.md +501 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/poetic.md +499 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/realistic.md +498 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/satirical.md +499 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/surreal.md +508 -0
- package/augment-extensions/writing-standards/screenplay/styles/rules/voice-over.md +500 -0
- package/augment-extensions/writing-standards/screenplay/themes/README.md +158 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/common-mistakes-and-fixes.md +643 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/complete-scene-example.md +311 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/individual-theme-examples.md +562 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/multi-theme-weaving.md +538 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/theme-application-guide.md +432 -0
- package/augment-extensions/writing-standards/screenplay/themes/examples/theme-integration-across-acts.md +637 -0
- package/augment-extensions/writing-standards/screenplay/themes/module.json +66 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/.gitkeep +2 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/ambition.md +458 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/betrayal.md +490 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/environment.md +458 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/fate.md +459 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/friendship.md +491 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/growth.md +491 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/identity.md +490 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/isolation.md +464 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/justice.md +461 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/love.md +489 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/power.md +494 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/redemption.md +483 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/revenge.md +489 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/survival.md +496 -0
- package/augment-extensions/writing-standards/screenplay/themes/rules/technology.md +463 -0
- package/cli/MODULES.md +302 -0
- package/cli/dist/cli.js +168 -10
- package/cli/dist/cli.js.map +1 -1
- package/cli/dist/commands/catalog.d.ts +13 -0
- package/cli/dist/commands/catalog.d.ts.map +1 -0
- package/cli/dist/commands/catalog.js +104 -0
- package/cli/dist/commands/catalog.js.map +1 -0
- package/cli/dist/commands/gui.d.ts +6 -0
- package/cli/dist/commands/gui.d.ts.map +1 -0
- package/cli/dist/commands/gui.js +211 -0
- package/cli/dist/commands/gui.js.map +1 -0
- package/cli/dist/commands/init.d.ts.map +1 -1
- package/cli/dist/commands/init.js +12 -0
- package/cli/dist/commands/init.js.map +1 -1
- package/cli/dist/commands/install-rules.d.ts +14 -0
- package/cli/dist/commands/install-rules.d.ts.map +1 -0
- package/cli/dist/commands/install-rules.js +127 -0
- package/cli/dist/commands/install-rules.js.map +1 -0
- package/cli/dist/commands/link.d.ts.map +1 -1
- package/cli/dist/commands/link.js +9 -11
- package/cli/dist/commands/link.js.map +1 -1
- package/cli/dist/commands/list.d.ts.map +1 -1
- package/cli/dist/commands/list.js +11 -28
- package/cli/dist/commands/list.js.map +1 -1
- package/cli/dist/commands/mcp.d.ts +48 -0
- package/cli/dist/commands/mcp.d.ts.map +1 -0
- package/cli/dist/commands/mcp.js +229 -0
- package/cli/dist/commands/mcp.js.map +1 -0
- package/cli/dist/commands/self-remove.d.ts +7 -0
- package/cli/dist/commands/self-remove.d.ts.map +1 -0
- package/cli/dist/commands/self-remove.js +179 -0
- package/cli/dist/commands/self-remove.js.map +1 -0
- package/cli/dist/commands/show.d.ts +19 -0
- package/cli/dist/commands/show.d.ts.map +1 -1
- package/cli/dist/commands/show.js +478 -63
- package/cli/dist/commands/show.js.map +1 -1
- package/cli/dist/commands/skill.d.ts +67 -0
- package/cli/dist/commands/skill.d.ts.map +1 -0
- package/cli/dist/commands/skill.js +513 -0
- package/cli/dist/commands/skill.js.map +1 -0
- package/cli/dist/commands/unlink.d.ts +6 -0
- package/cli/dist/commands/unlink.d.ts.map +1 -0
- package/cli/dist/commands/unlink.js +115 -0
- package/cli/dist/commands/unlink.js.map +1 -0
- package/cli/dist/commands/validate.d.ts +6 -0
- package/cli/dist/commands/validate.d.ts.map +1 -0
- package/cli/dist/commands/validate.js +159 -0
- package/cli/dist/commands/validate.js.map +1 -0
- package/cli/dist/types/gui.d.ts +62 -0
- package/cli/dist/types/gui.d.ts.map +1 -0
- package/cli/dist/types/gui.js +30 -0
- package/cli/dist/types/gui.js.map +1 -0
- package/cli/dist/utils/catalog-sync.d.ts +22 -0
- package/cli/dist/utils/catalog-sync.d.ts.map +1 -0
- package/cli/dist/utils/catalog-sync.js +157 -0
- package/cli/dist/utils/catalog-sync.js.map +1 -0
- package/cli/dist/utils/character-count.d.ts +56 -0
- package/cli/dist/utils/character-count.d.ts.map +1 -0
- package/cli/dist/utils/character-count.js +190 -0
- package/cli/dist/utils/character-count.js.map +1 -0
- package/cli/dist/utils/documentation-validator.d.ts +18 -0
- package/cli/dist/utils/documentation-validator.d.ts.map +1 -0
- package/cli/dist/utils/documentation-validator.js +233 -0
- package/cli/dist/utils/documentation-validator.js.map +1 -0
- package/cli/dist/utils/gui-helpers.d.ts +23 -0
- package/cli/dist/utils/gui-helpers.d.ts.map +1 -0
- package/cli/dist/utils/gui-helpers.js +159 -0
- package/cli/dist/utils/gui-helpers.js.map +1 -0
- package/cli/dist/utils/install-rules.d.ts +32 -0
- package/cli/dist/utils/install-rules.d.ts.map +1 -0
- package/cli/dist/utils/install-rules.js +375 -0
- package/cli/dist/utils/install-rules.js.map +1 -0
- package/cli/dist/utils/mcp-integration.d.ts +70 -0
- package/cli/dist/utils/mcp-integration.d.ts.map +1 -0
- package/cli/dist/utils/mcp-integration.js +292 -0
- package/cli/dist/utils/mcp-integration.js.map +1 -0
- package/cli/dist/utils/module-system.d.ts +232 -0
- package/cli/dist/utils/module-system.d.ts.map +1 -0
- package/cli/dist/utils/module-system.js +900 -0
- package/cli/dist/utils/module-system.js.map +1 -0
- package/cli/dist/utils/modules-catalog.d.ts +33 -0
- package/cli/dist/utils/modules-catalog.d.ts.map +1 -0
- package/cli/dist/utils/modules-catalog.js +163 -0
- package/cli/dist/utils/modules-catalog.js.map +1 -0
- package/cli/dist/utils/rule-install-hooks.d.ts +19 -0
- package/cli/dist/utils/rule-install-hooks.d.ts.map +1 -0
- package/cli/dist/utils/rule-install-hooks.js +224 -0
- package/cli/dist/utils/rule-install-hooks.js.map +1 -0
- package/cli/dist/utils/skill-system.d.ts +95 -0
- package/cli/dist/utils/skill-system.d.ts.map +1 -0
- package/cli/dist/utils/skill-system.js +313 -0
- package/cli/dist/utils/skill-system.js.map +1 -0
- package/modules.md +559 -105
- package/package.json +17 -6
|
@@ -0,0 +1,521 @@
|
|
|
1
|
+
# Vector Databases
|
|
2
|
+
|
|
3
|
+
## Overview
|
|
4
|
+
|
|
5
|
+
This document covers vector database fundamentals, including when to use vector databases, embedding generation, vector storage, similarity search, distance metrics, hybrid search, database selection, and use cases for semantic search, RAG (Retrieval-Augmented Generation), and recommendation systems.
|
|
6
|
+
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## When to Use Vector Databases
|
|
10
|
+
|
|
11
|
+
### Ideal Use Cases
|
|
12
|
+
|
|
13
|
+
**Use vector databases when:**
|
|
14
|
+
- ✅ Semantic search is required (meaning-based, not keyword-based)
|
|
15
|
+
- ✅ Building RAG (Retrieval-Augmented Generation) systems
|
|
16
|
+
- ✅ Similarity search across unstructured data (text, images, audio)
|
|
17
|
+
- ✅ Recommendation engines based on content similarity
|
|
18
|
+
- ✅ Anomaly detection using vector similarity
|
|
19
|
+
- ✅ Duplicate detection (near-duplicate content)
|
|
20
|
+
- ✅ Question-answering systems
|
|
21
|
+
- ✅ Image/video search by content
|
|
22
|
+
|
|
23
|
+
**Examples:**
|
|
24
|
+
- Semantic document search (find similar documents by meaning)
|
|
25
|
+
- Chatbots with context retrieval (RAG systems)
|
|
26
|
+
- Product recommendations (similar items)
|
|
27
|
+
- Image similarity search (reverse image search)
|
|
28
|
+
- Code search (find similar code snippets)
|
|
29
|
+
- Customer support (find similar tickets/solutions)
|
|
30
|
+
- Content moderation (detect similar harmful content)
|
|
31
|
+
|
|
32
|
+
### When to Use Traditional Databases Instead
|
|
33
|
+
|
|
34
|
+
**Use relational/NoSQL databases when:**
|
|
35
|
+
- ❌ Exact keyword matching is sufficient
|
|
36
|
+
- ❌ Structured data with clear relationships
|
|
37
|
+
- ❌ No need for semantic understanding
|
|
38
|
+
- ❌ Simple filtering and sorting operations
|
|
39
|
+
- ❌ ACID transactions are critical
|
|
40
|
+
- ❌ Cost optimization is priority (vector DBs can be expensive)
|
|
41
|
+
|
|
42
|
+
---
|
|
43
|
+
|
|
44
|
+
## Vector Database Fundamentals
|
|
45
|
+
|
|
46
|
+
### What is a Vector Database?
|
|
47
|
+
|
|
48
|
+
**Definition**: Database optimized for storing and querying high-dimensional vectors (embeddings)
|
|
49
|
+
|
|
50
|
+
**Key Characteristics:**
|
|
51
|
+
- Stores vectors (arrays of numbers representing data)
|
|
52
|
+
- Optimized for similarity search (nearest neighbor search)
|
|
53
|
+
- Supports high-dimensional data (100s to 1000s of dimensions)
|
|
54
|
+
- Fast approximate nearest neighbor (ANN) search
|
|
55
|
+
- Metadata filtering combined with vector search
|
|
56
|
+
|
|
57
|
+
**Example Vector:**
|
|
58
|
+
```
|
|
59
|
+
Text: "The cat sat on the mat"
|
|
60
|
+
Embedding: [0.234, -0.567, 0.891, ..., 0.123] # 1536 dimensions (OpenAI)
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
### How Vector Databases Work
|
|
64
|
+
|
|
65
|
+
**1. Embedding Generation:**
|
|
66
|
+
- Convert data (text, images, etc.) to vectors using ML models
|
|
67
|
+
- Each vector represents semantic meaning in high-dimensional space
|
|
68
|
+
- Similar items have similar vectors (close in vector space)
|
|
69
|
+
|
|
70
|
+
**2. Vector Storage:**
|
|
71
|
+
- Store vectors with metadata (original text, IDs, tags, etc.)
|
|
72
|
+
- Index vectors for fast similarity search
|
|
73
|
+
- Support CRUD operations on vectors
|
|
74
|
+
|
|
75
|
+
**3. Similarity Search:**
|
|
76
|
+
- Query with a vector (e.g., embedding of search query)
|
|
77
|
+
- Find k-nearest neighbors (most similar vectors)
|
|
78
|
+
- Return results ranked by similarity score
|
|
79
|
+
|
|
80
|
+
---
|
|
81
|
+
|
|
82
|
+
## Distance Metrics
|
|
83
|
+
|
|
84
|
+
### Common Distance Metrics
|
|
85
|
+
|
|
86
|
+
**1. Cosine Similarity (Most Common)**
|
|
87
|
+
- Measures angle between vectors
|
|
88
|
+
- Range: -1 (opposite) to 1 (identical)
|
|
89
|
+
- Ignores magnitude, focuses on direction
|
|
90
|
+
- **Best for**: Text embeddings, semantic search
|
|
91
|
+
|
|
92
|
+
```python
|
|
93
|
+
# Cosine similarity
|
|
94
|
+
from numpy import dot
|
|
95
|
+
from numpy.linalg import norm
|
|
96
|
+
|
|
97
|
+
def cosine_similarity(a, b):
|
|
98
|
+
return dot(a, b) / (norm(a) * norm(b))
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
**2. Euclidean Distance (L2)**
|
|
102
|
+
- Measures straight-line distance between vectors
|
|
103
|
+
- Range: 0 (identical) to ∞ (very different)
|
|
104
|
+
- Considers both direction and magnitude
|
|
105
|
+
- **Best for**: Image embeddings, spatial data
|
|
106
|
+
|
|
107
|
+
```python
|
|
108
|
+
# Euclidean distance
|
|
109
|
+
import numpy as np
|
|
110
|
+
|
|
111
|
+
def euclidean_distance(a, b):
|
|
112
|
+
return np.linalg.norm(a - b)
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
**3. Dot Product**
|
|
116
|
+
- Measures alignment and magnitude
|
|
117
|
+
- Range: -∞ to ∞
|
|
118
|
+
- Faster than cosine (no normalization)
|
|
119
|
+
- **Best for**: Normalized embeddings, performance-critical applications
|
|
120
|
+
|
|
121
|
+
```python
|
|
122
|
+
# Dot product
|
|
123
|
+
import numpy as np
|
|
124
|
+
|
|
125
|
+
def dot_product(a, b):
|
|
126
|
+
return np.dot(a, b)
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
**4. Manhattan Distance (L1)**
|
|
130
|
+
- Sum of absolute differences
|
|
131
|
+
- Range: 0 to ∞
|
|
132
|
+
- Less sensitive to outliers than Euclidean
|
|
133
|
+
- **Best for**: High-dimensional sparse data
|
|
134
|
+
|
|
135
|
+
### Choosing a Distance Metric
|
|
136
|
+
|
|
137
|
+
| Metric | Use Case | Pros | Cons |
|
|
138
|
+
|--------|----------|------|------|
|
|
139
|
+
| Cosine | Text embeddings, semantic search | Ignores magnitude, intuitive | Slower than dot product |
|
|
140
|
+
| Euclidean | Image embeddings, spatial data | Considers magnitude | Sensitive to scale |
|
|
141
|
+
| Dot Product | Normalized embeddings, speed | Fastest | Requires normalized vectors |
|
|
142
|
+
| Manhattan | Sparse high-dimensional data | Robust to outliers | Less intuitive |
|
|
143
|
+
|
|
144
|
+
**Recommendation**: Use **cosine similarity** for most text-based applications
|
|
145
|
+
|
|
146
|
+
---
|
|
147
|
+
|
|
148
|
+
## Popular Vector Databases
|
|
149
|
+
|
|
150
|
+
### Database Comparison
|
|
151
|
+
|
|
152
|
+
**Pinecone (Managed)**
|
|
153
|
+
- Fully managed cloud service
|
|
154
|
+
- Easy to use, minimal setup
|
|
155
|
+
- Auto-scaling and high availability
|
|
156
|
+
- Metadata filtering
|
|
157
|
+
- Hybrid search (vector + metadata)
|
|
158
|
+
- **Best for**: Production applications, minimal ops overhead
|
|
159
|
+
|
|
160
|
+
**Weaviate (Open Source + Managed)**
|
|
161
|
+
- Open source with managed cloud option
|
|
162
|
+
- Built-in vectorization (multiple models)
|
|
163
|
+
- GraphQL API
|
|
164
|
+
- Hybrid search (vector + keyword)
|
|
165
|
+
- Multi-tenancy support
|
|
166
|
+
- **Best for**: Flexibility, self-hosting option
|
|
167
|
+
|
|
168
|
+
**Milvus (Open Source)**
|
|
169
|
+
- Open source, CNCF project
|
|
170
|
+
- High performance, scalable
|
|
171
|
+
- Multiple index types (HNSW, IVF, etc.)
|
|
172
|
+
- GPU acceleration support
|
|
173
|
+
- Kubernetes-native
|
|
174
|
+
- **Best for**: Large-scale deployments, self-hosting
|
|
175
|
+
|
|
176
|
+
**Qdrant (Open Source + Managed)**
|
|
177
|
+
- Open source with managed cloud option
|
|
178
|
+
- Written in Rust (high performance)
|
|
179
|
+
- Rich filtering capabilities
|
|
180
|
+
- Payload-based filtering
|
|
181
|
+
- Snapshots and backups
|
|
182
|
+
- **Best for**: Advanced filtering, self-hosting
|
|
183
|
+
|
|
184
|
+
**Chroma (Open Source)**
|
|
185
|
+
- Open source, embedded database
|
|
186
|
+
- Simple API, easy to get started
|
|
187
|
+
- Built for LLM applications
|
|
188
|
+
- Local-first development
|
|
189
|
+
- Python/JavaScript SDKs
|
|
190
|
+
- **Best for**: Development, prototyping, local applications
|
|
191
|
+
|
|
192
|
+
**pgvector (PostgreSQL Extension)**
|
|
193
|
+
- PostgreSQL extension for vector storage
|
|
194
|
+
- Leverage existing PostgreSQL infrastructure
|
|
195
|
+
- ACID transactions with vectors
|
|
196
|
+
- Combine relational + vector data
|
|
197
|
+
- Familiar SQL interface
|
|
198
|
+
- **Best for**: Existing PostgreSQL users, hybrid workloads
|
|
199
|
+
|
|
200
|
+
### Selection Criteria
|
|
201
|
+
|
|
202
|
+
**Choose Pinecone if:**
|
|
203
|
+
- You want fully managed service
|
|
204
|
+
- Minimal ops overhead is priority
|
|
205
|
+
- You need auto-scaling
|
|
206
|
+
- Budget allows for managed service
|
|
207
|
+
|
|
208
|
+
**Choose Weaviate if:**
|
|
209
|
+
- You want built-in vectorization
|
|
210
|
+
- GraphQL API is preferred
|
|
211
|
+
- You need self-hosting option
|
|
212
|
+
- Hybrid search is critical
|
|
213
|
+
|
|
214
|
+
**Choose Milvus if:**
|
|
215
|
+
- You need maximum performance
|
|
216
|
+
- Large-scale deployment (billions of vectors)
|
|
217
|
+
- GPU acceleration is required
|
|
218
|
+
- Kubernetes infrastructure exists
|
|
219
|
+
|
|
220
|
+
**Choose Qdrant if:**
|
|
221
|
+
- Advanced filtering is critical
|
|
222
|
+
- You want Rust performance
|
|
223
|
+
- Self-hosting with managed option
|
|
224
|
+
- Payload-based search is needed
|
|
225
|
+
|
|
226
|
+
**Choose Chroma if:**
|
|
227
|
+
- You're prototyping/developing locally
|
|
228
|
+
- Simple API is priority
|
|
229
|
+
- Embedded database is preferred
|
|
230
|
+
- LLM application focus
|
|
231
|
+
|
|
232
|
+
**Choose pgvector if:**
|
|
233
|
+
- You already use PostgreSQL
|
|
234
|
+
- You need ACID transactions with vectors
|
|
235
|
+
- Hybrid relational + vector data
|
|
236
|
+
- Familiar SQL interface is preferred
|
|
237
|
+
|
|
238
|
+
---
|
|
239
|
+
|
|
240
|
+
## Hybrid Search
|
|
241
|
+
|
|
242
|
+
### What is Hybrid Search?
|
|
243
|
+
|
|
244
|
+
**Definition**: Combining vector similarity search with traditional keyword/metadata filtering
|
|
245
|
+
|
|
246
|
+
**Benefits:**
|
|
247
|
+
- More accurate results (semantic + keyword matching)
|
|
248
|
+
- Filter by metadata (date, category, author, etc.)
|
|
249
|
+
- Combine multiple ranking signals
|
|
250
|
+
- Better user experience
|
|
251
|
+
|
|
252
|
+
### Hybrid Search Patterns
|
|
253
|
+
|
|
254
|
+
**Pattern 1: Vector Search + Metadata Filtering**
|
|
255
|
+
```python
|
|
256
|
+
# Search for similar documents, filtered by category
|
|
257
|
+
results = index.query(
|
|
258
|
+
vector=query_embedding,
|
|
259
|
+
top_k=10,
|
|
260
|
+
filter={"category": "technology", "date": {"$gte": "2024-01-01"}}
|
|
261
|
+
)
|
|
262
|
+
```
|
|
263
|
+
|
|
264
|
+
**Pattern 2: Vector Search + Keyword Search**
|
|
265
|
+
```python
|
|
266
|
+
# Combine semantic search with keyword matching
|
|
267
|
+
vector_results = vector_search(query_embedding, top_k=50)
|
|
268
|
+
keyword_results = keyword_search(query_text, top_k=50)
|
|
269
|
+
|
|
270
|
+
# Merge and re-rank results
|
|
271
|
+
final_results = merge_and_rerank(vector_results, keyword_results)
|
|
272
|
+
```
|
|
273
|
+
|
|
274
|
+
**Pattern 3: Weighted Hybrid Search**
|
|
275
|
+
```python
|
|
276
|
+
# Weight vector and keyword scores
|
|
277
|
+
final_score = (0.7 * vector_score) + (0.3 * keyword_score)
|
|
278
|
+
```
|
|
279
|
+
|
|
280
|
+
### Implementing Hybrid Search
|
|
281
|
+
|
|
282
|
+
**Example with Weaviate:**
|
|
283
|
+
```python
|
|
284
|
+
import weaviate
|
|
285
|
+
|
|
286
|
+
client = weaviate.Client("http://localhost:8080")
|
|
287
|
+
|
|
288
|
+
# Hybrid search (vector + keyword)
|
|
289
|
+
result = client.query.get("Article", ["title", "content"]) \
|
|
290
|
+
.with_hybrid(
|
|
291
|
+
query="machine learning",
|
|
292
|
+
alpha=0.5 # 0.5 = equal weight vector/keyword
|
|
293
|
+
) \
|
|
294
|
+
.with_where({
|
|
295
|
+
"path": ["category"],
|
|
296
|
+
"operator": "Equal",
|
|
297
|
+
"valueString": "AI"
|
|
298
|
+
}) \
|
|
299
|
+
.with_limit(10) \
|
|
300
|
+
.do()
|
|
301
|
+
```
|
|
302
|
+
|
|
303
|
+
**Example with Pinecone:**
|
|
304
|
+
```python
|
|
305
|
+
import pinecone
|
|
306
|
+
|
|
307
|
+
index = pinecone.Index("my-index")
|
|
308
|
+
|
|
309
|
+
# Vector search with metadata filtering
|
|
310
|
+
results = index.query(
|
|
311
|
+
vector=query_embedding,
|
|
312
|
+
top_k=10,
|
|
313
|
+
filter={
|
|
314
|
+
"category": {"$eq": "AI"},
|
|
315
|
+
"published_date": {"$gte": "2024-01-01"}
|
|
316
|
+
},
|
|
317
|
+
include_metadata=True
|
|
318
|
+
)
|
|
319
|
+
```
|
|
320
|
+
|
|
321
|
+
---
|
|
322
|
+
|
|
323
|
+
## Use Cases
|
|
324
|
+
|
|
325
|
+
### 1. Semantic Search
|
|
326
|
+
|
|
327
|
+
**Problem**: Keyword search misses semantically similar content
|
|
328
|
+
|
|
329
|
+
**Solution**: Vector search finds documents by meaning, not just keywords
|
|
330
|
+
|
|
331
|
+
**Example:**
|
|
332
|
+
```
|
|
333
|
+
Query: "How to fix a leaky faucet"
|
|
334
|
+
Keyword search: Finds documents with exact words "leaky faucet"
|
|
335
|
+
Vector search: Also finds "dripping tap repair", "water fixture maintenance"
|
|
336
|
+
```
|
|
337
|
+
|
|
338
|
+
**Implementation:**
|
|
339
|
+
1. Generate embeddings for all documents
|
|
340
|
+
2. Store embeddings in vector database
|
|
341
|
+
3. Generate embedding for search query
|
|
342
|
+
4. Find k-nearest neighbors
|
|
343
|
+
5. Return ranked results
|
|
344
|
+
|
|
345
|
+
### 2. RAG (Retrieval-Augmented Generation)
|
|
346
|
+
|
|
347
|
+
**Problem**: LLMs lack domain-specific knowledge or up-to-date information
|
|
348
|
+
|
|
349
|
+
**Solution**: Retrieve relevant context from vector database, augment LLM prompt
|
|
350
|
+
|
|
351
|
+
**Workflow:**
|
|
352
|
+
1. User asks question
|
|
353
|
+
2. Generate embedding for question
|
|
354
|
+
3. Search vector database for relevant documents
|
|
355
|
+
4. Retrieve top-k most similar documents
|
|
356
|
+
5. Augment LLM prompt with retrieved context
|
|
357
|
+
6. Generate answer using LLM + context
|
|
358
|
+
|
|
359
|
+
**Example:**
|
|
360
|
+
```python
|
|
361
|
+
# RAG implementation
|
|
362
|
+
def rag_query(question, index, llm):
|
|
363
|
+
# 1. Generate question embedding
|
|
364
|
+
question_embedding = embed(question)
|
|
365
|
+
|
|
366
|
+
# 2. Retrieve relevant documents
|
|
367
|
+
results = index.query(question_embedding, top_k=5)
|
|
368
|
+
context = "\n".join([r.text for r in results])
|
|
369
|
+
|
|
370
|
+
# 3. Augment prompt with context
|
|
371
|
+
prompt = f"""
|
|
372
|
+
Context: {context}
|
|
373
|
+
|
|
374
|
+
Question: {question}
|
|
375
|
+
|
|
376
|
+
Answer based on the context above:
|
|
377
|
+
"""
|
|
378
|
+
|
|
379
|
+
# 4. Generate answer
|
|
380
|
+
answer = llm.generate(prompt)
|
|
381
|
+
return answer
|
|
382
|
+
```
|
|
383
|
+
|
|
384
|
+
### 3. Recommendation Systems
|
|
385
|
+
|
|
386
|
+
**Problem**: Recommend similar items based on content, not just collaborative filtering
|
|
387
|
+
|
|
388
|
+
**Solution**: Find items with similar embeddings
|
|
389
|
+
|
|
390
|
+
**Example:**
|
|
391
|
+
```python
|
|
392
|
+
# Product recommendation
|
|
393
|
+
def recommend_similar_products(product_id, index, top_k=5):
|
|
394
|
+
# Get product embedding
|
|
395
|
+
product_embedding = index.fetch([product_id])[0].vector
|
|
396
|
+
|
|
397
|
+
# Find similar products
|
|
398
|
+
results = index.query(
|
|
399
|
+
vector=product_embedding,
|
|
400
|
+
top_k=top_k + 1, # +1 to exclude self
|
|
401
|
+
filter={"product_id": {"$ne": product_id}}
|
|
402
|
+
)
|
|
403
|
+
|
|
404
|
+
return results[1:] # Exclude the product itself
|
|
405
|
+
```
|
|
406
|
+
|
|
407
|
+
---
|
|
408
|
+
|
|
409
|
+
## Best Practices
|
|
410
|
+
|
|
411
|
+
### 1. Embedding Generation
|
|
412
|
+
|
|
413
|
+
✅ **DO:**
|
|
414
|
+
- Use consistent embedding models (same model for indexing and querying)
|
|
415
|
+
- Normalize embeddings if using dot product
|
|
416
|
+
- Batch embed documents for efficiency
|
|
417
|
+
- Cache embeddings to avoid re-computation
|
|
418
|
+
- Version embeddings (track which model generated them)
|
|
419
|
+
|
|
420
|
+
❌ **DON'T:**
|
|
421
|
+
- Mix embeddings from different models
|
|
422
|
+
- Re-embed documents unnecessarily
|
|
423
|
+
- Ignore embedding model updates
|
|
424
|
+
- Store embeddings without metadata
|
|
425
|
+
|
|
426
|
+
### 2. Vector Storage
|
|
427
|
+
|
|
428
|
+
✅ **DO:**
|
|
429
|
+
- Store metadata with vectors (original text, IDs, timestamps)
|
|
430
|
+
- Use appropriate index type for your scale
|
|
431
|
+
- Monitor index size and performance
|
|
432
|
+
- Implement backup and recovery
|
|
433
|
+
- Version your vector data
|
|
434
|
+
|
|
435
|
+
❌ **DON'T:**
|
|
436
|
+
- Store only vectors without metadata
|
|
437
|
+
- Use flat index for large datasets (>100k vectors)
|
|
438
|
+
- Ignore index maintenance
|
|
439
|
+
- Skip backups
|
|
440
|
+
|
|
441
|
+
### 3. Similarity Search
|
|
442
|
+
|
|
443
|
+
✅ **DO:**
|
|
444
|
+
- Choose appropriate distance metric (cosine for text)
|
|
445
|
+
- Tune top_k based on use case
|
|
446
|
+
- Implement hybrid search for better accuracy
|
|
447
|
+
- Monitor query latency
|
|
448
|
+
- Use metadata filtering to narrow results
|
|
449
|
+
|
|
450
|
+
❌ **DON'T:**
|
|
451
|
+
- Use wrong distance metric
|
|
452
|
+
- Return too many results (top_k > 100)
|
|
453
|
+
- Rely solely on vector search (ignore metadata)
|
|
454
|
+
- Ignore performance optimization
|
|
455
|
+
|
|
456
|
+
### 4. Performance Optimization
|
|
457
|
+
|
|
458
|
+
✅ **DO:**
|
|
459
|
+
- Use approximate nearest neighbor (ANN) algorithms
|
|
460
|
+
- Tune index parameters (ef_construction, M for HNSW)
|
|
461
|
+
- Implement caching for frequent queries
|
|
462
|
+
- Batch operations when possible
|
|
463
|
+
- Monitor and optimize query latency
|
|
464
|
+
|
|
465
|
+
❌ **DON'T:**
|
|
466
|
+
- Use exact nearest neighbor for large datasets
|
|
467
|
+
- Ignore index tuning
|
|
468
|
+
- Query one vector at a time
|
|
469
|
+
- Skip performance monitoring
|
|
470
|
+
|
|
471
|
+
---
|
|
472
|
+
|
|
473
|
+
## Common Pitfalls
|
|
474
|
+
|
|
475
|
+
### 1. Wrong Distance Metric
|
|
476
|
+
|
|
477
|
+
**Problem**: Using Euclidean distance for text embeddings
|
|
478
|
+
|
|
479
|
+
**Solution**: Use cosine similarity for text, Euclidean for images
|
|
480
|
+
|
|
481
|
+
### 2. Not Normalizing Embeddings
|
|
482
|
+
|
|
483
|
+
**Problem**: Dot product gives inconsistent results
|
|
484
|
+
|
|
485
|
+
**Solution**: Normalize embeddings before using dot product
|
|
486
|
+
|
|
487
|
+
### 3. Ignoring Metadata
|
|
488
|
+
|
|
489
|
+
**Problem**: Vector search returns irrelevant results
|
|
490
|
+
|
|
491
|
+
**Solution**: Combine vector search with metadata filtering
|
|
492
|
+
|
|
493
|
+
### 4. Poor Chunking Strategy
|
|
494
|
+
|
|
495
|
+
**Problem**: Embeddings represent too much or too little context
|
|
496
|
+
|
|
497
|
+
**Solution**: Chunk documents appropriately (see vector-embeddings.md)
|
|
498
|
+
|
|
499
|
+
### 5. Not Versioning Embeddings
|
|
500
|
+
|
|
501
|
+
**Problem**: Can't track which model generated embeddings
|
|
502
|
+
|
|
503
|
+
**Solution**: Store embedding model version with vectors
|
|
504
|
+
|
|
505
|
+
---
|
|
506
|
+
|
|
507
|
+
## Summary
|
|
508
|
+
|
|
509
|
+
**Key Takeaways:**
|
|
510
|
+
1. Vector databases enable semantic search and similarity-based retrieval
|
|
511
|
+
2. Choose distance metric based on data type (cosine for text)
|
|
512
|
+
3. Use hybrid search for better accuracy (vector + metadata)
|
|
513
|
+
4. Popular options: Pinecone (managed), Weaviate (flexible), Milvus (scale)
|
|
514
|
+
5. Common use cases: semantic search, RAG, recommendations
|
|
515
|
+
6. Best practices: consistent embeddings, metadata storage, performance tuning
|
|
516
|
+
|
|
517
|
+
**Next Steps:**
|
|
518
|
+
- See `vector-embeddings.md` for embedding generation strategies
|
|
519
|
+
- See `vector-indexing.md` for index optimization
|
|
520
|
+
- See `examples/vector-database-example.md` for complete implementation
|
|
521
|
+
|