@ruaruababa/vibe-kit 1.0.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/CATALOG.md +317 -0
- package/README.md +121 -0
- package/aliases.json +65 -0
- package/bin/vibe.js +2 -0
- package/bundles.json +265 -0
- package/catalog.json +1560 -0
- package/dist/antigravity-skills/bin/cli.js +438 -0
- package/dist/antigravity-skills/lib/skill-utils.js +158 -0
- package/dist/antigravity-skills/scripts/build-catalog.js +305 -0
- package/dist/antigravity-skills/scripts/normalize-frontmatter.js +144 -0
- package/dist/antigravity-skills/scripts/validate-skills.js +230 -0
- package/dist/bin/vibe.js +2 -0
- package/dist/dist/src/cli/index.js +26 -0
- package/dist/lib/skill-utils.js +158 -0
- package/dist/scripts/build-catalog.js +50 -0
- package/dist/scripts/normalize-frontmatter.js +144 -0
- package/dist/scripts/validate-skills.js +56 -0
- package/dist/src/cli/index.js +146 -0
- package/dist/src/types/index.js +13 -0
- package/dist/src/utils/fs.js +1 -0
- package/package.json +43 -0
- package/skills/accessibility-compliance-accessibility-audit/SKILL.md +42 -0
- package/skills/accessibility-compliance-accessibility-audit/resources/implementation-playbook.md +502 -0
- package/skills/agent-orchestration-improve-agent/SKILL.md +349 -0
- package/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
- package/skills/agent-orchestrator/SKILL.md +24 -0
- package/skills/ai-engineer/SKILL.md +171 -0
- package/skills/airflow-dag-patterns/SKILL.md +41 -0
- package/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
- package/skills/angular-migration/SKILL.md +428 -0
- package/skills/anti-reversing-techniques/SKILL.md +42 -0
- package/skills/anti-reversing-techniques/resources/implementation-playbook.md +539 -0
- package/skills/api-design-principles/SKILL.md +37 -0
- package/skills/api-design-principles/assets/api-design-checklist.md +155 -0
- package/skills/api-design-principles/assets/rest-api-template.py +182 -0
- package/skills/api-design-principles/references/graphql-schema-design.md +583 -0
- package/skills/api-design-principles/references/rest-best-practices.md +408 -0
- package/skills/api-design-principles/resources/implementation-playbook.md +513 -0
- package/skills/api-documenter/SKILL.md +184 -0
- package/skills/api-testing-observability-api-mock/SKILL.md +46 -0
- package/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
- package/skills/application-performance-performance-optimization/SKILL.md +154 -0
- package/skills/architect-review/SKILL.md +174 -0
- package/skills/architecture-decision-records/SKILL.md +441 -0
- package/skills/architecture-patterns/SKILL.md +37 -0
- package/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
- package/skills/arm-cortex-expert/SKILL.md +306 -0
- package/skills/async-python-patterns/SKILL.md +39 -0
- package/skills/async-python-patterns/resources/implementation-playbook.md +678 -0
- package/skills/attack-tree-construction/SKILL.md +38 -0
- package/skills/attack-tree-construction/resources/implementation-playbook.md +671 -0
- package/skills/auth-implementation-patterns/SKILL.md +39 -0
- package/skills/auth-implementation-patterns/resources/implementation-playbook.md +618 -0
- package/skills/backend-architect/SKILL.md +333 -0
- package/skills/backend-development-feature-development/SKILL.md +180 -0
- package/skills/backend-security-coder/SKILL.md +156 -0
- package/skills/backtesting-frameworks/SKILL.md +39 -0
- package/skills/backtesting-frameworks/resources/implementation-playbook.md +647 -0
- package/skills/bash-defensive-patterns/SKILL.md +43 -0
- package/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
- package/skills/bash-pro/SKILL.md +310 -0
- package/skills/bats-testing-patterns/SKILL.md +34 -0
- package/skills/bats-testing-patterns/resources/implementation-playbook.md +614 -0
- package/skills/bazel-build-optimization/SKILL.md +397 -0
- package/skills/billing-automation/SKILL.md +42 -0
- package/skills/billing-automation/resources/implementation-playbook.md +544 -0
- package/skills/binary-analysis-patterns/SKILL.md +450 -0
- package/skills/blockchain-developer/SKILL.md +208 -0
- package/skills/business-analyst/SKILL.md +182 -0
- package/skills/c-pro/SKILL.md +56 -0
- package/skills/c4-architecture-c4-architecture/SKILL.md +389 -0
- package/skills/c4-code/SKILL.md +244 -0
- package/skills/c4-component/SKILL.md +153 -0
- package/skills/c4-container/SKILL.md +171 -0
- package/skills/c4-context/SKILL.md +150 -0
- package/skills/changelog-automation/SKILL.md +38 -0
- package/skills/changelog-automation/resources/implementation-playbook.md +538 -0
- package/skills/cicd-automation-workflow-automate/SKILL.md +51 -0
- package/skills/cicd-automation-workflow-automate/resources/implementation-playbook.md +1333 -0
- package/skills/clean-markdown/SKILL.md +23 -0
- package/skills/cloud-architect/SKILL.md +135 -0
- package/skills/code-documentation-code-explain/SKILL.md +46 -0
- package/skills/code-documentation-code-explain/resources/implementation-playbook.md +802 -0
- package/skills/code-documentation-doc-generate/SKILL.md +48 -0
- package/skills/code-documentation-doc-generate/resources/implementation-playbook.md +640 -0
- package/skills/code-refactoring-context-restore/SKILL.md +179 -0
- package/skills/code-refactoring-refactor-clean/SKILL.md +51 -0
- package/skills/code-refactoring-refactor-clean/resources/implementation-playbook.md +879 -0
- package/skills/code-refactoring-tech-debt/SKILL.md +386 -0
- package/skills/code-review-ai-ai-review/SKILL.md +450 -0
- package/skills/code-review-excellence/SKILL.md +40 -0
- package/skills/code-review-excellence/resources/implementation-playbook.md +515 -0
- package/skills/code-reviewer/SKILL.md +178 -0
- package/skills/codebase-cleanup-deps-audit/SKILL.md +51 -0
- package/skills/codebase-cleanup-deps-audit/resources/implementation-playbook.md +766 -0
- package/skills/codebase-cleanup-refactor-clean/SKILL.md +51 -0
- package/skills/codebase-cleanup-refactor-clean/resources/implementation-playbook.md +879 -0
- package/skills/codebase-cleanup-tech-debt/SKILL.md +386 -0
- package/skills/competitive-landscape/SKILL.md +34 -0
- package/skills/competitive-landscape/resources/implementation-playbook.md +494 -0
- package/skills/comprehensive-review-full-review/SKILL.md +146 -0
- package/skills/comprehensive-review-pr-enhance/SKILL.md +46 -0
- package/skills/comprehensive-review-pr-enhance/resources/implementation-playbook.md +691 -0
- package/skills/conductor-implement/SKILL.md +388 -0
- package/skills/conductor-manage/SKILL.md +39 -0
- package/skills/conductor-manage/resources/implementation-playbook.md +1120 -0
- package/skills/conductor-new-track/SKILL.md +433 -0
- package/skills/conductor-revert/SKILL.md +372 -0
- package/skills/conductor-setup/SKILL.md +426 -0
- package/skills/conductor-status/SKILL.md +338 -0
- package/skills/conductor-validator/SKILL.md +62 -0
- package/skills/content-marketer/SKILL.md +170 -0
- package/skills/context-driven-development/SKILL.md +400 -0
- package/skills/context-management-context-restore/SKILL.md +179 -0
- package/skills/context-management-context-save/SKILL.md +177 -0
- package/skills/context-manager/SKILL.md +185 -0
- package/skills/cost-optimization/SKILL.md +286 -0
- package/skills/cpp-pro/SKILL.md +59 -0
- package/skills/cqrs-implementation/SKILL.md +35 -0
- package/skills/cqrs-implementation/resources/implementation-playbook.md +540 -0
- package/skills/csharp-pro/SKILL.md +59 -0
- package/skills/customer-support/SKILL.md +170 -0
- package/skills/data-engineer/SKILL.md +224 -0
- package/skills/data-engineering-data-driven-feature/SKILL.md +182 -0
- package/skills/data-engineering-data-pipeline/SKILL.md +201 -0
- package/skills/data-quality-frameworks/SKILL.md +40 -0
- package/skills/data-quality-frameworks/resources/implementation-playbook.md +573 -0
- package/skills/data-scientist/SKILL.md +199 -0
- package/skills/data-storytelling/SKILL.md +465 -0
- package/skills/database-admin/SKILL.md +165 -0
- package/skills/database-architect/SKILL.md +268 -0
- package/skills/database-cloud-optimization-cost-optimize/SKILL.md +44 -0
- package/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
- package/skills/database-migration/SKILL.md +436 -0
- package/skills/database-migrations-migration-observability/SKILL.md +420 -0
- package/skills/database-migrations-sql-migrations/SKILL.md +53 -0
- package/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
- package/skills/database-optimizer/SKILL.md +167 -0
- package/skills/dbt-transformation-patterns/SKILL.md +34 -0
- package/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
- package/skills/debugger/SKILL.md +49 -0
- package/skills/debugging-strategies/SKILL.md +34 -0
- package/skills/debugging-strategies/resources/implementation-playbook.md +511 -0
- package/skills/debugging-toolkit-smart-debug/SKILL.md +197 -0
- package/skills/defi-protocol-templates/SKILL.md +466 -0
- package/skills/dependency-management-deps-audit/SKILL.md +44 -0
- package/skills/dependency-management-deps-audit/resources/implementation-playbook.md +766 -0
- package/skills/dependency-upgrade/SKILL.md +421 -0
- package/skills/deployment-engineer/SKILL.md +170 -0
- package/skills/deployment-pipeline-design/SKILL.md +371 -0
- package/skills/deployment-validation-config-validate/SKILL.md +496 -0
- package/skills/devops-troubleshooter/SKILL.md +161 -0
- package/skills/distributed-debugging-debug-trace/SKILL.md +44 -0
- package/skills/distributed-debugging-debug-trace/resources/implementation-playbook.md +1307 -0
- package/skills/distributed-tracing/SKILL.md +450 -0
- package/skills/django-pro/SKILL.md +180 -0
- package/skills/docs-architect/SKILL.md +98 -0
- package/skills/documentation-generation-doc-generate/SKILL.md +48 -0
- package/skills/documentation-generation-doc-generate/resources/implementation-playbook.md +640 -0
- package/skills/dotnet-architect/SKILL.md +197 -0
- package/skills/dotnet-backend-patterns/SKILL.md +37 -0
- package/skills/dotnet-backend-patterns/assets/repository-template.cs +523 -0
- package/skills/dotnet-backend-patterns/assets/service-template.cs +336 -0
- package/skills/dotnet-backend-patterns/references/dapper-patterns.md +544 -0
- package/skills/dotnet-backend-patterns/references/ef-core-best-practices.md +355 -0
- package/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
- package/skills/dummy-skill/SKILL.md +5 -0
- package/skills/dx-optimizer/SKILL.md +83 -0
- package/skills/e2e-testing-patterns/SKILL.md +41 -0
- package/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
- package/skills/elixir-pro/SKILL.md +59 -0
- package/skills/embedding-strategies/SKILL.md +491 -0
- package/skills/employment-contract-templates/SKILL.md +39 -0
- package/skills/employment-contract-templates/resources/implementation-playbook.md +493 -0
- package/skills/error-debugging-error-analysis/SKILL.md +47 -0
- package/skills/error-debugging-error-analysis/resources/implementation-playbook.md +1143 -0
- package/skills/error-debugging-error-trace/SKILL.md +43 -0
- package/skills/error-debugging-error-trace/resources/implementation-playbook.md +1361 -0
- package/skills/error-debugging-multi-agent-review/SKILL.md +216 -0
- package/skills/error-detective/SKILL.md +53 -0
- package/skills/error-diagnostics-error-analysis/SKILL.md +47 -0
- package/skills/error-diagnostics-error-analysis/resources/implementation-playbook.md +1143 -0
- package/skills/error-diagnostics-error-trace/SKILL.md +48 -0
- package/skills/error-diagnostics-error-trace/resources/implementation-playbook.md +1371 -0
- package/skills/error-diagnostics-smart-debug/SKILL.md +197 -0
- package/skills/error-handling-patterns/SKILL.md +35 -0
- package/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
- package/skills/event-sourcing-architect/SKILL.md +58 -0
- package/skills/event-store-design/SKILL.md +449 -0
- package/skills/fastapi-pro/SKILL.md +192 -0
- package/skills/fastapi-templates/SKILL.md +32 -0
- package/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
- package/skills/final-test/SKILL.md +5 -0
- package/skills/firmware-analyst/SKILL.md +320 -0
- package/skills/flutter-expert/SKILL.md +200 -0
- package/skills/framework-migration-code-migrate/SKILL.md +48 -0
- package/skills/framework-migration-code-migrate/resources/implementation-playbook.md +1052 -0
- package/skills/framework-migration-deps-upgrade/SKILL.md +48 -0
- package/skills/framework-migration-deps-upgrade/resources/implementation-playbook.md +755 -0
- package/skills/framework-migration-legacy-modernize/SKILL.md +132 -0
- package/skills/frontend-developer/SKILL.md +171 -0
- package/skills/frontend-mobile-development-component-scaffold/SKILL.md +403 -0
- package/skills/frontend-mobile-security-xss-scan/SKILL.md +322 -0
- package/skills/frontend-security-coder/SKILL.md +170 -0
- package/skills/full-stack-orchestration-full-stack-feature/SKILL.md +135 -0
- package/skills/gdpr-data-handling/SKILL.md +33 -0
- package/skills/gdpr-data-handling/resources/implementation-playbook.md +615 -0
- package/skills/git-advanced-workflows/SKILL.md +412 -0
- package/skills/git-pr-workflows-git-workflow/SKILL.md +140 -0
- package/skills/git-pr-workflows-onboard/SKILL.md +416 -0
- package/skills/git-pr-workflows-pr-enhance/SKILL.md +48 -0
- package/skills/git-pr-workflows-pr-enhance/resources/implementation-playbook.md +701 -0
- package/skills/github-actions-templates/SKILL.md +345 -0
- package/skills/gitlab-ci-patterns/SKILL.md +283 -0
- package/skills/gitops-workflow/SKILL.md +303 -0
- package/skills/gitops-workflow/references/argocd-setup.md +134 -0
- package/skills/gitops-workflow/references/sync-policies.md +131 -0
- package/skills/go-concurrency-patterns/SKILL.md +33 -0
- package/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
- package/skills/godot-gdscript-patterns/SKILL.md +33 -0
- package/skills/godot-gdscript-patterns/resources/implementation-playbook.md +804 -0
- package/skills/golang-pro/SKILL.md +179 -0
- package/skills/grafana-dashboards/SKILL.md +381 -0
- package/skills/graphql-architect/SKILL.md +182 -0
- package/skills/haskell-pro/SKILL.md +56 -0
- package/skills/helm-chart-scaffolding/SKILL.md +34 -0
- package/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
- package/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
- package/skills/helm-chart-scaffolding/references/chart-structure.md +500 -0
- package/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
- package/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
- package/skills/hr-pro/SKILL.md +126 -0
- package/skills/hybrid-cloud-architect/SKILL.md +168 -0
- package/skills/hybrid-cloud-networking/SKILL.md +238 -0
- package/skills/hybrid-search-implementation/SKILL.md +32 -0
- package/skills/hybrid-search-implementation/resources/implementation-playbook.md +567 -0
- package/skills/incident-responder/SKILL.md +213 -0
- package/skills/incident-response-incident-response/SKILL.md +168 -0
- package/skills/incident-response-smart-fix/SKILL.md +29 -0
- package/skills/incident-response-smart-fix/resources/implementation-playbook.md +838 -0
- package/skills/incident-runbook-templates/SKILL.md +395 -0
- package/skills/ios-developer/SKILL.md +219 -0
- package/skills/istio-traffic-management/SKILL.md +337 -0
- package/skills/java-pro/SKILL.md +177 -0
- package/skills/javascript-pro/SKILL.md +57 -0
- package/skills/javascript-testing-patterns/SKILL.md +35 -0
- package/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
- package/skills/javascript-typescript-typescript-scaffold/SKILL.md +361 -0
- package/skills/julia-pro/SKILL.md +209 -0
- package/skills/k8s-manifest-generator/SKILL.md +35 -0
- package/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
- package/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
- package/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
- package/skills/k8s-manifest-generator/references/deployment-spec.md +753 -0
- package/skills/k8s-manifest-generator/references/service-spec.md +724 -0
- package/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
- package/skills/k8s-security-policies/SKILL.md +346 -0
- package/skills/k8s-security-policies/assets/network-policy-template.yaml +177 -0
- package/skills/k8s-security-policies/references/rbac-patterns.md +187 -0
- package/skills/kpi-dashboard-design/SKILL.md +440 -0
- package/skills/kubernetes-architect/SKILL.md +170 -0
- package/skills/langchain-architecture/SKILL.md +350 -0
- package/skills/legacy-modernizer/SKILL.md +53 -0
- package/skills/legal-advisor/SKILL.md +70 -0
- package/skills/linkerd-patterns/SKILL.md +321 -0
- package/skills/llm-application-dev-ai-assistant/SKILL.md +35 -0
- package/skills/llm-application-dev-ai-assistant/resources/implementation-playbook.md +1236 -0
- package/skills/llm-application-dev-langchain-agent/SKILL.md +246 -0
- package/skills/llm-application-dev-prompt-optimize/SKILL.md +37 -0
- package/skills/llm-application-dev-prompt-optimize/resources/implementation-playbook.md +591 -0
- package/skills/llm-evaluation/SKILL.md +483 -0
- package/skills/machine-learning-ops-ml-pipeline/SKILL.md +314 -0
- package/skills/malware-analyst/SKILL.md +247 -0
- package/skills/market-sizing-analysis/SKILL.md +425 -0
- package/skills/market-sizing-analysis/examples/saas-market-sizing.md +349 -0
- package/skills/market-sizing-analysis/references/data-sources.md +360 -0
- package/skills/memory-forensics/SKILL.md +491 -0
- package/skills/memory-safety-patterns/SKILL.md +33 -0
- package/skills/memory-safety-patterns/resources/implementation-playbook.md +603 -0
- package/skills/mermaid-expert/SKILL.md +59 -0
- package/skills/microservices-patterns/SKILL.md +35 -0
- package/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
- package/skills/minecraft-bukkit-pro/SKILL.md +126 -0
- package/skills/ml-engineer/SKILL.md +168 -0
- package/skills/ml-pipeline-workflow/SKILL.md +257 -0
- package/skills/mlops-engineer/SKILL.md +219 -0
- package/skills/mobile-developer/SKILL.md +205 -0
- package/skills/mobile-security-coder/SKILL.md +184 -0
- package/skills/modern-javascript-patterns/SKILL.md +35 -0
- package/skills/modern-javascript-patterns/resources/implementation-playbook.md +910 -0
- package/skills/monorepo-architect/SKILL.md +61 -0
- package/skills/monorepo-management/SKILL.md +35 -0
- package/skills/monorepo-management/resources/implementation-playbook.md +621 -0
- package/skills/mtls-configuration/SKILL.md +359 -0
- package/skills/multi-cloud-architecture/SKILL.md +189 -0
- package/skills/multi-platform-apps-multi-platform/SKILL.md +203 -0
- package/skills/network-engineer/SKILL.md +169 -0
- package/skills/nextjs-app-router-patterns/SKILL.md +33 -0
- package/skills/nextjs-app-router-patterns/resources/implementation-playbook.md +543 -0
- package/skills/nft-standards/SKILL.md +395 -0
- package/skills/node-expert/SKILL.md +23 -0
- package/skills/nodejs-backend-patterns/SKILL.md +35 -0
- package/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
- package/skills/nx-workspace-patterns/SKILL.md +464 -0
- package/skills/observability-engineer/SKILL.md +237 -0
- package/skills/observability-monitoring-monitor-setup/SKILL.md +48 -0
- package/skills/observability-monitoring-monitor-setup/resources/implementation-playbook.md +505 -0
- package/skills/observability-monitoring-slo-implement/SKILL.md +43 -0
- package/skills/observability-monitoring-slo-implement/resources/implementation-playbook.md +1077 -0
- package/skills/on-call-handoff-patterns/SKILL.md +453 -0
- package/skills/openapi-spec-generation/SKILL.md +33 -0
- package/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
- package/skills/payment-integration/SKILL.md +77 -0
- package/skills/paypal-integration/SKILL.md +479 -0
- package/skills/pci-compliance/SKILL.md +478 -0
- package/skills/performance-engineer/SKILL.md +180 -0
- package/skills/performance-testing-review-ai-review/SKILL.md +450 -0
- package/skills/performance-testing-review-multi-agent-review/SKILL.md +216 -0
- package/skills/php-pro/SKILL.md +63 -0
- package/skills/posix-shell-pro/SKILL.md +304 -0
- package/skills/postgresql/SKILL.md +230 -0
- package/skills/postmortem-writing/SKILL.md +386 -0
- package/skills/projection-patterns/SKILL.md +33 -0
- package/skills/projection-patterns/resources/implementation-playbook.md +501 -0
- package/skills/prometheus-configuration/SKILL.md +404 -0
- package/skills/prompt-engineer/SKILL.md +272 -0
- package/skills/prompt-engineering-patterns/SKILL.md +213 -0
- package/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
- package/skills/prompt-engineering-patterns/assets/prompt-template-library.md +246 -0
- package/skills/prompt-engineering-patterns/references/chain-of-thought.md +399 -0
- package/skills/prompt-engineering-patterns/references/few-shot-learning.md +369 -0
- package/skills/prompt-engineering-patterns/references/prompt-optimization.md +414 -0
- package/skills/prompt-engineering-patterns/references/prompt-templates.md +470 -0
- package/skills/prompt-engineering-patterns/references/system-prompts.md +189 -0
- package/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
- package/skills/protocol-reverse-engineering/SKILL.md +29 -0
- package/skills/protocol-reverse-engineering/resources/implementation-playbook.md +509 -0
- package/skills/python-development-python-scaffold/SKILL.md +331 -0
- package/skills/python-packaging/SKILL.md +36 -0
- package/skills/python-packaging/resources/implementation-playbook.md +869 -0
- package/skills/python-performance-optimization/SKILL.md +36 -0
- package/skills/python-performance-optimization/resources/implementation-playbook.md +868 -0
- package/skills/python-pro/SKILL.md +158 -0
- package/skills/python-testing-patterns/SKILL.md +37 -0
- package/skills/python-testing-patterns/resources/implementation-playbook.md +906 -0
- package/skills/quant-analyst/SKILL.md +53 -0
- package/skills/rag-implementation/SKILL.md +421 -0
- package/skills/react-modernization/SKILL.md +34 -0
- package/skills/react-modernization/resources/implementation-playbook.md +512 -0
- package/skills/react-native-architecture/SKILL.md +33 -0
- package/skills/react-native-architecture/resources/implementation-playbook.md +670 -0
- package/skills/react-state-management/SKILL.md +441 -0
- package/skills/reference-builder/SKILL.md +188 -0
- package/skills/reverse-engineer/SKILL.md +173 -0
- package/skills/risk-manager/SKILL.md +61 -0
- package/skills/risk-metrics-calculation/SKILL.md +33 -0
- package/skills/risk-metrics-calculation/resources/implementation-playbook.md +554 -0
- package/skills/ruby-pro/SKILL.md +56 -0
- package/skills/rust-async-patterns/SKILL.md +33 -0
- package/skills/rust-async-patterns/resources/implementation-playbook.md +516 -0
- package/skills/rust-pro/SKILL.md +178 -0
- package/skills/saga-orchestration/SKILL.md +496 -0
- package/skills/sales-automator/SKILL.md +55 -0
- package/skills/sast-configuration/SKILL.md +212 -0
- package/skills/scala-pro/SKILL.md +82 -0
- package/skills/screen-reader-testing/SKILL.md +33 -0
- package/skills/screen-reader-testing/resources/implementation-playbook.md +544 -0
- package/skills/search-specialist/SKILL.md +80 -0
- package/skills/secrets-management/SKILL.md +364 -0
- package/skills/security-auditor/SKILL.md +169 -0
- package/skills/security-compliance-compliance-check/SKILL.md +55 -0
- package/skills/security-compliance-compliance-check/resources/implementation-playbook.md +963 -0
- package/skills/security-requirement-extraction/SKILL.md +33 -0
- package/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
- package/skills/security-scanning-security-dependencies/SKILL.md +43 -0
- package/skills/security-scanning-security-dependencies/resources/implementation-playbook.md +544 -0
- package/skills/security-scanning-security-hardening/SKILL.md +147 -0
- package/skills/security-scanning-security-sast/SKILL.md +495 -0
- package/skills/seo-authority-builder/SKILL.md +136 -0
- package/skills/seo-cannibalization-detector/SKILL.md +123 -0
- package/skills/seo-content-auditor/SKILL.md +83 -0
- package/skills/seo-content-planner/SKILL.md +108 -0
- package/skills/seo-content-refresher/SKILL.md +118 -0
- package/skills/seo-content-writer/SKILL.md +96 -0
- package/skills/seo-keyword-strategist/SKILL.md +95 -0
- package/skills/seo-meta-optimizer/SKILL.md +92 -0
- package/skills/seo-snippet-hunter/SKILL.md +114 -0
- package/skills/seo-structure-architect/SKILL.md +108 -0
- package/skills/service-mesh-expert/SKILL.md +58 -0
- package/skills/service-mesh-observability/SKILL.md +395 -0
- package/skills/shellcheck-configuration/SKILL.md +466 -0
- package/skills/similarity-search-patterns/SKILL.md +33 -0
- package/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
- package/skills/slo-implementation/SKILL.md +341 -0
- package/skills/solidity-security/SKILL.md +34 -0
- package/skills/solidity-security/resources/implementation-playbook.md +524 -0
- package/skills/spark-optimization/SKILL.md +427 -0
- package/skills/sql-optimization-patterns/SKILL.md +35 -0
- package/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
- package/skills/sql-pro/SKILL.md +173 -0
- package/skills/startup-analyst/SKILL.md +328 -0
- package/skills/startup-business-analyst-business-case/SKILL.md +487 -0
- package/skills/startup-business-analyst-financial-projections/SKILL.md +353 -0
- package/skills/startup-business-analyst-market-opportunity/SKILL.md +240 -0
- package/skills/startup-financial-modeling/SKILL.md +467 -0
- package/skills/startup-metrics-framework/SKILL.md +34 -0
- package/skills/startup-metrics-framework/resources/implementation-playbook.md +500 -0
- package/skills/stride-analysis-patterns/SKILL.md +33 -0
- package/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
- package/skills/stripe-integration/SKILL.md +454 -0
- package/skills/systems-programming-rust-project/SKILL.md +440 -0
- package/skills/tailwind-design-system/SKILL.md +33 -0
- package/skills/tailwind-design-system/resources/implementation-playbook.md +665 -0
- package/skills/tdd-orchestrator/SKILL.md +205 -0
- package/skills/tdd-workflows-tdd-cycle/SKILL.md +221 -0
- package/skills/tdd-workflows-tdd-green/SKILL.md +73 -0
- package/skills/tdd-workflows-tdd-green/resources/implementation-playbook.md +870 -0
- package/skills/tdd-workflows-tdd-red/SKILL.md +164 -0
- package/skills/tdd-workflows-tdd-refactor/SKILL.md +187 -0
- package/skills/team-collaboration-issue/SKILL.md +37 -0
- package/skills/team-collaboration-issue/resources/implementation-playbook.md +640 -0
- package/skills/team-collaboration-standup-notes/SKILL.md +44 -0
- package/skills/team-collaboration-standup-notes/resources/implementation-playbook.md +768 -0
- package/skills/team-composition-analysis/SKILL.md +413 -0
- package/skills/temporal-python-pro/SKILL.md +370 -0
- package/skills/temporal-python-testing/SKILL.md +170 -0
- package/skills/temporal-python-testing/resources/integration-testing.md +455 -0
- package/skills/temporal-python-testing/resources/local-setup.md +553 -0
- package/skills/temporal-python-testing/resources/replay-testing.md +462 -0
- package/skills/temporal-python-testing/resources/unit-testing.md +328 -0
- package/skills/terraform-module-library/SKILL.md +261 -0
- package/skills/terraform-module-library/references/aws-modules.md +63 -0
- package/skills/terraform-specialist/SKILL.md +166 -0
- package/skills/test-automator/SKILL.md +224 -0
- package/skills/threat-mitigation-mapping/SKILL.md +33 -0
- package/skills/threat-mitigation-mapping/resources/implementation-playbook.md +744 -0
- package/skills/threat-modeling-expert/SKILL.md +60 -0
- package/skills/track-management/SKILL.md +38 -0
- package/skills/track-management/resources/implementation-playbook.md +591 -0
- package/skills/turborepo-caching/SKILL.md +419 -0
- package/skills/tutorial-engineer/SKILL.md +139 -0
- package/skills/typescript-advanced-types/SKILL.md +35 -0
- package/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
- package/skills/typescript-pro/SKILL.md +55 -0
- package/skills/ui-minimal/SKILL.md +23 -0
- package/skills/ui-ux-designer/SKILL.md +209 -0
- package/skills/ui-visual-validator/SKILL.md +214 -0
- package/skills/unit-testing-test-generate/SKILL.md +319 -0
- package/skills/unity-developer/SKILL.md +230 -0
- package/skills/unity-ecs-patterns/SKILL.md +33 -0
- package/skills/unity-ecs-patterns/resources/implementation-playbook.md +625 -0
- package/skills/uv-package-manager/SKILL.md +37 -0
- package/skills/uv-package-manager/resources/implementation-playbook.md +830 -0
- package/skills/vector-database-engineer/SKILL.md +60 -0
- package/skills/vector-index-tuning/SKILL.md +42 -0
- package/skills/vector-index-tuning/resources/implementation-playbook.md +507 -0
- package/skills/wcag-audit-patterns/SKILL.md +41 -0
- package/skills/wcag-audit-patterns/resources/implementation-playbook.md +541 -0
- package/skills/web3-testing/SKILL.md +427 -0
- package/skills/workflow-orchestration-patterns/SKILL.md +333 -0
- package/skills/workflow-patterns/SKILL.md +38 -0
- package/skills/workflow-patterns/resources/implementation-playbook.md +621 -0
|
@@ -0,0 +1,868 @@
|
|
|
1
|
+
# Python Performance Optimization Implementation Playbook
|
|
2
|
+
|
|
3
|
+
This file contains detailed patterns, checklists, and code samples referenced by the skill.
|
|
4
|
+
|
|
5
|
+
# Python Performance Optimization
|
|
6
|
+
|
|
7
|
+
Comprehensive guide to profiling, analyzing, and optimizing Python code for better performance, including CPU profiling, memory optimization, and implementation best practices.
|
|
8
|
+
|
|
9
|
+
## When to Use This Skill
|
|
10
|
+
|
|
11
|
+
- Identifying performance bottlenecks in Python applications
|
|
12
|
+
- Reducing application latency and response times
|
|
13
|
+
- Optimizing CPU-intensive operations
|
|
14
|
+
- Reducing memory consumption and memory leaks
|
|
15
|
+
- Improving database query performance
|
|
16
|
+
- Optimizing I/O operations
|
|
17
|
+
- Speeding up data processing pipelines
|
|
18
|
+
- Implementing high-performance algorithms
|
|
19
|
+
- Profiling production applications
|
|
20
|
+
|
|
21
|
+
## Core Concepts
|
|
22
|
+
|
|
23
|
+
### 1. Profiling Types
|
|
24
|
+
- **CPU Profiling**: Identify time-consuming functions
|
|
25
|
+
- **Memory Profiling**: Track memory allocation and leaks
|
|
26
|
+
- **Line Profiling**: Profile at line-by-line granularity
|
|
27
|
+
- **Call Graph**: Visualize function call relationships
|
|
28
|
+
|
|
29
|
+
### 2. Performance Metrics
|
|
30
|
+
- **Execution Time**: How long operations take
|
|
31
|
+
- **Memory Usage**: Peak and average memory consumption
|
|
32
|
+
- **CPU Utilization**: Processor usage patterns
|
|
33
|
+
- **I/O Wait**: Time spent on I/O operations
|
|
34
|
+
|
|
35
|
+
### 3. Optimization Strategies
|
|
36
|
+
- **Algorithmic**: Better algorithms and data structures
|
|
37
|
+
- **Implementation**: More efficient code patterns
|
|
38
|
+
- **Parallelization**: Multi-threading/processing
|
|
39
|
+
- **Caching**: Avoid redundant computation
|
|
40
|
+
- **Native Extensions**: C/Rust for critical paths
|
|
41
|
+
|
|
42
|
+
## Quick Start
|
|
43
|
+
|
|
44
|
+
### Basic Timing
|
|
45
|
+
|
|
46
|
+
```python
|
|
47
|
+
import time
|
|
48
|
+
|
|
49
|
+
def measure_time():
|
|
50
|
+
"""Simple timing measurement."""
|
|
51
|
+
start = time.time()
|
|
52
|
+
|
|
53
|
+
# Your code here
|
|
54
|
+
result = sum(range(1000000))
|
|
55
|
+
|
|
56
|
+
elapsed = time.time() - start
|
|
57
|
+
print(f"Execution time: {elapsed:.4f} seconds")
|
|
58
|
+
return result
|
|
59
|
+
|
|
60
|
+
# Better: use timeit for accurate measurements
|
|
61
|
+
import timeit
|
|
62
|
+
|
|
63
|
+
execution_time = timeit.timeit(
|
|
64
|
+
"sum(range(1000000))",
|
|
65
|
+
number=100
|
|
66
|
+
)
|
|
67
|
+
print(f"Average time: {execution_time/100:.6f} seconds")
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
## Profiling Tools
|
|
71
|
+
|
|
72
|
+
### Pattern 1: cProfile - CPU Profiling
|
|
73
|
+
|
|
74
|
+
```python
|
|
75
|
+
import cProfile
|
|
76
|
+
import pstats
|
|
77
|
+
from pstats import SortKey
|
|
78
|
+
|
|
79
|
+
def slow_function():
|
|
80
|
+
"""Function to profile."""
|
|
81
|
+
total = 0
|
|
82
|
+
for i in range(1000000):
|
|
83
|
+
total += i
|
|
84
|
+
return total
|
|
85
|
+
|
|
86
|
+
def another_function():
|
|
87
|
+
"""Another function."""
|
|
88
|
+
return [i**2 for i in range(100000)]
|
|
89
|
+
|
|
90
|
+
def main():
|
|
91
|
+
"""Main function to profile."""
|
|
92
|
+
result1 = slow_function()
|
|
93
|
+
result2 = another_function()
|
|
94
|
+
return result1, result2
|
|
95
|
+
|
|
96
|
+
# Profile the code
|
|
97
|
+
if __name__ == "__main__":
|
|
98
|
+
profiler = cProfile.Profile()
|
|
99
|
+
profiler.enable()
|
|
100
|
+
|
|
101
|
+
main()
|
|
102
|
+
|
|
103
|
+
profiler.disable()
|
|
104
|
+
|
|
105
|
+
# Print stats
|
|
106
|
+
stats = pstats.Stats(profiler)
|
|
107
|
+
stats.sort_stats(SortKey.CUMULATIVE)
|
|
108
|
+
stats.print_stats(10) # Top 10 functions
|
|
109
|
+
|
|
110
|
+
# Save to file for later analysis
|
|
111
|
+
stats.dump_stats("profile_output.prof")
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
**Command-line profiling:**
|
|
115
|
+
```bash
|
|
116
|
+
# Profile a script
|
|
117
|
+
python -m cProfile -o output.prof script.py
|
|
118
|
+
|
|
119
|
+
# View results
|
|
120
|
+
python -m pstats output.prof
|
|
121
|
+
# In pstats:
|
|
122
|
+
# sort cumtime
|
|
123
|
+
# stats 10
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
### Pattern 2: line_profiler - Line-by-Line Profiling
|
|
127
|
+
|
|
128
|
+
```python
|
|
129
|
+
# Install: pip install line-profiler
|
|
130
|
+
|
|
131
|
+
# Add @profile decorator (line_profiler provides this)
|
|
132
|
+
@profile
|
|
133
|
+
def process_data(data):
|
|
134
|
+
"""Process data with line profiling."""
|
|
135
|
+
result = []
|
|
136
|
+
for item in data:
|
|
137
|
+
processed = item * 2
|
|
138
|
+
result.append(processed)
|
|
139
|
+
return result
|
|
140
|
+
|
|
141
|
+
# Run with:
|
|
142
|
+
# kernprof -l -v script.py
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
**Manual line profiling:**
|
|
146
|
+
```python
|
|
147
|
+
from line_profiler import LineProfiler
|
|
148
|
+
|
|
149
|
+
def process_data(data):
|
|
150
|
+
"""Function to profile."""
|
|
151
|
+
result = []
|
|
152
|
+
for item in data:
|
|
153
|
+
processed = item * 2
|
|
154
|
+
result.append(processed)
|
|
155
|
+
return result
|
|
156
|
+
|
|
157
|
+
if __name__ == "__main__":
|
|
158
|
+
lp = LineProfiler()
|
|
159
|
+
lp.add_function(process_data)
|
|
160
|
+
|
|
161
|
+
data = list(range(100000))
|
|
162
|
+
|
|
163
|
+
lp_wrapper = lp(process_data)
|
|
164
|
+
lp_wrapper(data)
|
|
165
|
+
|
|
166
|
+
lp.print_stats()
|
|
167
|
+
```
|
|
168
|
+
|
|
169
|
+
### Pattern 3: memory_profiler - Memory Usage
|
|
170
|
+
|
|
171
|
+
```python
|
|
172
|
+
# Install: pip install memory-profiler
|
|
173
|
+
|
|
174
|
+
from memory_profiler import profile
|
|
175
|
+
|
|
176
|
+
@profile
|
|
177
|
+
def memory_intensive():
|
|
178
|
+
"""Function that uses lots of memory."""
|
|
179
|
+
# Create large list
|
|
180
|
+
big_list = [i for i in range(1000000)]
|
|
181
|
+
|
|
182
|
+
# Create large dict
|
|
183
|
+
big_dict = {i: i**2 for i in range(100000)}
|
|
184
|
+
|
|
185
|
+
# Process data
|
|
186
|
+
result = sum(big_list)
|
|
187
|
+
|
|
188
|
+
return result
|
|
189
|
+
|
|
190
|
+
if __name__ == "__main__":
|
|
191
|
+
memory_intensive()
|
|
192
|
+
|
|
193
|
+
# Run with:
|
|
194
|
+
# python -m memory_profiler script.py
|
|
195
|
+
```
|
|
196
|
+
|
|
197
|
+
### Pattern 4: py-spy - Production Profiling
|
|
198
|
+
|
|
199
|
+
```bash
|
|
200
|
+
# Install: pip install py-spy
|
|
201
|
+
|
|
202
|
+
# Profile a running Python process
|
|
203
|
+
py-spy top --pid 12345
|
|
204
|
+
|
|
205
|
+
# Generate flamegraph
|
|
206
|
+
py-spy record -o profile.svg --pid 12345
|
|
207
|
+
|
|
208
|
+
# Profile a script
|
|
209
|
+
py-spy record -o profile.svg -- python script.py
|
|
210
|
+
|
|
211
|
+
# Dump current call stack
|
|
212
|
+
py-spy dump --pid 12345
|
|
213
|
+
```
|
|
214
|
+
|
|
215
|
+
## Optimization Patterns
|
|
216
|
+
|
|
217
|
+
### Pattern 5: List Comprehensions vs Loops
|
|
218
|
+
|
|
219
|
+
```python
|
|
220
|
+
import timeit
|
|
221
|
+
|
|
222
|
+
# Slow: Traditional loop
|
|
223
|
+
def slow_squares(n):
|
|
224
|
+
"""Create list of squares using loop."""
|
|
225
|
+
result = []
|
|
226
|
+
for i in range(n):
|
|
227
|
+
result.append(i**2)
|
|
228
|
+
return result
|
|
229
|
+
|
|
230
|
+
# Fast: List comprehension
|
|
231
|
+
def fast_squares(n):
|
|
232
|
+
"""Create list of squares using comprehension."""
|
|
233
|
+
return [i**2 for i in range(n)]
|
|
234
|
+
|
|
235
|
+
# Benchmark
|
|
236
|
+
n = 100000
|
|
237
|
+
|
|
238
|
+
slow_time = timeit.timeit(lambda: slow_squares(n), number=100)
|
|
239
|
+
fast_time = timeit.timeit(lambda: fast_squares(n), number=100)
|
|
240
|
+
|
|
241
|
+
print(f"Loop: {slow_time:.4f}s")
|
|
242
|
+
print(f"Comprehension: {fast_time:.4f}s")
|
|
243
|
+
print(f"Speedup: {slow_time/fast_time:.2f}x")
|
|
244
|
+
|
|
245
|
+
# Even faster for simple operations: map
|
|
246
|
+
def faster_squares(n):
|
|
247
|
+
"""Use map for even better performance."""
|
|
248
|
+
return list(map(lambda x: x**2, range(n)))
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
### Pattern 6: Generator Expressions for Memory
|
|
252
|
+
|
|
253
|
+
```python
|
|
254
|
+
import sys
|
|
255
|
+
|
|
256
|
+
def list_approach():
|
|
257
|
+
"""Memory-intensive list."""
|
|
258
|
+
data = [i**2 for i in range(1000000)]
|
|
259
|
+
return sum(data)
|
|
260
|
+
|
|
261
|
+
def generator_approach():
|
|
262
|
+
"""Memory-efficient generator."""
|
|
263
|
+
data = (i**2 for i in range(1000000))
|
|
264
|
+
return sum(data)
|
|
265
|
+
|
|
266
|
+
# Memory comparison
|
|
267
|
+
list_data = [i for i in range(1000000)]
|
|
268
|
+
gen_data = (i for i in range(1000000))
|
|
269
|
+
|
|
270
|
+
print(f"List size: {sys.getsizeof(list_data)} bytes")
|
|
271
|
+
print(f"Generator size: {sys.getsizeof(gen_data)} bytes")
|
|
272
|
+
|
|
273
|
+
# Generators use constant memory regardless of size
|
|
274
|
+
```
|
|
275
|
+
|
|
276
|
+
### Pattern 7: String Concatenation
|
|
277
|
+
|
|
278
|
+
```python
|
|
279
|
+
import timeit
|
|
280
|
+
|
|
281
|
+
def slow_concat(items):
|
|
282
|
+
"""Slow string concatenation."""
|
|
283
|
+
result = ""
|
|
284
|
+
for item in items:
|
|
285
|
+
result += str(item)
|
|
286
|
+
return result
|
|
287
|
+
|
|
288
|
+
def fast_concat(items):
|
|
289
|
+
"""Fast string concatenation with join."""
|
|
290
|
+
return "".join(str(item) for item in items)
|
|
291
|
+
|
|
292
|
+
def faster_concat(items):
|
|
293
|
+
"""Even faster with list."""
|
|
294
|
+
parts = [str(item) for item in items]
|
|
295
|
+
return "".join(parts)
|
|
296
|
+
|
|
297
|
+
items = list(range(10000))
|
|
298
|
+
|
|
299
|
+
# Benchmark
|
|
300
|
+
slow = timeit.timeit(lambda: slow_concat(items), number=100)
|
|
301
|
+
fast = timeit.timeit(lambda: fast_concat(items), number=100)
|
|
302
|
+
faster = timeit.timeit(lambda: faster_concat(items), number=100)
|
|
303
|
+
|
|
304
|
+
print(f"Concatenation (+): {slow:.4f}s")
|
|
305
|
+
print(f"Join (generator): {fast:.4f}s")
|
|
306
|
+
print(f"Join (list): {faster:.4f}s")
|
|
307
|
+
```
|
|
308
|
+
|
|
309
|
+
### Pattern 8: Dictionary Lookups vs List Searches
|
|
310
|
+
|
|
311
|
+
```python
|
|
312
|
+
import timeit
|
|
313
|
+
|
|
314
|
+
# Create test data
|
|
315
|
+
size = 10000
|
|
316
|
+
items = list(range(size))
|
|
317
|
+
lookup_dict = {i: i for i in range(size)}
|
|
318
|
+
|
|
319
|
+
def list_search(items, target):
|
|
320
|
+
"""O(n) search in list."""
|
|
321
|
+
return target in items
|
|
322
|
+
|
|
323
|
+
def dict_search(lookup_dict, target):
|
|
324
|
+
"""O(1) search in dict."""
|
|
325
|
+
return target in lookup_dict
|
|
326
|
+
|
|
327
|
+
target = size - 1 # Worst case for list
|
|
328
|
+
|
|
329
|
+
# Benchmark
|
|
330
|
+
list_time = timeit.timeit(
|
|
331
|
+
lambda: list_search(items, target),
|
|
332
|
+
number=1000
|
|
333
|
+
)
|
|
334
|
+
dict_time = timeit.timeit(
|
|
335
|
+
lambda: dict_search(lookup_dict, target),
|
|
336
|
+
number=1000
|
|
337
|
+
)
|
|
338
|
+
|
|
339
|
+
print(f"List search: {list_time:.6f}s")
|
|
340
|
+
print(f"Dict search: {dict_time:.6f}s")
|
|
341
|
+
print(f"Speedup: {list_time/dict_time:.0f}x")
|
|
342
|
+
```
|
|
343
|
+
|
|
344
|
+
### Pattern 9: Local Variable Access
|
|
345
|
+
|
|
346
|
+
```python
|
|
347
|
+
import timeit
|
|
348
|
+
|
|
349
|
+
# Global variable (slow)
|
|
350
|
+
GLOBAL_VALUE = 100
|
|
351
|
+
|
|
352
|
+
def use_global():
|
|
353
|
+
"""Access global variable."""
|
|
354
|
+
total = 0
|
|
355
|
+
for i in range(10000):
|
|
356
|
+
total += GLOBAL_VALUE
|
|
357
|
+
return total
|
|
358
|
+
|
|
359
|
+
def use_local():
|
|
360
|
+
"""Use local variable."""
|
|
361
|
+
local_value = 100
|
|
362
|
+
total = 0
|
|
363
|
+
for i in range(10000):
|
|
364
|
+
total += local_value
|
|
365
|
+
return total
|
|
366
|
+
|
|
367
|
+
# Local is faster
|
|
368
|
+
global_time = timeit.timeit(use_global, number=1000)
|
|
369
|
+
local_time = timeit.timeit(use_local, number=1000)
|
|
370
|
+
|
|
371
|
+
print(f"Global access: {global_time:.4f}s")
|
|
372
|
+
print(f"Local access: {local_time:.4f}s")
|
|
373
|
+
print(f"Speedup: {global_time/local_time:.2f}x")
|
|
374
|
+
```
|
|
375
|
+
|
|
376
|
+
### Pattern 10: Function Call Overhead
|
|
377
|
+
|
|
378
|
+
```python
|
|
379
|
+
import timeit
|
|
380
|
+
|
|
381
|
+
def calculate_inline():
|
|
382
|
+
"""Inline calculation."""
|
|
383
|
+
total = 0
|
|
384
|
+
for i in range(10000):
|
|
385
|
+
total += i * 2 + 1
|
|
386
|
+
return total
|
|
387
|
+
|
|
388
|
+
def helper_function(x):
|
|
389
|
+
"""Helper function."""
|
|
390
|
+
return x * 2 + 1
|
|
391
|
+
|
|
392
|
+
def calculate_with_function():
|
|
393
|
+
"""Calculation with function calls."""
|
|
394
|
+
total = 0
|
|
395
|
+
for i in range(10000):
|
|
396
|
+
total += helper_function(i)
|
|
397
|
+
return total
|
|
398
|
+
|
|
399
|
+
# Inline is faster due to no call overhead
|
|
400
|
+
inline_time = timeit.timeit(calculate_inline, number=1000)
|
|
401
|
+
function_time = timeit.timeit(calculate_with_function, number=1000)
|
|
402
|
+
|
|
403
|
+
print(f"Inline: {inline_time:.4f}s")
|
|
404
|
+
print(f"Function calls: {function_time:.4f}s")
|
|
405
|
+
```
|
|
406
|
+
|
|
407
|
+
## Advanced Optimization
|
|
408
|
+
|
|
409
|
+
### Pattern 11: NumPy for Numerical Operations
|
|
410
|
+
|
|
411
|
+
```python
|
|
412
|
+
import timeit
|
|
413
|
+
import numpy as np
|
|
414
|
+
|
|
415
|
+
def python_sum(n):
|
|
416
|
+
"""Sum using pure Python."""
|
|
417
|
+
return sum(range(n))
|
|
418
|
+
|
|
419
|
+
def numpy_sum(n):
|
|
420
|
+
"""Sum using NumPy."""
|
|
421
|
+
return np.arange(n).sum()
|
|
422
|
+
|
|
423
|
+
n = 1000000
|
|
424
|
+
|
|
425
|
+
python_time = timeit.timeit(lambda: python_sum(n), number=100)
|
|
426
|
+
numpy_time = timeit.timeit(lambda: numpy_sum(n), number=100)
|
|
427
|
+
|
|
428
|
+
print(f"Python: {python_time:.4f}s")
|
|
429
|
+
print(f"NumPy: {numpy_time:.4f}s")
|
|
430
|
+
print(f"Speedup: {python_time/numpy_time:.2f}x")
|
|
431
|
+
|
|
432
|
+
# Vectorized operations
|
|
433
|
+
def python_multiply():
|
|
434
|
+
"""Element-wise multiplication in Python."""
|
|
435
|
+
a = list(range(100000))
|
|
436
|
+
b = list(range(100000))
|
|
437
|
+
return [x * y for x, y in zip(a, b)]
|
|
438
|
+
|
|
439
|
+
def numpy_multiply():
|
|
440
|
+
"""Vectorized multiplication in NumPy."""
|
|
441
|
+
a = np.arange(100000)
|
|
442
|
+
b = np.arange(100000)
|
|
443
|
+
return a * b
|
|
444
|
+
|
|
445
|
+
py_time = timeit.timeit(python_multiply, number=100)
|
|
446
|
+
np_time = timeit.timeit(numpy_multiply, number=100)
|
|
447
|
+
|
|
448
|
+
print(f"\nPython multiply: {py_time:.4f}s")
|
|
449
|
+
print(f"NumPy multiply: {np_time:.4f}s")
|
|
450
|
+
print(f"Speedup: {py_time/np_time:.2f}x")
|
|
451
|
+
```
|
|
452
|
+
|
|
453
|
+
### Pattern 12: Caching with functools.lru_cache
|
|
454
|
+
|
|
455
|
+
```python
|
|
456
|
+
from functools import lru_cache
|
|
457
|
+
import timeit
|
|
458
|
+
|
|
459
|
+
def fibonacci_slow(n):
|
|
460
|
+
"""Recursive fibonacci without caching."""
|
|
461
|
+
if n < 2:
|
|
462
|
+
return n
|
|
463
|
+
return fibonacci_slow(n-1) + fibonacci_slow(n-2)
|
|
464
|
+
|
|
465
|
+
@lru_cache(maxsize=None)
|
|
466
|
+
def fibonacci_fast(n):
|
|
467
|
+
"""Recursive fibonacci with caching."""
|
|
468
|
+
if n < 2:
|
|
469
|
+
return n
|
|
470
|
+
return fibonacci_fast(n-1) + fibonacci_fast(n-2)
|
|
471
|
+
|
|
472
|
+
# Massive speedup for recursive algorithms
|
|
473
|
+
n = 30
|
|
474
|
+
|
|
475
|
+
slow_time = timeit.timeit(lambda: fibonacci_slow(n), number=1)
|
|
476
|
+
fast_time = timeit.timeit(lambda: fibonacci_fast(n), number=1000)
|
|
477
|
+
|
|
478
|
+
print(f"Without cache (1 run): {slow_time:.4f}s")
|
|
479
|
+
print(f"With cache (1000 runs): {fast_time:.4f}s")
|
|
480
|
+
|
|
481
|
+
# Cache info
|
|
482
|
+
print(f"Cache info: {fibonacci_fast.cache_info()}")
|
|
483
|
+
```
|
|
484
|
+
|
|
485
|
+
### Pattern 13: Using __slots__ for Memory
|
|
486
|
+
|
|
487
|
+
```python
|
|
488
|
+
import sys
|
|
489
|
+
|
|
490
|
+
class RegularClass:
|
|
491
|
+
"""Regular class with __dict__."""
|
|
492
|
+
def __init__(self, x, y, z):
|
|
493
|
+
self.x = x
|
|
494
|
+
self.y = y
|
|
495
|
+
self.z = z
|
|
496
|
+
|
|
497
|
+
class SlottedClass:
|
|
498
|
+
"""Class with __slots__ for memory efficiency."""
|
|
499
|
+
__slots__ = ['x', 'y', 'z']
|
|
500
|
+
|
|
501
|
+
def __init__(self, x, y, z):
|
|
502
|
+
self.x = x
|
|
503
|
+
self.y = y
|
|
504
|
+
self.z = z
|
|
505
|
+
|
|
506
|
+
# Memory comparison
|
|
507
|
+
regular = RegularClass(1, 2, 3)
|
|
508
|
+
slotted = SlottedClass(1, 2, 3)
|
|
509
|
+
|
|
510
|
+
print(f"Regular class size: {sys.getsizeof(regular)} bytes")
|
|
511
|
+
print(f"Slotted class size: {sys.getsizeof(slotted)} bytes")
|
|
512
|
+
|
|
513
|
+
# Significant savings with many instances
|
|
514
|
+
regular_objects = [RegularClass(i, i+1, i+2) for i in range(10000)]
|
|
515
|
+
slotted_objects = [SlottedClass(i, i+1, i+2) for i in range(10000)]
|
|
516
|
+
|
|
517
|
+
print(f"\nMemory for 10000 regular objects: ~{sys.getsizeof(regular) * 10000} bytes")
|
|
518
|
+
print(f"Memory for 10000 slotted objects: ~{sys.getsizeof(slotted) * 10000} bytes")
|
|
519
|
+
```
|
|
520
|
+
|
|
521
|
+
### Pattern 14: Multiprocessing for CPU-Bound Tasks
|
|
522
|
+
|
|
523
|
+
```python
|
|
524
|
+
import multiprocessing as mp
|
|
525
|
+
import time
|
|
526
|
+
|
|
527
|
+
def cpu_intensive_task(n):
|
|
528
|
+
"""CPU-intensive calculation."""
|
|
529
|
+
return sum(i**2 for i in range(n))
|
|
530
|
+
|
|
531
|
+
def sequential_processing():
|
|
532
|
+
"""Process tasks sequentially."""
|
|
533
|
+
start = time.time()
|
|
534
|
+
results = [cpu_intensive_task(1000000) for _ in range(4)]
|
|
535
|
+
elapsed = time.time() - start
|
|
536
|
+
return elapsed, results
|
|
537
|
+
|
|
538
|
+
def parallel_processing():
|
|
539
|
+
"""Process tasks in parallel."""
|
|
540
|
+
start = time.time()
|
|
541
|
+
with mp.Pool(processes=4) as pool:
|
|
542
|
+
results = pool.map(cpu_intensive_task, [1000000] * 4)
|
|
543
|
+
elapsed = time.time() - start
|
|
544
|
+
return elapsed, results
|
|
545
|
+
|
|
546
|
+
if __name__ == "__main__":
|
|
547
|
+
seq_time, seq_results = sequential_processing()
|
|
548
|
+
par_time, par_results = parallel_processing()
|
|
549
|
+
|
|
550
|
+
print(f"Sequential: {seq_time:.2f}s")
|
|
551
|
+
print(f"Parallel: {par_time:.2f}s")
|
|
552
|
+
print(f"Speedup: {seq_time/par_time:.2f}x")
|
|
553
|
+
```
|
|
554
|
+
|
|
555
|
+
### Pattern 15: Async I/O for I/O-Bound Tasks
|
|
556
|
+
|
|
557
|
+
```python
|
|
558
|
+
import asyncio
|
|
559
|
+
import aiohttp
|
|
560
|
+
import time
|
|
561
|
+
import requests
|
|
562
|
+
|
|
563
|
+
urls = [
|
|
564
|
+
"https://httpbin.org/delay/1",
|
|
565
|
+
"https://httpbin.org/delay/1",
|
|
566
|
+
"https://httpbin.org/delay/1",
|
|
567
|
+
"https://httpbin.org/delay/1",
|
|
568
|
+
]
|
|
569
|
+
|
|
570
|
+
def synchronous_requests():
|
|
571
|
+
"""Synchronous HTTP requests."""
|
|
572
|
+
start = time.time()
|
|
573
|
+
results = []
|
|
574
|
+
for url in urls:
|
|
575
|
+
response = requests.get(url)
|
|
576
|
+
results.append(response.status_code)
|
|
577
|
+
elapsed = time.time() - start
|
|
578
|
+
return elapsed, results
|
|
579
|
+
|
|
580
|
+
async def async_fetch(session, url):
|
|
581
|
+
"""Async HTTP request."""
|
|
582
|
+
async with session.get(url) as response:
|
|
583
|
+
return response.status
|
|
584
|
+
|
|
585
|
+
async def asynchronous_requests():
|
|
586
|
+
"""Asynchronous HTTP requests."""
|
|
587
|
+
start = time.time()
|
|
588
|
+
async with aiohttp.ClientSession() as session:
|
|
589
|
+
tasks = [async_fetch(session, url) for url in urls]
|
|
590
|
+
results = await asyncio.gather(*tasks)
|
|
591
|
+
elapsed = time.time() - start
|
|
592
|
+
return elapsed, results
|
|
593
|
+
|
|
594
|
+
# Async is much faster for I/O-bound work
|
|
595
|
+
sync_time, sync_results = synchronous_requests()
|
|
596
|
+
async_time, async_results = asyncio.run(asynchronous_requests())
|
|
597
|
+
|
|
598
|
+
print(f"Synchronous: {sync_time:.2f}s")
|
|
599
|
+
print(f"Asynchronous: {async_time:.2f}s")
|
|
600
|
+
print(f"Speedup: {sync_time/async_time:.2f}x")
|
|
601
|
+
```
|
|
602
|
+
|
|
603
|
+
## Database Optimization
|
|
604
|
+
|
|
605
|
+
### Pattern 16: Batch Database Operations
|
|
606
|
+
|
|
607
|
+
```python
|
|
608
|
+
import sqlite3
|
|
609
|
+
import time
|
|
610
|
+
|
|
611
|
+
def create_db():
|
|
612
|
+
"""Create test database."""
|
|
613
|
+
conn = sqlite3.connect(":memory:")
|
|
614
|
+
conn.execute("CREATE TABLE users (id INTEGER PRIMARY KEY, name TEXT)")
|
|
615
|
+
return conn
|
|
616
|
+
|
|
617
|
+
def slow_inserts(conn, count):
|
|
618
|
+
"""Insert records one at a time."""
|
|
619
|
+
start = time.time()
|
|
620
|
+
cursor = conn.cursor()
|
|
621
|
+
for i in range(count):
|
|
622
|
+
cursor.execute("INSERT INTO users (name) VALUES (?)", (f"User {i}",))
|
|
623
|
+
conn.commit() # Commit each insert
|
|
624
|
+
elapsed = time.time() - start
|
|
625
|
+
return elapsed
|
|
626
|
+
|
|
627
|
+
def fast_inserts(conn, count):
|
|
628
|
+
"""Batch insert with single commit."""
|
|
629
|
+
start = time.time()
|
|
630
|
+
cursor = conn.cursor()
|
|
631
|
+
data = [(f"User {i}",) for i in range(count)]
|
|
632
|
+
cursor.executemany("INSERT INTO users (name) VALUES (?)", data)
|
|
633
|
+
conn.commit() # Single commit
|
|
634
|
+
elapsed = time.time() - start
|
|
635
|
+
return elapsed
|
|
636
|
+
|
|
637
|
+
# Benchmark
|
|
638
|
+
conn1 = create_db()
|
|
639
|
+
slow_time = slow_inserts(conn1, 1000)
|
|
640
|
+
|
|
641
|
+
conn2 = create_db()
|
|
642
|
+
fast_time = fast_inserts(conn2, 1000)
|
|
643
|
+
|
|
644
|
+
print(f"Individual inserts: {slow_time:.4f}s")
|
|
645
|
+
print(f"Batch insert: {fast_time:.4f}s")
|
|
646
|
+
print(f"Speedup: {slow_time/fast_time:.2f}x")
|
|
647
|
+
```
|
|
648
|
+
|
|
649
|
+
### Pattern 17: Query Optimization
|
|
650
|
+
|
|
651
|
+
```python
|
|
652
|
+
# Use indexes for frequently queried columns
|
|
653
|
+
"""
|
|
654
|
+
-- Slow: No index
|
|
655
|
+
SELECT * FROM users WHERE email = 'user@example.com';
|
|
656
|
+
|
|
657
|
+
-- Fast: With index
|
|
658
|
+
CREATE INDEX idx_users_email ON users(email);
|
|
659
|
+
SELECT * FROM users WHERE email = 'user@example.com';
|
|
660
|
+
"""
|
|
661
|
+
|
|
662
|
+
# Use query planning
|
|
663
|
+
import sqlite3
|
|
664
|
+
|
|
665
|
+
conn = sqlite3.connect("example.db")
|
|
666
|
+
cursor = conn.cursor()
|
|
667
|
+
|
|
668
|
+
# Analyze query performance
|
|
669
|
+
cursor.execute("EXPLAIN QUERY PLAN SELECT * FROM users WHERE email = ?", ("test@example.com",))
|
|
670
|
+
print(cursor.fetchall())
|
|
671
|
+
|
|
672
|
+
# Use SELECT only needed columns
|
|
673
|
+
# Slow: SELECT *
|
|
674
|
+
# Fast: SELECT id, name
|
|
675
|
+
```
|
|
676
|
+
|
|
677
|
+
## Memory Optimization
|
|
678
|
+
|
|
679
|
+
### Pattern 18: Detecting Memory Leaks
|
|
680
|
+
|
|
681
|
+
```python
|
|
682
|
+
import tracemalloc
|
|
683
|
+
import gc
|
|
684
|
+
|
|
685
|
+
def memory_leak_example():
|
|
686
|
+
"""Example that leaks memory."""
|
|
687
|
+
leaked_objects = []
|
|
688
|
+
|
|
689
|
+
for i in range(100000):
|
|
690
|
+
# Objects added but never removed
|
|
691
|
+
leaked_objects.append([i] * 100)
|
|
692
|
+
|
|
693
|
+
# In real code, this would be an unintended reference
|
|
694
|
+
|
|
695
|
+
def track_memory_usage():
|
|
696
|
+
"""Track memory allocations."""
|
|
697
|
+
tracemalloc.start()
|
|
698
|
+
|
|
699
|
+
# Take snapshot before
|
|
700
|
+
snapshot1 = tracemalloc.take_snapshot()
|
|
701
|
+
|
|
702
|
+
# Run code
|
|
703
|
+
memory_leak_example()
|
|
704
|
+
|
|
705
|
+
# Take snapshot after
|
|
706
|
+
snapshot2 = tracemalloc.take_snapshot()
|
|
707
|
+
|
|
708
|
+
# Compare
|
|
709
|
+
top_stats = snapshot2.compare_to(snapshot1, 'lineno')
|
|
710
|
+
|
|
711
|
+
print("Top 10 memory allocations:")
|
|
712
|
+
for stat in top_stats[:10]:
|
|
713
|
+
print(stat)
|
|
714
|
+
|
|
715
|
+
tracemalloc.stop()
|
|
716
|
+
|
|
717
|
+
# Monitor memory
|
|
718
|
+
track_memory_usage()
|
|
719
|
+
|
|
720
|
+
# Force garbage collection
|
|
721
|
+
gc.collect()
|
|
722
|
+
```
|
|
723
|
+
|
|
724
|
+
### Pattern 19: Iterators vs Lists
|
|
725
|
+
|
|
726
|
+
```python
|
|
727
|
+
import sys
|
|
728
|
+
|
|
729
|
+
def process_file_list(filename):
|
|
730
|
+
"""Load entire file into memory."""
|
|
731
|
+
with open(filename) as f:
|
|
732
|
+
lines = f.readlines() # Loads all lines
|
|
733
|
+
return sum(1 for line in lines if line.strip())
|
|
734
|
+
|
|
735
|
+
def process_file_iterator(filename):
|
|
736
|
+
"""Process file line by line."""
|
|
737
|
+
with open(filename) as f:
|
|
738
|
+
return sum(1 for line in f if line.strip())
|
|
739
|
+
|
|
740
|
+
# Iterator uses constant memory
|
|
741
|
+
# List loads entire file into memory
|
|
742
|
+
```
|
|
743
|
+
|
|
744
|
+
### Pattern 20: Weakref for Caches
|
|
745
|
+
|
|
746
|
+
```python
|
|
747
|
+
import weakref
|
|
748
|
+
|
|
749
|
+
class CachedResource:
|
|
750
|
+
"""Resource that can be garbage collected."""
|
|
751
|
+
def __init__(self, data):
|
|
752
|
+
self.data = data
|
|
753
|
+
|
|
754
|
+
# Regular cache prevents garbage collection
|
|
755
|
+
regular_cache = {}
|
|
756
|
+
|
|
757
|
+
def get_resource_regular(key):
|
|
758
|
+
"""Get resource from regular cache."""
|
|
759
|
+
if key not in regular_cache:
|
|
760
|
+
regular_cache[key] = CachedResource(f"Data for {key}")
|
|
761
|
+
return regular_cache[key]
|
|
762
|
+
|
|
763
|
+
# Weak reference cache allows garbage collection
|
|
764
|
+
weak_cache = weakref.WeakValueDictionary()
|
|
765
|
+
|
|
766
|
+
def get_resource_weak(key):
|
|
767
|
+
"""Get resource from weak cache."""
|
|
768
|
+
resource = weak_cache.get(key)
|
|
769
|
+
if resource is None:
|
|
770
|
+
resource = CachedResource(f"Data for {key}")
|
|
771
|
+
weak_cache[key] = resource
|
|
772
|
+
return resource
|
|
773
|
+
|
|
774
|
+
# When no strong references exist, objects can be GC'd
|
|
775
|
+
```
|
|
776
|
+
|
|
777
|
+
## Benchmarking Tools
|
|
778
|
+
|
|
779
|
+
### Custom Benchmark Decorator
|
|
780
|
+
|
|
781
|
+
```python
|
|
782
|
+
import time
|
|
783
|
+
from functools import wraps
|
|
784
|
+
|
|
785
|
+
def benchmark(func):
|
|
786
|
+
"""Decorator to benchmark function execution."""
|
|
787
|
+
@wraps(func)
|
|
788
|
+
def wrapper(*args, **kwargs):
|
|
789
|
+
start = time.perf_counter()
|
|
790
|
+
result = func(*args, **kwargs)
|
|
791
|
+
elapsed = time.perf_counter() - start
|
|
792
|
+
print(f"{func.__name__} took {elapsed:.6f} seconds")
|
|
793
|
+
return result
|
|
794
|
+
return wrapper
|
|
795
|
+
|
|
796
|
+
@benchmark
|
|
797
|
+
def slow_function():
|
|
798
|
+
"""Function to benchmark."""
|
|
799
|
+
time.sleep(0.5)
|
|
800
|
+
return sum(range(1000000))
|
|
801
|
+
|
|
802
|
+
result = slow_function()
|
|
803
|
+
```
|
|
804
|
+
|
|
805
|
+
### Performance Testing with pytest-benchmark
|
|
806
|
+
|
|
807
|
+
```python
|
|
808
|
+
# Install: pip install pytest-benchmark
|
|
809
|
+
|
|
810
|
+
def test_list_comprehension(benchmark):
|
|
811
|
+
"""Benchmark list comprehension."""
|
|
812
|
+
result = benchmark(lambda: [i**2 for i in range(10000)])
|
|
813
|
+
assert len(result) == 10000
|
|
814
|
+
|
|
815
|
+
def test_map_function(benchmark):
|
|
816
|
+
"""Benchmark map function."""
|
|
817
|
+
result = benchmark(lambda: list(map(lambda x: x**2, range(10000))))
|
|
818
|
+
assert len(result) == 10000
|
|
819
|
+
|
|
820
|
+
# Run with: pytest test_performance.py --benchmark-compare
|
|
821
|
+
```
|
|
822
|
+
|
|
823
|
+
## Best Practices
|
|
824
|
+
|
|
825
|
+
1. **Profile before optimizing** - Measure to find real bottlenecks
|
|
826
|
+
2. **Focus on hot paths** - Optimize code that runs most frequently
|
|
827
|
+
3. **Use appropriate data structures** - Dict for lookups, set for membership
|
|
828
|
+
4. **Avoid premature optimization** - Clarity first, then optimize
|
|
829
|
+
5. **Use built-in functions** - They're implemented in C
|
|
830
|
+
6. **Cache expensive computations** - Use lru_cache
|
|
831
|
+
7. **Batch I/O operations** - Reduce system calls
|
|
832
|
+
8. **Use generators** for large datasets
|
|
833
|
+
9. **Consider NumPy** for numerical operations
|
|
834
|
+
10. **Profile production code** - Use py-spy for live systems
|
|
835
|
+
|
|
836
|
+
## Common Pitfalls
|
|
837
|
+
|
|
838
|
+
- Optimizing without profiling
|
|
839
|
+
- Using global variables unnecessarily
|
|
840
|
+
- Not using appropriate data structures
|
|
841
|
+
- Creating unnecessary copies of data
|
|
842
|
+
- Not using connection pooling for databases
|
|
843
|
+
- Ignoring algorithmic complexity
|
|
844
|
+
- Over-optimizing rare code paths
|
|
845
|
+
- Not considering memory usage
|
|
846
|
+
|
|
847
|
+
## Resources
|
|
848
|
+
|
|
849
|
+
- **cProfile**: Built-in CPU profiler
|
|
850
|
+
- **memory_profiler**: Memory usage profiling
|
|
851
|
+
- **line_profiler**: Line-by-line profiling
|
|
852
|
+
- **py-spy**: Sampling profiler for production
|
|
853
|
+
- **NumPy**: High-performance numerical computing
|
|
854
|
+
- **Cython**: Compile Python to C
|
|
855
|
+
- **PyPy**: Alternative Python interpreter with JIT
|
|
856
|
+
|
|
857
|
+
## Performance Checklist
|
|
858
|
+
|
|
859
|
+
- [ ] Profiled code to identify bottlenecks
|
|
860
|
+
- [ ] Used appropriate data structures
|
|
861
|
+
- [ ] Implemented caching where beneficial
|
|
862
|
+
- [ ] Optimized database queries
|
|
863
|
+
- [ ] Used generators for large datasets
|
|
864
|
+
- [ ] Considered multiprocessing for CPU-bound tasks
|
|
865
|
+
- [ ] Used async I/O for I/O-bound tasks
|
|
866
|
+
- [ ] Minimized function call overhead in hot loops
|
|
867
|
+
- [ ] Checked for memory leaks
|
|
868
|
+
- [ ] Benchmarked before and after optimization
|