@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.
Files changed (462) hide show
  1. package/CATALOG.md +317 -0
  2. package/README.md +121 -0
  3. package/aliases.json +65 -0
  4. package/bin/vibe.js +2 -0
  5. package/bundles.json +265 -0
  6. package/catalog.json +1560 -0
  7. package/dist/antigravity-skills/bin/cli.js +438 -0
  8. package/dist/antigravity-skills/lib/skill-utils.js +158 -0
  9. package/dist/antigravity-skills/scripts/build-catalog.js +305 -0
  10. package/dist/antigravity-skills/scripts/normalize-frontmatter.js +144 -0
  11. package/dist/antigravity-skills/scripts/validate-skills.js +230 -0
  12. package/dist/bin/vibe.js +2 -0
  13. package/dist/dist/src/cli/index.js +26 -0
  14. package/dist/lib/skill-utils.js +158 -0
  15. package/dist/scripts/build-catalog.js +50 -0
  16. package/dist/scripts/normalize-frontmatter.js +144 -0
  17. package/dist/scripts/validate-skills.js +56 -0
  18. package/dist/src/cli/index.js +146 -0
  19. package/dist/src/types/index.js +13 -0
  20. package/dist/src/utils/fs.js +1 -0
  21. package/package.json +43 -0
  22. package/skills/accessibility-compliance-accessibility-audit/SKILL.md +42 -0
  23. package/skills/accessibility-compliance-accessibility-audit/resources/implementation-playbook.md +502 -0
  24. package/skills/agent-orchestration-improve-agent/SKILL.md +349 -0
  25. package/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
  26. package/skills/agent-orchestrator/SKILL.md +24 -0
  27. package/skills/ai-engineer/SKILL.md +171 -0
  28. package/skills/airflow-dag-patterns/SKILL.md +41 -0
  29. package/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
  30. package/skills/angular-migration/SKILL.md +428 -0
  31. package/skills/anti-reversing-techniques/SKILL.md +42 -0
  32. package/skills/anti-reversing-techniques/resources/implementation-playbook.md +539 -0
  33. package/skills/api-design-principles/SKILL.md +37 -0
  34. package/skills/api-design-principles/assets/api-design-checklist.md +155 -0
  35. package/skills/api-design-principles/assets/rest-api-template.py +182 -0
  36. package/skills/api-design-principles/references/graphql-schema-design.md +583 -0
  37. package/skills/api-design-principles/references/rest-best-practices.md +408 -0
  38. package/skills/api-design-principles/resources/implementation-playbook.md +513 -0
  39. package/skills/api-documenter/SKILL.md +184 -0
  40. package/skills/api-testing-observability-api-mock/SKILL.md +46 -0
  41. package/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
  42. package/skills/application-performance-performance-optimization/SKILL.md +154 -0
  43. package/skills/architect-review/SKILL.md +174 -0
  44. package/skills/architecture-decision-records/SKILL.md +441 -0
  45. package/skills/architecture-patterns/SKILL.md +37 -0
  46. package/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
  47. package/skills/arm-cortex-expert/SKILL.md +306 -0
  48. package/skills/async-python-patterns/SKILL.md +39 -0
  49. package/skills/async-python-patterns/resources/implementation-playbook.md +678 -0
  50. package/skills/attack-tree-construction/SKILL.md +38 -0
  51. package/skills/attack-tree-construction/resources/implementation-playbook.md +671 -0
  52. package/skills/auth-implementation-patterns/SKILL.md +39 -0
  53. package/skills/auth-implementation-patterns/resources/implementation-playbook.md +618 -0
  54. package/skills/backend-architect/SKILL.md +333 -0
  55. package/skills/backend-development-feature-development/SKILL.md +180 -0
  56. package/skills/backend-security-coder/SKILL.md +156 -0
  57. package/skills/backtesting-frameworks/SKILL.md +39 -0
  58. package/skills/backtesting-frameworks/resources/implementation-playbook.md +647 -0
  59. package/skills/bash-defensive-patterns/SKILL.md +43 -0
  60. package/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
  61. package/skills/bash-pro/SKILL.md +310 -0
  62. package/skills/bats-testing-patterns/SKILL.md +34 -0
  63. package/skills/bats-testing-patterns/resources/implementation-playbook.md +614 -0
  64. package/skills/bazel-build-optimization/SKILL.md +397 -0
  65. package/skills/billing-automation/SKILL.md +42 -0
  66. package/skills/billing-automation/resources/implementation-playbook.md +544 -0
  67. package/skills/binary-analysis-patterns/SKILL.md +450 -0
  68. package/skills/blockchain-developer/SKILL.md +208 -0
  69. package/skills/business-analyst/SKILL.md +182 -0
  70. package/skills/c-pro/SKILL.md +56 -0
  71. package/skills/c4-architecture-c4-architecture/SKILL.md +389 -0
  72. package/skills/c4-code/SKILL.md +244 -0
  73. package/skills/c4-component/SKILL.md +153 -0
  74. package/skills/c4-container/SKILL.md +171 -0
  75. package/skills/c4-context/SKILL.md +150 -0
  76. package/skills/changelog-automation/SKILL.md +38 -0
  77. package/skills/changelog-automation/resources/implementation-playbook.md +538 -0
  78. package/skills/cicd-automation-workflow-automate/SKILL.md +51 -0
  79. package/skills/cicd-automation-workflow-automate/resources/implementation-playbook.md +1333 -0
  80. package/skills/clean-markdown/SKILL.md +23 -0
  81. package/skills/cloud-architect/SKILL.md +135 -0
  82. package/skills/code-documentation-code-explain/SKILL.md +46 -0
  83. package/skills/code-documentation-code-explain/resources/implementation-playbook.md +802 -0
  84. package/skills/code-documentation-doc-generate/SKILL.md +48 -0
  85. package/skills/code-documentation-doc-generate/resources/implementation-playbook.md +640 -0
  86. package/skills/code-refactoring-context-restore/SKILL.md +179 -0
  87. package/skills/code-refactoring-refactor-clean/SKILL.md +51 -0
  88. package/skills/code-refactoring-refactor-clean/resources/implementation-playbook.md +879 -0
  89. package/skills/code-refactoring-tech-debt/SKILL.md +386 -0
  90. package/skills/code-review-ai-ai-review/SKILL.md +450 -0
  91. package/skills/code-review-excellence/SKILL.md +40 -0
  92. package/skills/code-review-excellence/resources/implementation-playbook.md +515 -0
  93. package/skills/code-reviewer/SKILL.md +178 -0
  94. package/skills/codebase-cleanup-deps-audit/SKILL.md +51 -0
  95. package/skills/codebase-cleanup-deps-audit/resources/implementation-playbook.md +766 -0
  96. package/skills/codebase-cleanup-refactor-clean/SKILL.md +51 -0
  97. package/skills/codebase-cleanup-refactor-clean/resources/implementation-playbook.md +879 -0
  98. package/skills/codebase-cleanup-tech-debt/SKILL.md +386 -0
  99. package/skills/competitive-landscape/SKILL.md +34 -0
  100. package/skills/competitive-landscape/resources/implementation-playbook.md +494 -0
  101. package/skills/comprehensive-review-full-review/SKILL.md +146 -0
  102. package/skills/comprehensive-review-pr-enhance/SKILL.md +46 -0
  103. package/skills/comprehensive-review-pr-enhance/resources/implementation-playbook.md +691 -0
  104. package/skills/conductor-implement/SKILL.md +388 -0
  105. package/skills/conductor-manage/SKILL.md +39 -0
  106. package/skills/conductor-manage/resources/implementation-playbook.md +1120 -0
  107. package/skills/conductor-new-track/SKILL.md +433 -0
  108. package/skills/conductor-revert/SKILL.md +372 -0
  109. package/skills/conductor-setup/SKILL.md +426 -0
  110. package/skills/conductor-status/SKILL.md +338 -0
  111. package/skills/conductor-validator/SKILL.md +62 -0
  112. package/skills/content-marketer/SKILL.md +170 -0
  113. package/skills/context-driven-development/SKILL.md +400 -0
  114. package/skills/context-management-context-restore/SKILL.md +179 -0
  115. package/skills/context-management-context-save/SKILL.md +177 -0
  116. package/skills/context-manager/SKILL.md +185 -0
  117. package/skills/cost-optimization/SKILL.md +286 -0
  118. package/skills/cpp-pro/SKILL.md +59 -0
  119. package/skills/cqrs-implementation/SKILL.md +35 -0
  120. package/skills/cqrs-implementation/resources/implementation-playbook.md +540 -0
  121. package/skills/csharp-pro/SKILL.md +59 -0
  122. package/skills/customer-support/SKILL.md +170 -0
  123. package/skills/data-engineer/SKILL.md +224 -0
  124. package/skills/data-engineering-data-driven-feature/SKILL.md +182 -0
  125. package/skills/data-engineering-data-pipeline/SKILL.md +201 -0
  126. package/skills/data-quality-frameworks/SKILL.md +40 -0
  127. package/skills/data-quality-frameworks/resources/implementation-playbook.md +573 -0
  128. package/skills/data-scientist/SKILL.md +199 -0
  129. package/skills/data-storytelling/SKILL.md +465 -0
  130. package/skills/database-admin/SKILL.md +165 -0
  131. package/skills/database-architect/SKILL.md +268 -0
  132. package/skills/database-cloud-optimization-cost-optimize/SKILL.md +44 -0
  133. package/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
  134. package/skills/database-migration/SKILL.md +436 -0
  135. package/skills/database-migrations-migration-observability/SKILL.md +420 -0
  136. package/skills/database-migrations-sql-migrations/SKILL.md +53 -0
  137. package/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
  138. package/skills/database-optimizer/SKILL.md +167 -0
  139. package/skills/dbt-transformation-patterns/SKILL.md +34 -0
  140. package/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
  141. package/skills/debugger/SKILL.md +49 -0
  142. package/skills/debugging-strategies/SKILL.md +34 -0
  143. package/skills/debugging-strategies/resources/implementation-playbook.md +511 -0
  144. package/skills/debugging-toolkit-smart-debug/SKILL.md +197 -0
  145. package/skills/defi-protocol-templates/SKILL.md +466 -0
  146. package/skills/dependency-management-deps-audit/SKILL.md +44 -0
  147. package/skills/dependency-management-deps-audit/resources/implementation-playbook.md +766 -0
  148. package/skills/dependency-upgrade/SKILL.md +421 -0
  149. package/skills/deployment-engineer/SKILL.md +170 -0
  150. package/skills/deployment-pipeline-design/SKILL.md +371 -0
  151. package/skills/deployment-validation-config-validate/SKILL.md +496 -0
  152. package/skills/devops-troubleshooter/SKILL.md +161 -0
  153. package/skills/distributed-debugging-debug-trace/SKILL.md +44 -0
  154. package/skills/distributed-debugging-debug-trace/resources/implementation-playbook.md +1307 -0
  155. package/skills/distributed-tracing/SKILL.md +450 -0
  156. package/skills/django-pro/SKILL.md +180 -0
  157. package/skills/docs-architect/SKILL.md +98 -0
  158. package/skills/documentation-generation-doc-generate/SKILL.md +48 -0
  159. package/skills/documentation-generation-doc-generate/resources/implementation-playbook.md +640 -0
  160. package/skills/dotnet-architect/SKILL.md +197 -0
  161. package/skills/dotnet-backend-patterns/SKILL.md +37 -0
  162. package/skills/dotnet-backend-patterns/assets/repository-template.cs +523 -0
  163. package/skills/dotnet-backend-patterns/assets/service-template.cs +336 -0
  164. package/skills/dotnet-backend-patterns/references/dapper-patterns.md +544 -0
  165. package/skills/dotnet-backend-patterns/references/ef-core-best-practices.md +355 -0
  166. package/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
  167. package/skills/dummy-skill/SKILL.md +5 -0
  168. package/skills/dx-optimizer/SKILL.md +83 -0
  169. package/skills/e2e-testing-patterns/SKILL.md +41 -0
  170. package/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
  171. package/skills/elixir-pro/SKILL.md +59 -0
  172. package/skills/embedding-strategies/SKILL.md +491 -0
  173. package/skills/employment-contract-templates/SKILL.md +39 -0
  174. package/skills/employment-contract-templates/resources/implementation-playbook.md +493 -0
  175. package/skills/error-debugging-error-analysis/SKILL.md +47 -0
  176. package/skills/error-debugging-error-analysis/resources/implementation-playbook.md +1143 -0
  177. package/skills/error-debugging-error-trace/SKILL.md +43 -0
  178. package/skills/error-debugging-error-trace/resources/implementation-playbook.md +1361 -0
  179. package/skills/error-debugging-multi-agent-review/SKILL.md +216 -0
  180. package/skills/error-detective/SKILL.md +53 -0
  181. package/skills/error-diagnostics-error-analysis/SKILL.md +47 -0
  182. package/skills/error-diagnostics-error-analysis/resources/implementation-playbook.md +1143 -0
  183. package/skills/error-diagnostics-error-trace/SKILL.md +48 -0
  184. package/skills/error-diagnostics-error-trace/resources/implementation-playbook.md +1371 -0
  185. package/skills/error-diagnostics-smart-debug/SKILL.md +197 -0
  186. package/skills/error-handling-patterns/SKILL.md +35 -0
  187. package/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
  188. package/skills/event-sourcing-architect/SKILL.md +58 -0
  189. package/skills/event-store-design/SKILL.md +449 -0
  190. package/skills/fastapi-pro/SKILL.md +192 -0
  191. package/skills/fastapi-templates/SKILL.md +32 -0
  192. package/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
  193. package/skills/final-test/SKILL.md +5 -0
  194. package/skills/firmware-analyst/SKILL.md +320 -0
  195. package/skills/flutter-expert/SKILL.md +200 -0
  196. package/skills/framework-migration-code-migrate/SKILL.md +48 -0
  197. package/skills/framework-migration-code-migrate/resources/implementation-playbook.md +1052 -0
  198. package/skills/framework-migration-deps-upgrade/SKILL.md +48 -0
  199. package/skills/framework-migration-deps-upgrade/resources/implementation-playbook.md +755 -0
  200. package/skills/framework-migration-legacy-modernize/SKILL.md +132 -0
  201. package/skills/frontend-developer/SKILL.md +171 -0
  202. package/skills/frontend-mobile-development-component-scaffold/SKILL.md +403 -0
  203. package/skills/frontend-mobile-security-xss-scan/SKILL.md +322 -0
  204. package/skills/frontend-security-coder/SKILL.md +170 -0
  205. package/skills/full-stack-orchestration-full-stack-feature/SKILL.md +135 -0
  206. package/skills/gdpr-data-handling/SKILL.md +33 -0
  207. package/skills/gdpr-data-handling/resources/implementation-playbook.md +615 -0
  208. package/skills/git-advanced-workflows/SKILL.md +412 -0
  209. package/skills/git-pr-workflows-git-workflow/SKILL.md +140 -0
  210. package/skills/git-pr-workflows-onboard/SKILL.md +416 -0
  211. package/skills/git-pr-workflows-pr-enhance/SKILL.md +48 -0
  212. package/skills/git-pr-workflows-pr-enhance/resources/implementation-playbook.md +701 -0
  213. package/skills/github-actions-templates/SKILL.md +345 -0
  214. package/skills/gitlab-ci-patterns/SKILL.md +283 -0
  215. package/skills/gitops-workflow/SKILL.md +303 -0
  216. package/skills/gitops-workflow/references/argocd-setup.md +134 -0
  217. package/skills/gitops-workflow/references/sync-policies.md +131 -0
  218. package/skills/go-concurrency-patterns/SKILL.md +33 -0
  219. package/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
  220. package/skills/godot-gdscript-patterns/SKILL.md +33 -0
  221. package/skills/godot-gdscript-patterns/resources/implementation-playbook.md +804 -0
  222. package/skills/golang-pro/SKILL.md +179 -0
  223. package/skills/grafana-dashboards/SKILL.md +381 -0
  224. package/skills/graphql-architect/SKILL.md +182 -0
  225. package/skills/haskell-pro/SKILL.md +56 -0
  226. package/skills/helm-chart-scaffolding/SKILL.md +34 -0
  227. package/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
  228. package/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
  229. package/skills/helm-chart-scaffolding/references/chart-structure.md +500 -0
  230. package/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
  231. package/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
  232. package/skills/hr-pro/SKILL.md +126 -0
  233. package/skills/hybrid-cloud-architect/SKILL.md +168 -0
  234. package/skills/hybrid-cloud-networking/SKILL.md +238 -0
  235. package/skills/hybrid-search-implementation/SKILL.md +32 -0
  236. package/skills/hybrid-search-implementation/resources/implementation-playbook.md +567 -0
  237. package/skills/incident-responder/SKILL.md +213 -0
  238. package/skills/incident-response-incident-response/SKILL.md +168 -0
  239. package/skills/incident-response-smart-fix/SKILL.md +29 -0
  240. package/skills/incident-response-smart-fix/resources/implementation-playbook.md +838 -0
  241. package/skills/incident-runbook-templates/SKILL.md +395 -0
  242. package/skills/ios-developer/SKILL.md +219 -0
  243. package/skills/istio-traffic-management/SKILL.md +337 -0
  244. package/skills/java-pro/SKILL.md +177 -0
  245. package/skills/javascript-pro/SKILL.md +57 -0
  246. package/skills/javascript-testing-patterns/SKILL.md +35 -0
  247. package/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
  248. package/skills/javascript-typescript-typescript-scaffold/SKILL.md +361 -0
  249. package/skills/julia-pro/SKILL.md +209 -0
  250. package/skills/k8s-manifest-generator/SKILL.md +35 -0
  251. package/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
  252. package/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
  253. package/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
  254. package/skills/k8s-manifest-generator/references/deployment-spec.md +753 -0
  255. package/skills/k8s-manifest-generator/references/service-spec.md +724 -0
  256. package/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
  257. package/skills/k8s-security-policies/SKILL.md +346 -0
  258. package/skills/k8s-security-policies/assets/network-policy-template.yaml +177 -0
  259. package/skills/k8s-security-policies/references/rbac-patterns.md +187 -0
  260. package/skills/kpi-dashboard-design/SKILL.md +440 -0
  261. package/skills/kubernetes-architect/SKILL.md +170 -0
  262. package/skills/langchain-architecture/SKILL.md +350 -0
  263. package/skills/legacy-modernizer/SKILL.md +53 -0
  264. package/skills/legal-advisor/SKILL.md +70 -0
  265. package/skills/linkerd-patterns/SKILL.md +321 -0
  266. package/skills/llm-application-dev-ai-assistant/SKILL.md +35 -0
  267. package/skills/llm-application-dev-ai-assistant/resources/implementation-playbook.md +1236 -0
  268. package/skills/llm-application-dev-langchain-agent/SKILL.md +246 -0
  269. package/skills/llm-application-dev-prompt-optimize/SKILL.md +37 -0
  270. package/skills/llm-application-dev-prompt-optimize/resources/implementation-playbook.md +591 -0
  271. package/skills/llm-evaluation/SKILL.md +483 -0
  272. package/skills/machine-learning-ops-ml-pipeline/SKILL.md +314 -0
  273. package/skills/malware-analyst/SKILL.md +247 -0
  274. package/skills/market-sizing-analysis/SKILL.md +425 -0
  275. package/skills/market-sizing-analysis/examples/saas-market-sizing.md +349 -0
  276. package/skills/market-sizing-analysis/references/data-sources.md +360 -0
  277. package/skills/memory-forensics/SKILL.md +491 -0
  278. package/skills/memory-safety-patterns/SKILL.md +33 -0
  279. package/skills/memory-safety-patterns/resources/implementation-playbook.md +603 -0
  280. package/skills/mermaid-expert/SKILL.md +59 -0
  281. package/skills/microservices-patterns/SKILL.md +35 -0
  282. package/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
  283. package/skills/minecraft-bukkit-pro/SKILL.md +126 -0
  284. package/skills/ml-engineer/SKILL.md +168 -0
  285. package/skills/ml-pipeline-workflow/SKILL.md +257 -0
  286. package/skills/mlops-engineer/SKILL.md +219 -0
  287. package/skills/mobile-developer/SKILL.md +205 -0
  288. package/skills/mobile-security-coder/SKILL.md +184 -0
  289. package/skills/modern-javascript-patterns/SKILL.md +35 -0
  290. package/skills/modern-javascript-patterns/resources/implementation-playbook.md +910 -0
  291. package/skills/monorepo-architect/SKILL.md +61 -0
  292. package/skills/monorepo-management/SKILL.md +35 -0
  293. package/skills/monorepo-management/resources/implementation-playbook.md +621 -0
  294. package/skills/mtls-configuration/SKILL.md +359 -0
  295. package/skills/multi-cloud-architecture/SKILL.md +189 -0
  296. package/skills/multi-platform-apps-multi-platform/SKILL.md +203 -0
  297. package/skills/network-engineer/SKILL.md +169 -0
  298. package/skills/nextjs-app-router-patterns/SKILL.md +33 -0
  299. package/skills/nextjs-app-router-patterns/resources/implementation-playbook.md +543 -0
  300. package/skills/nft-standards/SKILL.md +395 -0
  301. package/skills/node-expert/SKILL.md +23 -0
  302. package/skills/nodejs-backend-patterns/SKILL.md +35 -0
  303. package/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
  304. package/skills/nx-workspace-patterns/SKILL.md +464 -0
  305. package/skills/observability-engineer/SKILL.md +237 -0
  306. package/skills/observability-monitoring-monitor-setup/SKILL.md +48 -0
  307. package/skills/observability-monitoring-monitor-setup/resources/implementation-playbook.md +505 -0
  308. package/skills/observability-monitoring-slo-implement/SKILL.md +43 -0
  309. package/skills/observability-monitoring-slo-implement/resources/implementation-playbook.md +1077 -0
  310. package/skills/on-call-handoff-patterns/SKILL.md +453 -0
  311. package/skills/openapi-spec-generation/SKILL.md +33 -0
  312. package/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
  313. package/skills/payment-integration/SKILL.md +77 -0
  314. package/skills/paypal-integration/SKILL.md +479 -0
  315. package/skills/pci-compliance/SKILL.md +478 -0
  316. package/skills/performance-engineer/SKILL.md +180 -0
  317. package/skills/performance-testing-review-ai-review/SKILL.md +450 -0
  318. package/skills/performance-testing-review-multi-agent-review/SKILL.md +216 -0
  319. package/skills/php-pro/SKILL.md +63 -0
  320. package/skills/posix-shell-pro/SKILL.md +304 -0
  321. package/skills/postgresql/SKILL.md +230 -0
  322. package/skills/postmortem-writing/SKILL.md +386 -0
  323. package/skills/projection-patterns/SKILL.md +33 -0
  324. package/skills/projection-patterns/resources/implementation-playbook.md +501 -0
  325. package/skills/prometheus-configuration/SKILL.md +404 -0
  326. package/skills/prompt-engineer/SKILL.md +272 -0
  327. package/skills/prompt-engineering-patterns/SKILL.md +213 -0
  328. package/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
  329. package/skills/prompt-engineering-patterns/assets/prompt-template-library.md +246 -0
  330. package/skills/prompt-engineering-patterns/references/chain-of-thought.md +399 -0
  331. package/skills/prompt-engineering-patterns/references/few-shot-learning.md +369 -0
  332. package/skills/prompt-engineering-patterns/references/prompt-optimization.md +414 -0
  333. package/skills/prompt-engineering-patterns/references/prompt-templates.md +470 -0
  334. package/skills/prompt-engineering-patterns/references/system-prompts.md +189 -0
  335. package/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
  336. package/skills/protocol-reverse-engineering/SKILL.md +29 -0
  337. package/skills/protocol-reverse-engineering/resources/implementation-playbook.md +509 -0
  338. package/skills/python-development-python-scaffold/SKILL.md +331 -0
  339. package/skills/python-packaging/SKILL.md +36 -0
  340. package/skills/python-packaging/resources/implementation-playbook.md +869 -0
  341. package/skills/python-performance-optimization/SKILL.md +36 -0
  342. package/skills/python-performance-optimization/resources/implementation-playbook.md +868 -0
  343. package/skills/python-pro/SKILL.md +158 -0
  344. package/skills/python-testing-patterns/SKILL.md +37 -0
  345. package/skills/python-testing-patterns/resources/implementation-playbook.md +906 -0
  346. package/skills/quant-analyst/SKILL.md +53 -0
  347. package/skills/rag-implementation/SKILL.md +421 -0
  348. package/skills/react-modernization/SKILL.md +34 -0
  349. package/skills/react-modernization/resources/implementation-playbook.md +512 -0
  350. package/skills/react-native-architecture/SKILL.md +33 -0
  351. package/skills/react-native-architecture/resources/implementation-playbook.md +670 -0
  352. package/skills/react-state-management/SKILL.md +441 -0
  353. package/skills/reference-builder/SKILL.md +188 -0
  354. package/skills/reverse-engineer/SKILL.md +173 -0
  355. package/skills/risk-manager/SKILL.md +61 -0
  356. package/skills/risk-metrics-calculation/SKILL.md +33 -0
  357. package/skills/risk-metrics-calculation/resources/implementation-playbook.md +554 -0
  358. package/skills/ruby-pro/SKILL.md +56 -0
  359. package/skills/rust-async-patterns/SKILL.md +33 -0
  360. package/skills/rust-async-patterns/resources/implementation-playbook.md +516 -0
  361. package/skills/rust-pro/SKILL.md +178 -0
  362. package/skills/saga-orchestration/SKILL.md +496 -0
  363. package/skills/sales-automator/SKILL.md +55 -0
  364. package/skills/sast-configuration/SKILL.md +212 -0
  365. package/skills/scala-pro/SKILL.md +82 -0
  366. package/skills/screen-reader-testing/SKILL.md +33 -0
  367. package/skills/screen-reader-testing/resources/implementation-playbook.md +544 -0
  368. package/skills/search-specialist/SKILL.md +80 -0
  369. package/skills/secrets-management/SKILL.md +364 -0
  370. package/skills/security-auditor/SKILL.md +169 -0
  371. package/skills/security-compliance-compliance-check/SKILL.md +55 -0
  372. package/skills/security-compliance-compliance-check/resources/implementation-playbook.md +963 -0
  373. package/skills/security-requirement-extraction/SKILL.md +33 -0
  374. package/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
  375. package/skills/security-scanning-security-dependencies/SKILL.md +43 -0
  376. package/skills/security-scanning-security-dependencies/resources/implementation-playbook.md +544 -0
  377. package/skills/security-scanning-security-hardening/SKILL.md +147 -0
  378. package/skills/security-scanning-security-sast/SKILL.md +495 -0
  379. package/skills/seo-authority-builder/SKILL.md +136 -0
  380. package/skills/seo-cannibalization-detector/SKILL.md +123 -0
  381. package/skills/seo-content-auditor/SKILL.md +83 -0
  382. package/skills/seo-content-planner/SKILL.md +108 -0
  383. package/skills/seo-content-refresher/SKILL.md +118 -0
  384. package/skills/seo-content-writer/SKILL.md +96 -0
  385. package/skills/seo-keyword-strategist/SKILL.md +95 -0
  386. package/skills/seo-meta-optimizer/SKILL.md +92 -0
  387. package/skills/seo-snippet-hunter/SKILL.md +114 -0
  388. package/skills/seo-structure-architect/SKILL.md +108 -0
  389. package/skills/service-mesh-expert/SKILL.md +58 -0
  390. package/skills/service-mesh-observability/SKILL.md +395 -0
  391. package/skills/shellcheck-configuration/SKILL.md +466 -0
  392. package/skills/similarity-search-patterns/SKILL.md +33 -0
  393. package/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
  394. package/skills/slo-implementation/SKILL.md +341 -0
  395. package/skills/solidity-security/SKILL.md +34 -0
  396. package/skills/solidity-security/resources/implementation-playbook.md +524 -0
  397. package/skills/spark-optimization/SKILL.md +427 -0
  398. package/skills/sql-optimization-patterns/SKILL.md +35 -0
  399. package/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
  400. package/skills/sql-pro/SKILL.md +173 -0
  401. package/skills/startup-analyst/SKILL.md +328 -0
  402. package/skills/startup-business-analyst-business-case/SKILL.md +487 -0
  403. package/skills/startup-business-analyst-financial-projections/SKILL.md +353 -0
  404. package/skills/startup-business-analyst-market-opportunity/SKILL.md +240 -0
  405. package/skills/startup-financial-modeling/SKILL.md +467 -0
  406. package/skills/startup-metrics-framework/SKILL.md +34 -0
  407. package/skills/startup-metrics-framework/resources/implementation-playbook.md +500 -0
  408. package/skills/stride-analysis-patterns/SKILL.md +33 -0
  409. package/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
  410. package/skills/stripe-integration/SKILL.md +454 -0
  411. package/skills/systems-programming-rust-project/SKILL.md +440 -0
  412. package/skills/tailwind-design-system/SKILL.md +33 -0
  413. package/skills/tailwind-design-system/resources/implementation-playbook.md +665 -0
  414. package/skills/tdd-orchestrator/SKILL.md +205 -0
  415. package/skills/tdd-workflows-tdd-cycle/SKILL.md +221 -0
  416. package/skills/tdd-workflows-tdd-green/SKILL.md +73 -0
  417. package/skills/tdd-workflows-tdd-green/resources/implementation-playbook.md +870 -0
  418. package/skills/tdd-workflows-tdd-red/SKILL.md +164 -0
  419. package/skills/tdd-workflows-tdd-refactor/SKILL.md +187 -0
  420. package/skills/team-collaboration-issue/SKILL.md +37 -0
  421. package/skills/team-collaboration-issue/resources/implementation-playbook.md +640 -0
  422. package/skills/team-collaboration-standup-notes/SKILL.md +44 -0
  423. package/skills/team-collaboration-standup-notes/resources/implementation-playbook.md +768 -0
  424. package/skills/team-composition-analysis/SKILL.md +413 -0
  425. package/skills/temporal-python-pro/SKILL.md +370 -0
  426. package/skills/temporal-python-testing/SKILL.md +170 -0
  427. package/skills/temporal-python-testing/resources/integration-testing.md +455 -0
  428. package/skills/temporal-python-testing/resources/local-setup.md +553 -0
  429. package/skills/temporal-python-testing/resources/replay-testing.md +462 -0
  430. package/skills/temporal-python-testing/resources/unit-testing.md +328 -0
  431. package/skills/terraform-module-library/SKILL.md +261 -0
  432. package/skills/terraform-module-library/references/aws-modules.md +63 -0
  433. package/skills/terraform-specialist/SKILL.md +166 -0
  434. package/skills/test-automator/SKILL.md +224 -0
  435. package/skills/threat-mitigation-mapping/SKILL.md +33 -0
  436. package/skills/threat-mitigation-mapping/resources/implementation-playbook.md +744 -0
  437. package/skills/threat-modeling-expert/SKILL.md +60 -0
  438. package/skills/track-management/SKILL.md +38 -0
  439. package/skills/track-management/resources/implementation-playbook.md +591 -0
  440. package/skills/turborepo-caching/SKILL.md +419 -0
  441. package/skills/tutorial-engineer/SKILL.md +139 -0
  442. package/skills/typescript-advanced-types/SKILL.md +35 -0
  443. package/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
  444. package/skills/typescript-pro/SKILL.md +55 -0
  445. package/skills/ui-minimal/SKILL.md +23 -0
  446. package/skills/ui-ux-designer/SKILL.md +209 -0
  447. package/skills/ui-visual-validator/SKILL.md +214 -0
  448. package/skills/unit-testing-test-generate/SKILL.md +319 -0
  449. package/skills/unity-developer/SKILL.md +230 -0
  450. package/skills/unity-ecs-patterns/SKILL.md +33 -0
  451. package/skills/unity-ecs-patterns/resources/implementation-playbook.md +625 -0
  452. package/skills/uv-package-manager/SKILL.md +37 -0
  453. package/skills/uv-package-manager/resources/implementation-playbook.md +830 -0
  454. package/skills/vector-database-engineer/SKILL.md +60 -0
  455. package/skills/vector-index-tuning/SKILL.md +42 -0
  456. package/skills/vector-index-tuning/resources/implementation-playbook.md +507 -0
  457. package/skills/wcag-audit-patterns/SKILL.md +41 -0
  458. package/skills/wcag-audit-patterns/resources/implementation-playbook.md +541 -0
  459. package/skills/web3-testing/SKILL.md +427 -0
  460. package/skills/workflow-orchestration-patterns/SKILL.md +333 -0
  461. package/skills/workflow-patterns/SKILL.md +38 -0
  462. 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