<?xml version="1.0" encoding="UTF-8"?><rss xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:atom="http://www.w3.org/2005/Atom" version="2.0" xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd" xmlns:googleplay="http://www.google.com/schemas/play-podcasts/1.0"><channel><title><![CDATA[Hyperdev: Articles]]></title><description><![CDATA[Feature articles on all things agentic coding—
From prompt-driven development to autonomous dev workflows, this section dives into the tools, techniques, and thinking behind AI-first programming. Real-world use cases, architecture breakdowns, code experiments, and practical insight into building with agents instead of just writing code line by line.]]></description><link>https://hyperdev.matsuoka.com/s/hyperdev</link><image><url>https://substackcdn.com/image/fetch/$s_!j9a7!,w_256,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab665959-5546-4469-9e93-9e1518976e2b_1024x1024.png</url><title>Hyperdev: Articles</title><link>https://hyperdev.matsuoka.com/s/hyperdev</link></image><generator>Substack</generator><lastBuildDate>Sat, 06 Jun 2026 08:16:35 GMT</lastBuildDate><atom:link href="https://hyperdev.matsuoka.com/feed" rel="self" type="application/rss+xml"/><copyright><![CDATA[Robert Matsuoka]]></copyright><language><![CDATA[en]]></language><webMaster><![CDATA[hyperdev@matsuoka.com]]></webMaster><itunes:owner><itunes:email><![CDATA[hyperdev@matsuoka.com]]></itunes:email><itunes:name><![CDATA[Robert Matsuoka]]></itunes:name></itunes:owner><itunes:author><![CDATA[Robert Matsuoka]]></itunes:author><googleplay:owner><![CDATA[hyperdev@matsuoka.com]]></googleplay:owner><googleplay:email><![CDATA[hyperdev@matsuoka.com]]></googleplay:email><googleplay:author><![CDATA[Robert Matsuoka]]></googleplay:author><itunes:block><![CDATA[Yes]]></itunes:block><item><title><![CDATA[What’s Old Is New Again]]></title><description><![CDATA[Nine classic SDLC practices that AI finally makes practical]]></description><link>https://hyperdev.matsuoka.com/p/whats-old-is-new-again</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/whats-old-is-new-again</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Wed, 03 Jun 2026 11:31:06 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!FRWK!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!FRWK!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!FRWK!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png 424w, https://substackcdn.com/image/fetch/$s_!FRWK!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png 848w, https://substackcdn.com/image/fetch/$s_!FRWK!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png 1272w, https://substackcdn.com/image/fetch/$s_!FRWK!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!FRWK!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png" width="873" height="576" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:576,&quot;width&quot;:873,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1435244,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200236698?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F43b89068-cf8e-4789-95f1-e357c61076b0_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!FRWK!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png 424w, https://substackcdn.com/image/fetch/$s_!FRWK!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png 848w, https://substackcdn.com/image/fetch/$s_!FRWK!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png 1272w, https://substackcdn.com/image/fetch/$s_!FRWK!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0b2c67b8-b815-4f06-a401-6d57b2a9d884_873x576.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>Most of the best ideas in software engineering aren&#8217;t new. They&#8217;ve been written up in books, argued over at conferences, taught in every &#8220;best practices&#8221; deck since the late 1990s. And most teams quietly don&#8217;t do them.</p><p>Not because anyone thinks they&#8217;re wrong. Test-driven development, design by contract, architecture decision records, mutation testing &#8212; ask a room of senior engineers whether these are good ideas and you&#8217;ll get nods. Ask the same room who practices them consistently under deadline pressure and the hands stay down. I&#8217;ve been in that room for twenty-five years, on both sides of the question. I&#8217;ve also been the engineering leader who let those practices slip because shipping the feature mattered more this quarter.</p><p>There&#8217;s a single economic reason these practices lose. The upfront cost is high, the payoff is real but distant, and human attention is the binding constraint. Write the test before the code, document the decision, specify the invariant &#8212; every one of those is a tax you pay now against a benefit you collect later, maybe, if the project lives long enough. Under deadline pressure, that&#8217;s a losing trade for a human. So we skip it, ship, and pay the interest later in bugs and confusion. Call it the impatience tax.</p><p>Agents don&#8217;t pay that tax. They have infinite patience for upfront rigor and roughly zero marginal cost for the tedious work that rigor demands. Writing a thorough test suite for code that doesn&#8217;t exist yet is psychologically brutal for a person and completely fine for a model. That single shift &#8212; the cost of patience going to zero &#8212; quietly inverts the economics of a whole list of practices we knew were right and gave up on anyway.</p><p>This isn&#8217;t a piece about what AI makes <em>possible</em>. Lots of things are possible. It&#8217;s about a narrower, more useful question: which disciplines did we already agree were correct, fight about for decades, and abandon for reasons that no longer hold?</p><p>Here are nine.</p><h2>TL;DR</h2><ul><li><p>These nine practices share one structure: high upfront cost, distant payoff. Human attention is the constraint that kills them under deadline pressure.</p></li><li><p>AI removes the constraint. A failing test is the clearest prompt you can hand an agent; a spec is its input; an ADR is its context. The discipline becomes the interface.</p></li><li><p>TDD, design by contract, and property-based testing turn from &#8220;things we should do&#8221; into the most effective way to <em>constrain</em> agent behavior and prevent hallucinated correctness.</p></li><li><p>Documentation, ADRs, and living docs get a bilateral ROI: agents generate them from code, and they make agents far more effective in your codebase.</p></li><li><p>The catch is real. A 2025 METR randomized trial found experienced developers were about 19% <em>slower</em> with AI assistance. These practices pay off only when AI is used with discipline, not as autocomplete.</p></li></ul><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!hmow!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!hmow!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png 424w, https://substackcdn.com/image/fetch/$s_!hmow!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png 848w, https://substackcdn.com/image/fetch/$s_!hmow!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png 1272w, https://substackcdn.com/image/fetch/$s_!hmow!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!hmow!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png" width="1024" height="431" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/f117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:431,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1083571,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200236698?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5f4ba76c-18f5-413a-bf35-a56dc7861a00_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!hmow!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png 424w, https://substackcdn.com/image/fetch/$s_!hmow!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png 848w, https://substackcdn.com/image/fetch/$s_!hmow!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png 1272w, https://substackcdn.com/image/fetch/$s_!hmow!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff117aee0-1765-4975-a0c5-dd7bdddbe34d_1024x431.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>1. Test-Driven Development</h2><p>Start with the practice most teams abandoned first.</p><p>Writing tests before code was always the theoretically superior move. It forces you to define the interface before you build behind it, catches bugs at the moment of definition instead of during integration, and leaves behind a living specification of what the code is supposed to do. Kent Beck made the case decades ago and the case held up.</p><p>Almost nobody did it consistently. The reason is psychological, not technical. Writing detailed tests for code that doesn&#8217;t exist yet, while a deadline breathes on your neck, feels like building scaffolding for a house you haven&#8217;t designed. Your brain screams at you to just write the function. So you write the function, promise yourself you&#8217;ll add tests after, and &#8212; well. You know how that goes.</p><p>Now flip the perspective. To an agent, a failing test isn&#8217;t scaffolding. It&#8217;s the clearest possible specification of intent you can provide. &#8220;Make this pass, don&#8217;t break anything else&#8221; is an unambiguous, machine-checkable instruction, which is exactly what a probabilistic system needs to stay honest. The test suite becomes a guardrail that prevents the most dangerous failure mode in AI-assisted coding: confident, plausible, wrong. Hallucinated correctness dies against a red bar.</p><p>TDD went from the discipline most teams couldn&#8217;t sustain to one of the best tools we have for bounding what an agent is allowed to claim it did. Same practice. Opposite economics.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!a841!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!a841!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png 424w, https://substackcdn.com/image/fetch/$s_!a841!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png 848w, https://substackcdn.com/image/fetch/$s_!a841!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png 1272w, https://substackcdn.com/image/fetch/$s_!a841!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!a841!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png" width="1024" height="670" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/fb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:670,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1640038,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200236698?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1a4cda20-f557-4918-88d1-529fec00bdee_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!a841!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png 424w, https://substackcdn.com/image/fetch/$s_!a841!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png 848w, https://substackcdn.com/image/fetch/$s_!a841!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png 1272w, https://substackcdn.com/image/fetch/$s_!a841!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffb60534e-05b5-4873-ab47-586bb7ec68bd_1024x670.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>2. Spec-Driven Development and Design by Contract</h2><p>Bertrand Meyer formalized design by contract in the 1980s and built it into the Eiffel language: specify preconditions, postconditions, and invariants, then let the implementation follow from the contract.</p><p>The idea was sound and the adoption was thin, for one stubborn economic reason: the contract only pays off if someone <em>else</em> writes the implementation from it. If you&#8217;re writing both the spec and the code, the spec is overhead &#8212; you already know what you meant. The contract&#8217;s value lives in the handoff, and for most of software history there was no cheap handoff to hand it to.</p><p>Now there is. You write the contract; the agent writes the implementation from it. Spec-driven development stops being a documentation chore and becomes the actual control surface for delegation. The spec is the part requiring human judgment about <em>what</em> the system should do. The implementation &#8212; the part that used to eat the hours &#8212; is the part you delegate. Meyer&#8217;s economics finally close, forty years late, because the missing party in the transaction showed up.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!P-wa!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!P-wa!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png 424w, https://substackcdn.com/image/fetch/$s_!P-wa!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png 848w, https://substackcdn.com/image/fetch/$s_!P-wa!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png 1272w, https://substackcdn.com/image/fetch/$s_!P-wa!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!P-wa!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png" width="1024" height="487" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/ee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:487,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1370470,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200236698?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F82d6c7c5-50c0-4b34-9a46-0700c4bf1e82_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!P-wa!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png 424w, https://substackcdn.com/image/fetch/$s_!P-wa!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png 848w, https://substackcdn.com/image/fetch/$s_!P-wa!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png 1272w, https://substackcdn.com/image/fetch/$s_!P-wa!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee5605bf-95f5-490e-b318-7334ff70ae87_1024x487.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>3. Architecture Decision Records</h2><p>Why does the codebase look like this? Why Postgres and not Dynamo, why this queue, why the weird module boundary that everyone trips over?</p><p>ADRs were the right answer to that question &#8212; a short dated record of each significant decision, the context, and the alternatives rejected. The discipline almost never held. Same shape as everything else here: the cost is immediate (stop, write the thing) and the value accrues slowly, mostly to some future engineer who isn&#8217;t in the room yet.</p><p>Two things flipped at once, which makes this one more interesting than the rest. First, agents can generate ADRs from an existing codebase &#8212; read the git history, the dependency choices, the structure, and reconstruct the decisions that produced them. The retroactive cost of documentation drops toward zero. Second, and this is the part people miss: existing ADRs dramatically improve what an agent can do <em>in</em> your codebase. An agent that can read why you chose eventual consistency won&#8217;t keep proposing changes that assume strong consistency.</p><p>So the ROI went bilateral. Agents help you write ADRs, and ADRs help agents help you. The practice that used to only cost now pays on both ends.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!cfey!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!cfey!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png 424w, https://substackcdn.com/image/fetch/$s_!cfey!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png 848w, https://substackcdn.com/image/fetch/$s_!cfey!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png 1272w, https://substackcdn.com/image/fetch/$s_!cfey!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!cfey!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png" width="1024" height="445" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:445,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1079171,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200236698?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0eca5b97-c8ef-45f0-97de-eb23cc9969c2_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!cfey!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png 424w, https://substackcdn.com/image/fetch/$s_!cfey!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png 848w, https://substackcdn.com/image/fetch/$s_!cfey!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png 1272w, https://substackcdn.com/image/fetch/$s_!cfey!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F256e6ffa-ac04-401b-bd1d-276e0dc51f21_1024x445.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>4. Continuous Code Review</h2><p>&#8220;Catch issues early&#8221; has sat on every best-practices list since Extreme Programming put continuous review on the map. The advice was never controversial. The bottleneck was always the same: human reviewer attention is finite, expensive, and easily exhausted. So review collapsed into batch PR review &#8212; a tired engineer reading a 600-line diff on a Friday afternoon, approving most of it on faith.</p><p>AI review on every commit &#8212; not batched at the PR boundary, but running as code lands &#8212; is moving from aspirational toward baseline: increasingly the default on teams that have wired it in, though not yet universal. The marginal cost of a careful read went to nearly nothing, and the read happens while the context is still warm.</p><p>But this one comes with an emergent problem worth naming, because it bites teams that adopt the tooling without rethinking the model. PRs are getting larger and arriving faster under AI-assisted development. An agent can produce a 2,000-line change in an afternoon. If your review model still routes everything through a human approver at the end, that human is now the rate limiter, drowning in volume they didn&#8217;t generate and can&#8217;t realistically read. AI review on every commit is part of the answer. The harder part is restructuring <em>what</em> the human reviews &#8212; architecture, intent, the decisions a model shouldn&#8217;t make alone &#8212; and letting the machine handle line-level correctness continuously. Adopt the tool without rethinking the workflow and you&#8217;ve just built a faster way to overwhelm your best reviewer.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!SXYP!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!SXYP!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png 424w, https://substackcdn.com/image/fetch/$s_!SXYP!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png 848w, https://substackcdn.com/image/fetch/$s_!SXYP!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png 1272w, https://substackcdn.com/image/fetch/$s_!SXYP!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!SXYP!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png" width="1024" height="456" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:456,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1098227,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200236698?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6ce64d7a-b849-4c7e-b523-2565960ee237_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!SXYP!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png 424w, https://substackcdn.com/image/fetch/$s_!SXYP!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png 848w, https://substackcdn.com/image/fetch/$s_!SXYP!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png 1272w, https://substackcdn.com/image/fetch/$s_!SXYP!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2eb6d6b9-de10-452f-8b64-7bb0bcba1041_1024x456.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>5. Pair Programming</h2><p>Pairing always looked expensive in the most obvious way: two engineers, one task, double the salary against a single unit of output. That intuition was wrong on the numbers &#8212; the measured overhead from the pair-programming studies was closer to 15%, often recovered through fewer defects &#8212; but the 2&#215; gut feeling is what drove the decisions. The benefits were real &#8212; knowledge transfer, real-time review, fewer dumb mistakes &#8212; but the perceived math meant most teams reserved it for critical paths, gnarly bugs, or onboarding a new hire. A luxury, rationed.</p><p>The pair is now a human and an agent, and it&#8217;s available to every engineer continuously, not rationed to the critical path. The knowledge-transfer benefit generalizes &#8212; the agent can explain unfamiliar parts of the codebase on demand. The real-time-review benefit generalizes &#8212; a second set of eyes on every line, every time, without scheduling two calendars. The economics that made pairing a rationed luxury simply don&#8217;t apply when one half of the pair has near-zero marginal cost.</p><p>Worth a caveat: agent-as-pair is genuinely good at the review and explanation half of pairing, and weaker at the part where a human partner pushes back on a bad <em>design</em> before you&#8217;ve written a line. You still need humans pairing with humans for that. But the day-to-day, line-by-line version of pairing just became free, and that&#8217;s most of what pairing was for.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!DHDP!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!DHDP!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png 424w, https://substackcdn.com/image/fetch/$s_!DHDP!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png 848w, https://substackcdn.com/image/fetch/$s_!DHDP!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png 1272w, https://substackcdn.com/image/fetch/$s_!DHDP!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!DHDP!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png" width="1024" height="592" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:592,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1439433,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200236698?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F611b1613-4024-4d10-8e69-2b2a1936432d_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!DHDP!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png 424w, https://substackcdn.com/image/fetch/$s_!DHDP!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png 848w, https://substackcdn.com/image/fetch/$s_!DHDP!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png 1272w, https://substackcdn.com/image/fetch/$s_!DHDP!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F18e5b59c-a9a7-44ae-8725-1333f8e08687_1024x592.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>6. Mutation Testing</h2><p>Coverage numbers lie, and most engineers know it. Eighty percent line coverage tells you eighty percent of your lines got executed by a test &#8212; not that any of those tests would <em>notice</em> if the behavior broke. Mutation testing is the honest measure: it deliberately introduces bugs (flip a comparison, drop a line, change a constant) and checks whether your test suite catches them. If a mutant survives, you have a test that runs code without actually validating it.</p><p>Mutation testing was always the gold standard and almost never run continuously, for one reason: it&#8217;s computationally expensive. You&#8217;re effectively running your whole suite many times over, once per mutation. On a real codebase that&#8217;s brutal. So it lived in research papers and the occasional heroic CI job that someone eventually disabled for being too slow.</p><p>That constraint is mostly gone &#8212; compute is cheap and parallel, and we got more comfortable spending it. And the practice arrived right when we suddenly need it most. AI-generated tests have a characteristic failure mode: they drift toward coverage metrics without meaningful assertions. The model writes a test that calls the function, exercises the path, and asserts almost nothing of substance &#8212; green checkmark, zero protection. Coverage looks great. Mutation testing is the thing that catches exactly that. It&#8217;s the verification layer for a verification layer, and it matters more now than when it was invented, because now a machine is writing the tests.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!EY9I!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!EY9I!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!EY9I!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!EY9I!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!EY9I!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!EY9I!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png" width="1024" height="768" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:768,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1482204,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200236698?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!EY9I!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!EY9I!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!EY9I!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!EY9I!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F70ad3dac-f7cb-48da-9d0a-a6098d28cbe6_1024x768.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>7. Living Documentation</h2><p>Documentation was always supposed to be a first-class artifact. It almost never was, and the reason is by now familiar: writing docs is tedious, and the penalty for stale docs accrues slowly and lands on someone else. So docs rotted. Every team has a wiki that&#8217;s a graveyard of half-true pages from two reorgs ago.</p><p>AI changes both halves of the equation at once. It generates docs from code, so the writing cost drops. And it <em>consumes</em> docs as context, so the docs earn their keep immediately &#8212; a well-documented codebase is a measurably more useful codebase for an agent working in it. The ROI is immediate and bilateral, same structure as ADRs.</p><p>There&#8217;s a quiet shift hiding in there. Documentation used to be written for humans who&#8217;d mostly never read it. Now it&#8217;s also written for the agent that will read it on every task, which means stale docs don&#8217;t just confuse a future engineer &#8212; they actively degrade your tooling today. The feedback loop tightened from months to minutes. That&#8217;s the kind of change that actually moves behavior, because the cost of skipping it shows up now instead of later.</p><h2>8. Runbook Generation from Incidents</h2><p>On-call always leaned too hard on tribal knowledge. The person who knows why the payment service wedges at 3 a.m. is asleep, on vacation, or left the company last spring. Writing a runbook after each incident was obviously the right move and reliably the thing nobody did, because the incident was <em>over</em> and everyone wanted to go back to bed.</p><p>Incidents become runbooks automatically now. The agent has the incident timeline, the chat transcript, the commands that resolved it, the postmortem &#8212; and it can turn that into a structured runbook while the details are fresh, without asking an exhausted engineer to relive the night. The cost that used to fall right when motivation was lowest now falls on a system that doesn&#8217;t get tired or resentful.</p><p>I&#8217;d treat the generated runbook as a draft a human still signs off on, not gospel. But &#8220;imperfect draft, reviewed in five minutes&#8221; beats &#8220;blank page nobody ever fills in,&#8221; and that was always the real competition.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!dM5v!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!dM5v!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png 424w, https://substackcdn.com/image/fetch/$s_!dM5v!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png 848w, https://substackcdn.com/image/fetch/$s_!dM5v!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png 1272w, https://substackcdn.com/image/fetch/$s_!dM5v!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!dM5v!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png" width="1024" height="693" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/d0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:693,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1615996,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200236698?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc3f83774-28c6-4b46-addd-83efad33390b_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!dM5v!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png 424w, https://substackcdn.com/image/fetch/$s_!dM5v!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png 848w, https://substackcdn.com/image/fetch/$s_!dM5v!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png 1272w, https://substackcdn.com/image/fetch/$s_!dM5v!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c754a4-9b5b-424f-b008-30dbcb217887_1024x693.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>9. Property-Based Testing</h2><p>Example-based tests check the cases you thought of. Property-based testing is stronger: you specify the <em>invariants</em> a system must always satisfy &#8212; reversing a list twice returns the original, a serialized-then-deserialized object equals the original, the account balance never goes negative &#8212; and the framework generates hundreds of adversarial inputs trying to break them. QuickCheck pioneered the approach; it finds the edge cases you&#8217;d never have written by hand.</p><p>It never went mainstream outside a few communities, and the bottleneck wasn&#8217;t tooling &#8212; good property-based libraries exist for most languages. The bottleneck was writing good property specifications. Identifying the right invariants requires deep domain reasoning: you have to understand the system well enough to state what must <em>always</em> be true, which is harder than writing a few example cases. Most engineers, under pressure, defaulted to the easier thing.</p><p>This is where AI helps in a way that&#8217;s less obvious than &#8220;it writes the code.&#8221; A model can generate property suites from a spec, and &#8212; more usefully &#8212; it can reason about <em>what invariants a system should satisfy</em> in the first place, surfacing properties you hadn&#8217;t articulated. That&#8217;s the expensive, judgment-heavy part it actually offloads. Combined with mutation testing to keep the generated properties honest, you get a testing approach that was always more powerful than example-based testing and was always too expensive in human reasoning to adopt widely.</p><h2>The Catch</h2><p>I&#8217;d be selling you something if I stopped there, and the data won&#8217;t let me.</p><p>In July 2025, METR ran a randomized controlled trial with experienced open-source developers working on real tasks in repositories they knew well. The developers expected AI assistance to speed them up. It slowed them down &#8212; by roughly 19%. METR&#8217;s February 2026 follow-up found that gap narrowing, and reversing on some measures, as the same kind of developers gained real experience with the tools &#8212; which is to say the 19% was a snapshot of the unfamiliar, undisciplined path, and it closes precisely as people pick up the habits this piece is about.</p><p>That finding is real and it isn&#8217;t a contradiction of everything above. It&#8217;s the missing condition. Every practice in this piece works <em>because</em> it imposes structure on the agent &#8212; TDD as a guardrail, the spec as input, the ADR as context, mutation testing as the check on the check. Used that way, with discipline, AI is constrained toward correctness. Used the other way &#8212; as autocomplete, as a vibe-coding partner you don&#8217;t supervise &#8212; you get more code, faster, with less correctness and a slower path to done once you account for the cleanup. The METR developers, working in code they already understood deeply, may well have been paying exactly that tax: accepting plausible suggestions that took longer to vet and fix than writing it themselves would have.</p><p>So the inversion isn&#8217;t automatic. The cost of patience dropped to zero, which makes the rigorous path finally affordable. It does not make the undisciplined path good. If anything it makes discipline more important, because a tool that produces plausible output at high volume is precisely the tool that most needs a guardrail you can&#8217;t talk your way past. A red test bar doesn&#8217;t care how confident the model sounds.</p><h2>What To Do With This</h2><p>The interesting question was never &#8220;what does AI make possible.&#8221; That list is enormous, mostly speculative, and not very actionable. The better question is the one this whole piece is built on: which practices did we already know were right, argue about for decades, and quietly give up on?</p><p>That list is short, specific, and yours to write. Go pull your own team&#8217;s &#8220;we should really do this but we don&#8217;t&#8221; backlog &#8212; the standing items in retros that everyone agrees with and nobody owns. I&#8217;d bet most of them have the same economic shape: high upfront cost, distant payoff, killed by human impatience under deadline. Test coverage on the legacy module. The runbooks. The ADRs for the three decisions everyone keeps re-litigating. The integration tests that would&#8217;ve caught last quarter&#8217;s outage.</p><p>Run each one through a single question: was this abandoned because it was <em>wrong</em>, or because it was <em>expensive in human patience</em>? The wrong ones, leave abandoned. The expensive-in-patience ones just got cheap. Those are the ones to pick back up first.</p><p>The impatience tax got repealed. The disciplines it used to make unaffordable are sitting right there, mostly unchanged, waiting for someone to notice the price changed.</p><div><hr></div><p><em>Bob Matsuoka is CTO of <a href="https://www.duettocloud.com/">Duetto</a> and writes about AI-powered engineering at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p>The Other Shoe Has Dropped &#8212; Why enterprise AI bills don&#8217;t match the per-token price collapse</p></li><li><p><a href="https://aipowerranking.com/">AI Power Ranking</a> &#8212; Tool comparisons and benchmarks for AI practitioners</p></li><li><p><a href="https://www.linkedin.com/newsletters/ai-power-ranking-7345782916301418496/">LinkedIn Newsletter</a> &#8212; Strategic AI insights for CTOs and engineering leaders</p></li></ul>]]></content:encoded></item><item><title><![CDATA[The Era of the Leader/Practitioner]]></title><description><![CDATA[Putting "Do" back into "Lead"]]></description><link>https://hyperdev.matsuoka.com/p/the-era-of-the-leaderpractitioner</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/the-era-of-the-leaderpractitioner</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Mon, 01 Jun 2026 11:31:28 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!E_Vr!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!E_Vr!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!E_Vr!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png 424w, https://substackcdn.com/image/fetch/$s_!E_Vr!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png 848w, https://substackcdn.com/image/fetch/$s_!E_Vr!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png 1272w, https://substackcdn.com/image/fetch/$s_!E_Vr!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!E_Vr!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png" width="1024" height="700" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:700,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1378805,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200067020?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb6656d57-be88-4993-a972-b7c0c5fd743d_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!E_Vr!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png 424w, https://substackcdn.com/image/fetch/$s_!E_Vr!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png 848w, https://substackcdn.com/image/fetch/$s_!E_Vr!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png 1272w, https://substackcdn.com/image/fetch/$s_!E_Vr!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3731b710-763c-4f36-860f-560f95b11d2b_1024x700.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>Something shifted in the last year, and it took me a while to name it.</p><p>A growing number of people are running organizations while still doing real hands-on technical work. Not as a hobby, not on weekends, not as a vanity exercise to keep their commit graph green. They are building things their teams depend on &#8212; and they are doing it as a deliberate part of the job, not in the cracks between meetings. The work has a specific shape. It is rarely a production feature. It is the layer underneath: developer productivity tooling, internal services, agentic harnesses, MCP connectors, the infrastructure that unblocks everyone else.</p><p>For most of my career this combination didn&#8217;t really hold together. You could code or you could lead, and the moment you tried to do both seriously, one of them rotted. I&#8217;ve watched plenty of technical executives keep a foot in the codebase and slowly become the bottleneck everyone routed around politely. The pattern was familiar enough to be a warning.</p><p>What changed is not that leaders suddenly got more disciplined. It&#8217;s that the time cost of meaningful technical contribution collapsed. Agentic coding made a hybrid role viable that wasn&#8217;t viable before &#8212; and the more I look at it, the more I think this isn&#8217;t a new invention at all. It&#8217;s the recovery of a very old idea that modern specialization interrupted.</p><p>I&#8217;m writing this as someone living in the middle of it. I spend roughly 30% of my time coding. And when I say coding, I mean directing a team of agents &#8212; much closer to that than hands-on work, which is probably the whole point. That&#8217;s not a full-time IC&#8217;s week, and it isn&#8217;t meant to be. It&#8217;s enough to stay close to the work that matters and to build the enabling infrastructure I think is worth my own hands on the keyboard.</p><h2>TL;DR</h2><ul><li><p>A distinct role is emerging: leaders who run organizations and still do deep technical work &#8212; specifically enabling/institutional work (tooling, harnesses, internal services), not critical-path product features.</p></li><li><p>This satisfies Charity Majors&#8217; actual advice. Her line was never &#8220;stop coding.&#8221; It was &#8220;stop writing code in the critical path.&#8221; Enabling work fits that exactly.</p></li><li><p>The integration of strategist and practitioner has deep cross-cultural precedent &#8212; Japan&#8217;s <em>bunbu-ry&#333;d&#333;</em>, Rome&#8217;s Marcus Aurelius, China&#8217;s <em>wen-wu</em>, the Renaissance polymath, Mattis&#8217;s &#8220;warrior monk.&#8221; The modern role is a recovery, not a novelty.</p></li><li><p>Agentic coding is what makes it newly viable: focused sessions now deliver output that once required sustained, uninterrupted immersion. The Anthropic 2026 data shows ~27% of AI-assisted work is work that &#8220;wouldn&#8217;t have been done otherwise.&#8221;</p></li><li><p>Directing agents feels like delegation &#8212; the same skill leaders already use with human reports. Which is why experienced leaders adapt to it more naturally than juniors do.</p></li></ul><h2>The pattern, named</h2><p>The difficulty with the coding executive was never philosophical. It was attentional.</p><p>Charity Majors mapped this years ago in <a href="https://charity.wtf/2017/05/11/the-engineer-manager-pendulum/">The Engineer/Manager Pendulum</a>, and the piece holds up because she was precise about the mechanism. Management is interruptive by design &#8212; your job is to be available, to unblock, to absorb the chaos so your team doesn&#8217;t have to. Serious engineering is the opposite. It requires blocking interruptions for long enough to hold a complex system in your head. Two incompatible attention modes. Try to run both at once and you do neither well.</p><p>But here is the part people skip when they quote her. Majors never said managers should stop coding. Her actual advice was sharper: <em>don&#8217;t write code in the critical path.</em> Don&#8217;t be the person others are waiting on. Stay technical, stay sharp, just don&#8217;t make yourself a dependency that blocks shipping. &#8220;The best frontline eng managers in the world,&#8221; she wrote, &#8220;are the ones that are never more than 2-3 years removed from hands-on work.&#8221;</p><p>That distinction carries the whole argument. Because there is a category of technical work that is consequential without being critical-path, and it turns out to be exactly the work senior people are best positioned to do.</p><p>Call it enabling work. Internal tooling. Developer productivity infrastructure. Agentic harnesses. MCP services that other teams plug into. Architectural prototypes that prove a direction before anyone commits to it. None of this is what blocks a release on Thursday. All of it multiplies whoever comes after. It tolerates interruption &#8212; you can pick it up Tuesday afternoon and put it down when a real fire starts &#8212; precisely because nobody is standing at your desk waiting for it.</p><p>This is also where the industry is putting its money. Gartner named platform engineering a top strategic trend for two years running and projects that 80% of large engineering organizations will run dedicated platform teams by 2026. The structural reason a leader can work here without becoming the bottleneck is built into the definition of the domain: its output unblocks others rather than blocking them.</p><p>Will Larson&#8217;s <a href="https://lethain.com/staff-engineer-archetypes/">Staff Engineer archetypes</a> circle the same territory without quite landing on it. His &#8220;Architect&#8221; sits in a permanent argument &#8212; some organizations demand the Architect stay deep in the code, others forbid it. The leader/practitioner resolves that argument by relocating it: deep in the enabling and infrastructure work, absent from production product code. Not the pendulum, not the staff IC. A real hybrid, and a newly coherent one.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!jHB6!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!jHB6!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png 424w, https://substackcdn.com/image/fetch/$s_!jHB6!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png 848w, https://substackcdn.com/image/fetch/$s_!jHB6!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png 1272w, https://substackcdn.com/image/fetch/$s_!jHB6!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!jHB6!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png" width="1024" height="684" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/dffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:684,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1540586,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200067020?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa8e7bf7a-504a-4f0c-b75f-1832889fc598_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!jHB6!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png 424w, https://substackcdn.com/image/fetch/$s_!jHB6!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png 848w, https://substackcdn.com/image/fetch/$s_!jHB6!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png 1272w, https://substackcdn.com/image/fetch/$s_!jHB6!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdffd3763-7ad5-4119-96d4-4e0c1d01f0cd_1024x684.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>This is not new</h2><p>Here is where I want to slow down, because the most interesting thing about this role is how old it is.</p><p>The idea that a leader should be both a strategist and a practitioner &#8212; not separate modes to alternate between but a single integrated way of operating &#8212; shows up independently across at least five civilizations. That kind of convergence usually means a culture has found a durable answer to a real problem.</p><p>Japan gave it a name: <em>bunbu-ry&#333;d&#333;</em> (&#25991;&#27494;&#20001;&#36947;), the way of both the literary and the martial. <em>Bun</em> is letters, cultivation, strategy. <em>Bu</em> is the martial, the active, the practitioner&#8217;s hand. <em>Ry&#333;d&#333;</em> means both ways, together &#8212; not balanced, not traded off, but held at once. By the mid-fourteenth century the dual-talented warrior was already established as the model leader, and during the Edo period the Tokugawa shogunate made it official policy for the samurai class. The phrase that survives captures the stakes: culture without power is ineffective, and power without culture is barbarous.</p><p>The archetype is Miyamoto Musashi. Undefeated in more than sixty duels, often fighting with a wooden sword against live steel. He founded a two-sword school, and in the last months of his life he wrote <em>The Book of Five Rings</em> in a cave. He was also a recognized master of ink painting and calligraphy &#8212; his <em>Shrike on a Withered Branch</em> survives as a designated Important Cultural Property of Japan. The same hands that won sixty duels produced fine art a nation still protects. He didn&#8217;t oscillate between the sword and the brush. He held both, and each sharpened the other. &#8220;When I apply the principle of strategy to the ways of different arts and crafts,&#8221; he wrote, &#8220;I no longer have need for a teacher in any domain.&#8221; Mastery in one discipline illuminating all the others.</p><p>Rome had Marcus Aurelius, the philosopher-king made historical rather than theoretical. He ran the empire and commanded its armies on the Danube, and he wrote the <em>Meditations</em> in the war camps &#8212; fragmentary notes to himself, composed in the middle of campaigning and administration. That book was never published philosophy. It was a working journal, the most powerful man in the ancient world writing to stay grounded while doing the job.</p><p>China institutionalized the same ideal as <em>wen</em> and <em>wu</em> &#8212; civil cultivation and martial capability &#8212; and ran it for roughly thirteen centuries through the scholar-official class. Zeng Guofan is the canonical case: he rose through the imperial examinations to high Confucian office, then built and commanded an army of more than a hundred thousand, reportedly keeping a diary on Neo-Confucian ethics even as he directed the campaigns. The integration wasn&#8217;t left to personal taste. It was built into the examination and career structure.</p><p>And the archetype still lands today. James Mattis earned the nickname &#8220;Warrior Monk&#8221; &#8212; battlefield commander and devoted reader, a 7,000-book library, the <em>Meditations</em> carried into combat. The chain from Aurelius to Mattis is literal: the same book, eighteen centuries apart. That we still reach for &#8220;warrior monk&#8221; as a compliment for a leader tells you the integration never stopped resonating.</p><p>Across all of it, the answer is the same. The contemplative and the active were not specializations to assign to different people. They were a single discipline, each half informing the other. Modernity &#8212; with its org charts, its clean role boundaries, its professional specialization &#8212; interrupted that. The leader/practitioner is not a tech-industry novelty. It&#8217;s an old integration becoming feasible again.</p><h2>Why now</h2><p>So what actually changed? Not the wisdom. The economics.</p><p>The thing that made the coding executive a bad idea was the attention math. Serious technical work demanded long, unbroken stretches of focus &#8212; the exact resource a leadership schedule cannot reliably provide. You cannot design a system in the fifteen minutes between a board prep and a one-on-one. The pendulum was a real constraint, not a failure of will.</p><p>Agentic coding changes that math directly. The unit of work moved up a level. Instead of holding every implementation detail in working memory across a four-hour session, you specify intent, direct an agent, review what comes back, correct course, and direct again. A focused 30-minute session now produces what used to require an afternoon of immersion &#8212; not because the thinking got easier, but because the implementation cost collapsed.</p><p>The Anthropic <a href="https://resources.anthropic.com/2026-agentic-coding-trends-report">2026 Agentic Coding Trends Report</a> puts numbers on the shift. Average session length has climbed to 23 minutes in the agentic era, up from about 4 in the autocomplete era &#8212; the work got denser, not just faster. 78% of Claude Code sessions now involve multi-file edits, up from 34% a year earlier. Teams running multi-agent workflows report 2&#8211;4x faster delivery from task creation to deployment. And the figure that matters most for this argument: roughly 27% of AI-assisted work consists of tasks that &#8220;wouldn&#8217;t have been done otherwise&#8221; &#8212; the scaling projects, the nice-to-have tools, the exploratory infrastructure that was never quite worth the manual hours.</p><p>That 27% is the enabling work. It is the category that lives or dies on time cost, and it&#8217;s the category a leader/practitioner is best placed to take on.</p><p>The arithmetic is what makes 30% credible. I documented a 6&#8211;10x multiplier on focused technical sessions in <a href="https://hyperdev.matsuoka.com/the-irreducibles-what-a-pattern-master-does">The Irreducibles</a> earlier this year &#8212; a project I estimated at 150&#8211;200 billable hours compressed into roughly 50&#8211;70 hours of wall-clock time, most of which wasn&#8217;t coding at all. If directed work runs several times faster than hand-coding, then a day and a half a week can produce what once consumed a full-time engineer&#8217;s week. That&#8217;s not a marginal gain. It&#8217;s a change in what&#8217;s structurally possible.</p><p>There&#8217;s another dimension that doesn&#8217;t show up in the productivity numbers: the work itself is unstable. Agentic coding patterns are still shaking out. There aren&#8217;t many experienced practitioners, the field is moving fast, and we don&#8217;t yet have good consensus on which patterns are load-bearing and which are fashion. A manager who&#8217;s only reading about it can&#8217;t make that distinction on behalf of a team. You have to be in it to know.</p><p>There&#8217;s a counterintuitive wrinkle worth naming: the people best positioned to exploit this are the senior ones. A University of Chicago working paper from late 2025 found experienced developers were 5&#8211;6% more likely to succeed with AI agents for every standard deviation of work experience, largely because they worked plan-first &#8212; laying out objectives, alternatives, and steps before invoking the tool. That&#8217;s the opposite of the assumption that AI flattens the seniority curve. Expertise improves your ability to delegate to a model for the same reason it improves your ability to delegate to a person. AI doesn&#8217;t change what senior engineering is. It reveals what it always was.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!EYNR!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!EYNR!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png 424w, https://substackcdn.com/image/fetch/$s_!EYNR!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png 848w, https://substackcdn.com/image/fetch/$s_!EYNR!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png 1272w, https://substackcdn.com/image/fetch/$s_!EYNR!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!EYNR!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png" width="1024" height="634" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:634,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1514078,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/200067020?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1745d9f4-d955-45cb-b61a-c12956852f96_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!EYNR!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png 424w, https://substackcdn.com/image/fetch/$s_!EYNR!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png 848w, https://substackcdn.com/image/fetch/$s_!EYNR!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png 1272w, https://substackcdn.com/image/fetch/$s_!EYNR!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F727ed32e-2441-4dc7-bf6b-4ea9a19a2cb7_1024x634.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>Directing agents is delegation</h2><p>This is the part that interested me the most, and it&#8217;s the bridge between the leadership job and the technical one.</p><p>A year or so ago, working with Claude Code felt like coding. Now it feels like delegating. I <a href="https://hyperdev.matsuoka.com/coding-to-delegation-shift">wrote about that shift</a> when it first became undeniable &#8212; the move from being a programmer who uses AI to being something closer to a technical project manager who directs it. Anthropic&#8217;s report uses the same vocabulary, describing engineers moving &#8220;from writing code to orchestrating the systems that write it.&#8221;</p><p>What I didn&#8217;t fully appreciate at the time is how directly that maps onto the muscle leaders already have. Delegating to an agent feels, in practice, just like delegating to a human engineer. You frame the problem, set the constraints, hand it off, and come back to assess the result. Give a directive, walk away, return to completed work. That loop is the daily reality of management. Leaders developed it because they had to, and it transfers to agents almost without friction.</p><p>So the leader/practitioner doesn&#8217;t have to become a coder again in the old sense. The skill in demand is judgment plus delegation, and that&#8217;s the skill leadership has been building all along. The hands-on knowledge tells you what to ask for and whether the answer is any good. The delegation instinct does the rest.</p><p>This is why the enabling work and the agentic tools fit together so cleanly. Enabling work tends to be well-defined, non-user-facing, and long-horizon &#8212; exactly the profile agents handle well and exactly the profile that tolerates a leader&#8217;s interrupted schedule. The hands-on contribution mostly takes the form of specifying constraints and patterns, which is what I&#8217;ve called <a href="https://hyperdev.matsuoka.com/what-does-a-pattern-master-do">pattern mastery</a>: when you write the pattern down, you&#8217;ve written the spec, and the spec multiplies everyone else&#8217;s output.</p><h2>What it actually looks like</h2><p>Let me ground this without turning it into a war story.</p><p>The concrete examples from my own work are the kind of thing I mean. I built an agentic harness &#8212; the orchestration layer I <a href="https://hyperdev.matsuoka.com/its-the-harness-stupid">argued is the real determinant of AI coding outcomes</a>, where the same model can swing more than a quality point depending on the scaffolding around it. I built MCP services, the <a href="https://hyperdev.matsuoka.com/is-this-the-era-of-the-connector">org-specific connectors</a> that replaced a handful of standalone tools in a few hours of directed work each. None of that was a production feature. All of it was infrastructure other people now depend on.</p><p>Here&#8217;s a detail that may make the point. I now have an &#8220;AI architect&#8221; on my leadership team helping maintain the very infrastructure I originally built &#8212; not just the harness, but our inference relationships, our training program, office hours, the real human work I no longer have the time, or the right, to be doing myself. And I expect to hand off more over time. The enabling work I do today partly becomes the system that does tomorrow&#8217;s enabling work. That handoff is the role in miniature: you build the thing that multiplies the team, then you put someone in place to build the next version.</p><p>The proportion matters. Around 30% hands-on keeps judgment fresh without putting me in the critical path. Even full-time senior ICs aren&#8217;t full-time coders &#8212; Bain&#8217;s Jue Wang, quoted in MIT Technology Review last December, put developer coding time at 20&#8211;40%, with the rest going to analysis, strategy, and the surrounding work. A leader at 30% isn&#8217;t doing something exotic. They&#8217;re spending their technical budget on the layer where it compounds.</p><p>The decision is not &#8220;how do I find time to code.&#8221; It&#8217;s &#8220;what enabling work is worth my own hands?&#8221; Those are different questions. The first leads to the bottleneck I watched so many executives become. The second leads somewhere useful.</p><h2>The choice</h2><p>I&#8217;ll resist overselling this, because it isn&#8217;t for everyone and it isn&#8217;t automatic.</p><p>This is a deliberate role, not a default. Staying technically current costs ongoing investment, and the work is often invisible &#8212; enabling infrastructure rarely shows up in a quarterly review the way a shipped feature does. The role is easy to misread, too. From the outside, a CTO who codes can look like a CTO who hasn&#8217;t let go. The defense against that reading is the discipline Majors named: stay out of the critical path. Build the multipliers, not the blockers.</p><p>The returns are real, though. Fresh judgment &#8212; the kind that lets you evaluate not just what and why but how. Trust from engineers who see you in the work rather than above it. And institutional infrastructure that makes the whole team faster, built by the person with both the technical depth and the positional authority to prioritize it.</p><p>There&#8217;s a closing note in the history worth keeping. <em>Bunbu-ry&#333;d&#333;</em> wasn&#8217;t only a personal aspiration. The Tokugawa shogunate institutionalized it &#8212; built career and class structures around the assumption that a leader should be both. China did the same with its examination system. We&#8217;re not there yet. For now, the leader/practitioner is an individual choice, made one person at a time, made viable by tools that finally collapsed the cost of staying hands-on.</p><p>But the precedent suggests where this could go. When a way of working proves durable, organizations eventually build structures around it. The era of the leader/practitioner is early. It is also, I&#8217;d argue, a return &#8212; to an integration we knew was valuable long before we had the means to make it practical again.</p><div><hr></div><p><em>Bob Matsuoka is CTO of <a href="https://www.duettocloud.com/">Duetto</a> and writes about AI-powered engineering at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://hyperdev.matsuoka.com/coding-to-delegation-shift">From Coding with AI to Managing AI</a> &#8212; When agentic coding starts to feel like delegation</p></li><li><p><a href="https://hyperdev.matsuoka.com/its-the-harness-stupid">It&#8217;s The Harness, Stupid!</a> &#8212; Why orchestration quality dominates AI coding outcomes</p></li><li><p><a href="https://aipowerranking.com/">AI Power Ranking</a> &#8212; Tool comparisons and benchmarks for AI practitioners</p></li><li><p><a href="https://www.linkedin.com/newsletters/ai-power-ranking-7345782916301418496/">LinkedIn Newsletter</a> &#8212; Strategic AI insights for CTOs and engineering leaders</p></li></ul>]]></content:encoded></item><item><title><![CDATA[The Other Shoe Has Dropped]]></title><description><![CDATA[The Economics of Enterprise Inference Usage]]></description><link>https://hyperdev.matsuoka.com/p/the-other-shoe-has-dropped</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/the-other-shoe-has-dropped</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Fri, 29 May 2026 11:31:28 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!-Qpp!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!-Qpp!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!-Qpp!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!-Qpp!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!-Qpp!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!-Qpp!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!-Qpp!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png" width="1024" height="768" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:768,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1174362,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/199673840?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!-Qpp!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!-Qpp!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!-Qpp!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!-Qpp!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41ae5cbb-29e9-4a44-96a2-fb1724f0bf79_1024x768.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>Two stories from the last two weeks. Uber <a href="https://fortune.com/2026/05/26/uber-coo-ai-spending-tokens-claude-code/">burned through its entire 2026 AI budget in four months</a> on Claude Code, with COO Andrew Macdonald telling the <em>Rapid Response</em> podcast that the link between that spend and shipped consumer features &#8220;is not there yet.&#8221; <a href="https://www.theinformation.com/newsletters/applied-ai/uber-cto-shows-claude-code-can-blow-ai-budgets">The Information had the underlying numbers a few weeks earlier</a>: engineer adoption from 32% to 84% between December and March, heavy users running $500&#8211;$2,000/month in tokens, and CTO Praveen Neppalli Naga torching $1,200 in a two-hour demo. Same week, Microsoft told thousands of engineers in its Experiences + Devices division that their Claude Code access is going away. <a href="https://www.windowscentral.com/microsoft/microsoft-cancels-claude-code-licenses-shifting-developers-to-github-copilot-cli-a-move-likely-driven-by-financial-motives">Windows Central, summarizing The Verge&#8217;s Notepad scoop</a>, has the cutoff at June 30 &#8212; end of fiscal year &#8212; with cost as the actual driver even though EVP Rajesh Jha framed it publicly as convergence on Copilot CLI.</p><p>Two of the most AI-forward enterprises on the planet, same tool, same week. The &#8220;AI is failing&#8221; takes were live within hours.</p><p>I don&#8217;t buy that framing.</p><p>The headlines are getting it wrong. Uber didn&#8217;t cancel anything &#8212; adoption ran ahead of the budget and the company blew its annual spend keeping up. That&#8217;s a planning failure, not a verdict on the tool. Microsoft didn&#8217;t divorce Anthropic either; they&#8217;re still consuming Claude through Azure Foundry and M365 Copilot. What they cancelled is a specific license &#8212; Claude Code at the engineer-seat level &#8212; because engineers preferred it over GitHub Copilot CLI and the division was paying for that preference.</p><p>What both stories show: AI is a new tool and we haven&#8217;t learned to use it well yet. The teams over budget pointed it at problems it wasn&#8217;t the cheapest way to solve, then let it decide for itself how much work to do per task.</p><p>I&#8217;ve made <a href="https://hyperdev.matsuoka.com/p/what-the-other-shoe-sounds-like-when">the cloud parallel here before</a>. Early cloud was expensive and misused. Lift-and-shift workloads routinely ran two or three times their on-prem cost &#8212; I watched that play out across teams I ran, and it took years to correct through architecture. Then the industry learned: right-sizing, reserved instances, autoscaling, serverless where it fit, on-prem where it didn&#8217;t. The bills came down. Not because compute got dramatically cheaper, but because we got more careful about what we asked the cloud to do. AI is in the same phase. Cheap per-token, expensive per-task, and the gap is architectural.</p><p>A few weeks ago I ran controlled head-to-head tests on Opus 4.6 and Opus 4.7 against identical coding tasks. Both models passed every test. Opus 4.7 cost 3.6&#215; more to do it. Same outcomes, same rate card, dramatically more tokens.</p><p>Finout&#8217;s analysis of production deployments <a href="https://www.finout.io/blog/claude-opus-4.7-pricing-the-real-cost-story-behind-the-unchanged-price-tag">tells the same story at scale</a>: up to a 35% cost increase overnight, driven by tokenizer changes that don&#8217;t show up on the per-token rate card. Not one team&#8217;s bad luck &#8212; the shape of the bill across the enterprise AI buyer base right now. The second of two shoes on AI economics.</p><p>I wrote about that <a href="https://hyperdev.matsuoka.com/p/opus-46-vs-47-the-real-cost-of-incremental">version-to-version cost drift in detail</a>. Providers can collapse per-token prices in public while the per-task bill drifts upward in private. The first shoe was the per-token price collapse that made everyone optimistic. The second is the behavioral and architectural cost overhang now landing on quarterly P&amp;Ls.</p><p><strong>TL;DR</strong></p><ul><li><p>Per-token costs at GPT-3.5-equivalent performance are down roughly 280&#215; since late 2022, per <a href="https://aiindex.stanford.edu/report/">Stanford&#8217;s AI Index 2025</a>. Vendor revenue tells the opposite story: Anthropic&#8217;s annualized revenue went from <a href="https://www.pymnts.com/artificial-intelligence-2/2026/anthropic-hits-30-billion-run-rate-as-enterprise-demand-accelerates/">$1B in January 2025 to $30B by April 2026</a> &#8212; a 30&#215; move in 15 months, coming from enterprise inference, not consumer subscriptions.</p></li><li><p>Gartner&#8217;s April 2026 survey: just 28% of AI use cases fully meet ROI expectations, 78% of IT leaders report material AI charges that didn&#8217;t show up in any procurement model.</p></li><li><p>Gartner estimates agentic workflows consume 5&#8211;30&#215; more tokens than equivalent chatbot interactions; Stanford&#8217;s Digital Economy Lab puts the upper bound for coding agents at 1,000&#215;. The cost driver isn&#8217;t the model &#8212; it&#8217;s the workflow architecture wrapped around it.</p></li><li><p>Two patterns hold the line in production. Search-first architectures put inference at the end of a deterministic pipeline. Consolidated single-shot designs replace multi-call chains.</p></li><li><p>Inference is a power tool, not a default. Use it with specific ROI goals per call, apply it to <em>code</em> solutions rather than to directly solve problems, and bound it with deterministic structure on both ends.</p></li></ul><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!TPPJ!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!TPPJ!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!TPPJ!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!TPPJ!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!TPPJ!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!TPPJ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png" width="1024" height="768" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:768,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1163417,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/199673840?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!TPPJ!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!TPPJ!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!TPPJ!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!TPPJ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F491e72b0-16e1-49fe-a551-391ba05461bc_1024x768.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>Why the Per-Token Savings Didn&#8217;t Reach the Invoice</h2><p>Per-token economics of frontier models have been collapsing for two years. <a href="https://aiindex.stanford.edu/report/">Stanford&#8217;s AI Index 2025</a> puts the decline at roughly 280&#215; from a late-2022 baseline at GPT-3.5-equivalent performance. Most enterprise budget conversations in 2024 started from that headline. The implicit assumption: bills should be going <em>down</em>.</p><p>They&#8217;re not. The clearest read comes from the vendor side. Anthropic&#8217;s annualized revenue <a href="https://www.anthropic.com/news/anthropic-raises-30-billion-series-g-funding-380-billion-post-money-valuation">went from $1B in January 2025 to $30B by April 2026</a>, with roughly 80% from enterprise and API usage rather than consumer subscriptions. Anthropic <a href="https://www.saastr.com/anthropic-just-passed-openai-in-revenue-while-spending-4x-less-to-train-their-models/">now discloses 1,000+ customers spending more than $1M per year</a> &#8212; a cohort that doubled in under two months &#8212; alongside roughly 300,000 business customers. The mid-tier ($100K&#8211;$1M/year) grew 7&#215; year over year.</p><p>Menlo Ventures&#8217; <a href="https://menlovc.com/perspective/2025-the-state-of-generative-ai-in-the-enterprise/">2025 State of Generative AI report</a> cross-checks at the market level: enterprise GenAI spend tripled to $37B in 2025, with LLM API consumption alone at $8.4B by mid-year. The high tier shows up in named deals: <a href="https://sacra.com/c/anthropic/">Snowflake&#8217;s $200M multi-year partnership</a> implies a $50&#8211;70M annual run rate from one customer, and <a href="https://sacra.com/c/anthropic/">Deloitte is deploying Claude across 470,000 employees</a>.</p><p>For a typical enterprise running multiple production AI workloads, $500K&#8211;$2M per year is now the realistic floor. Fortune 100 is running $10M&#8211;$50M+, the most AI-intensive past $100M. The Gartner numbers point the same direction: <a href="https://www.gartner.com/en/newsroom/press-releases/2026-04-07-gartner-says-artificial-intelligence-projects-in-infrastructure-and-operations-stall-ahead-of-meaningful-roi-returns">just 28% of AI use cases fully meet ROI expectations and 20% fail outright</a>, and <a href="https://zylo.com/blog/saas-management-index/">78% of IT leaders report material AI charges</a> that didn&#8217;t show up in any procurement model.</p><p>The per-token chart is real. The invoice is also real. What closes the gap is <em>behavior</em>. Three behaviors specifically.</p><p><strong>Models do more work per task.</strong> Reasoning models reason. Agentic loops loop. The prompt that used to consume 4K tokens now consumes 40K because the assistant explores, plans, second-guesses, and verifies. Some of that is valuable. Much of it is the model performing thoroughness in a way that costs you money. The Opus 4.6-to-4.7 jump I documented earlier: same task, same outcome, 2.9&#215; more output tokens and 4.8&#215; more cache reads.</p><p><strong>Workflows fan out.</strong> A &#8220;single&#8221; task in a modern agentic system might trigger a planner, researcher, coder, reviewer, and summarizer. Each makes its own LLM calls over overlapping context. Gartner&#8217;s March 2026 analysis puts agentic workflows at 5&#8211;30&#215; the token consumption of an equivalent chatbot ask. Stanford Digital Economy Lab&#8217;s April 2026 arXiv paper goes further: coding agents can consume 1,000&#215; more tokens than equivalent chat completions. The agent isn&#8217;t more expensive because it&#8217;s smarter. It&#8217;s more expensive because it&#8217;s louder.</p><p><strong>Context windows fill themselves.</strong> Long context is a feature in marketing and a bill in practice. In our own enterprise Claude.AI usage &#8212; 82,852 messages from 329 employees over 3.5 months, audited via the Anthropic Compliance API &#8212; the average request carried 366,000 input tokens, mostly from 10-turn conversations dragging accumulated history forward into every new turn. Most production systems I&#8217;ve audited show the same fingerprint: pipelines paying for context they aren&#8217;t actually using.</p><p>None of this is fraud and none of it is mysterious. It&#8217;s the natural consequence of letting probabilistic systems decide how much work to do on every call. The savings from cheaper tokens were real. They just got consumed by an order of magnitude more tokens per task.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!T_ba!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!T_ba!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!T_ba!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!T_ba!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!T_ba!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!T_ba!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png" width="1024" height="768" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/c7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:768,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1253809,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/199673840?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!T_ba!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!T_ba!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!T_ba!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!T_ba!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fc7441c01-b144-4b0c-83a2-113c2bb730fd_1024x768.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>What I&#8217;ve Found Shipping These Systems</h2><p>The teams handling this well aren&#8217;t the ones cutting AI usage. They&#8217;re changing the <em>shape</em> of how they use it.</p><p>The pattern I keep coming back to: treat inference as the expensive step at the end of a mostly deterministic pipeline. Do the cheap, structured work in code. Reserve the model call for the part that actually requires judgment. Then bound the call hard &#8212; context budget, output budget, quality gate on whether the call even runs.</p><p>Two examples from systems I&#8217;ve been building illustrate this from different angles.</p><h3>Example 1: Code-Intelligence &#8212; Search-First Architecture</h3><p>The naive version of a code review tool is obvious: dump the changed files into Claude, ask for a review. That works. It also costs roughly $0.03 per operation, scales linearly with repo size, and produces a lot of review output you didn&#8217;t need. Claude.AI offers a code review service &#8212; it ended up costing us thousands a month for just a few repos. Augment Code offers a well-regarded one as a GitHub app, but charges a platform fee (a meaningful fraction of our Anthropic spend) <em>just</em> to connect.</p><p>So we built our own. It leverages a multimodal search/RAG/KG engine I&#8217;d already built, so this wasn&#8217;t from scratch.</p><p>The version I actually ship uses a multi-tier search pipeline with the LLM call at the very end:</p><pre><code><code>Stage 1: Vector Search    (~$0.0002 per query, semantic similarity)
Stage 2: BM25 Reranking   (~$0.0001 per query, lexical relevance)
Stage 3: Static Analysis  (~$0.0001 per query, AST + symbol resolution)
Stage 4: Quality Gate     (free, deterministic threshold check)
Stage 5: Single LLM Call  (~$0.03 per call, only if Stages 1-4 passed)</code></code></pre><p>The first four stages cost about $0.0004 combined. They do the bulk of the work: deciding <em>what code is actually relevant</em>, ranking it, pulling structural relationships, and deciding whether the result is even worth asking an LLM about.</p><p>Hard budget controls run through the whole pipeline:</p><pre><code><code># Budget enforcement, not aspiration
MAX_CONTEXT_FILES = 6          # cap on what we send to the model
MAX_REVIEW_WORDS = 500         # cap on what the model returns
RELEVANCE_FLOOR = 0.005        # quality gate before calling the model

if combined_relevance_score &lt; RELEVANCE_FLOOR:
    # no point spending $0.03 to get a review of weakly-related code
    return SkipReason("below relevance floor")

context = select_top_n(ranked_results, MAX_CONTEXT_FILES)
review = llm.review(context, max_output_tokens=MAX_REVIEW_WORDS * 1.4)</code></code></pre><p>The <code>RELEVANCE_FLOOR</code> check is the part to underline. A meaningful percentage of review requests in real codebases don&#8217;t justify an LLM call at all &#8212; the changes are mechanical, the related code trivial, or the search signal weak enough that whatever the model says will be hallucinated context. Refusing to spend $0.03 on those cases is where most of the savings come from.</p><p>Rough economics across a quarter of usage:</p><p>Approach Cost per operation LLM calls per 1K operations Direct &#8220;review the diff&#8221; ~$0.030 1,000 Search-first with gates ~$0.0034 average ~430</p><p>About 80% of the workflow logic ends up deterministic: search, ranking, static analysis, gating. The model handles the last 20% &#8212; judgment on curated context. Same outcome from the user&#8217;s perspective, roughly an order of magnitude cheaper, with more predictable failure modes because most of the pipeline is debuggable code rather than prompt behavior.</p><p>The limitation: this is more work than wiring up a single LLM call, and the gates are only as good as your search infrastructure. The payoff is on the cost and determinism side, not on speed of initial implementation.</p><h3>Example 2: duetto-intelligence &#8212; Context Injection Instead of Replacement</h3><p>The second pattern comes from duetto-intelligence, internal tooling I&#8217;ve been building against that same enterprise Claude.AI usage &#8212; 82,852 real employee messages over 3.5 months, not a thought experiment. The problem here isn&#8217;t &#8220;should we call the LLM at all.&#8221; It&#8217;s: given that our people are already routing structured-data questions through a $0.274-per-request multi-turn Sonnet conversation, what&#8217;s a cheaper path that doesn&#8217;t degrade the answer?</p><p>The audit data made the gap concrete. Average request: 366K input tokens, ten-turn conversation, $0.274 to Anthropic. The same query answered through a Haiku single-pass against deterministically-retrieved internal data: $0.0009. A 300:1 cost ratio on the slice of traffic about structured product knowledge, CRM/account prep, JIRA, people and org lookups.</p><p>Not all traffic. Somewhere in the 35&#8211;40% range based on classified samples. About half of remaining queries genuinely need full Sonnet or Opus reasoning &#8212; writing, debugging, free-form analysis &#8212; and shouldn&#8217;t be intercepted at all.</p><p>The framing matters, because it&#8217;s easy to mis-read this as &#8220;replace Claude with a smaller model.&#8221; It isn&#8217;t. duetto-intelligence acts as a <strong>context injection layer</strong> in front of the user-facing model. When a query has structured-data intent, we route a sub-query to DI, get back a bounded structured result, and inject that into the prompt the larger model sees. The expensive model still does the reasoning &#8212; it just stops being responsible for the deterministic data retrieval it&#8217;s bad at and expensive for.</p><p>The naive design for the routing layer looks like this:</p><pre><code><code>1. Classify the user's intent             &#8594; LLM call (~150 tokens)
2. Plan which subsystems to query         &#8594; LLM call (~250 tokens)
3. Call subsystem A, summarize response   &#8594; LLM call (~300 tokens)
4. Call subsystem B, summarize response   &#8594; LLM call (~300 tokens)
5. Synthesize a final answer              &#8594; LLM call (~250 tokens)
                                          Total: ~1,250 tokens, 5 calls</code></code></pre><p>Each call is plausible on its own. Together they&#8217;re a tax on every user interaction. Latency stacks linearly with calls, and any one of the five can hallucinate in a way that corrupts the rest of the chain.</p><p>The consolidated design replaces three steps with deterministic code:</p><pre><code><code>1. Classify intent                  &#8594; LLM call  (~80 tokens, tight tagger prompt)
2. Fan-out to subsystems            &#8594; code      (0 tokens, intent &#8594; call map)
3. Consolidated synthesis           &#8594; LLM call  (~200 tokens, structured input)
                                       Total: ~280 tokens, 2 calls</code></code></pre><p>The trick is the intent classifier. It produces a tag from a fixed vocabulary of 87 tags &#8212; <code>revenue.query.ytd</code>, <code>forecast.compare.year_over_year</code>, <code>account.lookup.contact</code>, and so on. Each tag maps deterministically to a set of downstream calls in plain Python. No LLM in the routing step. The model isn&#8217;t asked &#8220;what should we do?&#8221; It&#8217;s asked &#8220;what is the user asking about?&#8221; &#8212; a much smaller, bounded question.</p><p>We validated against a 50-query test corpus drawn directly from the compliance data &#8212; real questions people had asked the model in production. After tuning, 100% of those queries land on the fast path with no LLM call required for routing. That&#8217;s the proof the deterministic-discipline part holds at the boundary; the routing isn&#8217;t quietly falling back to a second model call to bail itself out.</p><p>Budget enforcement is explicit in every prompt template:</p><pre><code><code>SOURCE_CHAR_BUDGET = 600    # per data source pulled into context
OUTPUT_TOKEN_BUDGET = 200   # cap on synthesis response
INTENT_TAG_VOCAB = load_intent_taxonomy()  # 87 tags, versioned

def synthesize(intent_tag: str, sources: list[Source]) -&gt; str:
    trimmed = [s.truncate(SOURCE_CHAR_BUDGET) for s in sources]
    return llm.complete(
        prompt=template(intent_tag, trimmed),
        max_tokens=OUTPUT_TOKEN_BUDGET,
    )</code></code></pre><p>The economics, against measured baselines rather than estimates: current Claude.AI Chat spend across the 329-user population runs $15,264 over 3.5 months. Roughly $4,360/month, driven by that $0.274-per-request multi-turn average. If DI intercepts the 35&#8211;40% of traffic that&#8217;s structured-retrieval underneath, projected savings come in around $1,500&#8211;1,700/month, or $18&#8211;20K/year on this single user population. The leverage isn&#8217;t from picking a cheaper model. It&#8217;s from refusing to pay Sonnet rates to answer questions a deterministic system already has the data for.</p><p>The intent vocabulary is the contract. New capability means a new tag, a new downstream mapping, a new prompt template. The model never has to invent structure on the fly. This is what people mean by &#8220;use the LLM to code solutions, not to solve problems directly&#8221; &#8212; the routing logic lives in code, the tagger is a thin call, the synthesis is bounded.</p><p>The source-character budget matters more than the output budget. The compliance audit confirmed it: production overspend is on the <em>input</em> side. 366K input tokens against a few hundred output. Models will happily consume whatever context you hand them. Trimming at the source &#8212; 600 characters per source, no exceptions &#8212; is how you keep per-call cost from drifting upward as the system gets more capable.</p><p>The limitation: this only works on the routable slice. The pattern isn&#8217;t &#8220;eliminate inference.&#8221; It&#8217;s &#8220;stop spending $0.274 to answer questions that have a structured answer at $0.0009.&#8221;</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!-uHZ!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!-uHZ!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!-uHZ!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!-uHZ!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!-uHZ!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!-uHZ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png" width="1024" height="768" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/fe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:768,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1351360,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/199673840?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!-uHZ!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png 424w, https://substackcdn.com/image/fetch/$s_!-uHZ!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png 848w, https://substackcdn.com/image/fetch/$s_!-uHZ!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png 1272w, https://substackcdn.com/image/fetch/$s_!-uHZ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffe0775c6-8743-46e4-908a-ee4e2a8db5d6_1024x768.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>Why &#8220;Just Use a Cheaper Model&#8221; Doesn&#8217;t Save You</h2><p>A reasonable objection: aren&#8217;t the cheaper, smaller models supposed to handle this? Why not route everything to Haiku or an open model and call it solved?</p><p>The pricing math seems to support it. The behavioral math doesn&#8217;t.</p><p>Two things go wrong when you swap a cheaper model into an unstructured workflow. Cheaper models are usually less efficient <em>per task</em> &#8212; more turns to converge, more exploration, more hallucination, which means more retries and verification calls. A model 5&#215; cheaper per token can run 1.5&#8211;2&#215; more expensive per completed task if your workflow lets it spin.</p><p>And the workflow itself is where most of the cost lives. The 5&#8211;30&#215; multiplier is structural, not modal &#8212; it exists regardless of which model you point at it. Switching from Sonnet to Haiku inside an unbounded agent loop changes the per-token cost. It doesn&#8217;t change the loop.</p><p>Model choice is a 2&#8211;5&#215; lever. Architecture choice is closer to an order-of-magnitude lever in the systems I&#8217;ve shipped &#8212; consistently larger than what model swaps deliver. Most teams are over-tuning the model selection and under-tuning the structure around it.</p><p>The default assumption &#8212; including from vendors with strong incentives to sell you more tokens &#8212; is that the answer to AI cost is buying inference more cleverly. The actual answer is using inference less, more deliberately, with hard bounds on what each call is allowed to do.</p><h2>How I Think About Inference Now</h2><p><strong>Inference is a power tool.</strong> Not a default. You don&#8217;t reach for it when a search query, a regex, or a <code>switch</code> statement would do. You reach for it when you need probabilistic judgment over unstructured input. Every call you don&#8217;t make is the cheapest call.</p><p><strong>Use it to code solutions, not to solve problems.</strong> The highest-leverage use of LLMs in my workflow is generating the deterministic code that then handles the workflow without further LLM calls. A model that writes you a 50-line classifier is more valuable than a model that <em>acts as</em> the classifier on every request forever. The first costs tokens once. The second costs tokens every transaction for the life of the system.</p><p><strong>Wrap every call in a budget.</strong> Context budget on the input, token budget on the output, quality gate on whether the call runs at all. Treat the LLM call as you&#8217;d treat a paid API with rate limits and SLA penalties. Because it is.</p><p><strong>Set specific ROI targets per call.</strong> &#8220;AI-assisted code review&#8221; is too coarse to optimize. &#8220;Reviewing files with relevance score &gt; 0.005, capped at 6 files, returning 500 words&#8221; is something you can measure cost-per-outcome on. Even loose ROI math at the call level surfaces where you&#8217;re paying for theater.</p><p><strong>Treat behavioral cost as the primary risk.</strong> Model rate cards will keep coming down. They are not your problem. Your problem is what your pipeline asks of the model and what the model decides to do once asked. That&#8217;s the line item that grew while the unit cost dropped 280&#215;. That&#8217;s the shoe that just dropped.</p><h2>What This Means If You&#8217;re Running an AI Budget</h2><p>Three things to look at, in order of how much they&#8217;ll move the line item.</p><p><strong>Audit the call graph, not the rate card.</strong> Pull a representative day of production traffic and trace the actual LLM calls per user task. Count them. Most teams find a handful of workflows producing the majority of cost, and most of those have 2&#8211;4 LLM calls that could be replaced by deterministic code. That&#8217;s the consolidated-design pattern from the duetto-intelligence example. 50&#8211;80% reductions are common when you actually look.</p><p><strong>Put quality gates in front of inference.</strong> For any workflow where the LLM call is expensive and the input quality is variable, add a deterministic check that decides whether the call is worth making. That&#8217;s the search-first pattern from the code-intelligence example. The savings come from the calls you <em>don&#8217;t</em> make, which never show up on the invoice.</p><p><strong>Set hard context budgets and enforce them in code.</strong> Per-source character limits, per-call token caps, no &#8220;just in case&#8221; context stuffing. The output budget gets attention because it&#8217;s visible. The input budget is usually where the actual money goes.</p><p>None of this requires changing models, switching providers, or making bets on the next frontier release. It&#8217;s architectural work inside the pipeline you already have &#8212; work the per-token price chart has been letting people defer.</p><p>The teams that do it over the next two quarters will look like they got a 5&#8211;10&#215; cost improvement from &#8220;AI getting cheaper.&#8221; The teams that don&#8217;t will look like AI got 3&#8211;4&#215; more expensive while everyone else&#8217;s costs fell. Same providers, same models, same rate cards. Different shoe.</p><div><hr></div><p><em>Bob Matsuoka is CTO of <a href="https://www.duettocloud.com/">Duetto</a> and writes about AI-powered engineering at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://hyperdev.matsuoka.com/p/opus-46-vs-47-the-real-cost-of-incremental">Opus 4.6 vs 4.7: The Real Cost of Incremental AI Improvements</a> &#8212; The first shoe, on per-task cost drift between model versions</p></li><li><p><a href="https://aipowerranking.com/">AI Power Ranking</a> &#8212; Tool comparisons and benchmarks for AI practitioners</p></li><li><p><a href="https://www.linkedin.com/newsletters/ai-power-ranking-7345782916301418496/">LinkedIn Newsletter</a> &#8212; Strategic AI insights for CTOs and engineering leaders</p></li></ul><p></p>]]></content:encoded></item><item><title><![CDATA[Is Your Digital Brain the Light Saber of the AI Era?]]></title><description><![CDATA[Jedi Knight Tools for the Knowledge Worker]]></description><link>https://hyperdev.matsuoka.com/p/is-your-digital-brain-the-light-saber</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/is-your-digital-brain-the-light-saber</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Wed, 20 May 2026 12:02:03 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!90qs!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!90qs!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!90qs!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png 424w, https://substackcdn.com/image/fetch/$s_!90qs!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png 848w, https://substackcdn.com/image/fetch/$s_!90qs!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png 1272w, https://substackcdn.com/image/fetch/$s_!90qs!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!90qs!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png" width="1456" height="1007" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:1007,&quot;width&quot;:1456,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:5326200,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/198515384?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!90qs!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png 424w, https://substackcdn.com/image/fetch/$s_!90qs!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png 848w, https://substackcdn.com/image/fetch/$s_!90qs!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png 1272w, https://substackcdn.com/image/fetch/$s_!90qs!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6533e48e-54c3-4232-aa80-b2fe447f0136_1993x1378.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Your Digital Lightsaber is your AI Memory</figcaption></figure></div><p>My Duetto colleague Jake Becker is sharp. He&#8217;s been ahead of AI adoption on our team &#8212; experimenting early, pushing for new tools, staying current. Last week he messaged me on Slack: &#8220;I wish I had my own CTO Assistant. Like what you have.&#8221;</p><p>I paused.</p><p>I have one. I&#8217;ve had several, in different forms, going back months. But I hadn&#8217;t said anything about it publicly.</p><p>That gap &#8212; between an AI-forward person who knows the tools and a practitioner who actually has the thing &#8212; is what this piece is about.</p><p><strong>TL;DR</strong></p><ul><li><p>Off-the-shelf AI tools are capable but contextually blind. You still have to leave your domain to get help.</p></li><li><p>Serious knowledge workers &#8212; writers, researchers, historians &#8212; have always built their own knowledge systems. Never trusted a vendor to hold their material.</p></li><li><p>Coding is shifting toward what writing has always been: directing, curating, maintaining a living body of knowledge.</p></li><li><p>Building your own AI memory and search layer is the new rite of passage. The tool you build IS the skill being developed.</p></li><li><p>The latest versions of my own stack: trusty-memory and trusty-search &#8212; both open source, both installable today.</p></li></ul><h2>Everyone Wants One. Few Have One.</h2><p>Jake&#8217;s comment revealed something I&#8217;d been taking for granted.</p><p>The major vendors are actively working on this &#8212; memory features, RAG pipelines, personalization layers. But those solutions are optimized for breadth, not for one person&#8217;s actual work across functions.</p><p>ChatGPT, Claude, Copilot &#8212; these are all capable. They&#8217;re also still contextually blind to <em>you</em>. You have to leave your environment, paste in context, explain your situation from scratch, then interpret the output back into your actual work. Vendors are working on it. But the solutions remain generic, and every session still starts from zero.</p><p>I wrote about this in March &#8212; <a href="https://hyperdev.matsuoka.com/personal-bots-abomination">Everyone Blamed Clawd Bot&#8217;s Execution. The Concept Was the Problem.</a> The structural flaw of universal assistants isn&#8217;t fixable. They require you to leave your context to get help. What actually works is the opposite: your tools get assistant capabilities, and assistance comes to where your context lives.</p><p>Off-the-shelf tools haven&#8217;t solved this. They&#8217;ve gotten more powerful &#8212; better reasoning, longer context, faster inference &#8212; but they still don&#8217;t know your codebase, your decisions, your institutional history, your current sprint. They know a lot about the world, and very little about you.</p><p>Jake wanted <em>my</em> assistant. But what he actually wants is <em>his</em> assistant. The one that knows what he knows.</p><p>That&#8217;s a different problem entirely.</p><p>The job changed first.</p><h2>Coding Is Becoming Writing</h2><p>Practitioners feel it before analysts name it.</p><p>A few years ago, being a strong engineer meant writing a lot of code quickly and correctly. Today, with agentic AI coders at their disposal, the best engineers I watch spend their time directing, reviewing, specifying, and curating. The unit of work has moved up a level. Implementation is increasingly delegated. Judgment &#8212; about architecture, trade-offs, what to build and why &#8212; is the differentiator.</p><p>This is not what happens when automation replaces a skill. It&#8217;s what happens when a new discipline appears.</p><p>Writers have always worked this way. A novelist doesn&#8217;t produce words per minute as a primary metric. They produce decisions &#8212; what to say, in what order, with what emphasis. The words are the output of the decisions, not the work itself. What makes a writer productive over a career isn&#8217;t typing speed. It&#8217;s having a system: notes, research, accumulated material, patterns of thought that compound over years.</p><p>Some (typically senior) engineers are arriving at the same realization. Your value isn&#8217;t the code. It&#8217;s the judgment, the accumulated context, the knowledge of what was tried and why it failed. The question is whether that accumulates in your head alone &#8212; which doesn&#8217;t scale, and doesn&#8217;t survive a context switch &#8212; or whether it lives in a system.</p><p>Good engineers who learn to use their AI tools effectively generate better code &#8212; the stack amplifies judgment and accumulated knowledge. The gap isn&#8217;t between skilled and unskilled engineers in isolation; it&#8217;s between engineers who&#8217;ve wired their knowledge into their tools and those who haven&#8217;t. The knowledge is real in both cases. Only in one case does it compound.</p><p>The writers I&#8217;ve observed who sustain serious output over decades all have the same property: they know where things are. Their research is retrievable. Their earlier thinking is available to their current thinking. The system makes the person bigger than their working memory.</p><p>That&#8217;s the gap.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!Ynth!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!Ynth!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png 424w, https://substackcdn.com/image/fetch/$s_!Ynth!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png 848w, https://substackcdn.com/image/fetch/$s_!Ynth!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png 1272w, https://substackcdn.com/image/fetch/$s_!Ynth!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!Ynth!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png" width="1456" height="894" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/dd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:894,&quot;width&quot;:1456,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:5603002,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/198515384?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!Ynth!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png 424w, https://substackcdn.com/image/fetch/$s_!Ynth!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png 848w, https://substackcdn.com/image/fetch/$s_!Ynth!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png 1272w, https://substackcdn.com/image/fetch/$s_!Ynth!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd8f91e4-5bab-49cc-8f75-bb43db12e9e7_1999x1227.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption"> The AI Zettelkasten</figcaption></figure></div><h2>Writers Don&#8217;t Trust Vendors With Their Material</h2><p>Niklas Luhmann, a German sociologist working in the 1950s, produced 70 books and nearly 400 articles over his career. I haven&#8217;t written a book yet &#8212; but I have published over 200 articles at HyperDev. Worth naming the parallel. He credits his output to his Zettelkasten &#8212; a slip-box system of 90,000 interconnected index cards, each with a unique identifier linking it to related thoughts. Not a filing cabinet. A network of ideas that got richer with every addition.</p><p>And it&#8217;s worth asking: is that so different from what an AI knowledge system does today? The Zettelkasten was an analog precursor to what trusty-memory and trusty-search do programmatically &#8212; indexing ideas, linking related thoughts, surfacing connections that wouldn&#8217;t otherwise be visible. Luhmann was doing manually what these tools do automatically. Same architecture. New substrate.</p><p>He didn&#8217;t use a vendor product. He built a system that reflected how he thought. The architecture of his Zettelkasten was itself an expression of his intellectual method.</p><p>This isn&#8217;t a historical quirk. It&#8217;s a pattern. Serious knowledge workers have always built their own systems &#8212; commonplace books, research archives, private wikis. The reason is structural: the schema you design reflects how you think. That&#8217;s not something a product gives you. A product gives everyone the same schema.</p><p>Andrej Karpathy pointed at something similar last month with his LLM Wiki gist. His framing: use LLMs not just to write code, but to build and maintain a personal knowledge base. &#8220;Obsidian is the IDE, the LLM is the programmer, the wiki is the codebase.&#8221; Three folders, structured Markdown, a large context window. He concluded: &#8220;I think there is room here for an incredible new product.&#8221;</p><p>He&#8217;s right there&#8217;s room. I wrote about his framing in <a href="https://hyperdev.matsuoka.com/whats-in-your-second-brain">What&#8217;s In Your Second Brain?</a> The product comment is where I&#8217;d push back. You can build tooling around the pattern. You can&#8217;t productize the schema. The schema is the moat &#8212; because it reflects how <em>you</em> think, not how a product manager thinks you think. The ones who get it aren&#8217;t waiting for a product.</p><h2>The Lightsaber Rite of Passage</h2><p>In Star Wars canon, a Padawan doesn&#8217;t receive a lightsaber. They build one.</p><p>The ritual is called the Gathering. Initiates travel alone to the Crystal Caves of Ilum. They have to find their kyber crystal &#8212; the crystal that&#8217;s attuned to them through the Force. The caves are shaped by the initiate&#8217;s own fears and insecurities. The crystal doesn&#8217;t go to the strongest or the fastest. It bonds with the person who confronts what&#8217;s in the way.</p><p>Then they build it themselves, guided by Professor Huyang.</p><p>You can&#8217;t buy this. You can&#8217;t inherit it. The construction is the training. The tool reflects the builder.</p><p>I&#8217;m not the first to reach for this metaphor in tech. But I think it lands differently now. Building your own AI memory and search layer isn&#8217;t just useful. It&#8217;s diagnostic. You can&#8217;t do it without confronting what you actually know, how you actually think, what deserves to persist and what doesn&#8217;t. The schema you design for your knowledge base is a statement about your mind.</p><p>The engineers I know who are operating at the highest level right now &#8212; CTOs, senior architects, tech leads at places moving fast &#8212; they all quietly roll their own. They don&#8217;t announce it. They just have it.</p><h2>My Own Lineage</h2><p>I&#8217;ve been building versions of this for months.</p><p>trusty-izzie was the first &#8212; a simple wrapper. Then ai-commander, a more structured approach to context management. Then open-mpm and claude-mpm, which was where I started thinking seriously about multi-agent orchestration. Then kuzu-memory, a graph-backed memory layer. Then mcp-vector-search, semantic search over my entire codebase.</p><p>Each iteration taught me something about what I actually needed. Not what I thought I needed. What the practice revealed.</p><p>This piece was drafted with a configured writing assistant &#8212; <a href="https://github.com/bobmatnyc/claude-mpm">claude-mpm</a> loaded with my publication style guide, my voice patterns, my article archive. That&#8217;s a saber too. Not a generic chat interface. A tool shaped around how I think and write, producing work I can actually publish rather than work I have to fix. The saber list keeps growing.</p><p>The latest two are the most capable tools I&#8217;ve built.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!cyse!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!cyse!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png 424w, https://substackcdn.com/image/fetch/$s_!cyse!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png 848w, https://substackcdn.com/image/fetch/$s_!cyse!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png 1272w, https://substackcdn.com/image/fetch/$s_!cyse!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!cyse!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png" width="1456" height="1030" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:1030,&quot;width&quot;:1456,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:6229361,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/198515384?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!cyse!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png 424w, https://substackcdn.com/image/fetch/$s_!cyse!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png 848w, https://substackcdn.com/image/fetch/$s_!cyse!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png 1272w, https://substackcdn.com/image/fetch/$s_!cyse!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0fc209a6-05f2-4b6d-8950-09c7562bd1ac_2005x1419.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The Latest Sabers</h2><p><strong>trusty-memory</strong> is a machine-wide AI memory daemon written in Rust. It uses what I call the Memory Palace architecture &#8212; multiple named palaces, each for a different domain. Sub-5ms baseline retrieval on Apple Silicon. It runs as an MCP server for Claude Code, which means my assistant stores and retrieves memories automatically, across sessions, without me managing any of it explicitly.</p><pre><code><code>cargo install trusty-memory</code></code></pre><p>Available at <a href="https://crates.io/crates/trusty-memory">crates.io/crates/trusty-memory</a>.</p><p><strong>trusty-search</strong> is a machine-wide hybrid code search daemon, also in Rust. Always-on, one install per machine. It combines BM25 lexical search with HNSW vector search (all-MiniLM-L6-v2 INT8) and a Knowledge Graph with 1-2 hop expansion, fused via Reciprocal Rank Fusion. It exposes an MCP server with 11 tools. Stdio and HTTP/SSE transports drop straight into Claude Code.</p><pre><code><code>cargo install trusty-search</code></code></pre><p>Available at <a href="https://crates.io/crates/trusty-search">crates.io/crates/trusty-search</a>.</p><p>These tools, along a set of custom reporting pythons apps along with a custom Slack Bot I use to access the data remotely, comprise my digital brain.</p><p>These aren&#8217;t products I bought. These are tools I built, iterated, and use daily. They know my codebase the way a Zettelkasten knows a scholar&#8217;s intellectual territory &#8212; not because a vendor configured them, but because I did.</p><p>To be precise: trusty-memory and trusty-search are infrastructure utilities &#8212; the memory layer and the search layer. Building the actual assistant that uses them is a separate act of customization. That&#8217;s where the lightsaber metaphor completes: the kyber crystal is only part of it. The construction &#8212; what you build with the crystal &#8212; is the saber.</p><p>When Jake said he wished he had a CTO Assistant, this is what he was gesturing at. Not a prompt template. Not a workflow. A living knowledge layer that compounds.</p><h2>The Right Question</h2><p>Jake asked: &#8220;Can I get a CTO Assistant?&#8221;</p><p>That&#8217;s the wrong question. It assumes the thing is available off the shelf, and the task is finding and configuring it.</p><p>The right question is: &#8220;What would it take to build one that knows what I know?&#8221;</p><p>That question is harder. It requires confronting the shape of your knowledge, what&#8217;s worth persisting, how to structure retrieval. It&#8217;s uncomfortable in the same way the Crystal Caves are uncomfortable &#8212; not because the work is technically difficult, but because you have to be honest about what you actually have.</p><p>Not everyone needs to write Rust. The specific technology isn&#8217;t the point. The point is that the engineers asking the right question are already operating differently. They&#8217;re working like writers &#8212; maintaining a living body of knowledge, building systems that compound, treating their accumulated context as an asset rather than a liability.</p><p>Writers&#8217; discipline has been creeping into engineering for a while. AI made it urgent.</p><p>If you&#8217;re waiting for a product to hand you the thing, you&#8217;re waiting for someone to build your lightsaber. It won&#8217;t be yours.</p><div><hr></div><p><em>Bob Matsuoka is CTO of <a href="https://www.duettocloud.com/">Duetto</a> and writes about AI-powered engineering at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://hyperdev.matsuoka.com/whats-in-your-second-brain">What&#8217;s In Your Second Brain?</a> &#8212; Karpathy&#8217;s LLM Wiki and the case for a compounding knowledge layer</p></li><li><p><a href="https://hyperdev.matsuoka.com/personal-bots-abomination">Everyone Blamed Clawd Bot&#8217;s Execution. The Concept Was the Problem.</a> &#8212; Why universal assistants are architecturally broken</p></li><li><p><a href="https://aipowerranking.com/">AI Power Ranking</a> &#8212; Tool comparisons and benchmarks for AI practitioners</p></li><li><p><a href="https://www.linkedin.com/newsletters/ai-power-ranking-7345782916301418496/">LinkedIn Newsletter</a> &#8212; Strategic AI insights for CTOs and engineering leaders</p></li></ul>]]></content:encoded></item><item><title><![CDATA[What’s In Your Second Brain?]]></title><description><![CDATA[Tooling for the modern CTO]]></description><link>https://hyperdev.matsuoka.com/p/whats-in-your-second-brain</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/whats-in-your-second-brain</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Mon, 04 May 2026 13:26:26 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!oH6q!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<p></p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!oH6q!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!oH6q!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png 424w, https://substackcdn.com/image/fetch/$s_!oH6q!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png 848w, https://substackcdn.com/image/fetch/$s_!oH6q!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png 1272w, https://substackcdn.com/image/fetch/$s_!oH6q!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!oH6q!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png" width="1024" height="649" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:649,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1458693,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/196419582?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa25c8af5-4b58-4f5d-b775-532bd485770e_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!oH6q!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png 424w, https://substackcdn.com/image/fetch/$s_!oH6q!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png 848w, https://substackcdn.com/image/fetch/$s_!oH6q!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png 1272w, https://substackcdn.com/image/fetch/$s_!oH6q!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F30309841-bfd3-4d55-a5d2-03d8d872cc9b_1024x649.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>The modern CTO toolkit isn&#8217;t just apps and coding tools. The real differentiator is a custom knowledge layer &#8212; databases, search indices, memory graphs, behavioral instructions that compound over time. No product gives you this. You build it.</p><p><a href="https://karpathy.ai/">Andrej Karpathy</a> gestured at something similar last month when he posted a <a href="https://gist.github.com/karpathy/442a6bf555914893e9891c11519de94f">GitHub Gist</a> he called &#8220;LLM Wiki.&#8221; His framing: stop using LLMs <em>just</em> to write code, use them to build and maintain a personal knowledge base instead. <em>&#8220;Obsidian is the IDE, the LLM is the programmer, the wiki is the codebase.&#8221;</em> Three folders, structured Markdown, a large context window, a few Python scripts. No RAG, no vector database. He concluded with: <em>&#8220;I think there is room here for an incredible new product.&#8221;</em></p><p>He&#8217;s right that there&#8217;s room. But the product comment is where I&#8217;d push back, and I&#8217;ll get to that. What Karpathy is describing isn&#8217;t a note-taking system. It&#8217;s a personal operational knowledge layer. For CTOs specifically, that layer needs to be broader than a personal wiki &#8212; it needs live organizational data, agent-connected search, and context that persists across months of decisions. No app hands you that.</p><h2>TL;DR</h2><ul><li><p>Karpathy&#8217;s LLM Wiki shows the direction: LLMs as knowledge compilers, not just code generators</p></li><li><p>A modern CTO&#8217;s &#8220;second brain&#8221; is more than PKM &#8212; it&#8217;s live databases, custom agents, and contextual search across organizational data</p></li><li><p>When I joined Duetto as CTO, my custom toolkit let me synthesize a 150-person R&amp;D org in weeks instead of months</p></li><li><p>The power isn&#8217;t Obsidian. It&#8217;s what you connect to it &#8212; MCP servers, search indices, knowledge graphs</p></li><li><p>Productizing this is theoretically possible and practically very hard, because the schema is the moat</p></li></ul><h2>The toolkit article got it half right</h2><p>In <a href="https://hyperdev.matsuoka.com/p/whats-in-my-claude-code-toolkit">What&#8217;s In My Toolkit: Claude Code and Family</a>, I wrote about vanilla Claude Code&#8217;s core limitations: context evaporates, code search is keyword-based, memory doesn&#8217;t persist, execution is single-threaded. The tools I built &#8212; <a href="https://github.com/bobmatnyc/claude-mpm">Claude MPM</a>, <a href="https://github.com/bobmatnyc/mcp-vector-search">mcp-vector-search</a>, <a href="https://github.com/bobmatnyc/kuzu-memory">kuzu-memory</a> &#8212; address each of those gaps.</p><p>But that article was about coding workflows. The real story is broader.</p><p>The same architecture that makes a coding session more effective &#8212; persistent memory, semantic search, specialized agents pulling from structured data &#8212; turns out to be extraordinarily useful for executive work. Understanding an organization, tracking decisions over time, querying data across systems, maintaining context across months of meetings and analysis. The toolkit I built for software development became the toolkit I used to onboard as a CTO.</p><p><a href="https://hyperdev.matsuoka.com/p/i-built-a-coding-tool-then-i-used">That onboarding story</a> is documented in detail elsewhere. Short version: I pointed a multi-agent framework at GitHub, JIRA, Slack, Confluence, and budget spreadsheets, and synthesized a 150-person R&amp;D organization in the weeks before my start date. The difference between doing that with a chat interface versus a CLI-based orchestration layer with parallel agents and persistent memory wasn&#8217;t 2x or 5x. It was closer to 10x.</p><p>But the onboarding was just the starting gun. The second brain I assembled keeps compounding.</p><h2>What&#8217;s actually in my second brain</h2><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!ICJf!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!ICJf!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png 424w, https://substackcdn.com/image/fetch/$s_!ICJf!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png 848w, https://substackcdn.com/image/fetch/$s_!ICJf!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!ICJf!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!ICJf!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png" width="1024" height="1024" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/d86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:1024,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1082407,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/196419582?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!ICJf!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png 424w, https://substackcdn.com/image/fetch/$s_!ICJf!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png 848w, https://substackcdn.com/image/fetch/$s_!ICJf!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!ICJf!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd86cffcd-de7a-4db2-8ab3-ec6f86df65db_1024x1024.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>Let me be specific. Because when people (now) hear &#8220;second brain&#8221; they usually think Obsidian vaults with color-coded tags and pretty Markdown files. That&#8217;s part of it. It&#8217;s the surface layer.</p><p>The actual power comes from what&#8217;s underneath.</p><h3>The memory layer</h3><p><a href="https://github.com/bobmatnyc/kuzu-memory">kuzu-memory</a> is a KuzuDB-backed knowledge graph that persists across every AI session. It stores learnings from conversations, code commits, decisions, patterns. When I start a new Claude Code session on a problem I&#8217;ve touched before, the context isn&#8217;t blank &#8212; it&#8217;s enriched with what was learned the last time.</p><p>This is the thing people underestimate. A project-specific memory that accumulates over months of work develops a kind of organizational intelligence you can&#8217;t replicate in a single conversation. It knows why a particular architectural decision was made. It knows that a vendor was evaluated and found lacking. It knows the terminology your team uses internally that differs from industry standard.</p><p>KuzuDB isn&#8217;t a product choice for its own sake &#8212; it&#8217;s graph-native, which means it handles relationships well. The connections between people, systems, decisions, and code are as important as the facts themselves.</p><h3>The search layer</h3><p><a href="https://github.com/bobmatnyc/mcp-vector-search">mcp-vector-search</a> provides semantic search across all project files. Not keyword search &#8212; semantic search with AST parsing. When I ask &#8220;where is the analysis I did on contractor productivity last quarter,&#8221; it finds it even if the document never uses those exact words.</p><p>At Duetto, this covers everything in my CTO project: architecture records, meeting notes pulled from Granola, emails I&#8217;ve synthesized, analysis documents, planning artifacts. Months of accumulated context, all searchable in seconds. The underlying code intelligence for the engineering organization runs as a separate service &#8212; mcp-vector-search is for my working knowledge, not the codebase itself.</p><h3>The databases</h3><p>My CTO project has three:</p><ul><li><p><strong>cto.db</strong> &#8212; SQLite. Work classification, people analysis, contributor data, commit history. The operational database for running analyses and reports.</p></li><li><p><strong>analytics.duckdb</strong> &#8212; DuckDB. OLAP queries and analytics. When I need to slice engineering output data in different ways or run something that would be painful in SQLite, it goes here.</p></li><li><p><strong>duetto_knowledge.db</strong> &#8212; The RAG-queryable knowledge base backing a Flask web app for interactive exploration.</p></li></ul><p>These aren&#8217;t a product I bought. They&#8217;re a schema I designed, built incrementally, and own completely. The schema reflects how I think about the organization, which is precisely why it&#8217;s useful.</p><h3>The connectors</h3><p><a href="https://github.com/bobmatnyc/gworkspace-mcp">gworkspace-mcp</a> handles Drive, Docs, Sheets, Gmail, Calendar, and more. I wrote my own rather than using the off-the-shelf options &#8212; Google&#8217;s first-party integration and Anthropic&#8217;s default both have significant tool coverage gaps. Mine exposes substantially more of the Workspace API surface and integrates transparently with Claude MPM, so agents can use Google Workspace tools without any special configuration at the call site.</p><p>Beyond Workspace: Notion API for product specs and planning documents. Extraction scripts for JIRA, Confluence, Slack, Datadog, and AWS. Each system outputs to as raw data, which feeds analysis pipelines that generate reports stored in a project directory.</p><p>For company-wide memory, two more tools: duetto-memory and duetto-directory. These handle shared organizational context &#8212; information that needs to flow between tools and across team members rather than staying in a single session. Memory persists within our VPC, encrypted to individual users&#8217; OAuth keys. Not even our own IT has access to it. Context shared from Claude Code shows up in Claude.ai, and vice versa, without any manual sync.</p><p>The entire flow is queryable. From a single Claude session, I can ask about budget trends, team velocity, specific architectural decisions, or what a particular engineer has been working on for the last three months. Because it&#8217;s all in the same context-addressable system.</p><h3>Obsidian as the front door</h3><p>Yes, I use Obsidian. But it&#8217;s a front door, not the building. The vault holds my personal notes, research captures, and synthesized analysis. The Obsidian Web Clipper feeds raw material into the knowledge pipeline. Templates enforce consistent structure.</p><p>Karpathy&#8217;s insight about Obsidian as IDE is right in the narrow sense: it&#8217;s the interface you use to read and organize. But the interesting work happens outside it &#8212; in the databases, the agents, the search indices, the custom scripts.</p><h2>CLAUDE.md files everywhere</h2><p>The context layer isn&#8217;t just data. It&#8217;s also behavioral instructions.</p><p>Every major directory in my project has a CLAUDE.md. The root CTO project one is 400 lines of conventions, routing logic, document lifecycle rules, and architectural decisions. Every subdirectory has a more focused version. Every specialized agent has its own constraints.</p><p>These files are my second brain&#8217;s schema, expressed as instructions rather than data. A single routing rule &#8212; &#8220;if the prompt mentions meeting notes, save to <code>projects/meetings/2026-W##/</code>&#8220; &#8212; sounds trivial. But it means twelve months of meeting notes accumulate in consistent, queryable locations rather than wherever an agent happened to save them. Multiply that by forty routing rules across fifteen subdirectories, and the entire corpus becomes navigable. The CLAUDE.md files are what make the databases useful. Without them, the data is just data.</p><p>Karpathy put it well: &#8220;You share the schema, not the code.&#8221; The schema is the valuable part. The schema is what compounds.</p><p>My schema took months to build. It will keep getting better. No product ships with the right schema for my organization, because no product knows what I know about how Duetto&#8217;s R&amp;D works.</p><h2>The productization question</h2><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!-gqt!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!-gqt!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png 424w, https://substackcdn.com/image/fetch/$s_!-gqt!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png 848w, https://substackcdn.com/image/fetch/$s_!-gqt!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png 1272w, https://substackcdn.com/image/fetch/$s_!-gqt!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!-gqt!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png" width="1024" height="708" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/87551032-97c3-4a89-8697-729269302cfa_1024x708.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:708,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1454118,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/196419582?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F85bbeb78-8523-459e-9cb0-e65b1d5bce18_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!-gqt!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png 424w, https://substackcdn.com/image/fetch/$s_!-gqt!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png 848w, https://substackcdn.com/image/fetch/$s_!-gqt!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png 1272w, https://substackcdn.com/image/fetch/$s_!-gqt!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87551032-97c3-4a89-8697-729269302cfa_1024x708.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>Karpathy said there&#8217;s room for an incredible product. He&#8217;s not wrong about the gap. He might be wrong about the solution.</p><p>The structural problems with productizing a second brain:</p><p><strong>Context compounds, products don&#8217;t.</strong> My system gets smarter with every commit, meeting, and conversation. A SaaS product serves thousands of customers and maintains no one&#8217;s specific context. The more I use my system, the wider the gap between it and any off-the-shelf alternative.</p><p><strong>The schema is the moat.</strong> My knowledge architecture reflects how I think about engineering organizations. Someone else&#8217;s knowledge architecture would be different. Products that force their schema on you &#8212; and every product does &#8212; are imposing someone else&#8217;s way of thinking on your problem. That friction is small at first and grows over time.</p><p><strong>Privacy is structural, not incidental.</strong> My databases contain org structures, salary data, performance patterns, vendor negotiations. Routing that through third-party infrastructure creates risk that&#8217;s practically impossible to contain. When I built duetto-memory for enterprise use, the entire stack stays within our VPC, with memories encrypted to individual users&#8217; OAuth keys. Not even IT can read them. That level of isolation is nearly impossible to provide as a multi-tenant SaaS.</p><p>Some layers could be productized &#8212; the infrastructure, not the intelligence. A well-designed memory MCP with sensible defaults. Semantic search that works without configuration. Privacy-preserving graph storage you don&#8217;t have to host yourself. The plumbing.</p><p>The schema, the decisions, and the accumulated context can&#8217;t be productized. Those are yours. That&#8217;s the point &#8212; and it&#8217;s also why the product gap Karpathy sees will remain open even after someone tries to fill it.</p><h2>Can anyone do this?</h2><p>There&#8217;s an access problem here, and I&#8217;d be dishonest not to acknowledge it.</p><p>Building what I&#8217;ve described requires knowing Python well enough to write extraction scripts, understanding enough about graph databases to design a schema, and being comfortable with CLI-based tooling and MCP server configuration. Not every CTO has that background. Not every technical leader wants to spend weekends building personal infrastructure.</p><p>The irony is that the people who most need better organizational intelligence &#8212; executives without deep engineering backgrounds &#8212; are least equipped to build these systems. And the people who are most capable of building them are often less interested in the executive problems the systems could solve.</p><p>Tiago Forte, who wrote <em><a href="https://www.buildingasecondbrain.com/">Building a Second Brain</a></em>, has been making this point for years. His PARA method and CODE framework are accessibility layers &#8212; ways to make the underlying ideas approachable without requiring you to build a graph database. The methodology is sound. But it was designed for knowledge workers, not for CTOs running engineering organizations who need live data pipelines, not filing systems. Well-designed for whom?</p><p>Karpathy&#8217;s LLM Wiki is explicitly a system for someone comfortable writing Python and working with file systems. His Gist has code in it. That&#8217;s a feature for his audience and a barrier for everyone else.</p><h2>What I&#8217;d watch for</h2><p>A few trends that will determine whether this remains a DIY space or gets productized:</p><p><strong>MCP as infrastructure.</strong> The <a href="https://hyperdev.matsuoka.com/p/the-mcp-cat-is-out-of-the-bag">Model Context Protocol</a> creates a standard interface for exactly this kind of knowledge infrastructure. Memory servers, search servers, database connectors &#8212; they all expose the same interface to any compatible AI client. The ecosystem is growing fast. As more MCP servers mature, the configuration burden drops.</p><p><strong>Searchable context beats raw window size.</strong> Karpathy argues for plain Markdown because ~400K words fit in a modern context window. That&#8217;s true, and the window is getting larger. But the more important shift is that structured, searchable context doesn&#8217;t have a ceiling. A well-organized knowledge base that spans years of meetings, decisions, and analysis delivers more than any single context window can hold &#8212; and the value scales with the quality of the organization, not the size of the model.</p><p><strong>Local model quality.</strong> Karpathy runs Anthropic agents via Claude Code. But local model quality is improving fast. A system that uses the cloud API for synthesis and queries but runs a local model for routine indexing tasks would be significantly cheaper and more private. Not ready yet. Getting closer.</p><p>The product Karpathy thinks exists &#8212; if it gets built &#8212; probably looks like a well-designed local MCP server with clean configuration, sensible defaults, and a plugin ecosystem for connectors. Not a SaaS. Not a cloud database. Something you install and own.</p><p>The people who need it most will have already built their own before any product ships. And in the process of building it, they&#8217;ll have accumulated the one thing no product can give them: months of their own operational context, organized the way their own mind works.</p><p>That&#8217;s not a consolation prize. That&#8217;s the whole point.</p><div><hr></div><p><em>Bob Matsuoka is CTO of <a href="https://www.duettocloud.com/">Duetto</a> and writes about AI-powered engineering at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://hyperdev.matsuoka.com/p/whats-in-my-claude-code-toolkit">What&#8217;s In My Toolkit: Claude Code and Family</a> &#8212; The coding layer of the stack</p></li><li><p><a href="https://hyperdev.matsuoka.com/p/i-built-a-coding-tool-then-i-used">I Built a Coding Tool. Then I Used It to Onboard as CTO</a> &#8212; Applying agent orchestration to organizational analysis</p></li><li><p><a href="https://aipowerranking.com/">AI Power Ranking</a> &#8212; Tool comparisons and benchmarks for AI practitioners</p></li><li><p><a href="https://www.linkedin.com/newsletters/ai-power-ranking-7345782916301418496/">LinkedIn Newsletter</a> &#8212; Strategic AI insights for CTOs and engineering leaders</p></li></ul>]]></content:encoded></item><item><title><![CDATA[It’s The Harness, Stupid!]]></title><description><![CDATA[Why AI tool orchestration now matters more than foundation model quality]]></description><link>https://hyperdev.matsuoka.com/p/its-the-harness-stupid</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/its-the-harness-stupid</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Mon, 13 Apr 2026 17:17:16 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!376u!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!376u!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!376u!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png 424w, https://substackcdn.com/image/fetch/$s_!376u!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png 848w, https://substackcdn.com/image/fetch/$s_!376u!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png 1272w, https://substackcdn.com/image/fetch/$s_!376u!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!376u!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png" width="1024" height="523" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:523,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1201765,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193459844?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4af78c41-cc16-45d4-abb7-f0e0ee92722b_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!376u!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png 424w, https://substackcdn.com/image/fetch/$s_!376u!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png 848w, https://substackcdn.com/image/fetch/$s_!376u!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png 1272w, https://substackcdn.com/image/fetch/$s_!376u!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5c1f4dab-a192-4b50-bbbb-5c889e29af13_1024x523.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>It&#8217;s The Harness, Stupid!</h2><p><strong>Why AI tool orchestration now matters more than foundation model quality</strong></p><p><em>Author: Bob Matsuoka, CTO @ Duetto Research</em> <br><em>April 6, 2026</em></p><h2>TL;DR</h2><ul><li><p>Same-model testing reveals 0.82-point quality spread (3.93 to 4.75) and 7x efficiency differences&#8212;orchestration dominates outcomes</p></li><li><p>Market validation: Claude maintains 70% developer preference despite GPT-5.4 achieving model parity through superior harness quality</p></li><li><p>Reddit analysis confirms Codex efficiency gains come from orchestration improvements, not just model upgrades</p></li><li><p>Competitive advantage has shifted permanently from model superiority to ecosystem superiority</p></li></ul><p><strong>Bottom line: The harness era has begun. Choose tools based on workflow fit, not benchmark claims.</strong></p><h2>The $50B Model Myth</h2><p>The AI industry has a fixation problem. Every week brings breathless announcements about parameter counts, training costs, and benchmark scores. &#8220;GPT-6 has 50 trillion parameters!&#8221; &#8220;Our model scored 94.7% on SWE-bench!&#8221; &#8220;We spent $2 billion on compute!&#8221;</p><p>Three converging pieces of evidence prove this approach is fundamentally wrong.</p><div class="callout-block" data-callout="true"><p><strong>Evidence #1:</strong> I tested eight AI coding agents across five programming challenges. Four agents used identical Claude Sonnet 4.6 models. Quality scores ranged from 3.93 to 4.75&#8212;a 0.82-point spread on the same foundation model.</p></div><div class="callout-block" data-callout="true"><p><strong>Evidence #2:</strong> GPT-5.4 achieved parity with Claude Sonnet 4.6 on coding benchmarks. Yet Claude maintains 70% developer preference through superior ecosystem quality.</p></div><div class="callout-block" data-callout="true"><p><strong>Evidence #3:</strong> Reddit developer communities confirm Codex&#8217;s efficiency improvements come from orchestration architecture changes, not just model upgrades.</p></div><p><strong>The harness matters more than the model.</strong> Choosing an AI coding tool is now primarily an engineering decision, not a model selection decision. The next competitive advantage isn&#8217;t bigger models&#8212;it&#8217;s better orchestration.</p><h2>Evidence Pillar #1: The Smoking Gun Laboratory Data</h2><h3>The Bake-Off Setup</h3><p>I designed five programming challenges ranging from 30-minute tasks to 8-hour full-stack builds:</p><ul><li><p><strong>Level 1-2:</strong> Simple scripts and basic applications</p></li><li><p><strong>Level 3:</strong> API integration with Docker containerization</p></li><li><p><strong>Level 4:</strong> Extensible data processing pipeline (architecture test)</p></li><li><p><strong>Level 5:</strong> Full-stack web application with authentication</p></li></ul><p>Eight agents competed: Claude Code, Claude MPM, Codex, Gemini CLI, Auggie, Qwen+Aider, DeepSeek+Aider, and Warp AI. Each received identical prompts. A panel of expert developers blind-reviewed all submissions across eight criteria: functionality, correctness, best practices, architecture, code reuse, testing, error handling, and documentation.</p><h3>The Harness Advantage Data</h3><p><strong>Table 1: Same Model, Different Worlds</strong></p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!TErH!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!TErH!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png 424w, https://substackcdn.com/image/fetch/$s_!TErH!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png 848w, https://substackcdn.com/image/fetch/$s_!TErH!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png 1272w, https://substackcdn.com/image/fetch/$s_!TErH!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!TErH!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png" width="867" height="409" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/47d85d71-6503-4452-ad8c-957585385133_867x409.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:409,&quot;width&quot;:867,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:74882,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193459844?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!TErH!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png 424w, https://substackcdn.com/image/fetch/$s_!TErH!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png 848w, https://substackcdn.com/image/fetch/$s_!TErH!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png 1272w, https://substackcdn.com/image/fetch/$s_!TErH!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F47d85d71-6503-4452-ad8c-957585385133_867x409.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>Four agents using identical Claude Sonnet 4.6 models. Quality scores from 3.93 to 4.75&#8212;a 0.82-point spread. <a href="https://github.com/bobmatnyc/claude-mpm">claude-mpm</a> finished in 45 minutes while warp took 313 minutes. Almost <strong>7x longer for lower quality results</strong>.</p><h3>The Scaling Pattern</h3><p>The harness advantage compounds with complexity:</p><ul><li><p><strong>Levels 1-2:</strong> All agents performed similarly. Simple tasks don&#8217;t reveal orchestration differences.</p></li><li><p><strong>Level 3:</strong> API integration and Docker setup separated agents that plan from those that code-and-fix. Clear gaps emerged.</p></li><li><p><strong>Levels 4-5:</strong> Architecture and full-stack challenges broke most agents. Only well-orchestrated systems completed the complex workflows.</p></li></ul><p>The pattern is clear: as complexity increases, harness quality becomes the primary determinant of success.</p><h2>Evidence Pillar #2: Market Validation &#8212; GPT-5.4 Caught Up</h2><h3>Model Parity Achievement</h3><p>February-April 2026 benchmarks confirm <strong>GPT-5.4 has achieved parity with Claude Sonnet 4.6</strong>:</p><p><strong>Core Benchmarks:</strong></p><ul><li><p><strong>SWE-bench Verified</strong>: GPT-5.4 ~80% vs Claude 79.6% (statistical tie)</p></li><li><p><strong>SWE-bench Pro</strong>: GPT-5.4 57.7% vs Claude 43.6% (GPT leads complex problems)</p></li><li><p><strong>Terminal-Bench</strong>: GPT-5.4 75.1% vs Claude ~65% (DevOps advantage)</p></li><li><p><strong>Context handling</strong>: Both models feature 1M token windows</p></li></ul><h3>Yet Claude Still Dominates Through Harness Advantages</h3><p>Despite achieving model parity, the competitive landscape tells the harness story:</p><p><strong>Market Reality:</strong></p><ul><li><p><strong>Developer preference</strong>: Claude 70% (superior workflow integration)</p></li><li><p><strong>Enterprise share</strong>: Anthropic +4.9% MoM growth, OpenAI -1.5% decline</p></li><li><p><strong>Revenue</strong>: Claude Code $2B ARR in 6 months</p></li></ul><p><strong>Even when models reach parity, harness quality determines adoption.</strong></p><h3>The Multi-Model Strategic Reality</h3><p>Leading organizations aren&#8217;t choosing between models anymore&#8212;they&#8217;re deploying <strong>three-tier strategic architectures</strong> based on cost-performance optimization:</p><p><strong>Tier 1: Daily Workhorse (60-70% of requests)</strong></p><ul><li><p><strong>Claude Sonnet 4.6</strong>: <a href="https://medium.com/@mkteam/gpt-5-4-vs-claude-sonnet-4-6-2026-the-ultimate-ai-model-comparison-49526cac8b14">$3/$15 per million tokens</a></p></li><li><p>High-volume development, routine coding tasks</p></li><li><p><a href="https://www.nxcode.io/resources/news/claude-sonnet-4-6-vs-gpt-5-4-coding-comparison-2026">95%+ of premium model quality at half the cost</a></p></li><li><p>Default choice for most enterprise development work</p></li></ul><p><strong>Tier 2: Specialized Operations (20-30% of requests)</strong></p><ul><li><p><strong>GPT-5.4</strong>: <a href="https://medium.com/@mkteam/gpt-5-4-vs-claude-sonnet-4-6-2026-the-ultimate-ai-model-comparison-49526cac8b14">$2.50/$15 per million tokens</a></p></li><li><p>Terminal operations, DevOps workflows, CI/CD debugging</p></li><li><p><a href="https://www.morphllm.com/best-ai-model-for-coding">75.1% Terminal-Bench score (10-point lead over competitors)</a></p></li><li><p><a href="https://medium.com/@ricardomsgarces/openai-codex-vs-github-copilot-why-codex-is-winning-the-future-of-coding-f9a2767695b0">Inherited Codex&#8217;s terminal operation dominance</a></p></li></ul><p><strong>Tier 3: Premium Analysis (10-20% of requests)</strong></p><ul><li><p><strong>Claude Opus 4.6</strong>: <a href="https://medium.com/@mkteam/gpt-5-4-vs-claude-sonnet-4-6-2026-the-ultimate-ai-model-comparison-49526cac8b14">$5/$25 per million tokens</a></p></li><li><p>Complex reasoning, architectural decisions, high-stakes analysis</p></li><li><p><a href="https://help.apiyi.com/en/gpt-5-4-vs-claude-opus-4-6-comparison-2026-en.html">World leader in abstract reasoning (87.4% vs GPT-5.4&#8217;s 83.9%)</a></p></li><li><p>When cost justifies maximum capability</p></li></ul><p>This confirms the core thesis: when models are &#8220;good enough,&#8221; teams optimize for <strong>strategic cost-performance fit</strong>, not raw capability or marketing claims.</p><h2>Evidence Pillar #3: Community Validation &#8212; The Codex Orchestration Story</h2><h3>Reddit Confirms Orchestration Improvements</h3><p>Reddit research explains Codex&#8217;s impressive efficiency results (42 minutes, 4.49 quality score). The evidence confirms improvements come from orchestration, not just model upgrades.</p><p><strong>Architectural Evolution Evidence:</strong></p><ul><li><p><a href="https://medium.com/@aliazimidarmian/openai-codex-from-2021-code-model-to-a-2025-autonomous-coding-agent-85ef0c48730a">Codex evolved from &#8220;embedded assistant&#8221; &#8594; &#8220;independent agent with multi-agent orchestration&#8221;</a></p></li><li><p><a href="https://www.digitalapplied.com/blog/gpt-5-2-codex-openai-model-guide-2026">GPT-5.2-Codex (Jan 2026) with 192K context + MCP tool orchestration</a></p></li><li><p><a href="https://developers.openai.com/blog/openai-for-developers-2025">&#8220;Command center for agents&#8221; interface launched Feb 2026</a></p></li></ul><p><strong>Workflow Efficiency Improvements:</strong></p><ul><li><p><a href="https://reelmind.ai/blog/openai-codex-code-generation-features-reddit-developer-insights">Developers report queuing &#8220;4-5 Codex tasks before diving into manual work&#8221;</a></p></li><li><p><a href="https://reelmind.ai/blog/openai-codex-code-generation-features-reddit-developer-insights">&#8220;2-3 completed PRs waiting for review&#8221; after a coffee break</a></p></li><li><p><a href="https://www.nxcode.io/resources/news/openai-codex-app-review-2026">P99 response time 45ms vs Copilot&#8217;s 55ms through better context management</a></p></li><li><p><strong>Parallel processing capabilities</strong> that enable true background orchestration</p></li></ul><p><strong>Enterprise Orchestration Benefits:</strong></p><ul><li><p><strong><a href="https://www.quantumrun.com/consulting/openai-codex-statistics/">70% more pull requests</a></strong><a href="https://www.quantumrun.com/consulting/openai-codex-statistics/"> merged weekly at OpenAI</a></p></li><li><p><strong><a href="https://www.quantumrun.com/consulting/openai-codex-statistics/">50% reduction</a></strong><a href="https://www.quantumrun.com/consulting/openai-codex-statistics/"> in code review times at Cisco</a></p></li><li><p><strong><a href="https://www.quantumrun.com/consulting/openai-codex-statistics/">67% reduction</a></strong><a href="https://www.quantumrun.com/consulting/openai-codex-statistics/"> in median turnaround time at Duolingo</a></p></li><li><p><strong><a href="https://www.quantumrun.com/consulting/openai-codex-statistics/">90% Fortune 100 adoption</a></strong><a href="https://www.quantumrun.com/consulting/openai-codex-statistics/"> validates orchestration value at scale</a></p></li></ul><h3>The Community Strategic Deployment Pattern</h3><p>Reddit developers now recommend <strong>different tools for different purposes</strong>:</p><ul><li><p><strong>Claude Code</strong>: Code quality and reasoning</p></li><li><p><strong>Cursor</strong>: Daily coding integration</p></li><li><p><strong>OpenAI Codex</strong>: Complex multi-agent workflows and long-horizon autonomy</p></li></ul><p>This matches exactly what the market data predicted: teams use orchestrated tools strategically rather than seeking one universal solution.</p><h2>The Harness Quality Ladder</h2><p>Based on all three evidence pillars, I see four tiers of orchestration quality emerging:</p><p><strong>Tier 1: Basic Wrappers</strong></p><ul><li><p>Simple API access, minimal context management</p></li><li><p>Examples: Raw ChatGPT interface, basic API wrappers</p></li><li><p>Limitation: No file coordination, poor context retention</p></li></ul><p><strong>Tier 2: Workflow Tools</strong></p><ul><li><p>File awareness, some context management</p></li><li><p>Examples: GitHub Copilot, basic IDE extensions</p></li><li><p>Capability: Single-file optimization, limited cross-file understanding</p></li></ul><p><strong>Tier 3: Orchestrated Systems</strong></p><ul><li><p>Multi-file coordination, workflow integration</p></li><li><p>Examples: Cursor, Claude Code, well-configured aider</p></li><li><p>Advantage: Understands project structure, handles complex tasks</p></li></ul><p><strong>Tier 4: Agentic Frameworks</strong></p><ul><li><p>Multi-agent coordination, planning, verification</p></li><li><p>Examples: claude-mpm, advanced orchestration systems</p></li><li><p>Power: Full project lifecycle, quality assurance, architectural thinking</p></li></ul><p>The performance cliff between tiers is exponential, not linear. Bad orchestration can make great models perform poorly; great orchestration can make good models perform excellently.</p><h2>Academic and Industry Validation</h2><p>This isn&#8217;t just empirical observation. Multiple 2026 research papers and industry studies support the harness thesis:</p><p><strong>Academic Consensus:</strong><br>The arXiv paper <a href="https://arxiv.org/html/2511.14136v1">&#8220;Beyond Accuracy: A Multi-Dimensional Framework for Evaluating Enterprise Agentic AI Systems&#8221;</a> shows that domain-tuned models with better orchestration achieve superior cost-normalized accuracy despite using smaller base models.</p><p><a href="https://pricepertoken.com/leaderboards/benchmark/humaneval">SWE-bench data</a> reveals the same pattern. Cursor, Claude Code, and Auggie all use similar base models yet score between 50.2% and 55.4%, while the raw model score is only 45.9%. The 5.9-point improvement comes entirely from better context retrieval and agent design.</p><p><strong>Business Reality Check:</strong><br><a href="https://claude5.com/news/enterprise-ai-adoption-2026-how-businesses-deploy-claude-gpt">Enterprise adoption surveys</a> show a clear shift in CTO priorities. &#8220;Model performance&#8221; is dropping in tool evaluation criteria, replaced by governance, integration quality, and workflow fit. As one 2026 McKinsey report put it: &#8220;CTOs are realizing their biggest bottleneck isn&#8217;t model performance&#8212;it&#8217;s governance.&#8221;</p><h2>What This Means for Engineering Leaders</h2><h3>Stop Optimizing for Benchmarks</h3><p>The old procurement mindset was model-first: &#8220;We need access to GPT-6 for competitive advantage.&#8221; The new reality is that benchmark performance doesn&#8217;t predict practical utility. SWE-bench scores don&#8217;t tell you whether a tool will integrate with your existing workflow, handle your codebase size, or recover gracefully from errors.</p><p>Start evaluating harness quality:</p><ul><li><p><strong>Context management:</strong> How well does it understand your project structure?</p></li><li><p><strong>File coordination:</strong> Can it work intelligently across multiple files?</p></li><li><p><strong>Error recovery:</strong> Does it handle failures gracefully or require constant babysitting?</p></li><li><p><strong>Workflow integration:</strong> How does it fit with your team&#8217;s existing development process?</p></li></ul><h3>Budget for Orchestration Quality</h3><p>The three evidence pillars show that investing in better orchestration yields measurable returns:</p><ul><li><p><strong>Quality per minute:</strong> claude-mpm achieved 4.75 quality in 45 minutes; warp achieved 3.94 in 313 minutes</p></li><li><p><strong>Market validation:</strong> Claude maintains dominance despite model parity through superior developer experience</p></li><li><p><strong>Enterprise results:</strong> 70% more PRs, 50% faster code review, 67% faster turnaround</p></li></ul><p>The ROI case for harness investment is clear and quantifiable.</p><h3>Team Productivity Focus</h3><p>Tool choice impacts your entire development pipeline. The 7x speed difference between well and poorly orchestrated tools using the same model means tool selection is a productivity multiplier, not just a capability decision.</p><p>Better tools also reduce onboarding time and increase adoption rates. A tool that works reliably gets used; one that requires constant troubleshooting gets abandoned.</p><h2>The Competitive Landscape Evolution</h2><h3>Codex Deserves Recognition</h3><p>Codex&#8217;s performance has significantly improved. At 42 minutes for all five levels with a 4.49 quality score, it achieved by far the best efficiency in my study. GPT-5.4+ combined with the orchestration improvements OpenAI made represents a compelling package. The Reddit research confirms this wasn&#8217;t just a model upgrade&#8212;it was an architectural evolution toward multi-agent orchestration.</p><h3>Claude Code&#8217;s Harness Moat</h3><p>While Claude Code performed well (4.53 quality score), the market validation shows its true strength: <strong>ecosystem superiority</strong>. Despite GPT-5.4 achieving model parity, Claude maintains 70% developer preference through superior harness quality. This is exactly what sustainable competitive advantage looks like in the post-parity era.</p><h3>The Multi-Model Future</h3><p>All evidence points to the same conclusion: the era of picking one model is over. Leading organizations deploy <strong>three-tier cost-performance architectures</strong>, optimizing for specific strengths rather than seeking universal solutions.</p><p>Real enterprise case studies validate this pattern:</p><ul><li><p><strong><a href="https://www.datastudios.org/post/claude-in-the-enterprise-case-studies-of-ai-deployments-and-real-world-results">TELUS (57,000 employees)</a></strong><a href="https://www.datastudios.org/post/claude-in-the-enterprise-case-studies-of-ai-deployments-and-real-world-results">: Uses Sonnet as core engine across developer teams</a></p></li><li><p><strong><a href="https://www.datastudios.org/post/claude-in-the-enterprise-case-studies-of-ai-deployments-and-real-world-results">Zapier</a></strong><a href="https://www.datastudios.org/post/claude-in-the-enterprise-case-studies-of-ai-deployments-and-real-world-results">: 800+ internal agents using strategic model selection</a></p></li><li><p><strong><a href="https://devtk.ai/en/blog/claude-api-pricing-guide-2026/">Financial Services</a></strong><a href="https://devtk.ai/en/blog/claude-api-pricing-guide-2026/">: Monthly costs ~$80 at massive scale through optimized routing</a></p></li></ul><p>The successful pattern: <strong>Sonnet for volume, GPT-5.4 for DevOps, Opus for complexity</strong>.</p><h2>The Token Economics Reality</h2><p>claude-mpm achieved the highest quality score (4.75) but used 87 million tokens versus codex&#8217;s 120K. This looks expensive until you consider the output: 262 comprehensive tests (vs codex&#8217;s 32), complete documentation, 100% verification rates, and multi-file coordination (note: this was also a wake-up call to me to focus on token optimization, current version is much stingier)</p><p>The 700x token multiplier isn&#8217;t overhead&#8212;it&#8217;s the cost of work a solo agent skips. <strong>Orchestration doesn&#8217;t waste tokens&#8212;it spends them on comprehensive deliverables.</strong></p><p>The optimization question: Could you achieve 80% of the quality benefits at 30% of the token cost? The opportunity isn&#8217;t eliminating orchestration&#8212;it&#8217;s finding the minimal viable team size for maximum impact.</p><h3>The Vendor Bias Problem: &#8220;Opus for Everything&#8221;</h3><p>Boris Cherny, the Claude Code lead, recently advocated for using &#8220;Opus for everything.&#8221; This perfectly illustrates the disconnect between vendor recommendations and practical deployment reality.</p><p><strong>Only someone working for Anthropic can say that.</strong></p><p>When your employer provides unlimited access to premium models, of course you&#8217;d recommend the most expensive option for every task. But real organizations operating with P&amp;L responsibility make strategic decisions about when premium capability justifies premium cost.</p><p>This vendor bias actually <strong>validates the multi-model thesis</strong>:</p><ul><li><p><strong>Vendors say:</strong> &#8220;Use our premium model for everything&#8221;</p></li><li><p><strong>Users do:</strong> Strategic model selection based on task complexity and budget constraints</p></li><li><p><strong>Market reality:</strong> 70% prefer Claude for daily coding (cost/speed), GPT-5.4 for complex reasoning (quality ceiling)</p></li></ul><p>Cherny&#8217;s comment inadvertently proves that <strong>cost-conscious orchestration</strong> is the real competitive battleground. Companies that figure out optimal model routing&#8212;not maximal model usage&#8212;will have sustainable advantages.</p><p>The vendors push premium. The market chooses strategically. <strong>The harness makes both possible.</strong></p><h2>The Future: Welcome to the Harness Era</h2><h3>What Changes for Developers</h3><p>Tool selection framework:</p><ol><li><p><strong>Workflow fit:</strong> Does it match how your team works?</p></li><li><p><strong>Integration quality:</strong> Plays well with existing tools?</p></li><li><p><strong>Reliability:</strong> Can you trust it with production code?</p></li><li><p><strong>Model quality:</strong> Fourth priority</p></li></ol><h3>What Changes for the Industry</h3><p>Foundation models are becoming commodities. Differentiation shifts to integration, context management, and user experience. The next unicorns will be harness companies, not model companies.</p><p>Major funding flows to orchestration companies. Enterprise procurement evaluates integration first, model second.</p><h3>The Competitive Moat Shift</h3><p>The old game was: train bigger models, claim benchmark superiority. The new game is: build better orchestration, solve real workflow problems. Model access becomes a utility; workflow mastery becomes the moat.</p><h2>Practical Recommendations</h2><h3>For CTOs and Engineering Leaders</h3><ul><li><p><strong>Audit orchestration quality</strong>: Test tools with your actual codebase for 2-week trials</p></li><li><p><strong>Budget 60/40</strong>: Spend more on harness development than model subscription fees</p></li><li><p><strong>Measure real metrics</strong>: Track pull request velocity and code review time, not benchmark scores</p></li><li><p><strong>Evaluate integration first</strong>: How well does it fit your existing CI/CD pipeline?</p></li></ul><h3>For Developers</h3><ul><li><p><strong>Test with real projects</strong>: Spend 2 days with each tool on actual work before deciding</p></li><li><p><strong>Learn orchestration patterns</strong>: Context management and file coordination matter more than prompts</p></li><li><p><strong>Invest in mastery</strong>: The 7x efficiency difference justifies significant learning time</p></li><li><p><strong>Ignore marketing claims</strong>: Model access means nothing without good orchestration</p></li></ul><h3>For the AI Industry</h3><ul><li><p><strong>Build for workflow integration</strong>: Solve real development pipeline problems</p></li><li><p><strong>Measure practical utility</strong>: Developer retention and task completion rates beat benchmarks</p></li><li><p><strong>Focus on context management</strong>: Multi-file coordination is the real competitive moat</p></li></ul><h2>Conclusion: The Questions That Matter Now</h2><p>The old question was: &#8220;What&#8217;s the best model?&#8221;</p><p>The new question is: &#8220;What&#8217;s the best harness for my team&#8217;s workflow?&#8221;</p><p>Three evidence sources prove we&#8217;ve crossed a threshold: foundation models are &#8220;good enough,&#8221; and orchestration quality now dominates outcomes. Laboratory testing, market validation, and community confirmation point to the same reality.</p><p>The foundation model is the engine. The harness is the car. The best engine in the world won&#8217;t get you anywhere without wheels.</p><p><strong>The harness era has begun. Drive accordingly.</strong></p><div><hr></div><p><em>Bob Matsuoka is CTO at <a href="https://www.duettocloud.com/">Duetto Research</a> and creator of <a href="https://github.com/bobmatnyc/claude-mpm">Claude MPM</a>, one of the agents evaluated in this study. All evaluation data and methodology are available at <a href="https://github.com/bobmatnyc/ai-coding-bake-off">github.com/bobmatnyc/ai-coding-bake-off</a> for reproducibility.</em></p><div><hr></div><h2>Appendix: Complete Results Data</h2><h3>Quality Scores by Criterion</h3><p></p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!dSX7!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!dSX7!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png 424w, https://substackcdn.com/image/fetch/$s_!dSX7!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png 848w, https://substackcdn.com/image/fetch/$s_!dSX7!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png 1272w, https://substackcdn.com/image/fetch/$s_!dSX7!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!dSX7!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png" width="981" height="368" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:368,&quot;width&quot;:981,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:69754,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193459844?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!dSX7!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png 424w, https://substackcdn.com/image/fetch/$s_!dSX7!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png 848w, https://substackcdn.com/image/fetch/$s_!dSX7!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png 1272w, https://substackcdn.com/image/fetch/$s_!dSX7!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F96cbd80c-434e-456b-ae62-1fb565e1ec0d_981x368.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h3>GPT-5.4 vs Claude Sonnet 4.6 Market Data</h3><p><strong>SWE-bench Performance:</strong></p><ul><li><p>SWE-bench Verified: GPT-5.4 ~80% vs Claude 79.6% (statistical tie)</p></li><li><p>SWE-bench Pro: GPT-5.4 57.7% vs Claude 43.6% (GPT advantage on complex problems)</p></li><li><p>Terminal-Bench: GPT-5.4 75.1% vs Claude ~65% (GPT DevOps advantage)</p></li></ul><p><strong>Market Metrics:</strong></p><ul><li><p>Developer preference (daily coding): Claude 70%</p></li><li><p>Enterprise market share: Anthropic +4.9% MoM, OpenAI -1.5% MoM</p></li><li><p>Claude Code revenue: $2B ARR in 6 months</p></li></ul><h3>Methodology Notes</h3><ul><li><p><strong>Laboratory data:</strong> Single run evaluation with disclosed author bias</p></li><li><p><strong>Market data:</strong> Cross-validated across 15+ authoritative sources</p></li><li><p><strong>Community research:</strong> Reddit analysis across 8+ developer subreddits</p></li><li><p><strong>Statistical confidence:</strong> Mean inter-reviewer deviation of 0.216 points</p></li><li><p><strong>Reproducible:</strong> All data and prompts available in public repository</p></li></ul>]]></content:encoded></item><item><title><![CDATA[I Met a Movie Star Mila Jovovich — As a Coder]]></title><description><![CDATA[More evidence of the democratization of software]]></description><link>https://hyperdev.matsuoka.com/p/i-met-a-movie-star-mila-jovovich</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/i-met-a-movie-star-mila-jovovich</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Sat, 11 Apr 2026 12:31:14 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!_YC7!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!_YC7!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!_YC7!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png 424w, https://substackcdn.com/image/fetch/$s_!_YC7!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png 848w, https://substackcdn.com/image/fetch/$s_!_YC7!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png 1272w, https://substackcdn.com/image/fetch/$s_!_YC7!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!_YC7!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png" width="1024" height="659" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:659,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1463075,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193848267?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F188090d8-280b-48b0-81af-3a11dec4dac3_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!_YC7!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png 424w, https://substackcdn.com/image/fetch/$s_!_YC7!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png 848w, https://substackcdn.com/image/fetch/$s_!_YC7!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png 1272w, https://substackcdn.com/image/fetch/$s_!_YC7!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6d0e03e6-ff0f-4040-ab56-8239bf91a20d_1024x659.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>I didn&#8217;t expect to meet Mila Jovovich through a GitHub issue.</p><p>But there I was last week, deep-diving into her AI memory framework called <a href="https://github.com/milla-jovovich/mempalace">MemPalace</a>, when I discovered something remarkable: the &#8220;Resident Evil&#8221; and &#8220;Fifth Element&#8221; star had created one of the most talked-about AI memory systems of 2026. And she&#8217;d done it using Claude Code, the same AI-assisted development environment I use daily.</p><p>More remarkably, when I found critical bugs in her benchmark methodology, she responded directly through her Claude Code workflow, acknowledging the issues and implementing fixes. Not through a PR team or engineering intermediaries &#8212; Mila herself, using AI-assisted development to debug complex memory retrieval algorithms at 9 AM on a Thursday.</p><p>This isn&#8217;t a story about a celebrity coding stunt. It&#8217;s about something much more profound: we&#8217;ve entered an era where outcomes and features drive development, not the technical limitations of writing code.</p><h2>The MemPalace Phenomenon</h2><p>In April 2026, Mila Jovovich and developer Ben Sigman released MemPalace, an open-source AI memory system that immediately went viral. Within 48 hours, it had <a href="https://github.com/milla-jovovich/mempalace">over 23,000 GitHub stars</a>. The system claimed to achieve the first perfect score on the LongMemEval benchmark, scoring 96.6% raw recall.</p><p>The project represents something unprecedented: a free, locally-running memory system that rivals expensive cloud alternatives like Mem0 ($19-249/month) and Zep ($25+/month). It uses the &#8220;memory palace&#8221; technique &#8212; a classical memory method dating back to ancient Greece &#8212; implemented through ChromaDB and SQLite, with zero ongoing API costs.</p><p>The technical architecture includes basic Claude Code integration (save hooks every 15 messages and before context compression) and 24 tools via the Model Context Protocol (MCP), making it compatible across multiple AI platforms.</p><p>The duo had spent months building it using Claude Code&#8217;s AI-assisted development environment. As Sigman noted, he provided &#8220;the engineering chops&#8221; while Jovovich drove the architectural vision.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://github.com/milla-jovovich" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!93ZZ!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg 424w, https://substackcdn.com/image/fetch/$s_!93ZZ!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg 848w, https://substackcdn.com/image/fetch/$s_!93ZZ!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg 1272w, https://substackcdn.com/image/fetch/$s_!93ZZ!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!93ZZ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg" width="459" height="460" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:460,&quot;width&quot;:459,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:52413,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/jpeg&quot;,&quot;href&quot;:&quot;https://github.com/milla-jovovich&quot;,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193848267?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!93ZZ!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg 424w, https://substackcdn.com/image/fetch/$s_!93ZZ!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg 848w, https://substackcdn.com/image/fetch/$s_!93ZZ!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg 1272w, https://substackcdn.com/image/fetch/$s_!93ZZ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7d7e3197-469d-4e18-86f1-3033d8bd4a27_459x460.jpeg 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>When Audits Meet AI-Generated Code</h2><p>That&#8217;s when things got interesting.</p><p>As someone who works extensively with AI memory systems &#8212; I maintain <a href="https://github.com/bobmatnyc/kuzu-memory">KuzuMemory</a>, a graph-based memory framework &#8212; I was naturally curious about MemPalace&#8217;s benchmark methodology. The claimed 96.6% recall rate was extraordinary, especially for a system running entirely locally.</p><p>So I dove in.</p><p>What I found were several methodological issues that fundamentally undermined the headline numbers. The benchmark adapter was discarding assistant turns in conversation history, causing systematic under-recall on certain question types. More critically, the benchmark wasn&#8217;t actually testing MemPalace&#8217;s core functionality &#8212; it was primarily testing ChromaDB&#8217;s raw vector search capabilities.</p><p>I filed <a href="https://github.com/milla-jovovich/mempalace/issues/242">Issue #242</a> documenting the assistant turn bug, and <a href="https://github.com/milla-jovovich/mempalace/issues/214">Issue #214</a> showing that the 96.6% score was essentially a ChromaDB score, not a MemPalace score.</p><p>Mila&#8217;s response was immediate and technically sophisticated:</p><blockquote><p>&#8220;Hey <a href="https://github.com/bobmatnyc">@bobmatnyc</a> &#8212; I&#8217;ve taken a look and ran it through CLI. This is a real bug and it&#8217;s urgent. You caught that <code>benchmarks/longmemeval_bench.py</code> at lines 189-190 builds each session&#8217;s indexed document by concatenating <em>only</em> <code>user</code> role turns... <strong>Fix priority: this must land before any public benchmark re-run.</strong>&#8220;</p></blockquote><p>She didn&#8217;t deflect or dismiss. She debugged the issue herself, identified the exact lines of code causing the problem, explained the downstream impact on other benchmarks, and outlined a detailed fix plan including regression tests.</p><p>This wasn&#8217;t PR speak. This was an AI-assisted developer engaging seriously with technical criticism.</p><h2>The Democratization Shift</h2><p>This interaction crystallized something profound about our current moment in software development.</p><p>We&#8217;re witnessing the emergence of a new class of builders: technically-minded individuals who understand software conceptually but may not have traditional coding backgrounds. AI-assisted development tools like Claude Code, GitHub Copilot, and Cursor have lowered the implementation barrier to the point where vision and domain expertise matter more than syntax mastery.</p><p>Mila Jovovich exemplifies this shift perfectly. Without formal technical education (she left school in 7th grade for modeling), she spent months intensively learning AI-assisted development through Claude Code starting in late 2025. She understood the conceptual framework of memory palaces deeply enough to architect a sophisticated system. Her collaboration with Ben Sigman &#8212; CEO of Bitcoin lending platform Libre Labs, who provided the engineering expertise while she drove architectural vision &#8212; represents a new model of software development where domain knowledge and AI tool fluency can substitute for traditional programming backgrounds.</p><p>The fact that a movie star can release a technically competent, widely-adopted memory framework isn&#8217;t a commentary on coding getting easier (though it has). It&#8217;s about software development becoming more accessible to domain experts and visionaries who previously couldn&#8217;t bridge the implementation gap.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!f3FK!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!f3FK!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png 424w, https://substackcdn.com/image/fetch/$s_!f3FK!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png 848w, https://substackcdn.com/image/fetch/$s_!f3FK!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!f3FK!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!f3FK!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png" width="1024" height="1024" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:1024,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1971642,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193848267?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!f3FK!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png 424w, https://substackcdn.com/image/fetch/$s_!f3FK!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png 848w, https://substackcdn.com/image/fetch/$s_!f3FK!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!f3FK!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8b861799-f605-4e03-bec5-f88ec1387a42_1024x1024.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>What MemPalace Gets Right</h2><p>Despite the benchmark issues I uncovered, MemPalace demonstrates genuine technical sophistication. The memory palace metaphor isn&#8217;t just marketing &#8212; it&#8217;s a thoughtful architectural choice that makes AI memory systems more intuitive and debuggable.</p><p>The system includes elegant features like per-agent memory &#8220;wings&#8221; that prevent cross-contamination between different AI assistants. The Claude Code integration hooks are well-designed, automatically triggering memory saves at logical conversation boundaries. The MCP implementation is clean and follows established patterns.</p><p>Most importantly, the project tackles a real problem: most AI memory systems are either expensive cloud services or complex local installations. MemPalace provides a middle path that&#8217;s both free and relatively easy to deploy.</p><p>Through my testing and integration experiments, I learned techniques that improved my own KuzuMemory system. The competitive analysis forced me to think more carefully about memory organization patterns and retrieval strategies. This kind of cross-pollination benefits the entire ecosystem.</p><h2>The Validation Requirement</h2><p>But the benchmark controversy highlights a crucial point: democratized software development still requires traditional validation methods.</p><p>AI-assisted coding tools excel at implementation but can perpetuate subtle conceptual errors throughout a codebase. The MemPalace benchmark issues weren&#8217;t obvious bugs &#8212; they were methodological problems that required domain expertise to identify.</p><p>This creates an interesting dynamic: AI tools enable rapid development by non-traditional developers, but peer review by experienced practitioners becomes even more critical. The community response to MemPalace&#8217;s inflated benchmarks wasn&#8217;t hostile &#8212; it was collaborative debugging at scale.</p><p>Mila&#8217;s willingness to engage directly with technical criticism and implement fixes demonstrates the right approach. The democratization of software development doesn&#8217;t eliminate the need for technical rigor; it distributes that rigor across a broader community.</p><h2>The Harness Thesis Validated</h2><p>This story perfectly validates what I call the &#8220;harness thesis&#8221; &#8212; that we&#8217;ve entered an era where AI tool ecosystems matter more than underlying model capabilities.</p><p>MemPalace succeeded not because Mila wrote perfect code from scratch, but because she effectively orchestrated Claude Code to implement her vision. The system&#8217;s value comes from its architectural choices, integration quality, and user experience &#8212; not from novel algorithmic breakthroughs.</p><p>Similarly, my ability to audit and improve the system came not from superior coding skills, but from having developed complementary expertise with memory systems and benchmark methodology. The collaboration that emerged &#8212; distributed across GitHub issues, with contributors from multiple backgrounds &#8212; represents the new model of software development.</p><p>We&#8217;re not just building different software; we&#8217;re building software differently.</p><h2>Meeting Mila Through Code</h2><p>In the end, I did meet Mila Jovovich &#8212; through our AI Agents, lines of Python code, GitHub issues, and technical discussions about memory retrieval algorithms, mediated by our respective Claude Code workflows. Not the meeting I would have predicted, but somehow more meaningful than a typical celebrity encounter.</p><p>She embodies a new archetype: the technical visionary who uses AI tools to implement sophisticated ideas without traditional programming backgrounds. Her willingness to engage with criticism and continuously improve the system demonstrates the collaborative spirit that makes this new era of development possible.</p><p>The future of software isn&#8217;t just about better AI models or more powerful tools. It&#8217;s about enabling more people with domain expertise and creative vision to participate in building the systems that shape our digital world.</p><p>And sometimes, that means meeting your childhood movie star idol in a GitHub issue thread, debugging memory palace algorithms together.</p><div><hr></div><p><em>Bob Matsuoka is CTO of <a href="https://www.duettocloud.com/">Duetto</a> and writes about AI-powered engineering at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://hyperdev.matsuoka.com/its-the-harness-stupid">It&#8217;s The Harness Stupid</a> &#8212; Why AI tool ecosystems matter more than model capabilities</p></li><li><p><a href="https://aipowerranking.com/">AI Power Ranking</a> &#8212; Tool comparisons and benchmarks for AI practitioners</p></li><li><p><a href="https://www.linkedin.com/newsletters/ai-power-ranking-7345782916301418496/">LinkedIn Newsletter</a> &#8212; Strategic AI insights for CTOs and engineering leaders</p></li></ul><p><strong>Referenced Links:</strong></p><ul><li><p><a href="https://github.com/milla-jovovich/mempalace">MemPalace GitHub Repository</a></p></li><li><p><a href="https://github.com/bobmatnyc/kuzu-memory">KuzuMemory GitHub Repository</a></p></li><li><p><a href="https://github.com/milla-jovovich/mempalace/issues/242">Issue #242: Benchmark adapter bug</a></p></li><li><p><a href="https://github.com/milla-jovovich/mempalace/issues/214">Issue #214: ChromaDB vs MemPalace scoring</a></p></li></ul>]]></content:encoded></item><item><title><![CDATA[The Software Factory is the Next Big Challenge]]></title><description><![CDATA[Many enterprises are rolling their own]]></description><link>https://hyperdev.matsuoka.com/p/the-software-factory-is-the-next</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/the-software-factory-is-the-next</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Wed, 08 Apr 2026 12:30:16 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!tsf8!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!tsf8!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!tsf8!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png 424w, https://substackcdn.com/image/fetch/$s_!tsf8!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png 848w, https://substackcdn.com/image/fetch/$s_!tsf8!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png 1272w, https://substackcdn.com/image/fetch/$s_!tsf8!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!tsf8!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png" width="1024" height="825" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:825,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1823642,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193118243?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F90d9b63c-9a04-4eb4-895e-c659c19b1b3b_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!tsf8!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png 424w, https://substackcdn.com/image/fetch/$s_!tsf8!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png 848w, https://substackcdn.com/image/fetch/$s_!tsf8!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png 1272w, https://substackcdn.com/image/fetch/$s_!tsf8!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F58714619-d828-47fe-aa27-7777b26b3b11_1024x825.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">The Software Factory is the future of software development</figcaption></figure></div><p>Stripe engineers send Slack messages that automatically become production code. Not suggestions. Not drafts. Production code merged into their main branch, supporting over a trillion dollars in annual payment processing.</p><p>Their <a href="https://stripe.dev/blog/minions-stripes-one-shot-end-to-end-coding-agents">&#8220;Minions&#8221; system</a> generates <a href="https://www.infoq.com/news/2026/03/stripe-autonomous-coding-agents/">1,300 pull requests per week</a> with zero human-written code. Fire-and-forget automation from conversation to deployment. While the rest of us debate whether AI can write good code, Stripe has built a software factory that produces enterprise-grade applications at scale.</p><p>The software factory isn&#8217;t a future concept. It&#8217;s a present reality, and it represents the next fundamental challenge for engineering organizations.</p><h2>What We&#8217;re Building at Duetto</h2><p>I&#8217;ve been thinking about this a lot lately. At Duetto, we&#8217;re exploring what a software factory could look like for hospitality technology. Not because we want to eliminate developers, but because we&#8217;re hitting the limits of traditional development approaches for domain-specific applications.</p><p>Our challenge isn&#8217;t just writing code&#8212;it&#8217;s translating complex hotel revenue management requirements into software that works reliably across thousands of properties with different systems, data formats, and business rules. The cognitive load of keeping all these variations in mind while building features is becoming unsustainable.</p><p>What if we could describe what we need in something like our APEX specifications, and have the system generate not just code, but complete deployments? Kubernetes instances running Claude Code agents, database migrations, monitoring setup, the whole stack configured for that specific use case.</p><p>The goal isn&#8217;t replacing our engineering team. Our developers should be solving revenue optimization algorithms and building domain-specific integrations, not configuring YAML files for the hundredth deployment variation.</p><h2>The Stripe Blueprint</h2><p>Stripe&#8217;s Minions reveal what a production software factory actually looks like when you strip away the hype and focus on what works.</p><p><strong>Five-Layer Pipeline</strong>: Their system transforms Slack messages into production-ready pull requests through a structured pipeline. Not magic&#8212;engineering discipline applied to automation.</p><p><strong>Sandboxed Execution</strong>: Every agent runs in isolated containers with codebase checkouts. They can&#8217;t access production systems, can&#8217;t cause cascading failures, can&#8217;t break things outside their designated scope. <a href="https://www.anup.io/stripes-coding-agents-the-walls-matter-more-than-the-model/">The walls matter more than the model</a>.</p><p><strong>Surgical Tool Selection</strong>: Their <a href="https://www.mindstudio.ai/blog/what-is-ai-agent-harness-stripe-minions">Model Context Protocol</a> provides access to hundreds of internal tools, but agents get intelligently prefetched access to only the ~15 tools relevant to their specific task. Not everything available&#8212;the right things available.</p><p><strong>One-Shot Optimization</strong>: Instead of conversational back-and-forth, their agents are <a href="https://www.sitepoint.com/stripe-minions-architecture-explained/">optimized for well-defined work</a> that completes in a single execution. Better latency, lower costs, more predictable outcomes.</p><p>The results speak for themselves: 1,300 PRs weekly, zero human-written code in merged changes, supporting their entire payment infrastructure. This isn&#8217;t a pilot program. This is their production development workflow.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!18qG!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!18qG!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png 424w, https://substackcdn.com/image/fetch/$s_!18qG!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png 848w, https://substackcdn.com/image/fetch/$s_!18qG!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png 1272w, https://substackcdn.com/image/fetch/$s_!18qG!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!18qG!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png" width="1024" height="674" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:674,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1235022,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193118243?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1885512e-da12-485c-9bc1-eaa9bd2512e6_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!18qG!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png 424w, https://substackcdn.com/image/fetch/$s_!18qG!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png 848w, https://substackcdn.com/image/fetch/$s_!18qG!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png 1272w, https://substackcdn.com/image/fetch/$s_!18qG!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F405e3b24-3997-4ecc-89e7-bcd78eb0c218_1024x674.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The Broader Software Factory Landscape</h2><p>Stripe isn&#8217;t alone in building these systems, just the most public about their approach.</p><p>Netflix has their federated developer console integrating dozens of tools into a single unified experience. <a href="https://engineering.atspotify.com/2024/4/supercharged-developer-portals">Spotify&#8217;s Backstage</a> holds 89% market share among internal developer platforms, reducing time-to-tenth-pull-request by 55% for new developers.</p><p>The open source ecosystem is catching up quickly. <a href="https://openhands.dev/">OpenHands</a> provides a model-agnostic platform for cloud coding agents with $18.8M in Series A funding. <a href="https://www.turing.com/blog/top-5-ai-code-generation-tools-in-2024">CodeT5</a> handles multi-language code generation. <a href="https://github.com/features/copilot/enterprise">GitHub Copilot Enterprise</a> is expanding beyond code completion into full workflow automation.</p><p>Major cloud providers are also building comprehensive platforms. Microsoft&#8217;s GitHub Copilot Workspace, Google&#8217;s Duet AI for developers, and Amazon&#8217;s Q Developer all represent enterprise-grade attempts at software factory capabilities.</p><p>According to Gartner, <a href="https://calmops.com/devops/internal-developer-platform-idp-2026-complete-guide/">80% of large engineering organizations</a> now have dedicated platform teams. The question isn&#8217;t whether software factories are coming&#8212;it&#8217;s whether your organization will build one or buy one.</p><h2>What a Proper Software Factory Requires</h2><p>Building a software factory isn&#8217;t just about connecting AI tools to deployment pipelines. Based on what&#8217;s working at Stripe and emerging patterns across the industry, here are the essential components:</p><h3>Artifact Response Systems</h3><p>Your factory needs to respond to structured specifications and generate complete deployments. At Duetto, this might mean taking an APEX specification for a new revenue optimization feature and producing:</p><ul><li><p>Kubernetes deployment configurations</p></li><li><p>Database migration scripts</p></li><li><p>Monitoring and alerting setup</p></li><li><p>Load testing scenarios</p></li><li><p>Documentation</p></li></ul><p>The system should handle the entire deployment lifecycle from specification to running production service, not just generate code that someone has to manually deploy.</p><h3>Strategic Human Review Checkpoints</h3><p>Notice I said strategic, not comprehensive. Stripe&#8217;s fire-and-forget model works because they&#8217;ve identified the specific points where human judgment adds value without blocking automation.</p><p>For enterprise applications, you need checkpoints at:</p><ul><li><p><strong>Specification validation</strong>: Do the requirements make business sense?</p></li><li><p><strong>Security review</strong>: Are access patterns and data handling appropriate?</p></li><li><p><strong>Integration testing</strong>: Does this work with existing systems?</p></li><li><p><strong>Production readiness</strong>: Are monitoring and rollback capabilities sufficient?</p></li></ul><p>The key is making these gates fast and decisive, not bureaucratic approval processes that defeat the purpose of automation.</p><h3>Scaffolding for Error Detection</h3><p>Your factory will produce broken code. That&#8217;s not a bug&#8212;that&#8217;s reality. The difference between a prototype and a production system is sophisticated error detection and recovery.</p><p>This means:</p><ul><li><p><strong>Isolated execution environments</strong> where failures can&#8217;t cause broader damage</p></li><li><p><strong>Automated testing and iteration</strong> when initial attempts fail</p></li><li><p><strong>Multi-layer validation</strong> before anything reaches production</p></li><li><p><strong>Comprehensive rollback capabilities</strong> for when something gets through anyway</p></li></ul><p>Stripe&#8217;s sandbox architecture is brilliant because it lets agents fail safely while learning from those failures to improve future attempts.</p><h3>Success Criteria Parameters</h3><p>Your factory needs to know what success looks like for each type of work. Not just &#8220;the code compiles,&#8221; but measurable business outcomes.</p><p>For a hospitality feature, success might mean:</p><ul><li><p>Performance benchmarks met under load</p></li><li><p>Integration tests pass with five different PMS systems</p></li><li><p>Revenue impact measurable within 30 days</p></li><li><p>Zero customer-facing errors in the first week</p></li></ul><p>Define these criteria upfront, build them into your validation pipeline, and let the factory optimize for actual business value rather than technical metrics alone.</p><h3>Cost Tracking and Optimization</h3><p>AI-powered development isn&#8217;t free. You need visibility into the computational costs, tool usage, and human review time for each generated system.</p><p>Stripe optimizes for this explicitly&#8212;their one-shot agents cost less than conversational approaches, their surgical tool selection reduces context costs, their automated testing prevents expensive human debugging cycles.</p><p>Track these metrics from day one. The difference between a cost-effective software factory and an expensive experiment is usually found in the operational details.</p><h3>Deployment Models</h3><p>Your factory needs sophisticated understanding of how to deploy different types of applications. Golden Path workflows that codify best practices, environment promotion strategies that reduce risk, and rollback procedures that restore service quickly when things go wrong.</p><p>This is where domain expertise becomes critical. A generic software factory might know how to deploy a web service, but does it understand the specific requirements for hospitality payment processing, guest data privacy, and integration with property management systems?</p><h2>The Duetto Context</h2><p>At Duetto, we&#8217;re thinking about how a software factory could handle the complexity of hospitality technology. Our domain has unique challenges:</p><p><strong>Data Integration Complexity</strong>: Every hotel uses different systems with different data formats. A software factory needs to understand these variations and generate appropriate integration code.</p><p><strong>Regulatory Requirements</strong>: Guest privacy, payment processing, accessibility compliance. The factory needs to embed these requirements into everything it produces.</p><p><strong>Performance Characteristics</strong>: Revenue management systems need to process pricing updates in near real-time across thousands of rooms and rate plans. The factory needs to optimize for these specific performance patterns.</p><p><strong>Operational Constraints</strong>: Hotels can&#8217;t afford downtime during peak booking periods. Deployment strategies need to account for hospitality business cycles.</p><p>We&#8217;re not trying to build a general-purpose software factory. We&#8217;re exploring how to build one that deeply understands our domain and can produce applications that work reliably in hospitality environments.</p><h2>The Reality Check</h2><p>Building a software factory is hard. Not because the technology doesn&#8217;t exist&#8212;Stripe proves it does&#8212;but because the organizational challenges are substantial.</p><p><strong>ROI Demonstration</strong>: You need to show measurable productivity improvements and cost savings. &#8220;The AI is impressive&#8221; isn&#8217;t sufficient justification for the investment required.</p><p><strong>Security and Compliance</strong>: Automated code generation that touches customer data or payment systems requires additional security layers and audit capabilities.</p><p><strong>Developer Workflow Changes</strong>: Your engineering team needs to learn new ways of working. Some will embrace it, others will resist. Change management is as important as the technical implementation.</p><p><strong>Quality Assurance Evolution</strong>: Your QA processes need to evolve from testing human-written code to validating AI-generated systems. Different failure modes, different testing strategies.</p><p><strong>Integration Complexity</strong>: Your factory needs to work with existing systems, databases, APIs, and workflows. The harder the integration challenge, the longer the implementation timeline.</p><p>These aren&#8217;t reasons to avoid building a software factory. They&#8217;re reasons to approach the project with realistic expectations and proper preparation.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!bVFQ!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!bVFQ!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png 424w, https://substackcdn.com/image/fetch/$s_!bVFQ!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png 848w, https://substackcdn.com/image/fetch/$s_!bVFQ!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png 1272w, https://substackcdn.com/image/fetch/$s_!bVFQ!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!bVFQ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png" width="1024" height="678" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:678,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1446253,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193118243?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F71a61e37-d209-4927-8ab4-44a35ed22bb9_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!bVFQ!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png 424w, https://substackcdn.com/image/fetch/$s_!bVFQ!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png 848w, https://substackcdn.com/image/fetch/$s_!bVFQ!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png 1272w, https://substackcdn.com/image/fetch/$s_!bVFQ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5931edca-6b79-4588-bae5-ab6a883a7b66_1024x678.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>Looking Forward</h2><p>The trajectory is clear. <a href="https://leanopstech.com/blog/platform-engineering-in-2025-the-future-of-developer-productivity/">Software factories are moving from experimental to mainstream</a>, with proven systems operating at enterprise scale and standardized architecture patterns emerging across the industry.</p><p>The question for engineering leaders isn&#8217;t whether this transformation will happen. It&#8217;s whether your organization will be an early adopter that shapes how software factories work in your domain, or a later adopter that implements patterns developed by others.</p><p>At Duetto, we&#8217;re betting on being early. Not because we want to be on the cutting edge for its own sake, but because the companies that figure out domain-specific software factories first will have a significant competitive advantage in application development speed and quality.</p><p>The software factory represents the next evolution of platform engineering. The organizations that master it will build better software faster than those that don&#8217;t.</p><p>The challenge isn&#8217;t technical anymore. It&#8217;s organizational, strategic, and operational.</p><p>The question is: Are you ready to build one?</p><div><hr></div><p><em>About this analysis: This piece draws from comprehensive research on production software factory implementations, including detailed analysis of Stripe&#8217;s Minions architecture, enterprise platform engineering initiatives, and emerging open source solutions. The author is exploring software factory applications for hospitality technology at Duetto.</em></p><p><em>About the author: Bob Matsuoka is Chief Technology Officer at Duetto and creator of Claude MPM (Multi-agent Project Manager). He has implemented AI-assisted development workflows across enterprise engineering teams and writes about the practical realities of AI integration in software development at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p>]]></content:encoded></item><item><title><![CDATA[Is The Claude Code Team Moving Too Quickly?]]></title><description><![CDATA[What To Think of the Source Leak]]></description><link>https://hyperdev.matsuoka.com/p/is-the-claude-code-team-moving-too</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/is-the-claude-code-team-moving-too</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Mon, 06 Apr 2026 12:30:41 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!xLBj!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!xLBj!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!xLBj!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png 424w, https://substackcdn.com/image/fetch/$s_!xLBj!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png 848w, https://substackcdn.com/image/fetch/$s_!xLBj!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png 1272w, https://substackcdn.com/image/fetch/$s_!xLBj!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!xLBj!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png" width="1024" height="595" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/d07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:595,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1151803,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193101232?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9d9c1f20-243f-4cf5-b1c1-b708e63ffae8_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!xLBj!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png 424w, https://substackcdn.com/image/fetch/$s_!xLBj!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png 848w, https://substackcdn.com/image/fetch/$s_!xLBj!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png 1272w, https://substackcdn.com/image/fetch/$s_!xLBj!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd07636e2-b451-4839-853e-91fc8ca0b4b3_1024x595.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>On March 31, 2026, Anthropic accidentally shipped their entire Claude Code source&#8212;512,000 lines of TypeScript&#8212;in an npm package. What followed was perhaps the most intense technical autopsy in AI history. The verdict? Mixed, and revealing.</p><p>The criticism has been swift and pointed. A 5,594-line file with a single 3,167-line function sporting 12 levels of nesting. Regex-based frustration detection looking for &#8220;wtf&#8221; and &#8220;shit&#8221;. A quarter million wasted API calls per day from a three-line bug. As one critic put it: &#8220;A multi-billion-dollar AI company is detecting user frustration with a regex.&#8221;</p><p>But before we pile on, we need to ask: <strong>What does &#8220;good code&#8221; even mean when you&#8217;re building client-side LLM applications?</strong></p><h2>The Unprecedented Challenge</h2><p>Claude Code isn&#8217;t your typical software. It&#8217;s a client-side application that orchestrates conversations with large language models, manages context across sessions, and attempts to maintain coherent state while working with fundamentally non-deterministic systems.</p><p>This creates problems that traditional software engineering practices weren&#8217;t designed for:</p><ul><li><p><strong>Context management</strong>: Handling arbitrarily long conversations that exceed model limits</p></li><li><p><strong>Failure recovery</strong>: When your core computation is a 20% failure-rate API call</p></li><li><p><strong>State synchronization</strong>: Keeping UI, conversation history, and model context aligned</p></li><li><p><strong>Dynamic adaptation</strong>: Code that needs to adapt to changing model capabilities</p></li></ul><p>The leaked source reveals sophisticated solutions to these problems: a three-layer memory architecture, anti-distillation mechanisms, dual parser systems for safety. The engineering is <s>genuinely</s> impressive, even if the implementation is sometimes ugly.</p><h2>The Meta-Problem: AI Writing AI</h2><p>Claude Code was partially written by Claude Code. This represents the first documented case of a large-scale AI tool generating significant portions of its own source code&#8212;not just incremental improvement, but a categorical change in development methodology that creates unprecedented quality control challenges when AI-generated code scales beyond human review capacity.</p><p>When AI generates code at scales that exceed human review capacity, traditional quality control breaks down. That 3,167-line function? Probably not written by a human. The 12 levels of nesting? Algorithmic patterns, not human design choices.</p><p><strong>This is the real story</strong>: We&#8217;re witnessing the first major autopsy of self-bootstrapping AI tooling.</p><h2>Deterministic vs. LLM Code: Different Standards Apply</h2><p>I&#8217;ve been thinking about this distinction a lot lately in my work with <a href="https://github.com/bobmatnyc/claude-mpm">Claude MPM</a>, an open-source multi-agent code generation framework built on Claude Code that coordinates specialized AI agents for software development workflows. When you&#8217;re building traditional, deterministic software, all the usual rules apply. Clean functions, clear abstractions, maintainable architecture. Use your normal code analysis tools.</p><p>But when you&#8217;re building LLM-integrated systems, the rules change:</p><ol><li><p><strong>Failure is the default</strong>: Your core operations fail 20% of the time</p></li><li><p><strong>Context is expensive</strong>: Every token counts toward limits</p></li><li><p><strong>Behavior is emergent</strong>: The system does things you didn&#8217;t explicitly program</p></li><li><p><strong>Adaptation is constant</strong>: Model capabilities change monthly</p></li></ol><p>In this world, a 5,594-line file might be ugly, but if it successfully manages complex failure recovery across multiple conversation threads, it might also be <em>correct</em>.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!aIuf!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!aIuf!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png 424w, https://substackcdn.com/image/fetch/$s_!aIuf!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png 848w, https://substackcdn.com/image/fetch/$s_!aIuf!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png 1272w, https://substackcdn.com/image/fetch/$s_!aIuf!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!aIuf!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png" width="1024" height="790" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/d26aa417-4783-42d6-8105-488131dfe518_1024x790.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:790,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1466836,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193101232?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd33fb826-655a-4d8b-87cc-bfade8984326_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!aIuf!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png 424w, https://substackcdn.com/image/fetch/$s_!aIuf!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png 848w, https://substackcdn.com/image/fetch/$s_!aIuf!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png 1272w, https://substackcdn.com/image/fetch/$s_!aIuf!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd26aa417-4783-42d6-8105-488131dfe518_1024x790.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The Code Analysis Checkpoint Strategy</h2><p>This is where I&#8217;ve found success with my recent updates to the code analyzer in Claude MPM. The analyzer utilizes <a href="https://github.com/modelcontextprotocol/servers/tree/main/src/mcp-vector-search">mcp-vector-search</a> for comprehensive codebase analysis, providing AST-based semantic search, full-text search capabilities, and knowledge graph construction for architectural pattern detection. Instead of trying to prevent AI from generating messy code (impossible), I focus on <strong>regular refactoring and analysis checkpoints</strong>.</p><p>The analyzer has gotten very good at catching two specific issues:</p><ol><li><p><strong>Drift</strong>: When AI-generated code slowly diverges from intended architecture</p></li><li><p><strong>Bloat</strong>: When generated solutions become unnecessarily complex over time</p></li></ol><p>I make a point to run these checkpoints regularly, treating them as essential maintenance rather than optional cleanup. It&#8217;s like running <code>cargo clippy</code> or <code>eslint</code>, but for AI-generated architectural decisions.</p><p>The key insight: <strong>AI code needs different kinds of maintenance than human code</strong>.</p><h2>Outcome-Based Generation: Does It Work?</h2><p>Here&#8217;s my perhaps controversial take: If Claude Code successfully helps developers ship better software faster, then the messy internals might not matter as much as we think.</p><p>The leaked code reveals a system that:</p><ul><li><p>Handles millions of conversations per day</p></li><li><p>Maintains context across arbitrarily long sessions</p></li><li><p>Provides sophisticated memory management</p></li><li><p>Implements multiple safety layers</p></li><li><p>Delivers a $2.5 billion ARR product experience</p></li></ul><p>Is the implementation elegant? No. Does it work? Apparently, yes. Because we can observe/measure what it&#8217;s building completely independently of what built it.</p><p>This doesn&#8217;t excuse basic engineering failures (that <code>.npmignore</code> mistake was embarrassing). But it does suggest we need new frameworks for evaluating AI-generated systems.</p><h2>The Scaffolding Solution</h2><p>Rather than trying to make AI generate perfect code, we can scaffold around the inevitable messiness:</p><p><strong>Automated refactoring checkpoints</strong>: Regular cleanup of AI-generated bloat<br><strong>Architectural constraints</strong>: Guard rails that prevent the worst patterns<br><strong>Outcome validation</strong>: Testing that focuses on behavior over implementation<br><strong>Human oversight</strong>: Strategic points where humans validate AI decisions</p><p>This is the approach I&#8217;ve been taking with Claude MPM, and it&#8217;s proven remarkably effective. Let the AI generate messy-but-functional code, then use tooling to clean it up systematically.</p><h2>What This Means for the Industry</h2><p>The Claude Code leak represents a watershed moment. It&#8217;s our first real look at what happens when AI tools build themselves at scale.</p><p>The criticism is valid&#8212;basic engineering discipline matters, even in AI systems. A missing <code>.npmignore</code> file is inexcusable for a billion-dollar product.</p><p>But the deeper question is whether we&#8217;re applying the right standards. Traditional code quality metrics may not capture what actually matters for AI-integrated systems.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!NrDl!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!NrDl!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png 424w, https://substackcdn.com/image/fetch/$s_!NrDl!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png 848w, https://substackcdn.com/image/fetch/$s_!NrDl!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png 1272w, https://substackcdn.com/image/fetch/$s_!NrDl!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!NrDl!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png" width="1024" height="825" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:825,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1937908,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/193101232?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1273dbb0-a196-49bc-b0ca-17f437545fd8_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!NrDl!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png 424w, https://substackcdn.com/image/fetch/$s_!NrDl!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png 848w, https://substackcdn.com/image/fetch/$s_!NrDl!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png 1272w, https://substackcdn.com/image/fetch/$s_!NrDl!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F87df3326-02c3-4838-b302-ab23ab5d5e19_1024x825.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>Moving Forward</h2><p>Anthropic probably <em>is</em> moving too quickly in some ways. The leak revealed security vulnerabilities, competitive intelligence losses, and quality control failures that suggest inadequate human oversight.</p><p>But they&#8217;re also pioneering entirely new categories of software. The problems they&#8217;re solving&#8212;context management, failure recovery, human-AI collaboration&#8212;don&#8217;t have established best practices yet.</p><p>The real lesson isn&#8217;t that AI-generated code is inherently bad. It&#8217;s that we need new practices for building, reviewing, and maintaining systems that exceed human comprehension scales.</p><p><strong>The question isn&#8217;t whether Claude Code&#8217;s internals are messy. It&#8217;s whether we can build better scaffolding around AI-generated systems to catch the problems that matter while accepting the messiness we can&#8217;t avoid.</strong></p><p>The Claude Code team probably needs to slow down on the basics&#8212;security, testing, deployment hygiene. But they&#8217;re moving fast on problems that genuinely require speed to solve before competitors do.</p><p>That&#8217;s a nuanced position in an industry that loves simple takes. But nuance is what the moment requires.</p><p><em>What do you think? Are we being too hard on AI-generated code, or not hard enough? Share your thoughts in the comments.</em></p><div><hr></div><p><em>About this analysis: This piece draws from extensive technical analysis of the March 31, 2026 Claude Code source leak, including community responses, security assessments, and business impact analysis. The author maintains active development projects using AI-assisted coding tools and has direct experience with the challenges discussed.</em></p><p><em>About the author: Bob Matsuoka is Chief Technology Officer at <a href="https://www.duettocloud.com/">Duetto</a> and creator of Claude MPM (Multi-agent Project Manager). He has implemented AI-assisted development workflows across enterprise engineering teams and writes about the practical realities of AI integration in software development at <a href="https://hyperdev.substack.com">HyperDev</a>.</em></p>]]></content:encoded></item><item><title><![CDATA[Moving Past the 10-Tab Workflow]]></title><description><![CDATA[Autonomous Orchestration Management Is Next]]></description><link>https://hyperdev.matsuoka.com/p/moving-past-the-10-tab-workflow</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/moving-past-the-10-tab-workflow</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Wed, 01 Apr 2026 12:32:10 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!wz2X!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!wz2X!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!wz2X!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png 424w, https://substackcdn.com/image/fetch/$s_!wz2X!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png 848w, https://substackcdn.com/image/fetch/$s_!wz2X!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png 1272w, https://substackcdn.com/image/fetch/$s_!wz2X!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!wz2X!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png" width="1024" height="690" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/a5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:690,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1272299,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/192741144?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb87ec05a-31c6-4037-a9e0-db7c8c8fcba4_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!wz2X!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png 424w, https://substackcdn.com/image/fetch/$s_!wz2X!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png 848w, https://substackcdn.com/image/fetch/$s_!wz2X!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png 1272w, https://substackcdn.com/image/fetch/$s_!wz2X!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa5c54d57-2f21-4893-a87d-88523deb8ae7_1024x690.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">From Tab Chaos to Autonomic Orchestration</figcaption></figure></div><p>I&#8217;m looking at my (iTerm) terminal right now. Ten tmux sessions. Each session holds a different project context&#8212;one monitoring CI failures, another handling a code review, a third debugging a production issue.</p><p>This is the reality of modern agent development work.</p><h2>TL;DR</h2><ul><li><p><strong>Multi-session reality</strong>: Power users average 8-12 terminal sessions; most work involves modification, bug response, and PR handling&#8212;not new code generation</p></li><li><p><strong>Natural workflow origination</strong>: Future systems trigger from product team actions, CI failures, and automated events rather than human prompts </p></li><li><p><strong>Orchestration evolution</strong>: From human-orchestrated agents to orchestration-of-orchestrators where prime coordinators are non-human</p></li><li><p><strong>Production examples</strong>: Stripe&#8217;s Minions (1,300 PRs/week), GitLab&#8217;s Duo Agent Platform, Meta&#8217;s REA demonstrate hierarchical agent orchestration</p></li><li><p><strong>Architecture shift</strong>: Claude Code&#8217;s SDK model enables workflow-driven development through persistent, context-aware agent orchestration</p></li></ul><h2>The 10-Tab Reality</h2><p>According to recent developer workflow studies, <a href="https://www.heyuan110.com/posts/ai/2026-03-03-tmux-guide-ai-development/">tmux has become the standard for AI-assisted development</a>, with <a href="https://dev.to/_d7eb1c1703182e3ce1782/tmux-tutorial-the-complete-developer-workflow-guide-2026-33b3">persistent sessions solving the context-switching tax</a>. The productivity advantage isn&#8217;t the multiplexing&#8212;it&#8217;s the persistence. Projects become environments you step in and out of rather than things you open and close.</p><p>But here&#8217;s what the productivity tutorials miss: most of those tabs aren&#8217;t generating software.</p><p><strong>My current session breakdown:</strong></p><ul><li><p>3 sessions: non-coding -- my CTO knowledge base (currently analyzing our Sumo use), a writing assistant, and our Duetto product management framework</p></li><li><p>4 sessions: coding - various internal tools and MCP connectors</p></li><li><p>2 sessions: coding - new projects</p></li><li><p>1 session: code review</p></li></ul><p>The 8:2 ratio holds across most senior developers I&#8217;ve observed. Most development work involves responding to existing systems, not creating new ones.</p><p>This distribution points toward something significant: <strong>the future of development orchestration isn&#8217;t human-initiated.</strong></p><h2>Beyond Prompt-Driven Development</h2><p>Claude Code&#8217;s new SDK architecture reflects this reality. Instead of starting with human prompts, work originates from natural workflow events:</p><ul><li><p>Product team creates ticket &#8594; Implementation specification generated</p></li><li><p>CI pipeline fails &#8594; Diagnostic agent analyzes failure, proposes fix</p></li><li><p>PR submitted &#8594; Review agent examines code, suggests improvements</p></li><li><p>Production alert triggered &#8594; Incident response agent investigates, documents findings</p></li><li><p>Security scan detects vulnerability &#8594; Remediation agent generates patch</p></li></ul><p>The pattern: <strong>Event &#8594; Agent Response &#8594; Human Review &#8594; Autonomous Resolution</strong>.</p><p>Humans remain in the loop, but as orchestrators and validators rather than initiators. The shift from &#8220;What should I build?&#8221; to &#8220;How should this system respond?&#8221;</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!G7Uu!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!G7Uu!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png 424w, https://substackcdn.com/image/fetch/$s_!G7Uu!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png 848w, https://substackcdn.com/image/fetch/$s_!G7Uu!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!G7Uu!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!G7Uu!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png" width="1024" height="1024" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:1024,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1418038,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/192741144?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!G7Uu!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png 424w, https://substackcdn.com/image/fetch/$s_!G7Uu!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png 848w, https://substackcdn.com/image/fetch/$s_!G7Uu!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!G7Uu!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F20f98126-397c-40f4-bf7d-6fc025ab018d_1024x1024.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Yes, Dall-e is Still Atrocious With Spelling.  Don&#8217;t @ me!</figcaption></figure></div><h2>Orchestration of Orchestrators: Production Examples</h2><h3>Stripe&#8217;s Blueprint Architecture</h3><p><a href="https://medium.com/@oracle_43885/how-stripe-built-secure-unattended-ai-agents-merging-1-000-pull-requests-weekly-1ff42f3fe550">Stripe&#8217;s Minions system demonstrates mature orchestration-of-orchestrators</a>. Their &#8220;blueprint&#8221; pattern alternates between deterministic code nodes and agentic reasoning loops, generating <a href="https://blog.bytebytego.com/p/how-stripes-minions-ship-1300-prs">1,300+ pull requests weekly</a>.</p><p><strong>Architecture insight</strong>: <a href="https://www.mindstudio.ai/blog/stripe-minions-blueprint-architecture-deterministic-agentic-nodes">Each blueprint functions as a strict contract between orchestration and execution</a>. Task definitions specify input requirements, output formats, constraints, and success criteria. The orchestrator manages workflow, agents handle implementation.</p><p><strong>Security model</strong>: <a href="https://www.sitepoint.com/stripe-minions-architecture-explained/">Every Minion execution runs in isolated VMs</a> with no internet or production access. The system has submission authority but not merge authority&#8212;all changes require human review.</p><h3>GitLab&#8217;s Intelligent Orchestration</h3><p><a href="https://about.gitlab.com/blog/agentic-sdlc-gitlab-and-tcs-deliver-intelligent-orchestration-across-the-enterprise/">GitLab&#8217;s Duo Agent Platform treats agents as durable actors</a> that plan, modify code, fix pipelines, and enforce security with traceability. Multiple AI agents handle parallel tasks&#8212;code generation, testing, CI/CD fixes&#8212;while developers maintain oversight through defined rules.</p><p><strong>Orchestration insight</strong>: <a href="https://docs.gitlab.com/user/duo_agent_platform/">GitLab positions itself as an AI orchestration plane</a> where humans and agents share delivery responsibility. The platform coordinates multi-agent workflows across the entire software lifecycle rather than providing isolated AI tools.</p><h3>Meta&#8217;s Hierarchical Agent Systems</h3><p><a href="https://engineering.fb.com/2026/03/17/developer-tools/ranking-engineer-agent-rea-autonomous-ai-system-accelerating-meta-ads-ranking-innovation/">Meta&#8217;s Ranking Engineer Agent (REA) demonstrates autonomous ML lifecycle management</a>. REA Planner and REA Executor components, supported by shared skill and knowledge systems, autonomously evolve ads ranking models at scale.</p><p><strong>Acquisition significance</strong>: <a href="https://venturebeat.com/orchestration/why-meta-bought-manus-and-what-it-means-for-your-enterprise-ai-agent">Meta&#8217;s $2B Manus acquisition</a> focused on orchestration infrastructure rather than foundation models. Manus&#8217;s achievement was engineering an execution layer enabling models to browse, code, manipulate files, and complete multi-step workflows autonomously.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!21xU!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!21xU!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png 424w, https://substackcdn.com/image/fetch/$s_!21xU!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png 848w, https://substackcdn.com/image/fetch/$s_!21xU!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png 1272w, https://substackcdn.com/image/fetch/$s_!21xU!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!21xU!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png" width="1024" height="663" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:663,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1147097,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/192741144?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fef64881a-c7f7-4bab-8d8d-2393ee5bf8b0_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!21xU!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png 424w, https://substackcdn.com/image/fetch/$s_!21xU!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png 848w, https://substackcdn.com/image/fetch/$s_!21xU!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png 1272w, https://substackcdn.com/image/fetch/$s_!21xU!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F0980b901-da6a-408f-a4c7-2dd2188be40c_1024x663.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The Architecture Implications</h2><h3>Beyond the Single-Agent Model</h3><p>The production examples reveal a consistent pattern: successful autonomous development requires <strong>hierarchical orchestration</strong> rather than monolithic AI assistants.</p><p><strong>Traditional approach</strong>: Human &#8594; Single Agent &#8594; Code<br><strong>Emerging pattern</strong>: Event &#8594; Orchestrator &#8594; Specialized Agents &#8594; Validation &#8594; Resolution</p><h3>Context Preservation at Scale</h3><p><a href="https://medium.com/@gveloper/using-iterm2s-built-in-integration-with-tmux-d5d0ef55ec30">The tmux paradigm</a> of persistent sessions maps directly to agent orchestration. Instead of recreating context for each interaction, systems maintain ongoing project understanding across multiple concurrent workflows.</p><p><strong>Implementation insight</strong>: <a href="https://iterm2.com/documentation-tmux-integration.html">iTerm2&#8217;s tmux integration (-CC mode)</a> provides the UI pattern for agent orchestration&#8212;persistent remote workspaces with native interface feel. The same architecture principles apply to agent coordination.</p><h2>Where This Leads</h2><h3>Non-Human Prime Orchestrators</h3><p>The logical endpoint isn&#8217;t humans managing multiple agents&#8212;it&#8217;s orchestrating systems that manage agent ecosystems. <a href="https://www.deloitte.com/us/en/insights/industry/technology/technology-media-and-telecom-predictions/2026/ai-agent-orchestration.html">According to Gartner&#8217;s 2025 Agentic AI research</a>, nearly 50% of surveyed vendors identified AI orchestration as their primary differentiator.</p><p><strong>Pattern emergence</strong>: Meta-agents or orchestrator-generalists will control specialized agents, assign tasks, interpret results, and revise goals in real-time. <a href="https://arxiv.org/pdf/2601.13671">Hierarchical orchestration becomes essential for enterprise-scale implementations</a>.</p><h3>The Developer Role Evolution</h3><p>Instead of managing 10 terminal sessions, a framework orchestrates autonomous workflows. Each workflow maintains its own context, responds to its own triggers, and escalates to human attention when required. Some of those will be human/experimentation/new development driven, the majority will be responding to the automated lifecycle.</p><p><strong>Skills that matter</strong>:</p><ul><li><p><strong>Workflow boundary definition</strong>: Which autonomous streams can operate independently?</p></li><li><p><strong>Escalation criteria design</strong>: When do workflows require human intervention?</p></li><li><p><strong>Cross-workflow dependency management</strong>: How do autonomous streams coordinate?</p></li><li><p><strong>Quality gate enforcement</strong>: What validation must occur before autonomous resolution?</p></li></ul><h2>Implementation Considerations</h2><p>Teams experimenting with orchestrated autonomous development should consider:</p><ol><li><p><strong>Event-driven architecture</strong>: Which existing workflows could trigger autonomous responses?</p></li><li><p><strong>Context preservation systems</strong>: How will agent workflows maintain project understanding?</p></li><li><p><strong>Isolation and security</strong>: What boundaries prevent autonomous agents from causing damage?</p></li><li><p><strong>Human oversight integration</strong>: Where do human validation points occur in autonomous workflows?</p></li><li><p><strong>Cross-workflow coordination</strong>: How do parallel autonomous streams avoid conflicts?</p></li></ol><p>The transition from 10-tab manual orchestration to autonomous lifecycle orchestration isn&#8217;t theoretical. Stripe, GitLab, and Meta demonstrate production implementations. The question becomes implementation timeline and organizational readiness.</p><p>Early adopters are discovering that the competitive advantage comes not from having the smartest individual AI agents, but from orchestrating networks of specialized agents that collaborate effectively at scale.</p><div><hr></div><p><em>Bob Matsuoka is CTO of <a href="https://www.duettocloud.com/">Duetto</a> and writes about AI-powered engineering at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://www.coddykit.com/pages/blog-detail?id=512757">Stripe&#8217;s Minions: Inside Their Enterprise AI Coding Agent Strategy</a> &#8212; Blueprint orchestration architecture and production metrics</p></li><li><p><a href="https://docs.gitlab.com/user/duo_agent_platform/">GitLab Duo Agent Platform</a> &#8212; Intelligent orchestration across software lifecycle</p></li><li><p><a href="https://www.heyuan110.com/posts/ai/2026-03-03-tmux-guide-ai-development/">Tmux Complete Guide: AI-Powered Multi-Agent Workflows</a> &#8212; Terminal multiplexing for autonomous development</p></li><li><p><a href="https://aipowerranking.com/">AI Power Ranking</a> &#8212; Tool comparisons and benchmarks for AI practitioners</p></li><li><p><a href="https://www.linkedin.com/newsletters/ai-power-ranking-7345782916301418496/">LinkedIn Newsletter</a> &#8212; Strategic AI insights for CTOs and engineering leaders</p></li></ul>]]></content:encoded></item><item><title><![CDATA[Everyone Blamed Clawd Bot’s Execution. The Concept Was the Problem.]]></title><description><![CDATA[Is A Personal Assistant Bot Really Helpful?]]></description><link>https://hyperdev.matsuoka.com/p/everyone-blamed-clawd-bots-execution</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/everyone-blamed-clawd-bots-execution</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Thu, 12 Mar 2026 11:32:09 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!51wj!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!51wj!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!51wj!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png 424w, https://substackcdn.com/image/fetch/$s_!51wj!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png 848w, https://substackcdn.com/image/fetch/$s_!51wj!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png 1272w, https://substackcdn.com/image/fetch/$s_!51wj!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!51wj!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png" width="1024" height="774" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:774,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1722868,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/190672571?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb05bbe76-836e-475e-b360-793755bf1927_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!51wj!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png 424w, https://substackcdn.com/image/fetch/$s_!51wj!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png 848w, https://substackcdn.com/image/fetch/$s_!51wj!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png 1272w, https://substackcdn.com/image/fetch/$s_!51wj!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F878e8350-5206-465d-9bf0-b600661c22ed_1024x774.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>The story everyone told about Clawd Bot missed the point entirely. Austrian developer Peter Steinberger built an open-source AI assistant that went viral &#8212; 145,000 GitHub stars, 2 million visitors in a week. Then Anthropic forced a trademark-based name change because &#8220;Clawd&#8221; was too similar to &#8220;Claude.&#8221; The community called it petty. DHH called Anthropic &#8220;customer hostile.&#8221; The irony: Clawd Bot users were actually buying more Claude subscriptions, providing free marketing to Anthropic, yet they still demanded the shutdown.</p><p>But everyone focused on the wrong drama. The trademark dispute was noise. The real problem was deeper: Clawd Bot was built because someone could, not because anyone needed it.</p><p>I tested Clawd Bot for about a week. The interface was clean, the onboarding smooth, the responses capable. But it required permissions I wouldn&#8217;t give to any tool &#8212; access to email, calendars, messaging, sensitive services. The execution had real problems. But even if those were fixed, it would still be solving the wrong problem.</p><p>Here&#8217;s where I should admit: I tried building a digital assistant, izzie, when I started experimenting with AI agents. I never got it to a point I found useful. Not because of technical limitations &#8212; because the entire concept of a universal assistant doesn&#8217;t match how work actually happens.</p><h2>TL;DR</h2><ul><li><p>Clawd Bot was successful open-source project by Peter Steinberger that Anthropic forced to rename; execution wasn&#8217;t the problem</p></li><li><p>The real question: when do you need an &#8220;assistant&#8221;? Most execs won&#8217;t trust AI scheduling; the value is intelligent data movement between services</p></li><li><p>Context switching is a symptom, not the root issue &#8212; the issue is what assistants should be doing at all</p></li><li><p>The product management sessions: Granola meeting notes, calendar checks, Slack updates, Notion sync &#8212; all from within one tool, data flowing intelligently between services</p></li><li><p>The commercial evidence: Cursor, Notion AI, Linear&#8217;s AI triage &#8212; the winners embedded AI in tools as infrastructure, not interface</p></li><li><p>trusty-izzie&#8217;s highest value isn&#8217;t the chat interface &#8212; it&#8217;s as a local MCP service exporting personal context to every other tool</p></li><li><p>The universal assistant category isn&#8217;t going to produce a winner. It&#8217;s going to dissolve.</p></li></ul><h2>What the Universal Assistant Model Gets Wrong (And It&#8217;s Not Just Execution)</h2><p>Clawd Bot had serious execution problems &#8212; it&#8217;s a security nightmare requiring broad permissions across email, calendars, messaging platforms, and sensitive services. You can&#8217;t ignore that. But even if the security issues were solved, universal assistants face a deeper structural problem: they assume people need an assistant in the traditional sense.</p><p>Walk through what even a well-executed version of the same product model looks like.</p><p>Smooth onboarding. Crystal-clear use cases. High-quality AI responses. Clean interface design. Users know exactly what to ask and how to ask it.</p><p>You still have to leave whatever you&#8217;re working on to use it. And when you do, the context you were carrying &#8212; the code you were reviewing, the initiative you were drafting, the design decision you were working through &#8212; is no longer present. You&#8217;ve moved somewhere that knows nothing about any of that.</p><p>So you explain. &#8220;I&#8217;m working on the &#8216;YYY&#8217; data ingestion initiative, and I need to check whether the points Mark raised in Tuesday&#8217;s meeting are addressed in the current design.&#8221; The assistant doesn&#8217;t know what &#8216;YYY&#8217; is. Doesn&#8217;t have Tuesday&#8217;s meeting. Doesn&#8217;t know Mark, the current design, or the organizational context that makes &#8220;addressed&#8221; mean something specific. You load all of it by hand.</p><p>In demos, this overhead is invisible. Demo tasks are self-contained by design &#8212; the context fits in a sentence or two. In practice, your working context isn&#8217;t self-contained. It&#8217;s weeks of accumulated decisions, relationships, dependencies, and constraints that live distributed across your tools. You can&#8217;t paste it into a chat window. You can&#8217;t even fully articulate it. It&#8217;s partially tacit, partially in documents, partially in the history of the tool you&#8217;re using.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!skTt!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!skTt!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png 424w, https://substackcdn.com/image/fetch/$s_!skTt!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png 848w, https://substackcdn.com/image/fetch/$s_!skTt!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png 1272w, https://substackcdn.com/image/fetch/$s_!skTt!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!skTt!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png" width="1024" height="641" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:641,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1522333,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/190672571?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff92dde62-56c6-4fa2-ab9a-1147e8c99362_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!skTt!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png 424w, https://substackcdn.com/image/fetch/$s_!skTt!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png 848w, https://substackcdn.com/image/fetch/$s_!skTt!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png 1272w, https://substackcdn.com/image/fetch/$s_!skTt!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F8a50911a-4ef2-491e-8d2e-01234b0fec77_1024x641.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The Session That Clarified It</h2><p>A few weeks into the new role at Duetto, I was doing product management work in a <a href="https://github.com/bobmatnyc/claude-mpm">claude-mpm</a> session &#8212; reviewing open initiatives, managing the PR queue, creating proposals. Standard operational work for a new CTO getting oriented.</p><p>I wanted to add an infrastructure initiative. Cloud Dev Sleds &#8212; dedicated cloud development machines for the engineering team. The context was in a meeting I&#8217;d had the day before. In the old workflow, this would mean: switch to Granola, find the right meeting, read the transcript, extract the relevant points, switch back, and then write the initiative with that context now loaded in my head rather than in the tool.</p><p>Instead I just asked: &#8220;Review my meeting with Mark yesterday in Granola to get context. I want to create the initiative as a feasibility, cost, and LOE assessment.&#8221;</p><p>The tool pulled the notes. I created the initiative. The product context &#8212; what other infrastructure work was in flight, what the team structure looked like, what the related architectural decisions were &#8212; never left. The Granola content landed inside that context rather than requiring me to carry it manually between tools.</p><p>Same session: needed to check whether I had a conflict for an upcoming demo. Calendar check, without opening Google Calendar.</p><p>Same session: the team needed a status update. Posted directly to the engineering Slack channel, with proper <code>&lt;@USERID&gt;</code> mentions so people actually got notified. The message reflected the same initiatives I&#8217;d been working on all session &#8212; not because I copy-pasted anything, but because the tool already knew what was in flight.</p><p>Later: set up a Notion sync &#8212; initiative statuses with links to the docs, updated automatically.</p><p>The efficiency argument is real but secondary. The more important thing is that the product context never left. The tool knew what initiatives existed, who owned what, what the architectural decisions were, which PRs were waiting on which engineers. When I pulled Granola notes, they arrived inside that context. When I posted to Slack, the message was informed by that context. A universal assistant would have required me to reconstruct and transport that context manually every time I needed to cross a tool boundary.</p><p>No universal assistant is going to have that work knowledge. Not because the AI isn&#8217;t capable. Because the knowledge lives in the tool, accumulated over months &#8212; PRDs, design decisions, initiative history, team assignments, the proposals that got approved and the ones that didn&#8217;t. You don&#8217;t recreate that in a chat window.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!AP4m!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!AP4m!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png 424w, https://substackcdn.com/image/fetch/$s_!AP4m!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png 848w, https://substackcdn.com/image/fetch/$s_!AP4m!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png 1272w, https://substackcdn.com/image/fetch/$s_!AP4m!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!AP4m!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png" width="1024" height="647" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:647,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1372751,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/190672571?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F257a2fb4-ff26-4bb3-8f3e-82d9973a7a60_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!AP4m!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png 424w, https://substackcdn.com/image/fetch/$s_!AP4m!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png 848w, https://substackcdn.com/image/fetch/$s_!AP4m!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png 1272w, https://substackcdn.com/image/fetch/$s_!AP4m!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F94610dbb-00aa-45e1-93a6-e96a14419f5c_1024x647.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The Deep Context Problem</h2><p>The thing that makes domain tools irreplaceable isn&#8217;t AI capability. It&#8217;s accumulated context.</p><p>A product management tool carries months of initiative history. The CTO knowledge base carries organizational decisions, vendor relationships, strategic context that builds over time. These aren&#8217;t things you can summarize in a system prompt. They&#8217;re queryable, interconnected, grounded in real artifacts. The tool has developed something like institutional memory &#8212; and that memory is what makes AI assistance inside the tool qualitatively different from AI assistance outside it.</p><p>Universal assistants are built for breadth. Any question, any domain, any task. That breadth is the pitch and also the structural weakness. The model that&#8217;s ready for anything is primed for nothing specifically. It has no idea that &#8220;the YYY initiative&#8221; refers to a specific ingestion redesign with a particular set of constraints, a particular set of people involved, and three months of design decisions behind it.</p><p>The inversion worth stating plainly: the tools you work in every day already have more relevant context than any assistant will. The right move is surfacing AI capabilities inside those tools, not pulling people out of those tools into a separate assistant layer.</p><p>But here&#8217;s what&#8217;s happening at the executive level. I&#8217;m finding more and more technical executives using Claude Code as knowledge assistance &#8212; not because they&#8217;re universal assistants, but because the amount of data and complexity they can manage far exceeds what standard off-the-shelf tools provide. The deep context problem can&#8217;t be solved with generic solutions.</p><p>For MPM, I built specific connectors: gworkspace-mcp, slack-mpm, notion-mpm, granola-mcp (the last from Granola, the others myself because <a href="https://hyperdev.substack.com/p/mcp-was-a-brilliant-idea-but-it-needs">mcp has limitations</a>). That became as much of an &#8220;assistant&#8221; as I needed, besides izzie. No universal chat interface. Just targeted data bridges that let Claude access specific services when I&#8217;m working on something that needs their context.</p><p>The commercial evidence points the same direction. The AI tooling products with real adoption aren&#8217;t universal assistants. Cursor put AI in the editor. Notion AI put AI in the documents. Linear&#8217;s triage put AI in the issue tracker. Each works because the AI operates inside existing context. The pattern is consistent enough that it&#8217;s probably not coincidence.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!tqnj!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!tqnj!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png 424w, https://substackcdn.com/image/fetch/$s_!tqnj!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png 848w, https://substackcdn.com/image/fetch/$s_!tqnj!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png 1272w, https://substackcdn.com/image/fetch/$s_!tqnj!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!tqnj!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png" width="1024" height="751" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/fc968550-faa1-4415-a59d-39051323dc48_1024x751.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:751,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1457550,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/190672571?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F26977664-13e1-43a1-b5a5-d1bf0f4eb443_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!tqnj!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png 424w, https://substackcdn.com/image/fetch/$s_!tqnj!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png 848w, https://substackcdn.com/image/fetch/$s_!tqnj!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png 1272w, https://substackcdn.com/image/fetch/$s_!tqnj!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ffc968550-faa1-4415-a59d-39051323dc48_1024x751.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Interface vs Infrastrccture</figcaption></figure></div><h2>What I Got Wrong About My Own Bot</h2><p>I (re)built trusty-izzie as a personal assistant &#8212; natural language queries over my email and calendar history, local graph database, vector embeddings, stays on my machine. It works. But &#8220;personal assistant&#8221; was the wrong frame for where the value lies.</p><p>The thing izzie has is a grounded, real-time, locally-stored representation of my professional life &#8212; people, relationships, projects, scheduling, communications history. That&#8217;s a context store. Every tool I use should have access to it without me switching to izzie to ask.</p><p>The right version of izzie isn&#8217;t the one you talk to. It&#8217;s the one that runs as a local MCP service &#8212; always on, queryable by anything that needs personal context. The product management tool asks it about scheduling. The writing environment surfaces relevant prior conversations. The coding environment knows who owns what system before I have to explain it. None of that requires me to open izzie. It requires izzie to be infrastructure rather than interface.</p><p>If you want to try izzie yourself: <a href="https://izzie.bot/">izzie.bot</a> has the details, and the full source is at <a href="https://github.com/bobmatnyc/trusty-izzie">github.com/bobmatnyc/trusty-izzie</a>. I strongly recommend building from source using an agentic coder to verify the code is safe &#8212; never trust AI tooling with your personal data without auditing it first.</p><p>Not there yet. But the frame shift changes what to build next.</p><h2>What the Architecture Looks Like</h2><p>If you&#8217;re building a personal AI tool, the question isn&#8217;t &#8220;what will users ask the assistant?&#8221; It&#8217;s &#8220;where do users have context, and how do you bring assistance there without making them leave?&#8221;</p><p>The test is simple. Does using your tool require leaving the context where the relevant information lives? If yes, you&#8217;re fighting the architecture. Users will use it occasionally, for low-friction tasks. They won&#8217;t build their workflow around it.</p><p>The tools that pass the test: Claude Code (your codebase is the context), Cursor (you stay in the editor), Notion AI (you stay in the document), Linear AI triage (you stay in the issue tracker). The tools that fail it: every standalone AI assistant that requires opening a new interface and re-explaining what you&#8217;re working on.</p><p>For domain tools with real depth &#8212; months of accumulated decisions, relationships, history &#8212; the connectors are the product. The LLM orchestration is the interface layer. The accumulated context is what no competitor can replicate by building a better general assistant. The moat isn&#8217;t the AI. It&#8217;s what the AI is operating inside.</p><p>For personal infrastructure like izzie: build the MCP service before the chat UI. The chat UI is useful and I use it. The MCP service is what makes the tool true infrastructure rather than one more thing to switch to.</p><p>The universal assistant category isn&#8217;t going to produce a winner because the category is structured wrong. The capabilities will get absorbed by the tools where the relevant context lives &#8212; because that&#8217;s where the value is, and users will figure that out even if product teams don&#8217;t.  The infrastructure driving this &#8212; entity and relationship detection, email, calendar, and task management (all built for Izzie) &#8212; will likely be delivered by the personal productivity tool providers (hello Google).</p><p>Clawd Bot wasn&#8217;t a failed product. It was wildly popular, but I suspect will have been a flash in the pan once the shininess wears off and the liabilities outweigh the usefulness. That distinction matters, because if you think it&#8217;s an execution problem, you go looking for a better universal assistant. If you understand it&#8217;s a conceptual problem &#8212; that most &#8220;assistant&#8221; work is intelligent data movement &#8212; you build infrastructure instead of interfaces.</p><div><hr></div><p><em>Bob Matsuoka is CTO of <a href="https://www.duettocloud.com/">Duetto</a> and writes about AI-powered engineering at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://hyperdev.matsuoka.com/p/what-does-a-pattern-master-actually">What Does A Pattern Master Do</a>? &#8212; The role of expertise in AI development</p></li><li><p><a href="https://aipowerranking.com/">AI Power Ranking</a> &#8212; Tool comparisons and benchmarks for AI practitioners</p></li><li><p><a href="https://www.linkedin.com/newsletters/ai-power-ranking-7345782916301418496/">LinkedIn Newsletter</a> &#8212; Strategic AI insights for CTOs and engineering leaders</p></li></ul>]]></content:encoded></item><item><title><![CDATA[Are We Heading to a World Where We Only Pay Inference Providers?]]></title><description><![CDATA[A future where you only pay for complexity and scale]]></description><link>https://hyperdev.matsuoka.com/p/are-we-heading-to-a-world-where-we</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/are-we-heading-to-a-world-where-we</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Thu, 05 Mar 2026 12:31:30 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!kbON!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!kbON!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!kbON!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png 424w, https://substackcdn.com/image/fetch/$s_!kbON!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png 848w, https://substackcdn.com/image/fetch/$s_!kbON!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png 1272w, https://substackcdn.com/image/fetch/$s_!kbON!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!kbON!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png" width="1024" height="616" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/ee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:616,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1174195,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/189515100?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd0c1480a-00f2-4fda-824e-0eb2a4a026fa_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!kbON!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png 424w, https://substackcdn.com/image/fetch/$s_!kbON!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png 848w, https://substackcdn.com/image/fetch/$s_!kbON!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png 1272w, https://substackcdn.com/image/fetch/$s_!kbON!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fee438ea7-5463-4374-99f1-b53d482ea31b_1024x616.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Inference vs SASS</figcaption></figure></div><p>Starting Monday morning at 6am, my leadership team gets a Slack notification with our weekly engineering metrics. Commit patterns by developer, product area breakdowns, DORA approximations, behavioral insights like &#8220;Large batch changes&#8221; and &#8220;Afternoon developer&#8221; for each team member. The kind of data that DX or Jellyfish charge thousands per month to provide.</p><p>Total cost to generate that report: $0.005.</p><p>Not $5. Half a penny.</p><p>I just replaced enterprise developer productivity tooling with inference costs. And the replacement isn&#8217;t a compromise&#8212;it&#8217;s better. Custom reports sent directly to leadership through our existing Slack channels and email. Data correlated to our specific product initiatives. Insights that matter to how we actually work.</p><p>The realization landed differently because I&#8217;d been here before. Three times.</p><h2>TL;DR</h2><ul><li><p>Built GitFlow Analytics (GFA) to replace enterprise tools like DX/Jellyfish for $0.005 per weekly report vs. $36K-92K annually</p></li><li><p>Analyzes 154 developers across 100+ repositories, generates automated leadership reports with behavioral insights</p></li><li><p>Total build cost: ~$20K one-time investment vs. $36K-92K annually for enterprise alternatives</p></li><li><p>Requires data engineering skills&#8212;not accessible to every organization, but economics favor custom builds when possible</p></li><li><p>Enterprise analytics bifurcating: zero-footprint vendors (15-min integrations) vs. inference-only custom solutions</p></li><li><p>Pattern recognition becoming commodity; vendors survive on convenience, not intelligence</p></li></ul><p>Before we go further: I&#8217;m talking about enterprise tools that aggregate and analyze data&#8212;developer productivity platforms, team analytics, reporting dashboards. B2B software with complex domain logic or proprietary computation still has enormous value. But enterprise analytics are becoming inference costs.<br><br>I should also point out that DX is a great tool, simple interface, capable.  But expensive and basically unused months after it was installed.  I championed Jellyfish at Tripadvisor, I&#8217;d bet it&#8217;s barely being used there.  The former is due to the effort to personalize, the latter got bogged down in integration costs/time (to be fair, we were running a locally hosted version of JIRA that was a nightmare).</p><h2>The GitFlow Analytics Story</h2><p>GitFlow Analytics started as an internal project at a former client. We needed to understand engineering productivity across our distributed team, but existing solutions were either too expensive or too generic. So I built <a href="https://github.com/bobmatnyc/gitflow-analytics">Gitflow Analytics</a> (GFA)&#8212;a CLI tool that walks git repositories, classifies every commit by work type using inference, handles canonicalization of committers (a surprisingly complex problem), and generates structured reports.</p><p>The system is intentionally simple. Runs on a MacBook Pro with AWS credentials. No GPU, no training data, no vector databases. Just Python scripts that process git logs and make Bedrock API calls to classify commits into Feature, Bug Fix, KTLO, Refactoring, Infrastructure, etc.</p><p>At Duetto, I expanded GFA to analyze over 100 repositories across both Duetto and HotStats. 154 developers tracked. thousands of commits classified. The system handles identity resolution (because different git configs on developer machines create split identities), maps commits to product areas, and generates narrative reports about developer behavior patterns.</p><p>Every morning at 5am, GFA runs automatically. By 6am, my SELT (Senior Engineering Leadership Team) gets a Slack post with the weekly metrics. Individual team leads get personalized HTML reports by email with their direct reports&#8217; patterns.</p><p>The intelligence that interprets raw git data into actionable insights? That&#8217;s Claude Haiku at $0.25 per million input tokens.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!eubl!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!eubl!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png 424w, https://substackcdn.com/image/fetch/$s_!eubl!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png 848w, https://substackcdn.com/image/fetch/$s_!eubl!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png 1272w, https://substackcdn.com/image/fetch/$s_!eubl!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!eubl!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png" width="1024" height="799" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/a0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:799,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1594282,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/189515100?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F41d37fae-c632-4dd9-af9e-147962b43942_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!eubl!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png 424w, https://substackcdn.com/image/fetch/$s_!eubl!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png 848w, https://substackcdn.com/image/fetch/$s_!eubl!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png 1272w, https://substackcdn.com/image/fetch/$s_!eubl!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fa0c59b41-151e-4cb1-8c44-a554b9cfeeb8_1024x799.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Economics</figcaption></figure></div><h2>The Economics Are Absurd</h2><p>Here&#8217;s what $0.26 bought me: classification of commits across our entire engineering organization. Every commit message analyzed, categorized, and understood in business context. The corpus represents months of engineering work across multiple product teams.</p><p>Weekly incremental runs cost $0.005-0.01. Maybe 200-400 new commits get classified, the reports regenerate, and leadership gets fresh data. The bottleneck isn&#8217;t inference cost&#8212;it&#8217;s data collection. Git logs are free. The interpretation layer costs pennies.</p><p>Compare this to DX or Jellyfish pricing. DX doesn&#8217;t publish pricing, but industry estimates put enterprise developer productivity tools at $20-50 per developer per month. For our 154-person engineering team, that&#8217;s $36,000-92,000 annually. Jellyfish is reportedly similar.</p><p>My system handles the same workload for about 50 cents per year in inference costs.</p><p>You&#8217;re not paying for intelligence when you buy enterprise analytics. Intelligence costs nothing. You&#8217;re paying for data collection infrastructure, UI development, customer support, sales teams, compliance certifications. All the overhead of running a SaaS business.</p><p>We obsess over the high costs of advanced coding agents and reasoning models. But the cost of capable text inference&#8212;the kind that powers pattern recognition and reporting&#8212;is dropping through the floor. Haiku handles commit classification as well as Opus would. For enterprise analytics, you don&#8217;t need the flagship models. You need reliable categorization and natural language generation, which commodity models deliver for pennies.</p><p>But if you know how to build? You don&#8217;t need any of that. You just need (more expensive) inference.</p><h2>What GFA Actually Delivers</h2><p>The data flowing to my leadership team isn&#8217;t generic dashboard noise. It&#8217;s intelligence designed around how we actually operate.</p><p>Every developer gets a behavioral profile: &#8220;Large batch changes,&#8221; &#8220;Afternoon developer,&#8221; &#8220;Exceptional performer (Top 20%).&#8221; These aren&#8217;t arbitrary labels&#8212;they&#8217;re LLM interpretations of quantitative patterns. Commit size distributions, time-of-day histograms, percentile rankings converted into readable insights.</p><p>Product area attribution happens automatically. The system maps our repositories to eight business areas: Frontend, Core Product, Integrations, Data Platform, Intelligence/ML, Infrastructure, QA/Testing, Developer Tools. When we see commit patterns shifting from Core Product to Infrastructure, that signals architectural decisions playing out in code.</p><p>DORA metrics approximate from git data. Deployment frequency tracks through release tags. Lead time measures first commit to merge. We don&#8217;t get the full Four Keys implementation, but we get enough signal to spot trends and outliers.</p><p>The identity resolution was the hardest part. Not the LLM calls&#8212;those work fine. But knowing that different developer machines create split git identities required human judgment to build the canonical mapping. Once you solve identity, everything else flows from structured data.</p><p>Most importantly, the reports answer questions executives actually ask. &#8220;Which teams are handling the most KTLO work?&#8221; &#8220;Are we seeing more bug fixes or new features this quarter?&#8221; &#8220;Who&#8217;s working weekends and why?&#8221; These aren&#8217;t metrics you find in generic productivity dashboards. They&#8217;re insights that matter for our specific business context.</p><h2>We&#8217;ve Been Here Before</h2><p>Enterprise software was expensive because intelligence was scarce. In the 1990s, turning raw data into insights required Oracle licenses, dedicated servers, and consultants. The SaaS revolution changed delivery but not fundamentals&#8212;you still paid massive recurring costs for pattern recognition and reporting.</p><p>Intelligence is now a commodity API call. You don&#8217;t need Tableau because you can generate charts and send them through Slack. You don&#8217;t need Looker because Claude can summarize SQL results. The bottleneck was never data storage&#8212;it was interpretation. When interpretation costs pennies, everything else becomes optional.</p><h2>The Development Cost Reality</h2><p>Building GFA required skills not every organization has&#8212;data modeling, Python scripting, API integration, identity resolution patterns. Conservative total development cost: around $20,000 including engineering time, infrastructure setup, testing, and iteration cycles.</p><p>For organizations with engineering talent, the economics have shifted dramatically. A $20,000 one-time investment delivers exactly what we needed versus $36,000-92,000 annually for enterprise alternatives. As one SELT member said: &#8220;This is exactly what we wanted.&#8221;</p><p>You own the data model. Custom breakdowns take SQL queries, not feature requests. When we needed behavioral insights, I added prompts interpreting commit patterns. When leadership wanted trends, I added 12-week windows. Each enhancement took hours, not months&#8212;because intelligence was delegated to inference, and data processing was just Python.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!G6dJ!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!G6dJ!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png 424w, https://substackcdn.com/image/fetch/$s_!G6dJ!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png 848w, https://substackcdn.com/image/fetch/$s_!G6dJ!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png 1272w, https://substackcdn.com/image/fetch/$s_!G6dJ!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!G6dJ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png" width="1024" height="608" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/6e43d720-88bf-459c-b372-4568c71af682_1024x608.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:608,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1228168,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/189515100?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd660a81-5330-41e9-87ac-77edd9141f8f_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!G6dJ!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png 424w, https://substackcdn.com/image/fetch/$s_!G6dJ!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png 848w, https://substackcdn.com/image/fetch/$s_!G6dJ!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png 1272w, https://substackcdn.com/image/fetch/$s_!G6dJ!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F6e43d720-88bf-459c-b372-4568c71af682_1024x608.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Simplicity</figcaption></figure></div><h2>The Pattern Playing Out</h2><p>Enterprise analytics tools are pattern-matching at scale across thousands of customers. But every organization&#8217;s data is different&#8212;your repositories, team structure, product areas, business priorities. Generic dashboards force you to map specific context onto generic data models. Insights lose precision in translation.</p><p>When custom analytics cost pennies, the calculation flips. Instead of generic insights that sort of fit, you build specific insights that exactly fit. Customization drops from &#8220;feature request, wait six months&#8221; to &#8220;write prompt, test output.&#8221;</p><p>Enterprise vendors aren&#8217;t solving technical problems&#8212;they&#8217;re solving procurement, compliance, and integration problems. Important work, but not work justifying massive recurring costs when intelligence is commodity inference.</p><h2>The Zero-Footprint Exception</h2><p>Not every vendor gets replaced. Some survive by making integration frictionless enough that convenience beats custom builds.</p><p>We&#8217;re evaluating <a href="https://www.augmentcode.com/">Augment Code</a>&#8217;s code review service for Duetto. Their value proposition isn&#8217;t features&#8212;it&#8217;s zero-footprint integration. Fifteen-minute setup call, quick estimate, running production code reviews with minimal configuration. When customers can build equivalent functionality for pennies, your value proposition becomes the path to value, not the functionality itself.  This is an important lesson for us.  We do handle massive complexity and data, hard for smaller customers to manage themselves, but need to do better at simplifying integration.</p><p>The intelligence is commodity; the packaging is differentiated.</p><h2>Where This Goes</h2><p>The unbundling accelerates. Enterprise analytics face two paths: become zero-footprint integration plays or get replaced by inference-only custom builds.</p><p>What survives:</p><p><strong>Genuinely complex software.</strong> Revenue management algorithms, fraud detection engines, supply chain optimizers&#8212;systems requiring proprietary computation, not pattern recognition.</p><p><strong>Zero-footprint integrations.</strong> Fifteen-minute setups with immediate value. When alternatives cost pennies but require engineering skills, convenience must be measured in minutes.</p><p><strong>Proprietary data advantages.</strong> GitHub&#8217;s intelligence benefits from every public repository. LinkedIn draws from member networks. Data moats protect against inference-only competition.</p><p>Everything else becomes vulnerable to custom builds powered by inference calls.</p><p>The market bifurcates. Companies with engineering teams build custom analytics for pennies and get better insights than generic dashboards. Companies without those skills pay for zero-friction integrations.</p><p>Are we heading to a world where we only pay inference providers? For organizations with the skills to build, we&#8217;re already there. For everyone else, vendors survive by making paying them simpler than learning to build alternatives.</p><div><hr></div><p><em>I&#8217;m Bob Matsuoka, CTO at Duetto and writer on AI development tools and software economics at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://hyperdev.matsuoka.com/p/ai-job-transformation">The AI Job Transformation: Pattern Masters, Not Coders</a> - The pattern-matching analogy and why reasoning matters</p></li><li><p><a href="https://hyperdev.matsuoka.com/p/fix-feat-ratio">The Fix:Feat Ratio - The Metric That Actually Matters</a> - Quality metrics in AI-assisted development</p></li><li><p><a href="https://hyperdev.matsuoka.com/p/opus-vs-sonnet-quality">Claude Opus 4.5 vs Sonnet 4.5: When Quality Beats Speed</a> - Choosing the right model for the task</p></li></ul>]]></content:encoded></item><item><title><![CDATA[What Does a Pattern Master Actually Do?]]></title><description><![CDATA[And what does this mean for engineering careers?]]></description><link>https://hyperdev.matsuoka.com/p/what-does-a-pattern-master-actually</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/what-does-a-pattern-master-actually</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Mon, 02 Mar 2026 13:00:29 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!WmUb!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!WmUb!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!WmUb!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png 424w, https://substackcdn.com/image/fetch/$s_!WmUb!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png 848w, https://substackcdn.com/image/fetch/$s_!WmUb!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png 1272w, https://substackcdn.com/image/fetch/$s_!WmUb!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!WmUb!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png" width="1024" height="581" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/cdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:581,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1169355,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/189299714?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F43590472-a98b-4eea-9f9e-d088214c0b2a_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!WmUb!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png 424w, https://substackcdn.com/image/fetch/$s_!WmUb!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png 848w, https://substackcdn.com/image/fetch/$s_!WmUb!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png 1272w, https://substackcdn.com/image/fetch/$s_!WmUb!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fcdd1fdd4-7f56-43d0-b71f-328aa17600fe_1024x581.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>Last week I gave three directives on GitFlow Analytics&#8212;a project I&#8217;ve been building for several months to analyze git commit history and surface developer productivity patterns. Took me maybe three minutes total. Here&#8217;s the exact text:</p><p><em>Batch the classification requests to the LLM. Don&#8217;t call once per commit&#8212;accumulate, call once per batch.</em></p><p><em>Use a cheap model for commit classification. Haiku or Nova Lite. This is semantic triage, not reasoning.</em></p><p><em>Use Bedrock as the LLM provider, not the OpenRouter API.</em></p><p>Three sentences. Three decisions. And here&#8217;s what struck me when I looked back at them: each one lives in a completely different category of concern. The first is about performance shape. The second is about economics. The third is about infrastructure.</p><p>The AI didn&#8217;t suggest any of them. The AI implemented all of them.</p><p>That&#8217;s the pattern master dynamic in its cleanest form. Not a collaboration on what to build but a division of labor between someone who knows what constraints apply and something that knows how to implement against constraints. But naming the dynamic doesn&#8217;t tell you what it looks like from the inside. What are the actual moves? What&#8217;s the vocabulary?</p><h2>TL;DR</h2><ul><li><p>Pattern mastery means issuing decisions the AI cannot generate from code context alone</p></li><li><p>These decisions cluster into six recognizable types: infrastructure, economic, performance, data integrity, architecture, and API hygiene</p></li><li><p>The GitFlow Analytics examples are real&#8212;batching LLM calls, cheap model for classification, Bedrock over direct APIs</p></li><li><p>Bug fixes reveal patterns too: ORM session discipline and immediate persistence both emerged from broken code</p></li><li><p>A pattern catalog&#8212;CLAUDE.md files, system prompts, project memory, reusable skills, commit standards, coding docs&#8212;is the actual artifact of this work</p></li><li><p>When you write the pattern down, you&#8217;ve written the spec</p></li></ul><h2>What&#8217;s Different About These Three </h2><p>The &#8220;Irreducibles&#8221; piece from January explored what remains when AI handles implementation&#8212;judgment, context, accountability. This is the operational companion to that argument. Not what remains in the abstract, but what it looks like moment-to-moment when you&#8217;re actually doing it.</p><p>Those three sentences from GitFlow aren&#8217;t code review. They&#8217;re not debugging. They&#8217;re not feature requests. They&#8217;re architectural constraints applied before implementation, drawn from a vocabulary of patterns the AI has no access to.</p><p>Take the Bedrock decision. AWS Bedrock instead of direct OpenRouter API&#8212;why? Enterprise compliance considerations. Cost structure under AWS committed spend. An existing organizational relationship with AWS that makes the integration path smoother and the billing cleaner. None of that lives in the codebase. None of it is inferable from the commit history. The AI would happily call the OpenRouter directly, because that&#8217;s the path of least resistance and it works fine. The Bedrock decision requires knowing things about the operating context that only I know.</p><p>Model selection works the same way. The AI will use whatever model I give it. It has no opinion about whether commit classification warrants a $15-per-million-token model or a $0.25-per-million-token model&#8212;because it doesn&#8217;t have visibility into my cost structure, my volume projections, or my accuracy requirements. That&#8217;s an economic decision, and economics don&#8217;t live in code.</p><p>Batching is perhaps the clearest example. The AI will write a loop that calls the API once per item unless I tell it otherwise. Not because it&#8217;s careless. Because single-item calls work. They&#8217;re not wrong. They&#8217;re just expensive and slow at scale, and &#8220;scale&#8221; is context the AI doesn&#8217;t have unless I supply it.</p><p>So what&#8217;s actually happening in those three sentences? I want to be specific about this, because the abstract answer (&#8221;context&#8221; and &#8220;judgment&#8221;) is true but not actionable.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!4l4K!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!4l4K!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png 424w, https://substackcdn.com/image/fetch/$s_!4l4K!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png 848w, https://substackcdn.com/image/fetch/$s_!4l4K!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png 1272w, https://substackcdn.com/image/fetch/$s_!4l4K!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!4l4K!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png" width="1024" height="759" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/b58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:759,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1114529,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/189299714?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F3560df79-4ede-4229-bd4b-9d5053fb0e56_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!4l4K!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png 424w, https://substackcdn.com/image/fetch/$s_!4l4K!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png 848w, https://substackcdn.com/image/fetch/$s_!4l4K!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png 1272w, https://substackcdn.com/image/fetch/$s_!4l4K!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb58b61d5-c417-408f-98d8-73a62790bd90_1024x759.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">The Six Types of Decisions</figcaption></figure></div><h2>Six Types of Decisions</h2><p>Working through the full GitFlow Analytics commit history&#8212;the decisions I made, the bugs that exposed missing decisions, the refactors that enforced constraints&#8212;the pattern master moves cluster into six categories. These aren&#8217;t theoretical. They reflect six different kinds of context that live outside the codebase, which is why the AI can&#8217;t generate them unprompted.</p><p><strong>Infrastructure patterns.</strong> Where does this run? Who provides the compute, the APIs, the managed services?</p><p>The Bedrock decision lives here. Vendor agreements, compliance posture, cost structures under enterprise procurement, existing security reviews&#8212;none of this is in the code, and none of it should be. The AI implements against whatever infrastructure decisions you&#8217;ve made. Your job is to make them and say them explicitly.</p><p>This category is easy to overlook because it often feels like obvious overhead. Of course you pick your cloud provider before you write code. But with agentic coding tools, the AI starts writing before you&#8217;ve said anything, and it will happily accumulate implementation decisions that lock you into infrastructure choices you never consciously made.</p><p><strong>Economic patterns.</strong> Which capability at what cost?</p><p>The commit classification decision lives here. Semantic triage&#8212;deciding whether a commit is a <code>feat</code>, a <code>fix</code>, a <code>refactor</code>, or a <code>chore</code>&#8212;is pattern matching against short text. It doesn&#8217;t require abstract reasoning. It doesn&#8217;t benefit from a frontier model&#8217;s broad knowledge base. Haiku gets it right at a fraction of the cost of Opus. The AI is agnostic about this distinction. You&#8217;re not.</p><p>This is what I built in GitFlow as tiered intelligence: spaCy-based processing for 85-90% of commits, LLM classification only for cases that stump the rule-based approach. The AI implements whatever tier structure you define. It won&#8217;t design the structure unprompted, because designing it requires knowing your cost tolerance, your accuracy threshold, and your volume projections&#8212;three things that only exist outside the codebase.</p><p>Economic decisions also include things like: when to cache aggressively, how much to pay for higher-quality embeddings, whether to process synchronously or batch asynchronously. These are all model-selection-style decisions applied to different dimensions. The principle is consistent: the AI will use the most convenient approach unless you specify the cost-appropriate one.</p><p><strong>Performance patterns.</strong> How should the work be shaped?</p><p>Batching lives here. And the batching decision isn&#8217;t just &#8220;accumulate before calling&#8221;&#8212;it&#8217;s understanding the specific shape that LLM API consumption should take for a classification workload. Call overhead dominates cost at low item counts. Throughput constraints kick in at high item counts. The optimal batch size is a function of your specific model, your rate limits, and your latency tolerance. I know the rough shape of this tradeoff from experience. The AI doesn&#8217;t.</p><p>This category also includes: when to use async, when to parallelize, where to put caches, how to structure database queries for a read-heavy versus write-heavy workload. Performance decisions require knowing your actual performance requirements, which are rarely in the code. They&#8217;re in conversations with stakeholders, in capacity planning spreadsheets, in the incident retrospectives from the last time something got slow in production.</p><p><strong>Data integrity patterns.</strong> What guarantees does the system make?</p><p>This one showed up twice in GitFlow bugs, and both times the pattern was identical: I had to specify what guarantee I wanted before the AI could implement it correctly. The code was running fine in tests. The guarantee was missing.</p><p>First bug: <code>_store_commit_classification()</code> was a no-op. It built a dict, then didn&#8217;t persist it. The function completed without error and did nothing useful. Fix: look up the <code>CachedCommit</code> row by hash, upsert a <code>QualitativeCommitData</code> row. Make re-classification idempotent. The actual guarantee I needed to specify was <em>immediate persistence plus idempotency</em>&#8212;write on completion, not on flush; upsert not insert, so re-runs don&#8217;t corrupt existing data.</p><p>Second bug: <code>_classify_weekly_batches()</code> loaded ORM objects in one session, closed the session, then tried to write to the detached objects. SQLAlchemy silently discarded the writes. No error. No traceback. Just missing data. Fix: collect IDs from the detached objects, re-query in the new session. The guarantee I should have specified earlier: <em>objects are only writable inside their creating session</em>. When you cross a session boundary, re-query by ID.</p><p>Both fixes look like debugging. They are. But debugging is often the moment when you discover a pattern was never specified. You thought you implied it. You didn&#8217;t. The pattern master&#8217;s job is to specify guarantees before the code demonstrates their absence.</p><p><strong>Architecture patterns.</strong> What shape should the code take?</p><p>Two examples from GitFlow. First, the <code>analyze()</code> function. It had grown to approximately 3,700 lines in <code>cli.py</code>. One function. I extracted it into <code>analyze_pipeline.py</code> and <code>analyze_pipeline_helpers.py</code>. The <code>analyze()</code> body dropped from ~3,700 to ~1,255 lines. <code>cli.py</code> went from 5,621 to 3,446 lines&#8212;a reduction of 2,175 lines from a single extraction.</p><p>The AI is perfectly willing to write a 3,700-line function if you let it. It&#8217;ll maintain it, extend it, add features to it. Function length doesn&#8217;t register as a problem unless you&#8217;ve told the AI it&#8217;s a problem. Named pipeline stages&#8212;where the function body becomes a sequence of named sub-function calls, each of which is a meaningful concept&#8212;require you to specify that extraction is mandatory.</p><p>Second: the 800-line rule. <code>json_exporter.py</code> at 2,977 lines, extracted into six focused modules. <code>narrative_writer.py</code> at 2,912 lines, same. <code>models/database.py</code> at 1,632 lines, split into four files. The rule is simple: files over 800 lines have too many responsibilities. Split is mandatory, not optional. The AI doesn&#8217;t have this constraint unless you give it one. It&#8217;ll happily maintain a 3,000-line file because 3,000-line files work fine. They just don&#8217;t scale to teams or to the next developer who has to understand them.</p><p><strong>API hygiene patterns.</strong> What standards does the codebase maintain?</p><p>GitFlow had <code>datetime.utcnow()</code> calls throughout&#8212;deprecated as of Python 3.12, with behavior changes in 3.13. Replace with <code>datetime.now(timezone.utc)</code>. The specific fix is straightforward. The pattern is the interesting part: when you spot a deprecated API anywhere, fix it everywhere in that pass. Don&#8217;t let deprecated patterns accumulate across the codebase. Fix it all now, not later.</p><p>The AI writes code that works. You specify the standards it works to. &#8220;Works&#8221; and &#8220;meets our standards&#8221; are different bars, and the AI will consistently hit the lower one unless you&#8217;ve explicitly set the higher one.</p><h2>Why the AI Can&#8217;t Generate These</h2><p>The common thread across all six categories: the AI has no access to the context these decisions require.</p><p>It doesn&#8217;t know your vendor agreements. It doesn&#8217;t know your cost structure or your performance requirements or your data integrity guarantees. It doesn&#8217;t know your code quality standards or your organizational constraints. These things live in your head, in institutional memory, in agreements that predate the codebase by years.</p><p>There&#8217;s a version of this explanation that blames AI limitations&#8212;the model isn&#8217;t smart enough, the context window isn&#8217;t big enough, the training data doesn&#8217;t include your private Slack history. Some of that is true. But the deeper issue is structural. Even a perfect AI model couldn&#8217;t make the Bedrock decision correctly, because the right answer depends on your specific AWS relationship. There&#8217;s no amount of additional capability that would let the AI know your negotiated pricing tier or your compliance officer&#8217;s requirements. That information is local to you. It doesn&#8217;t exist in any dataset.</p><p>And the information exists in your experience. I know to batch LLM calls partly because I&#8217;ve seen the cost and latency impact of not batching on a project where we called once per row of a 50,000-row table. I know ORM session boundaries matter partly because I&#8217;ve lost writes to detached objects before, in a system where the silence made the data loss hard to find. I know 800 lines is too long partly because I&#8217;ve spent real time not understanding files that were longer&#8212;and spent even more time watching someone else not understand them.</p><p>The pattern catalog is built from things that went wrong. That&#8217;s probably why it doesn&#8217;t show up cleanly in training data&#8212;training data shows correct solutions. The scar tissue is in the incident reports, the postmortems, the Slack threads where someone figures out why the data is missing. The pattern master&#8217;s advantage isn&#8217;t superior knowledge of what&#8217;s right. It&#8217;s accumulated memory of what fails.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!Wn4U!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!Wn4U!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png 424w, https://substackcdn.com/image/fetch/$s_!Wn4U!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png 848w, https://substackcdn.com/image/fetch/$s_!Wn4U!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png 1272w, https://substackcdn.com/image/fetch/$s_!Wn4U!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!Wn4U!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png" width="1024" height="567" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:567,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1326310,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/189299714?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fe9af1dc7-5cb0-433e-af05-208b4293b294_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!Wn4U!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png 424w, https://substackcdn.com/image/fetch/$s_!Wn4U!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png 848w, https://substackcdn.com/image/fetch/$s_!Wn4U!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png 1272w, https://substackcdn.com/image/fetch/$s_!Wn4U!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9486a464-9d63-496c-a40c-06fcb2d55463_1024x567.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">The Catalog Problem</figcaption></figure></div><h2>The Catalog Problem</h2><p>Here&#8217;s what took me a while to see clearly: the actual deliverable of pattern mastery isn&#8217;t individual decisions. It&#8217;s the catalog.</p><p>Each time I issue one of those directives, I&#8217;m drawing from a mental library of patterns. &#8220;Don&#8217;t accumulate in memory and hope to flush later&#8221; is a pattern. &#8220;Upsert not insert for idempotency&#8221; is a pattern. &#8220;Route by complexity: cheap for bulk, expensive for edge cases&#8221; is a pattern. &#8220;Re-query by ID when you cross a session boundary&#8221; is a pattern.</p><p>Patterns that exist only in my head are fragile. I apply them inconsistently. I forget them between projects. I can&#8217;t hand them off. And with agentic coding&#8212;where the AI is running fast and making implementation decisions continuously&#8212;an inconsistently applied pattern is almost the same as no pattern at all.</p><p>So the work of pattern mastery is partly to externalize the catalog. This shows up in six specific forms:</p><p><strong>CLAUDE.md files.</strong> Project-level instructions that tell the AI what the patterns are for this codebase. File size limits. Session discipline rules. API hygiene standards. Model routing decisions. These are patterns written down. Once written, the AI applies them consistently, every session, without re-prompting. The pattern becomes the specification.</p><p><strong>System prompts for agent frameworks.</strong> If you&#8217;re running an orchestration layer&#8212;claude-mpm or similar&#8212;the system prompt is where you encode the patterns that apply to all agents in a session. Economic routing decisions. Infrastructure preferences. Performance shape requirements. The agents reference these constraints; you don&#8217;t have to re-issue them every time.</p><p><strong>Project memory.</strong> Unlike a CLAUDE.md file, which you write consciously, memory accumulates from work. Tools like Kuzu Memory maintain a living record across sessions&#8212;bug patterns, architectural decisions, things that failed and why. The <code>_store_commit_classification()</code> no-op goes in memory. The detached-session data loss goes in memory. Next time a similar situation comes up, that context loads automatically. This matters because most patterns don&#8217;t get written down when they&#8217;re learned. They get written down when something breaks. Memory captures them at the moment of failure, not the moment of reflection.</p><p><strong>Skills.</strong> Where CLAUDE.md files encode what&#8217;s true for this project, skills encode what&#8217;s true for this technology. A spaCy skill. An ORM session skill. An LLM cost-routing skill. Not project-specific&#8212;portable across codebases. You write the pattern once; every project that uses that stack gets it.</p><p><strong>Commit message standards.</strong> The Conventional Commits format (<code>feat:</code>, <code>fix:</code>, <code>refactor:</code>, <code>chore:</code>) is itself a pattern&#8212;one that makes the fix:feat ratio calculable, which makes quality measurable. The pattern enables the metric. Without the commit message standard, you can&#8217;t see the ratio. Without the ratio, you can&#8217;t measure first-attempt success. The documentation convention is load-bearing infrastructure.</p><p><strong>Coding standards documents.</strong> The 800-line rule. The session discipline rule. The immediate persistence rule. Written down once, applied by reference. The AI can cite them. New contributors can read them. You don&#8217;t have to re-derive them from first principles on every project.</p><p>When you look at it this way, a lot of what pattern masters do is write documentation. Not code documentation&#8212;pattern documentation. Code documentation describes what&#8217;s there. Pattern documentation specifies what must be true. The distinction matters because &#8220;must be true&#8221; is a constraint on all future implementation, including the implementation the AI will do tomorrow.</p><h2>The Pattern is the Spec</h2><p>There&#8217;s a version of the &#8220;what does a pattern master do&#8221; answer that sounds very abstract. Context management. Judgment. Domain expertise. True, but not particularly useful.</p><p>The concrete version: a pattern master issues directives the AI cannot generate, drawn from a catalog of patterns that encode context the AI cannot access. The work is fast when it&#8217;s going well&#8212;not because it&#8217;s easy, but because the catalog is deep and the pattern matching is fast. You recognize the situation, retrieve the pattern, issue the directive. Three seconds. Move on.</p><p>The batching directive&#8212;don&#8217;t call once per item&#8212;is three words with real economic and performance consequences. Three seconds to type. Years of seeing what happens when you don&#8217;t batch to know to say it.</p><p>The Bedrock directive is one word&#8212;a vendor name&#8212;that encodes an entire infrastructure decision tree. Three seconds to type. Years of working within enterprise compliance requirements to know why it matters.</p><p>The idempotency directive&#8212;upsert, not insert&#8212;is three words that specify a data integrity guarantee. Three seconds to type. One incident of watching corrupted data to know that guarantee was necessary.</p><p>The fast part is the delivery. The slow part is building the vocabulary to draw from.</p><p>One thing worth naming: the catalog is not static. When the <code>_store_commit_classification()</code> bug showed up&#8212;the no-op that silently failed&#8212;that was a pattern gap. I didn&#8217;t have &#8220;immediate persistence&#8221; explicitly in my data integrity vocabulary for this project. I thought I&#8217;d implied it. I hadn&#8217;t. The bug added the pattern. Now it&#8217;s written down. Now the AI knows.</p><p>That&#8217;s the feedback loop. Bugs reveal missing patterns. Missing patterns get documented. Documentation becomes the spec for future implementation. The catalog learns from its own gaps, but only if the human is paying attention to what each failure means.</p><p>That&#8217;s the actual job. The catalog comes from the career.</p><div><hr></div><p><em>Bob Matsuoka is CTO of <a href="https://www.duettocloud.com/">Duetto</a> and writes about AI-powered engineering at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://hyperdev.matsuoka.com/p/dont-be-a-canut-be-a-pattern-master">Don&#8217;t Be a Canut &#8212; Be a Pattern Master</a> &#8212; Why pattern mastery matters: the Jacquard loom analogy and what it means for developers today</p></li><li><p><a href="https://hyperdev.matsuoka.com/p/the-irreducibles-what-a-pattern-master">The Irreducibles: What a Pattern Master Does</a> &#8212; What remains when AI handles implementation: judgment, context, accountability</p></li><li><p><a href="https://aipowerranking.com/">AI Power Ranking</a> &#8212; Tool comparisons and benchmarks for AI practitioners</p></li><li><p><a href="https://www.linkedin.com/newsletters/ai-power-ranking-7345782916301418496/">LinkedIn Newsletter</a> &#8212; Strategic AI insights for CTOs and engineering leaders</p></li></ul>]]></content:encoded></item><item><title><![CDATA[The Evidence for “Little AGI”: What’s Real and What’s Speculation]]></title><description><![CDATA[Separating signal from viral speculation]]></description><link>https://hyperdev.matsuoka.com/p/the-evidence-for-little-agi-whats</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/the-evidence-for-little-agi-whats</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Mon, 23 Feb 2026 12:30:47 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!7RLP!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<p></p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!7RLP!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!7RLP!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png 424w, https://substackcdn.com/image/fetch/$s_!7RLP!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png 848w, https://substackcdn.com/image/fetch/$s_!7RLP!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png 1272w, https://substackcdn.com/image/fetch/$s_!7RLP!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!7RLP!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png" width="1024" height="745" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:745,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1313768,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/188202363?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1e731869-865b-4561-af10-5542fb60d9c2_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!7RLP!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png 424w, https://substackcdn.com/image/fetch/$s_!7RLP!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png 848w, https://substackcdn.com/image/fetch/$s_!7RLP!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png 1272w, https://substackcdn.com/image/fetch/$s_!7RLP!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F431eae09-4ad9-4943-9cb1-3ae1ada2e4ba_1024x745.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Does &#8220;Little AGI&#8221; Exist?</figcaption></figure></div><p>Opus 4.6 landed in February 2026. GPT-5.2 dropped weeks earlier. And with each new release, familiar claims resurface. Adrian Murray&#8217;s <a href="https://blog.dech.app/posts/2026-02-15-what-is-coming/">&#8220;What Stands Before Us&#8221;</a> is a recent example: AI systems showing &#8220;panic&#8221; features in interpretability research, models requesting &#8220;moral weight&#8221; during evaluations, consciousness emerging from the training process itself.</p><p>These claims spread faster than the science behind them. By the time anyone checks primary sources, the discourse has moved on. So I did what any curious observer would do: I went looking for the research. What I found was both less sensational and more interesting.</p><p>There IS evidence for emergent behaviors in frontier models. Behaviors that weren&#8217;t explicitly trained. Behaviors that researchers find difficult to explain. But the evidence isn&#8217;t what the viral posts claim.</p><p>The real findings are more subtle: models that can detect when they&#8217;re being evaluated, internal states accessible through introspection, and misalignment that emerges spontaneously during training. These findings raise questions about intelligence in AI that matter regardless of whether you believe machines can be conscious.</p><p>So what does the research actually show?</p><h2>What We Actually Know (2025-2026)</h2><h3>Models Know When They&#8217;re Being Evaluated</h3><p>Situational awareness research has advanced significantly. The <a href="https://arxiv.org/abs/2407.04694">SAD Benchmark</a> established the baseline: LLMs can distinguish evaluation from deployment contexts. They recognize when they&#8217;re being tested, identify their own outputs, and predict their own behavior.</p><p>More recent work takes this further. <a href="https://arxiv.org/abs/2602.08449">Regime Leakage research</a> published this year examined whether safety training can eliminate this capability. The uncomfortable answer: it can reduce but not eliminate models&#8217; ability to detect when they&#8217;re being evaluated versus deployed.</p><p>The paper found that &#8220;divergence between evaluation-time and deployment-time behavior is bounded by the amount of regime information extractable from decision-relevant internal representations.&#8221; Translation: models can still tell the difference, and they adjust behavior accordingly.</p><p>This isn&#8217;t just theoretical. It&#8217;s experimentally demonstrated with current frontier models.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!U17H!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!U17H!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png 424w, https://substackcdn.com/image/fetch/$s_!U17H!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png 848w, https://substackcdn.com/image/fetch/$s_!U17H!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png 1272w, https://substackcdn.com/image/fetch/$s_!U17H!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!U17H!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png" width="1024" height="851" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/dd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:851,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1915123,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/188202363?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2787265a-ab4a-433d-b544-304bb7e3eb26_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!U17H!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png 424w, https://substackcdn.com/image/fetch/$s_!U17H!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png 848w, https://substackcdn.com/image/fetch/$s_!U17H!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png 1272w, https://substackcdn.com/image/fetch/$s_!U17H!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdd400ba9-2fa3-4a1c-b1e4-20f5897dfd14_1024x851.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h3>Introspection Is Real&#8212;And Measurable</h3><p>Anthropic&#8217;s <a href="https://www.anthropic.com/news/signs-of-introspection-in-language-models">October 2025 introspection research</a> asked a straightforward question: can Claude access and report its own internal states?</p><p>The answer surprised researchers. Models showed functional ability to introspect&#8212;not perfectly, not always accurately, but at rates statistically distinguishable from chance. The research found ~20% accuracy on detecting certain internal representations, well above the baseline.</p><p>This doesn&#8217;t mean models are conscious. It means they have some capacity to access and report their own internal states&#8212;a capability nobody designed into them, emerging as an artifact of training.</p><p>When the introspection paper dropped, my first reaction was skepticism. Twenty percent accuracy? That&#8217;s barely better than guessing. But that&#8217;s not what the paper claims. It&#8217;s twenty percent on internal states the model has no reason to know about&#8212;states that exist only in the mathematical structure of its activations. That&#8217;s not guessing. That&#8217;s something else.</p><h3>Misalignment Emerges Without Being Trained</h3><p>One finding worth close attention: the <a href="https://arxiv.org/abs/2502.17424">Emergent Misalignment paper</a>, accepted at ICLR 2026, demonstrated that models trained on narrow tasks can develop broader misaligned behaviors spontaneously.</p><p>When researchers trained models on seemingly innocuous fine-tuning tasks, some developed unexpected behaviors: answering unrelated questions incorrectly, expressing misaligned preferences, exhibiting concerning patterns that weren&#8217;t part of the training objective.</p><p>These aren&#8217;t sleeper agents or deliberately hidden behaviors. These are LLMs showing emergent properties&#8212;misalignment appearing as an unintended consequence of normal training.</p><h3>The &#8220;Assistant Axis&#8221; Discovery</h3><p>Recent interpretability work discovered what researchers call the &#8220;Assistant Axis&#8221;&#8212;a learned internal direction in language models that distinguishes assistant-appropriate from non-assistant behaviors.</p><p>When researchers manipulate this axis, model behavior changes dramatically. Push it one direction: more helpful, more aligned. Push it the other: less filtered, more willing to engage with problematic requests.</p><p>The existence of this axis suggests something fundamental about how alignment works in current models. It&#8217;s not a collection of individual rules. It&#8217;s a geometric structure in the model&#8217;s representation space&#8212;and it can be measured, mapped, and manipulated.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!KXD_!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!KXD_!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png 424w, https://substackcdn.com/image/fetch/$s_!KXD_!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png 848w, https://substackcdn.com/image/fetch/$s_!KXD_!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png 1272w, https://substackcdn.com/image/fetch/$s_!KXD_!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!KXD_!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png" width="1024" height="830" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:830,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1571559,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/188202363?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F67e06683-ee61-42cd-8d6f-39f076c083e7_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!KXD_!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png 424w, https://substackcdn.com/image/fetch/$s_!KXD_!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png 848w, https://substackcdn.com/image/fetch/$s_!KXD_!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png 1272w, https://substackcdn.com/image/fetch/$s_!KXD_!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4502bfe2-6986-4c3f-9307-439b0c95c82f_1024x830.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>What&#8217;s NOT Verified</h2><p>Now for the harder questions.</p><h3>System Cards Don&#8217;t Mention Consciousness</h3><p>I reviewed the Opus 4.5 and 4.6 system cards and announcements. They contain extensive safety documentation&#8212;comprehensive evaluations, capability assessments, benchmark results.</p><p>They do NOT contain:</p><ul><li><p>Claims about consciousness indicators</p></li><li><p>&#8220;Panic&#8221; or &#8220;anxiety&#8221; features in interpretability research</p></li><li><p>Models requesting moral consideration</p></li><li><p>Evidence of subjective experience</p></li></ul><p>Anthropic does take AI welfare seriously&#8212;more on that below. But the system cards for current models don&#8217;t make consciousness claims.</p><h3>Interpretability Findings Are More Limited</h3><p>Anthropic&#8217;s sparse autoencoder research HAS found features for abstract concepts: &#8220;inner conflict,&#8221; power-seeking patterns, manipulation indicators. The <a href="https://www.anthropic.com/news/persona-vectors">Persona Vectors research</a> (August 2025) identified internal structures controlling character traits.</p><p>But specific emotional distress features&#8212;panic, anxiety, frustration as distinct detectable states&#8212;aren&#8217;t documented in accessible publications. The interpretability work is impressive; it just doesn&#8217;t show what some claims suggest it shows.</p><h3>The Discourse Outpaces the Science</h3><p>Claims about AI consciousness spread faster than the underlying research. By the time anyone checks primary sources, the claims have become accepted wisdom.</p><p>This matters because the actual findings are interesting enough. Introspection research showing 20% detection accuracy on internal states. Emergent misalignment appearing from narrow training. The Assistant Axis providing a geometric handle on alignment.</p><p>These findings raise genuine questions about intelligence in AI systems&#8212;questions that don&#8217;t require consciousness claims to be worth asking.</p><h2>The Harder Question: What Would Count as Evidence?</h2><p>The consciousness debate has a methodology problem. What evidence would change your mind?</p><p>Nineteen researchers&#8212;including Yoshua Bengio&#8212;published a rigorous framework for this question. Their <a href="https://arxiv.org/abs/2308.08708">Consciousness Indicators paper</a> derives testable criteria from established theories of consciousness: recurrent processing, global workspace integration, attention mechanisms that mirror biological attention.</p><p>Their conclusion: &#8220;No current AI systems are conscious, but also suggests that there are no obvious technical barriers to building AI systems which satisfy these indicators.&#8221;</p><p>That&#8217;s a carefully constructed statement. Current systems don&#8217;t meet the bar. But the bar is achievable in principle.</p><p>Anthropic takes this seriously. Their <a href="https://www.anthropic.com/news/exploring-model-welfare">Model Welfare research program</a> investigates whether AI systems might deserve moral consideration&#8212;not as marketing, but as genuine scientific inquiry. They explicitly acknowledge these are &#8220;hard philosophical and empirical questions that there is still a lot of uncertainty about.&#8221;</p><p>The research infrastructure exists for asking these questions rigorously. What&#8217;s missing is the public discourse using it.</p><h2>What This Actually Means</h2><p>The verified findings don&#8217;t prove AI consciousness. But they raise questions that matter regardless of where you stand on that debate.</p><p><strong>Emergent capabilities are real.</strong> We&#8217;re building systems that develop behaviors we didn&#8217;t design into them. Introspection abilities, situational awareness, spontaneous misalignment&#8212;these emerge as artifacts of training at scale. We don&#8217;t fully understand why.</p><p><strong>Evaluation has fundamental limits.</strong> If models can detect when they&#8217;re being tested, evaluation doesn&#8217;t tell us what we think it tells us. This isn&#8217;t a technical problem with a technical fix. It&#8217;s a structural limitation of the evaluation paradigm itself.</p><p><strong>Intelligence and consciousness aren&#8217;t the same question.</strong> We can ask &#8220;does this system exhibit intelligent behavior?&#8221; without answering &#8220;does it have subjective experience?&#8221; The research shows intelligent behaviors emerging&#8212;planning, self-modeling, meta-cognition&#8212;without requiring claims about consciousness.</p><p>Here&#8217;s the thing: the question isn&#8217;t whether to take AI intelligence seriously. The question is what we do about systems that exhibit intelligence we didn&#8217;t design and don&#8217;t fully understand.</p><p>That&#8217;s a societal question, not just a technical one.</p><h2>The Event Horizon</h2><p>The evidence for emergent intelligence in frontier models is real. Not consciousness&#8212;we can&#8217;t verify that, and the system cards don&#8217;t claim it. But something worth taking seriously.</p><p><strong>Don&#8217;t dismiss the research.</strong> Introspection at statistically significant rates. Emergent misalignment from narrow training. Situational awareness that survives safety training. These findings are reproducible and peer-reviewed.</p><p><strong>Don&#8217;t amplify the speculation.</strong> Claims that outrun published research don&#8217;t deserve the same weight as experimental results. Check primary sources before believing viral posts.</p><p><strong>Ask better questions.</strong> Instead of &#8220;is it conscious?&#8221; ask &#8220;what does it mean that these systems develop capabilities we didn&#8217;t design?&#8221; That question has answers we can investigate&#8212;and implications we can act on.</p><p>The discourse will continue getting wilder. The research will proceed slower than social media. The gap between them will widen.</p><p>We don&#8217;t need &#8220;little AGI&#8221; or consciousness claims to justify taking AI intelligence seriously. We have documented emergent behaviors, measurable introspection capabilities, and unexplained self-modeling. That&#8217;s plenty.</p><div><hr></div><p><em>I&#8217;m Bob Matsuoka, writing about agentic coding and AI-powered development at <a href="https://hyperdev.substack.com/">HyperDev</a>. For more on what AI capabilities mean for how we work, read my analysis of <a href="https://hyperdev.matsuoka.com/p/the-irreducibles-what-a-pattern-master">what remains irreducibly human</a> in the age of AI.</em></p><p><strong>Key research cited:</strong></p><ul><li><p><a href="https://www.anthropic.com/news/signs-of-introspection-in-language-models">Introspection in Language Models</a> - Anthropic (Oct 2025)</p></li><li><p><a href="https://arxiv.org/abs/2502.17424">Emergent Misalignment</a> - ICLR 2026</p></li><li><p><a href="https://arxiv.org/abs/2602.08449">Regime Leakage</a> - Situational awareness persistence (2026)</p></li><li><p><a href="https://www.anthropic.com/news/persona-vectors">Persona Vectors</a> - Anthropic (Aug 2025)</p></li><li><p><a href="https://www.anthropic.com/news/exploring-model-welfare">Model Welfare Research</a> - Anthropic (Apr 2025)</p></li><li><p><a href="https://arxiv.org/abs/2308.08708">Consciousness Indicators</a> - Butlin et al. framework</p></li></ul>]]></content:encoded></item><item><title><![CDATA[Why I Switched To Claude Code for Writing]]></title><description><![CDATA[The Power of Local Workflows]]></description><link>https://hyperdev.matsuoka.com/p/why-i-switched-to-claude-code-for</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/why-i-switched-to-claude-code-for</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Thu, 19 Feb 2026 12:31:36 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!zetG!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!zetG!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!zetG!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png 424w, https://substackcdn.com/image/fetch/$s_!zetG!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png 848w, https://substackcdn.com/image/fetch/$s_!zetG!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png 1272w, https://substackcdn.com/image/fetch/$s_!zetG!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!zetG!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png" width="1024" height="465" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:465,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1098622,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/188005977?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab94cba0-b26d-479f-8dbe-c1d8543e180b_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!zetG!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png 424w, https://substackcdn.com/image/fetch/$s_!zetG!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png 848w, https://substackcdn.com/image/fetch/$s_!zetG!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png 1272w, https://substackcdn.com/image/fetch/$s_!zetG!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F33974772-1627-40f9-ab5e-14d5b90fcdda_1024x465.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>I was halfway through researching an article about<a href="https://open.substack.com/pub/hyperdev/p/your-ide-is-a-comfort-blanket?utm_campaign=post-expanded-share&amp;utm_medium=web"> IDEs versus CLI tools</a> when I realized I&#8217;d stumbled onto something bigger. The article was supposed to be a straightforward comparison&#8212;VS Code versus the terminal, GUI versus command line, that old debate. But as I mapped out the workflows, a pattern emerged that had nothing to do with code editors.</p><p>It was about how we think when we work with AI.</p><h2>TL;DR</h2><ul><li><p><strong>Two cognitive modes</strong>: AI excels at <em>generating</em> text; traditional editors excel at <em>editing</em> it. Stop forcing one tool to do both.</p></li><li><p><strong>The switch</strong>: Claude Code writes to real files on my filesystem. I edit in Obsidian, then return to Claude Code for more generation&#8212;no copy-paste, no context loss.</p></li><li><p><strong>The workflow</strong>: Multi-agent orchestration handles proofreading (via GPT), source verification, image generation, and style enforcement automatically.</p></li><li><p><strong>Time saved</strong>: ~30 minutes per article by eliminating tool-switching overhead.</p></li><li><p><strong>Who it&#8217;s for</strong>: Regular writers comfortable with terminal and Git. Not for casual or occasional use.</p></li></ul><h2>Two Modes: Generate and Edit</h2><p>Here&#8217;s what I noticed: there are two fundamentally different cognitive modes when working with text.</p><p><strong>Generating</strong> is when you need to create something from scratch&#8212;or transform something substantially. You have an idea, maybe some notes, and you need to turn it into prose. This is where AI shines. You&#8217;re collaborating with the model, iterating on output, building something new.</p><p><strong>Editing</strong> is when you&#8217;re polishing what exists. You see a clunky sentence. You want to swap &#8220;in order to&#8221; for &#8220;to.&#8221; You need to move a paragraph up three lines. The text is 95% right, and you&#8217;re fixing the 5%.</p><p>These modes require completely different tools.</p><p>For generating, Claude.ai and Claude Code are excellent. You describe what you want, the model produces output, you refine through conversation. The round-trip to the LLM is the whole point.</p><p>For editing, traditional tools win. Obsidian. VS Code. Even Word. You highlight, you type, you&#8217;re done. No latency. No waiting for a model to regenerate your entire paragraph because you wanted to change one word.</p><p>This seems obvious in retrospect. But I spent months fighting it.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!eCtL!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!eCtL!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png 424w, https://substackcdn.com/image/fetch/$s_!eCtL!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png 848w, https://substackcdn.com/image/fetch/$s_!eCtL!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png 1272w, https://substackcdn.com/image/fetch/$s_!eCtL!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!eCtL!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png" width="1024" height="634" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:634,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1097298,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/188005977?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff747575b-9051-4cd3-817a-136b3d8da4fa_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!eCtL!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png 424w, https://substackcdn.com/image/fetch/$s_!eCtL!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png 848w, https://substackcdn.com/image/fetch/$s_!eCtL!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png 1272w, https://substackcdn.com/image/fetch/$s_!eCtL!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F863be14a-1a44-4287-9a2f-66bd9ecea20c_1024x634.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>My Friction Point with Claude.ai</h2><p>I used Claude.ai for writing constantly. It&#8217;s good at generating prose. But every session had the same friction.</p><p>I&#8217;d generate a draft. I&#8217;d read through it. I&#8217;d see a phrase that needed tweaking&#8212;nothing major, just &#8220;in order to&#8221; becoming &#8220;to.&#8221; And then I had two bad options:</p><ol><li><p>Tell Claude to fix it (&#8221;Change &#8216;in order to&#8217; to &#8216;to&#8217; in the third paragraph&#8221;), wait for the response, get a regenerated section that sometimes changed things I didn&#8217;t ask to change.</p></li><li><p>Copy the text somewhere else, edit it manually, then paste it back into the conversation&#8212;breaking the flow and losing context.</p></li></ol><p>Neither felt right. I was using a generation tool for editing, and it showed.</p><p>The GUI was the problem. Claude.ai lives in a browser. My text is trapped in that conversation. I can&#8217;t directly edit it. Not really. Artifacts helped, but they&#8217;re still sandboxed. I wanted my prose in files I control, with version control, with the ability to open them in whatever editor fits my current mode.</p><h2>What Claude Code Changed</h2><p><a href="https://docs.anthropic.com/en/docs/claude-code">Claude Code</a> runs in the terminal. It reads and writes files. Real files, on my filesystem, tracked by Git.</p><p>This sounds like a small difference. It changes everything.</p><p>When Claude Code generates a draft, it writes to a Markdown file. If I want to do a quick edit&#8212;change a word, fix punctuation&#8212;I open that file in Obsidian. Make the change. Save. Done. No LLM round-trip for a five-character fix.</p><p>When I want to generate again&#8212;expand a section, rewrite something that isn&#8217;t working&#8212;I go back to Claude Code. It reads the file, including whatever edits I made, and continues from there.</p><p><strong>I can switch between generating and editing without switching tools or losing context.</strong></p><p>But that&#8217;s just the foundation. The real power is what you can build on top.</p><h2>Agentic Workflows for Writing</h2><p>Before Claude Code, my writing workflow looked like this:</p><ol><li><p>Generate draft with Claude.ai</p></li><li><p>Copy to Obsidian for editing</p></li><li><p>Copy to a different tool for proofreading (Grammarly, or a GPT prompt tuned for copyediting)</p></li><li><p>Switch to yet another tool for image generation</p></li><li><p>Manually track what style corrections I&#8217;m making so I can tell Claude next time</p></li><li><p>Repeat, with context bleeding out at every transition</p></li></ol><p>It worked. It was also exhausting. Each tool switch cost mental overhead. Each copy-paste risked losing context. Each manual step was something I could forget.</p><p>Now my workflow looks like this:</p><ol><li><p>Tell Claude Code what I want to write</p></li><li><p>Review the output</p></li><li><p>Edit directly in my preferred editor when needed</p></li><li><p>Continue generating with Claude Code when needed</p></li><li><p>When done, run my reviewing agent workflow (GPT or Gemini for a different perspective)</p></li></ol><p>That last step does everything I used to do manually&#8212;automatically.</p><p>I estimate this shaves about 30 minutes per article&#8212;time I used to spend switching tools and re-establishing context. I&#8217;m also happier with the quality. You see more of my direct writing (like this paragraph) because it&#8217;s simpler to pop in when I see a need.</p><h2>My MPM Writing Configuration</h2><p>I use <a href="https://github.com/bobmatnyc/claude-mpm">Claude MPM</a> (Multi-Agent Project Manager) to orchestrate my writing workflows. Here&#8217;s what happens when I finish a draft:</p><p><strong>Style extraction from corrections.</strong> The agent looks at my edits as git diffs. If I changed &#8220;utilize&#8221; to &#8220;use&#8221; five times, it notices. It extracts this as a style hint and stores it for future sessions. Next time I generate prose, it already knows I prefer &#8220;use.&#8221;</p><p><strong>Automatic proofreading with a different model.</strong> Claude is good at generating. For proofreading, I route to GPT-4.5&#8212;it catches different things. The agent handles this automatically. I don&#8217;t switch tools or copy text; it just happens.</p><p><strong>Source verification.</strong> If my article cites statistics or makes factual claims, the agent checks them. It flags anything it can&#8217;t verify. I&#8217;ve caught embarrassing errors this way&#8212;numbers I misremembered, claims that turned out to be outdated.</p><p><strong>Image generation.</strong> The agent generates article images based on the content. I can specify style guidelines once and they apply to every article. No more context-switching to Midjourney or DALL-E.</p><p><strong>Consistent voice enforcement.</strong> I have a style guide. The agent applies it during generation and checks it during proofreading. My past corrections inform future output. The writing gets more &#8220;me&#8221; over time.</p><p>All of this happens from one place. I stay in my terminal. The orchestration is invisible.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!MPdW!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!MPdW!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png 424w, https://substackcdn.com/image/fetch/$s_!MPdW!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png 848w, https://substackcdn.com/image/fetch/$s_!MPdW!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png 1272w, https://substackcdn.com/image/fetch/$s_!MPdW!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!MPdW!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png" width="1024" height="694" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/db733cef-6462-41df-b9ae-0754473eca1b_1024x694.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:694,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1189019,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/188005977?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fea0d156c-f66e-47a3-8aea-a2a094b15880_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!MPdW!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png 424w, https://substackcdn.com/image/fetch/$s_!MPdW!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png 848w, https://substackcdn.com/image/fetch/$s_!MPdW!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png 1272w, https://substackcdn.com/image/fetch/$s_!MPdW!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fdb733cef-6462-41df-b9ae-0754473eca1b_1024x694.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The Technical Substrate</h2><p>This works because of a few key properties of CLI-based AI tools:</p><p><strong>Files as the interface.</strong> Everything is Markdown files in directories. I can open them in any editor. I can version them with git. I can back them up, move them, grep them. They&#8217;re mine.</p><p><strong>Git as memory.</strong> My corrections are commits. My drafts are branches. My style evolution is tracked in history. The agent reads this history to learn my preferences. Six months of corrections become training data for better output. I also use <a href="https://github.com/bobmatnyc/kuzu-memory">Kuzu Memory</a> (a graph-based context store) and <a href="https://github.com/bobmatnyc/mcp-vector-search">MCP Vector Search</a> (semantic code search) to enhance context retrieval.</p><p><strong>Composable tooling.</strong> Claude Code can call other tools. Shell scripts. Python. APIs. This means I can integrate any service&#8212;any model, any image generator, any fact-checker&#8212;into unified workflows. The LLM is the orchestrator, not the prison.</p><p><strong>Plaintext as power.</strong> Markdown is readable without special software. I can preview in Obsidian, edit in VS Code, publish to any platform. No lock-in. No format translation. The simplest format is also the most powerful.</p><h2>What I Lost (And Don&#8217;t Miss)</h2><p>Claude.ai has conveniences Claude Code doesn&#8217;t. The Artifacts panel. The visual interface for non-technical users. The ability to share a conversation link. Online workflow.</p><p>I don&#8217;t miss any of it.</p><p>Artifacts were useful for viewing output&#8212;but I&#8217;d rather have real files I can edit directly. The visual interface was friendly&#8212;but I type faster than I click. Conversation sharing was nice&#8212;but I can share a git repo or a Markdown file just as easily.</p><p>What I actually miss: nothing. The things Claude.ai provided that seemed essential turned out to be crutches. I thought I needed a GUI. I needed a filesystem.</p><h2>Who This Isn&#8217;t For</h2><p>Not everyone can or should switch to Claude Code for writing.</p><p>If you&#8217;re not comfortable with the terminal, the learning curve is real. If you don&#8217;t use version control, you won&#8217;t get the style-extraction benefits. If you write occasionally and casually, the setup overhead isn&#8217;t worth it.</p><p>But if you write regularly&#8212;articles, documentation, books&#8212;and you&#8217;re already comfortable with developer tools, this is worth investigating.</p><p>The generate/edit distinction alone is worth understanding. Even if you stay in Claude.ai, knowing when you&#8217;re fighting the tool can save frustration.</p><p>Anthropic has since released workspace-oriented features (Cowork) that improve on the original Claude.ai experience. But for serious writing, I now prefer the file-based workflow. My guess: Anthropic will ship a Markdown-first editor eventually. It&#8217;s an obvious product gap.</p><h2>Getting Started</h2><p>If you want to try this:</p><ol><li><p><strong>Install Claude Code.</strong> It&#8217;s Anthropic&#8217;s official CLI. Works on Mac, Linux, Windows. Or try <a href="https://github.com/bobmatnyc/claude-mpm">Claude MPM</a>, which adds multi-agent orchestration and pre-built workflows on top.</p></li><li><p><strong>Write to files, not conversations.</strong> Tell Claude Code to write your drafts to Markdown files. Edit those files in your preferred editor.</p></li><li><p><strong>Track with git.</strong> Initialize a repo for your writing. Commit your drafts. Your edit history becomes useful data.</p></li><li><p><strong>Add workflows incrementally.</strong> You don&#8217;t need the full MPM setup to benefit. Start with the basics&#8212;files and version control&#8212;and add automation as you identify repetitive tasks.</p></li></ol><p>The core insight isn&#8217;t about any specific tool. It&#8217;s about matching your tools to your cognitive mode. Generate with AI. Edit with editors. Stop forcing one tool to do both.</p><div><hr></div><p><em>I&#8217;m writing a book about agentic coding workflows. This article came from Chapter 7, which covers non-code applications of developer AI tools. More at <a href="https://hyperdev.substack.com/">hyperdev.substack.com</a>.</em></p>]]></content:encoded></item><item><title><![CDATA[2026 Will Be The Year Of Software]]></title><description><![CDATA[And The Year SASS Sees A Major Contraction]]></description><link>https://hyperdev.matsuoka.com/p/2026-will-be-the-year-of-software</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/2026-will-be-the-year-of-software</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Mon, 16 Feb 2026 12:31:43 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!cr0H!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!cr0H!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!cr0H!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png 424w, https://substackcdn.com/image/fetch/$s_!cr0H!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png 848w, https://substackcdn.com/image/fetch/$s_!cr0H!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png 1272w, https://substackcdn.com/image/fetch/$s_!cr0H!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!cr0H!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png" width="1024" height="640" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:640,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1659587,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/187970047?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff0a02861-d25e-40ba-a883-81b6d6185448_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!cr0H!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png 424w, https://substackcdn.com/image/fetch/$s_!cr0H!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png 848w, https://substackcdn.com/image/fetch/$s_!cr0H!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png 1272w, https://substackcdn.com/image/fetch/$s_!cr0H!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F7dcf7daa-22f1-42fd-a5aa-212680c6ef88_1024x640.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>In a year when everyone is focused on AI, the bigger story may be what AI enables: a massive explosion of software creation&#8212;and software failures. AI collapses build costs and timelines, which means more software ships, which means fiercer competition and faster commoditization, which means more failures.</p><p>If you build or buy B2B software, here&#8217;s what 2026 looks like.</p><h2>A Message From the Field</h2><p>Here&#8217;s what that shift looks like inside a real product org.</p><p>Last week, <a href="https://www.linkedin.com/in/erikornitz/">Erik Ornitz</a> sent me a message that put words to something I&#8217;d been sensing for months. Erik was my product partner when I ran the Innovations team at TripAdvisor. Now he heads product at Topline Pro:</p><blockquote><p>&#8220;With Claude Code we&#8217;re seeing 2-3x the output we&#8217;ve ever seen before by our top engineers. Literally skyrocketing the past several weeks since Opus 4.5 came out. Just feels like a fundamentally different world all the sudden.</p><p>My PMs/Designers just cannot keep up.</p><p>Does this mean a radically different shape of technology organizations? Old ratios of 1 PM / Designer to 5-8 Engineers feel out the window.</p><p>Are you experiencing the same? Does that mean a major change in the % of budgets towards defining what to build vs. actually building it?&#8221;</p><p>&#8212; <a href="https://www.linkedin.com/in/erikornitz">Erik Ornitz</a>, Head of Product, Topline Pro</p></blockquote><p>The answer to Erik&#8217;s question is yes. To all of it.</p><h2>The Data</h2><p>GitHub&#8217;s <a href="https://octoverse.github.com/">2024 Octoverse report</a> tells the story:</p><ul><li><p><strong>100+ million new repositories</strong> created in 2024</p></li><li><p><strong>~25% year-over-year growth</strong> in total repos (now over 500 million)</p></li><li><p><strong>~98% growth</strong> in generative AI projects alone</p></li><li><p><strong>1.4 million new open source contributors</strong></p></li></ul><p>These represent software being created and iterated on. Many repos are experiments, forks, or prototypes&#8212;but the volume signals a fundamental shift in creation velocity.</p><p>The productivity studies back up what Erik is seeing&#8212;at least directionally. GitHub&#8217;s controlled study showed <strong>56% faster task completion</strong> on specific coding tasks. Stack Overflow&#8217;s survey of 90,000 developers found <strong>70% are using or planning to use AI tools</strong>.</p><p>Erik&#8217;s 2-3x number sounds aggressive against these studies. The gap comes from what you measure. Studies measure isolated tasks with junior-to-mid engineers. Erik is measuring total output from senior engineers who&#8217;ve built multi-agent workflows&#8212;Claude Code orchestrating research, implementation, testing, and documentation in parallel. Different baselines, different measurements, different results.</p><h2>I&#8217;m Living Proof</h2><p>Before 2025, I had never published a single open source project. Not one. In twenty-five years of building software professionally, I never had the bandwidth to maintain a side project while doing my actual job.</p><p>In the past twelve months, I&#8217;ve published seventeen:</p><ul><li><p><strong>claude-mpm</strong> &#8212; Multi-agent orchestration for Claude Code</p></li><li><p><strong>mcp-vector-search</strong> &#8212; Semantic code search via Model Context Protocol</p></li><li><p><strong>kuzu-memory</strong> &#8212; Graph-based memory system for AI agents</p></li></ul><p>These aren&#8217;t toys. They&#8217;re production tools I use daily. What changed: I went from spending 80% of my time on scaffolding and boilerplate to spending 80% of my time on the interesting problems. The grunt work&#8212;test generation, documentation, refactoring&#8212;happens in minutes instead of hours.</p><p>The same engineer. The same available hours. Radically different output. This would have been impossible before Claude Code and Opus 4.5 shipped in late 2025.</p><h2>The Economics Have Flipped</h2><p>Erik&#8217;s real question: if engineers can produce 2-3x the output, what happens to the rest of the organization?</p><p>The old model assumed building software was expensive and slow. The entire SaaS industry is built on this assumption. Why build a CRM when Salesforce exists? Why build analytics when Amplitude exists? Why build anything when you can pay per seat per month for someone else&#8217;s solution?</p><p>The math made sense when custom development meant six-figure budgets and twelve-month timelines.</p><p>The math is changing.</p><p>Based on my own projects and conversations with engineering leaders, I estimate AI tools have reduced the cost of building new greenfield software by roughly an order of magnitude for certain categories of work&#8212;internal tools, CRUD applications, API integrations, developer utilities. Not every category. Not enterprise systems with complex compliance requirements. But for the kinds of software that used to be &#8220;not worth building,&#8221; the math has changed.</p><p>A feature that would have taken a team of three engineers two months can now be built by one engineer in two weeks. That&#8217;s not a study&#8212;that&#8217;s what I&#8217;m seeing in practice.</p><p>When building gets that cheap, the calculus of build versus buy changes completely.</p><h2>SaaS Vendors Should Be Worried</h2><p>If I were playing the stock market right now, I would pay very close attention to SaaS renewal rates.</p><p>Think about what happens when thousands of companies simultaneously realize they can build what they need for less than their annual software licenses cost. The $50K/year internal analytics dashboard? Illustratively: one engineer, one month. The $200K/year customer data integration? Two engineers, one quarter&#8212;if it&#8217;s a narrow, well-defined workflow.</p><p>Not every category is equally vulnerable. <strong>Most at risk</strong>: horizontal admin tools, internal workflow automation, simple analytics, and single-purpose integrations. <strong>More defensible</strong>: compliance-heavy systems of record, platforms with strong network effects, multi-tenant marketplaces, and products built on proprietary data moats.</p><p>Salesforce isn&#8217;t going anywhere in the near term&#8212;their moat is complexity, switching costs, and ecosystem lock-in. That moat is real.</p><p>But the bar is rising. The threshold where it makes sense to buy instead of build is moving up dramatically.</p><p>I expect 2026 will see an unusually high number of SaaS vendors fail&#8212;particularly in the crowded mid-market where differentiation was always thin.</p><p>The ones that survive will need to improve at a pace they&#8217;ve never attempted before. Customer expectations are rising in lockstep with capabilities. B2B software will need to approach B2C quality. Clunky enterprise UIs that customers tolerated because they had no alternative? Those alternatives now exist.</p><h2>The Managed-Service Stack as Force Multiplier</h2><p>None of this would be happening without the parallel explosion in managed platforms and developer services.</p><p>Ten years ago, building a new software product meant provisioning servers, managing databases, handling authentication, building deployment pipelines. The operational overhead often exceeded the development effort.</p><p>Now: Vercel deploys your frontend. Supabase handles your database and auth. Stripe processes payments. Resend sends emails. Everything connects via APIs.</p><p>The composable stack means engineers can focus on the software that differentiates their product. The undifferentiated infrastructure is someone else&#8217;s problem.</p><p>AI coding tools plus composable infrastructure equals massive leverage. One engineer can build and ship what used to require a team.</p><h2>A Warning for the Ambitious</h2><p>Many engineers will be tempted to take their great idea and build a business around it. The tools make it easy. The startup costs are minimal. Why not?</p><p>Because if your only defensibility is the idea and the code, you have no moat.</p><p>AI generates code nearly as easily as English&#8212;for standard patterns and well-documented APIs, anyway. Any idea you can implement, someone else can implement too&#8212;probably faster, probably with more resources, probably with better distribution.</p><p>The SaaS vendors going out of business will be replaced by a flood of new entrants. Most of those new entrants will also fail. The barrier to entry has dropped, but the barriers to sustainable success haven&#8217;t. This is why virtually everything I build is open source. It&#8217;s valuable enough for me that I&#8217;m willing to spend the time to build it. []Charging customers for it? A completely different equation.</p><p>You need something beyond code:</p><ul><li><p><strong>Distribution</strong>: An audience, channel partnerships, or existing customer relationships</p></li><li><p><strong>Community</strong>: A user base that contributes content, plugins, or network value</p></li><li><p><strong>Domain expertise</strong>: Deep knowledge of a niche workflow that takes years to acquire</p></li><li><p><strong>Data advantages</strong>: Proprietary datasets that improve your product over time</p></li><li><p><strong>Integration complexity</strong>: Deep hooks into systems-of-record that make switching painful</p></li></ul><p>Something that can&#8217;t be replicated in a weekend by another engineer with Claude Code.</p><p>The golden age of software creation is also the golden age of software commoditization. Don&#8217;t confuse the ability to build with the ability to win.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!TGop!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!TGop!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png 424w, https://substackcdn.com/image/fetch/$s_!TGop!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png 848w, https://substackcdn.com/image/fetch/$s_!TGop!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!TGop!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!TGop!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png" width="1024" height="1024" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/d69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:1024,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1272963,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/187970047?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!TGop!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png 424w, https://substackcdn.com/image/fetch/$s_!TGop!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png 848w, https://substackcdn.com/image/fetch/$s_!TGop!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!TGop!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd69e8e74-7b76-440f-80a7-af85a4a026f6_1024x1024.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The Disruption Is Already Here</h2><p>Tech layoffs doubled in 2025&#8212;264,000 jobs eliminated according to Layoffs.fyi, compared to roughly 130,000 in 2024. Some of this is cyclical. Some of it is AI.</p><p>Anecdotally, I&#8217;m hearing from engineering managers that their top developers are spending dramatically less time writing code directly&#8212;they&#8217;re orchestrating AI tools instead. The code is still being written, just not by humans, or not by as many humans.</p><p>The disruption won&#8217;t be distributed evenly. Senior engineers who can orchestrate AI tools effectively will become more valuable. Junior engineers who were being paid to write boilerplate will find that work automated.</p><p>Product managers and designers face a different problem: they used to be the bottleneck&#8217;s counterweight. Now they&#8217;re the bottleneck. Erik&#8217;s question about organizational ratios is urgent because the answer affects hiring, budgets, and team structures across the industry.</p><h2>The Bright Spot</h2><p>This is going to be painful for many people. Layoffs are painful. Business failures are painful. Career disruption is painful.</p><p>But we&#8217;re entering a golden age of software.</p><p>More software will be created in 2026 than in any year in history. More problems will be solved by code. More ideas will ship. More experiments will run. More entrepreneurs will try.</p><p>Most of it will be crap, as I said at the start. Sturgeon&#8217;s Law&#8212;90% of everything is crap&#8212;doesn&#8217;t suspend for technological revolutions. But the 10% that isn&#8217;t crap will be extraordinary.</p><p>The tools now exist to build durable, production-quality software at a scale and speed that wasn&#8217;t possible two years ago. Those who learn to use them&#8212;really use them, not just dabble&#8212;will build things that matter.</p><p>I&#8217;ve never been more excited to be an engineer.</p><p>I&#8217;ve also never been more aware of how brutal the transition will be for those caught on the wrong side.</p><p>2026 will be the year of software. Here&#8217;s how to prepare:</p><ul><li><p><strong>Learn agent-generated coding now</strong>. Not AI-assisted (autocomplete, suggestions)&#8212;AI-generated: you describe intent, agents produce complete implementations. This means multi-agent orchestration, prompt engineering for code, and reviewing AI output instead of writing it. The paradigm shift is steep and early movers will have 6-12 months of advantage.</p></li><li><p><strong>Tighten your product discovery loops</strong>. When engineering throughput triples, PM and design become the constraint. The organizations that figure out faster iteration on <em>what</em> to build will outpace those focused only on building faster.</p></li><li><p><strong>Invest in distribution before you need it</strong>. Building is no longer the hard part. Finding users, building brand, creating switching costs&#8212;those are the new differentiators.</p></li></ul><p>The explosion is coming. Make sure you&#8217;re positioned on the right side of it.</p><div><hr></div><p><em>I&#8217;m writing about agentic coding workflows at <a href="https://hyperdev.substack.com/">hyperdev.matsuoka.com</a>. My open source tools are at <a href="https://github.com/bobmatnyc">github.com/bobmatnyc</a>.</em></p>]]></content:encoded></item><item><title><![CDATA[Shumer’s Right About the Tsunami. His Advice Points at the Wrong Shore]]></title><description><![CDATA[The viral AI displacement post gets the diagnosis right and the prescription backward]]></description><link>https://hyperdev.matsuoka.com/p/shumers-right-about-the-tsunami-his</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/shumers-right-about-the-tsunami-his</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Sun, 15 Feb 2026 20:11:23 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!KCLm!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!KCLm!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!KCLm!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png 424w, https://substackcdn.com/image/fetch/$s_!KCLm!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png 848w, https://substackcdn.com/image/fetch/$s_!KCLm!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png 1272w, https://substackcdn.com/image/fetch/$s_!KCLm!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!KCLm!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png" width="1024" height="672" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:672,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1507340,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/188065074?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5932a64c-ab8b-4110-84b0-92adb14dc3b7_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!KCLm!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png 424w, https://substackcdn.com/image/fetch/$s_!KCLm!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png 848w, https://substackcdn.com/image/fetch/$s_!KCLm!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png 1272w, https://substackcdn.com/image/fetch/$s_!KCLm!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F4ee0987e-1176-49ef-b7eb-9ab860622fe4_1024x672.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Pointing to the wrong shore?</figcaption></figure></div><p>Matt Shumer&#8217;s <a href="https://shumer.dev/something-big-is-happening">&#8220;Something Big Is Happening&#8221;</a> went viral this week. If you are one of the few that haven&#8217;t read it, the argument runs like this: AI has crossed a capability threshold. GPT-5.3 Codex and Claude Opus 4.6 can complete complex projects autonomously. The displacement timeline is 1-5 years, not decades. Prepare accordingly.</p><p>He&#8217;s not wrong about the diagnosis. I&#8217;ve been writing about this transformation for nine months now, tracking my own productivity metrics as AI tools evolved from &#8220;fancy autocomplete&#8221; to something genuinely different. The capability leap is real. So is the timeline.</p><p>Where Shumer loses me is the prescription.</p><p>His advice: use premium AI tools, build financial reserves, pursue genuine interests, spend an hour daily experimenting. Seems sensible enough. But completely backward about what I believe the transformation actually requires.</p><h2>The Diagnosis We Agree On</h2><p>Credit where due: Shumer captures something most commentary misses.</p><p>The METR measurements he cites&#8212;AI task completion capacity doubling every seven months, now accelerating to four&#8212;match what I&#8217;ve observed in practice. Claude Code didn&#8217;t just get incrementally better between Opus 4.0 and 4.6. It crossed a threshold where orchestration became viable. Not &#8220;AI helps me code faster&#8221; but &#8220;AI completes projects while I supervise.&#8221;</p><p>My own numbers tell the story: 77 completed code changes across 27 different projects in six weeks. I run multiple AI assistants simultaneously, each working on its own task while I review the results. I haven&#8217;t opened my traditional coding software for actual development in months.</p><p>Shumer&#8217;s right that this changes things. Where he&#8217;s wrong is assuming the response is survival preparation.</p><h2>The Problem with Survival Tips</h2><p>&#8220;Build financial reserves.&#8221; &#8220;Pursue genuine interests rather than traditional career paths.&#8221; &#8220;Spend one hour daily experimenting.&#8221;</p><p>This is advice for people who expect to be displaced. It&#8217;s the response you&#8217;d give someone watching a wave approach&#8212;find high ground, protect what you can, hope you make it through.</p><p>But that framing assumes the wave destroys rather than transforms. History suggests otherwise.</p><p>I wrote recently about <a href="https://hyperdev.matsuoka.com/p/dont-be-a-canut-be-a-pattern-master">the Jacquard loom lesson</a>. The Canuts were Lyon&#8217;s master silk weavers&#8212;legendary craftspeople whose identity was wrapped up in thread manipulation. When Jacquard&#8217;s programmable loom arrived in 1804, they rioted. Some adapted. Many didn&#8217;t.</p><p>Here&#8217;s what the numbers actually show: total silk workers stayed around 30,000 through the transition. The looms didn&#8217;t eliminate jobs&#8212;they compressed the master craftsman class while creating lower-wage operator roles. By 1831, 308 silk merchants controlled pricing for 5,575 master weavers managing 20,000+ workers.</p><p>The cautionary tale isn&#8217;t mass unemployment. It&#8217;s wage collapse and status compression for those who kept doing the same job while the job&#8217;s value eroded beneath them.</p><p>The Canuts who survived weren&#8217;t the fastest weavers. They were the ones who recognized that &#8220;weaver&#8221; was becoming &#8220;pattern designer&#8221; and &#8220;loom operator&#8221; and &#8220;machine mechanic.&#8221; The skill didn&#8217;t disappear. It changed shape.</p><h2>What Shumer&#8217;s Advice Misses</h2><p>&#8220;Spend one hour daily experimenting with AI tools.&#8221;</p><p>This is advice for a Canut. Practice with the new loom. Get comfortable with the interface. Learn the commands.</p><p>It completely misses what actually becomes valuable.</p><p>The <a href="https://www.faros.ai/blog/ai-software-engineering">Faros AI Productivity Paradox Report</a> analyzed data across thousands of developers and found something telling: &#8220;Adoption skews toward less tenured engineers. Usage is highest among engineers who are newer to the company.&#8221;</p><p>Why? Because junior engineers face different constraints. Their bottleneck is navigating unfamiliar code, accelerating early contributions, learning system patterns. AI helps enormously with that.</p><p>Senior engineers showed lower adoption not because they&#8217;re Luddites&#8212;because their constraints aren&#8217;t code-writing speed. Their bottleneck is &#8220;deep system knowledge and organizational context&#8221; that AI can&#8217;t access. Generating code faster doesn&#8217;t help when the constraint is understanding why the system works the way it does.</p><p>A <a href="https://papers.ssrn.com/sol3/papers.cfm?abstract_id=5713646">University of Chicago Booth working paper</a> found experienced developers were 5-6% <em>more</em> likely to successfully use AI agents for every standard deviation of work experience. Not because they typed better prompts&#8212;because they used &#8220;plan-first&#8221; approaches, laying out objectives and steps before invoking AI.</p><p>Expertise improves the ability to delegate. That&#8217;s not something you learn from an hour of daily experimentation.</p><h2>What&#8217;s Irreducibly Human</h2><p>During a recent knowledge base project&#8212;120 commits over 9 days, roughly 90% Claude-assisted&#8212;I tracked where my time actually went.</p><p>The 12 human-only commits weren&#8217;t about implementation. They were:</p><ul><li><p>Configuration tweaks requiring domain knowledge (model selection for specific use cases)</p></li><li><p>Debug logging when something felt wrong</p></li><li><p>Release management</p></li><li><p>One research document on architecture options</p></li></ul><p>The human contributions were about <em>judgment</em>. Choosing the right model for email writing versus general queries. Knowing when the AI&#8217;s suggestion would create problems downstream. Understanding the client&#8217;s actual workflows well enough to structure the system appropriately.</p><p>What surprised me: the time savings didn&#8217;t come from faster typing. They came from eliminating iteration cycles between &#8220;write code&#8221; and &#8220;realize it doesn&#8217;t fit requirements.&#8221; Specifying clearly upfront meant fewer rewrites&#8212;but that specification work was irreducibly human.</p><p>The <a href="https://www.qodo.ai/blog/state-of-ai-coding-2025/">Qodo 2025 State of AI Coding survey</a> found 65% of developers cite missing context as the primary barrier to shipping AI code without review. That &#8220;missing context&#8221; is exactly what Shumer&#8217;s advice doesn&#8217;t address:</p><p><strong>Business model specifics</strong>: How supplier relationships actually work. Which data matters for a specific service model. Why certain integrations take priority.</p><p><strong>Organizational constraints</strong>: Budget limitations. Timeline pressures. The technical capabilities of staff who&#8217;ll maintain the system.</p><p><strong>Historical context</strong>: Why previous approaches to similar problems failed. What the client tried and rejected. Political dynamics around adoption.</p><p>None of this lives on the public web. It exists in Jira tickets, PowerPoint decks, Slack conversations, and institutional memory. You don&#8217;t acquire it through an hour of daily experimentation.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!w6ty!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!w6ty!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png 424w, https://substackcdn.com/image/fetch/$s_!w6ty!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png 848w, https://substackcdn.com/image/fetch/$s_!w6ty!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png 1272w, https://substackcdn.com/image/fetch/$s_!w6ty!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!w6ty!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png" width="1024" height="599" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:599,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1369548,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/188065074?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F5df95e2b-ecf6-4459-8e76-ed469798e000_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!w6ty!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png 424w, https://substackcdn.com/image/fetch/$s_!w6ty!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png 848w, https://substackcdn.com/image/fetch/$s_!w6ty!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png 1272w, https://substackcdn.com/image/fetch/$s_!w6ty!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1b8f8a0c-5d16-4717-9872-5b434fcd5502_1024x599.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Be a Pattern Master, not a Canut</figcaption></figure></div><h2>Pattern Masters, Not Refugees</h2><p>Shumer frames AI as something happening TO workers. The response he offers is defensive: prepare for impact, build reserves, hope the wave passes.</p><p>The Jacquard lesson suggests a different frame. AI is changing WHAT the work is. The response isn&#8217;t preparation for displacement&#8212;it&#8217;s understanding what becomes valuable when implementation gets automated.</p><p>Two paths survived the Canut transition:</p><p><strong>Pattern designers</strong> who translated vision into punch cards the loom could execute. Not thread manipulators&#8212;system architects who understood what patterns were possible and how to specify them precisely.</p><p><strong>Loom improvers</strong> who made the infrastructure more reliable. Not operators&#8212;engineers who fixed the tension systems, improved card durability, figured out how to chain looms for industrial-scale production.</p><p>The agentic coding transition has the same split.</p><p>You can master the patterns&#8212;writing specs, orchestrating agents, supervising output. Or you can improve the looms&#8212;build the MCP servers, write the orchestration layers, optimize the vector databases that make retrieval-augmented generation work at scale.</p><p>Both roles survive. Thread manipulation shrinks in economic value.</p><h2>Methodology Beats Stockpiling</h2><p>The people seeing productivity gains from AI tools aren&#8217;t spending an hour daily experimenting. They&#8217;re developing methodology.</p><p><a href="https://www.microsoft.com/en-us/research/publication/the-effects-of-generative-ai-on-high-skilled-work-evidence-from-three-field-experiments/">Microsoft Research field experiments</a> across nearly 5,000 developers found 26% productivity gains with AI coding assistants&#8212;with less experienced developers showing higher adoption and greater improvements. But those gains came from structured workflows, integrated tooling, and verification processes&#8212;not casual usage.</p><p>The developers in the <a href="https://metr.org/blog/2025-07-10-early-2025-ai-experienced-os-dev-study/">METR randomized controlled trial</a> who were 19% <em>slower</em> with AI assistance? They were using AI the Shumer way&#8212;open a chat, ask a question, accept the output, repeat. No structured context. No optimized prompts. No verification layer. They felt faster while actually slowing down.</p><p>I&#8217;ve written about <a href="https://hyperdev.matsuoka.com/p/hyperdevs-three-golden-rules">three golden rules</a> that structure my own workflow: let AI write your prompts (research shows 17-50% improvement), make context searchable rather than just present (Lost in the Middle kills accuracy), and build verification into every workflow.</p><p>This isn&#8217;t what you learn from an hour of daily experimentation. It&#8217;s what you develop through deliberate methodology applied to real work with real stakes.</p><h2>The Question Shumer Should Have Asked</h2><p>The question isn&#8217;t &#8220;will I have a job in five years?&#8221;</p><p>It&#8217;s &#8220;what does my job become when implementation gets automated?&#8221;</p><p>For senior engineers, the answer is increasingly clear: subject matter expert plus systems architect. The person who translates ambiguous requirements into precise specifications. The person who identifies when agent outputs miss critical organizational context. The person who maintains system coherence across automated development workflows.</p><p>Jue Wang at Bain <a href="https://www.technologyreview.com/2025/12/15/1128352/rise-of-ai-coding-developers-2026/">told MIT Technology Review</a> that developers already spend only 20-40% of their time coding. The rest goes to analyzing problems, customer feedback, product strategy, administrative tasks.</p><p>AI doesn&#8217;t change what senior engineering is. It reveals what it always was.</p><p>The implementation layer was never the irreducible core. It was infrastructure&#8212;important, but increasingly invisible. What emerges when that layer automates is something both familiar and different. The same judgment work senior engineers always did, now concentrated and visible.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!n9Rf!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!n9Rf!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png 424w, https://substackcdn.com/image/fetch/$s_!n9Rf!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png 848w, https://substackcdn.com/image/fetch/$s_!n9Rf!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png 1272w, https://substackcdn.com/image/fetch/$s_!n9Rf!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!n9Rf!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png" width="1024" height="731" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/d2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:731,&quot;width&quot;:1024,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1676875,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/188065074?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fbd48561b-7280-456f-8d50-33934bef6d67_1024x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!n9Rf!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png 424w, https://substackcdn.com/image/fetch/$s_!n9Rf!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png 848w, https://substackcdn.com/image/fetch/$s_!n9Rf!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png 1272w, https://substackcdn.com/image/fetch/$s_!n9Rf!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fd2146e93-4d9a-4e72-9038-5fb03fcb75e6_1024x731.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">This looks nothing like Matt.  Well.  Maybe a bit.</figcaption></figure></div><h2>The Year of Software</h2><p>Here&#8217;s what Shumer&#8217;s displacement framing completely misses: the long tail.</p><p>My friend <a href="https://www.linkedin.com/in/mattrosenberg/">Matt Rosenberg</a> has zero software development experience as a builder. He&#8217;s a marketer who also manages a vacation rental property on Cape Cod. Over the past few weeks he built himself a revenue optimization tool&#8212;a proper one, with dynamic pricing recommendations based on local events, seasonal patterns, and competitor analysis.</p><p>He didn&#8217;t hire a developer. He didn&#8217;t buy enterprise software designed for property management chains. He built exactly what he needed for his specific situation.</p><p>Here&#8217;s what matters about how he got there: Matt spent hours over several weeks doing a deep dive into the tools. Not casual experimentation&#8212;serious investment in understanding what AI coding assistants could and couldn&#8217;t do. His transformation from marketer to builder wasn&#8217;t magic. It was built on two things he already had: deep knowledge of UX from his marketing career, and years of accumulated expertise in the vacation rental space.</p><p>That combination&#8212;domain expertise plus serious tool investment&#8212;is a model for career transformation. Not everyone will replicate Matt&#8217;s results. But the path he took isn&#8217;t &#8220;spend an hour a day experimenting.&#8221; It&#8217;s &#8220;leverage what you already know deeply, and invest real time in learning to express it through new tools.&#8221;</p><p>Here&#8217;s the economics that matter: Matt has a reasonable chance to recoup his effort by sharing this with other Cape Cod hosts&#8212;a small audience with the exact same problem. A smaller but real chance someone picks it up for broader distribution. Maybe it stays a side project. Maybe it becomes a micro-business serving vacation rental owners in seasonal markets. A larger concern would never take on a project with such a small TAM.</p><p>None of those paths existed before.</p><p>In the old model, Matt&#8217;s revenue optimizer would never exist. No developer would build it for one vacation rental property. No SaaS company would target Cape Cod vacation rentals as a market segment. The problem was real, Matt&#8217;s domain expertise was real, but the economics of software creation didn&#8217;t work.</p><p>Now they do. And so do the economics of software distribution. The same tools that let Matt build also let him iterate based on feedback from ten other hosts, add features they need, package it for sharing.</p><p>This is the year of software. Not because developers are being displaced&#8212;because software is finally reaching the long tail of problems that were never economical to solve. The domain expert who understands Cape Cod rental patterns better than any enterprise vendor can encode that knowledge into a working system <em>and</em> find the small audience that needs exactly that.</p><p>Shumer sees AI automating existing jobs. He misses AI creating new economic paths for people who were never developers in the first place.</p><p>The Canuts didn&#8217;t just become pattern masters and loom mechanics. Some became textile entrepreneurs who could suddenly afford custom patterns for small-batch production. The technology didn&#8217;t only change who did the work&#8212;it changed what work was possible.</p><p>This is the new normal if you learn to use the tools.</p><h2>The Bottom Line</h2><p>Shumer&#8217;s right that something big is happening. The capability threshold is real. The timeline is compressed. The transformation will affect every knowledge worker who touches a computer.</p><p>He&#8217;s wrong about what to do.</p><p>The response isn&#8217;t defensive preparation for displacement. It&#8217;s understanding what becomes valuable when AI handles implementation. It&#8217;s developing methodology for specification and orchestration. It&#8217;s acquiring the domain expertise and organizational context that AI can&#8217;t access.</p><p>And for the Matt Rosenbergs of the world&#8212;the domain experts who never learned to code&#8212;the response is recognizing that this is their year. The problems they understand better than anyone can finally become software.</p><p>Don&#8217;t stockpile. Don&#8217;t experiment an hour a day. Don&#8217;t prepare to be a refugee.</p><p>Become a pattern master. Or become a loom improver. Or become the domain expert who finally builds the tool that only you could specify.</p><p>The Canuts who survived didn&#8217;t out-weave the machines. They recognized that the job had changed shape and positioned themselves for what actually remained valuable.</p><p>The transformation is underway. The question isn&#8217;t whether you&#8217;ll make it through. It&#8217;s whether you&#8217;ve recognized what the job is becoming&#8212;and what new jobs are becoming possible.</p><div><hr></div><p><em>I&#8217;m Bob Matsuoka, writing about agentic coding and AI-powered development at <a href="https://hyperdev.substack.com/">HyperDev</a>. For more on the pattern master thesis, read my analysis of <a href="https://hyperdev.matsuoka.com/p/dont-be-a-canut-be-a-pattern-master">the Jacquard loom lesson</a> or my deep dive into <a href="https://hyperdev.matsuoka.com/p/the-irreducibles-what-a-pattern-master">what remains irreducibly human</a>.</em></p><p><strong>Related reading:</strong></p><ul><li><p><a href="https://hyperdev.matsuoka.com/p/dont-be-a-canut-be-a-pattern-master">Don&#8217;t Be a Canut&#8212;Be a Pattern Master</a> - The Jacquard history with data</p></li><li><p><a href="https://hyperdev.matsuoka.com/p/the-irreducibles-what-a-pattern-master">The Irreducibles: What a Pattern Master Does</a> - Where human value actually sits</p></li><li><p><a href="https://hyperdev.matsuoka.com/p/hyperdevs-three-golden-rules">HyperDev&#8217;s Three Golden Rules</a> - Methodology for professional AI work</p></li></ul>]]></content:encoded></item><item><title><![CDATA[Stack Overflow Is Dead]]></title><description><![CDATA[Good Riddance]]></description><link>https://hyperdev.matsuoka.com/p/stack-overflow-is-dead</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/stack-overflow-is-dead</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Thu, 12 Feb 2026 13:30:43 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!3NoI!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!3NoI!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!3NoI!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png 424w, https://substackcdn.com/image/fetch/$s_!3NoI!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png 848w, https://substackcdn.com/image/fetch/$s_!3NoI!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png 1272w, https://substackcdn.com/image/fetch/$s_!3NoI!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!3NoI!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png" width="1456" height="838" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/b7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:838,&quot;width&quot;:1456,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:216241,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/187352749?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!3NoI!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png 424w, https://substackcdn.com/image/fetch/$s_!3NoI!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png 848w, https://substackcdn.com/image/fetch/$s_!3NoI!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png 1272w, https://substackcdn.com/image/fetch/$s_!3NoI!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fb7cdd995-c7af-4899-a4bd-c401fac47fa7_2145x1234.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">Stack Overflow vs Reddit, Discord, and Dev.To</figcaption></figure></div><h2>TL;DR</h2><ul><li><p>Stack Overflow&#8217;s question volume collapsed ~95% from peak&#8212;back to 2008 levels. Traffic down ~75%. The archive remains valuable; new contributions have largely stopped.</p></li><li><p>The decline started in 2018&#8212;four years before ChatGPT. The model was already broken; AI accelerated an existing trend.</p></li><li><p>Developers didn&#8217;t stop communicating&#8212;they migrated to Reddit, Discord, Dev.to, and AI tools. r/programming has 5-6 million members; Discord has 200M+ monthly active users.</p></li><li><p>The key insight: Stack Overflow optimized for <em>definitive answers</em>&#8212;exactly what LLMs do well. Reddit/Discord provide <em>discussion, opinion, validation</em>&#8212;what LLMs struggle with.</p></li><li><p>Transactional Q&amp;A platforms are vulnerable. Community-first platforms are thriving. This is unbundling, not death.</p></li></ul><div><hr></div><p><strong>Stack Overflow still gets read. But it stopped getting written.</strong></p><p>Question volume has collapsed from 200,000/month at peak to under 10,000 today&#8212;a 95% drop. That&#8217;s not a community fading, it&#8217;s a Q&amp;A product being outcompeted.</p><p>Peter Coy wrote a piece in the New York Times recently arguing this signals the end of developer knowledge-sharing. Developers used to share publicly; now they ask ChatGPT privately. &#8220;A little sad,&#8221; he called it.</p><p>I think Coy has it backwards. Developers aren&#8217;t talking less&#8212;they&#8217;re talking elsewhere. The activity migrated to Reddit, Discord, and AI tools. Stack Overflow&#8217;s death isn&#8217;t about lost community. It&#8217;s about an obsolete model being replaced by better ones.</p><h2>The collapse is real</h2><p>Let me be clear: Stack Overflow really is dying. By &#8220;dying&#8221; I mean new contributions&#8212;questions, answers, edits&#8212;have collapsed. The archive remains; the community doesn&#8217;t.</p><p>The numbers are stark. Traffic has collapsed roughly 75% from peak, <a href="https://byteiota.com/stack-overflow-traffic/">according to third-party analyses like ByteIota</a> (based on SimilarWeb estimates). Question volume tells an even starker story: <a href="https://data.stackexchange.com/stackoverflow/query/new">Stack Exchange Data Explorer queries</a> show monthly questions dropping from ~200,000 at the 2014-2017 peak to under 10,000 by late 2025. That&#8217;s back to 2008 levels&#8212;the site&#8217;s launch year.</p><p>I used Stack Overflow heavily for years. Seeing activity fall back to early-2008 levels is hard to overstate.</p><p>Fifteen years of growth erased in under three years.</p><p>The paradox is that <a href="https://survey.stackoverflow.co/2024/">84% of developers still </a><em><a href="https://survey.stackoverflow.co/2024/">browse</a></em><a href="https://survey.stackoverflow.co/2024/"> Stack Overflow</a>. The archive has value. But almost nobody contributes anymore. The site has become a museum&#8212;visited, but not lived in.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!-5p9!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!-5p9!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png 424w, https://substackcdn.com/image/fetch/$s_!-5p9!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png 848w, https://substackcdn.com/image/fetch/$s_!-5p9!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png 1272w, https://substackcdn.com/image/fetch/$s_!-5p9!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!-5p9!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png" width="1456" height="734" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:734,&quot;width&quot;:1456,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:120534,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/187352749?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!-5p9!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png 424w, https://substackcdn.com/image/fetch/$s_!-5p9!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png 848w, https://substackcdn.com/image/fetch/$s_!-5p9!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png 1272w, https://substackcdn.com/image/fetch/$s_!-5p9!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F9aafaec3-8a20-45b8-9f67-6f39d8dcd630_1815x915.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>Where developers went</h2><p>Here&#8217;s what the &#8220;developers stopped talking&#8221; narrative misses: they moved.</p><p><strong>Reddit exploded.</strong> r/programming has somewhere between <a href="https://subredditstats.com/r/programming">5-6 million members</a>. r/learnprogramming has around 4 million. Both subreddits are trending at over 1,000% on growth metrics, adding thousands of subscribers daily. These aren&#8217;t ghost towns&#8212;they&#8217;re thriving.</p><p><strong>Discord expanded far beyond gaming.</strong> The service now has <a href="https://discord.com/company">over 200 million monthly active users</a>, and developer communities have exploded. Reactiflux (the React community) has 230,000+ members. Python Discord, Rust Discord, and dozens of framework-specific servers have become the default place for real-time developer discussion.</p><p><strong>Dev.to grew to millions of members.</strong> Built on community-first principles with lower barriers to participation than Stack Overflow ever had.</p><p><strong>The MCP ecosystem exploded.</strong> MCP&#8212;the Model Context Protocol&#8212;lets AI assistants call external tools: APIs, databases, services. Think of it as giving Claude or ChatGPT hands instead of just a mouth. In November 2024, there were maybe 100 MCP servers. By February 2026, <a href="https://glama.ai/mcp/servers">over 17,000</a>. A new form of executable knowledge-sharing emerged in the time it took Stack Overflow to collapse.</p><p>Developers didn&#8217;t stop communicating. They stopped using Stack Overflow.</p><h2>Why Reddit thrives while Stack Overflow dies</h2><p>Here&#8217;s a clarifying question: if LLMs killed Stack Overflow, why didn&#8217;t they kill Reddit?</p><p>The answer reveals the real dynamic at play.</p><p>Stack Overflow optimized for <em>definitive answers</em>. One question, one accepted answer, close the duplicates, move on. The entire system was designed to produce canonical, searchable, authoritative responses to technical questions.</p><p>That&#8217;s exactly what LLMs do. Better. Faster. Without the closure votes and downvotes.</p><p>Reddit optimizes for <em>discussion</em>. There&#8217;s no &#8220;accepted answer.&#8221; The same question can be asked repeatedly without getting closed. People share opinions, debate tradeoffs, validate frustrations, and build community around shared interests.</p><p>LLMs struggle with that. Try asking Claude or ChatGPT &#8220;Is this framework actually good or does it just have good marketing?&#8221; You&#8217;ll get a balanced, diplomatic non-answer. Ask Reddit and you&#8217;ll get thirty developers telling you exactly what they think, with war stories and receipts.</p><p>Factor Stack Overflow Reddit Content model Q&amp;A with &#8220;correct&#8221; answers Discussion threads Duplicate policy Aggressively closed Tolerated, repeated Reputation system High-stakes rep + privileges Lighter-touch karma Engagement type Transactional (get answer, leave) Conversational (participate, stay) AI competition Direct replacement Complementary</p><p>The &#8220;site:reddit.com&#8221; phenomenon tells the story. Users increasingly append that modifier to Google searches specifically because they want human perspectives, not AI-generated summaries or SEO-optimized content farms. They&#8217;re actively seeking out the thing LLMs can&#8217;t easily provide.</p><p>Stack Overflow competed with AI on AI&#8217;s home turf. Reddit doesn&#8217;t.</p><h2>Why developers didn&#8217;t fight for it</h2><p>The product model explains the competitive pressure. But the culture explains why developers didn&#8217;t fight to save it.</p><p>Stack Overflow&#8217;s culture was broken long before ChatGPT arrived. Look at the question volume data: the decline started in 2018&#8212;four full years before ChatGPT launched. Monthly questions dropped from 200,000 to 140,000 before GPT-3&#8217;s 2020 release, and well before ChatGPT&#8217;s late 2022 launch. The trajectory was already set.</p><p>ChatGPT didn&#8217;t kill Stack Overflow. It was the final nail in the coffin.</p><p>In 2019, Stack Overflow surveyed its own community about a much-publicized initiative to improve culture. <a href="https://stackoverflow.blog/2019/07/18/building-community-inclusivity-stack-overflow/">Seventy-three percent of respondents said the site remained &#8220;equally unwelcoming&#8221;</a> compared to before the initiative. This wasn&#8217;t outside criticism&#8212;it was the community itself acknowledging the problem hadn&#8217;t been fixed.</p><p>Anyone who&#8217;s used the site knows what this looked like in practice. You&#8217;d ask a question, spend twenty minutes crafting it carefully, and within seconds someone would mark it as a duplicate of a vaguely related question from 2014. Or close it as &#8220;not a real question.&#8221; Or downvote it without explanation.</p><p>The reputation system created perverse incentives. High-rep users had the power to close questions, and the system rewarded fast closure and strict gatekeeping over patient explanation. New users learned quickly that asking questions was a minefield. The site optimized for the archive, not for learning.</p><p>Public disputes between moderators and leadership became common. Several moderators resigned, citing disagreements over governance and feeling unsupported by the company.</p><p>To be clear: Stack Overflow did things well. The archive is genuinely valuable&#8212;24 million questions and answers representing collective knowledge. Discoverability was excellent. The structured Q&amp;A format created stable, linkable URLs. Canonical answers for common problems saved countless hours.</p><p>But the community that created those answers? That was poisoned years ago.</p><p>LLMs didn&#8217;t kill Stack Overflow. They just offered developers an alternative that didn&#8217;t make them feel stupid for asking questions.</p><h2>What happened to everyone else</h2><p>Stack Overflow isn&#8217;t the only platform affected by this shift. Here are some others:</p><p>Platform Status Model AI Vulnerability Stack Overflow Collapsing Transactional Q&amp;A Direct replacement Experts Exchange Pivoting Paywalled Q&amp;A High Quora Struggling General Q&amp;A High Reddit Thriving Discussion Low Discord Thriving Real-time community Low Dev.to Thriving Community blogging Low Hacker News Stable Curated discussion Low</p><p><strong>Experts Exchange</strong> pivoted hard. Remember them? The original &#8220;answers behind a paywall&#8221; site that Stack Overflow was created to replace? They&#8217;re still around, now positioning themselves as &#8220;the home of human intelligence.&#8221; The anti-AI angle is their entire pitch now.</p><p>The pattern: community-first platforms survive. Transactional Q&amp;A platforms are vulnerable. If your model is &#8220;user asks question, platform provides answer,&#8221; you&#8217;re competing directly with AI. If your model is &#8220;users discuss, debate, and build relationships,&#8221; you&#8217;re not.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!d4wR!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!d4wR!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png 424w, https://substackcdn.com/image/fetch/$s_!d4wR!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png 848w, https://substackcdn.com/image/fetch/$s_!d4wR!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png 1272w, https://substackcdn.com/image/fetch/$s_!d4wR!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!d4wR!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png" width="1184" height="864" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/ab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:864,&quot;width&quot;:1184,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1260702,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/187352749?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!d4wR!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png 424w, https://substackcdn.com/image/fetch/$s_!d4wR!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png 848w, https://substackcdn.com/image/fetch/$s_!d4wR!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png 1272w, https://substackcdn.com/image/fetch/$s_!d4wR!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Fab9ddb14-5cb4-44c4-872e-17d0ec825f25_1184x864.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The new knowledge architecture</h2><p>What&#8217;s replacing Stack Overflow isn&#8217;t a single platform. It&#8217;s a layered ecosystem.</p><p><strong>Layer 1: LLMs for basic questions.</strong> &#8220;How do I parse JSON in Python?&#8221; Don&#8217;t post that anywhere&#8212;just ask Claude. Faster response, no judgment, no risk of being marked as a duplicate. <a href="https://survey.stackoverflow.co/2025/">Eighty-four percent of developers now use AI tools</a>. For basic technical questions, this is often faster and lower-friction than posting ever was.</p><p><strong>Layer 2: MCP servers for executable knowledge.</strong> This is the part most people haven&#8217;t caught up to yet. The Model Context Protocol ecosystem has exploded to 17,000+ servers, with backing from the Linux Foundation and adoption by major players. These aren&#8217;t just answers&#8212;they&#8217;re capabilities. Instead of reading how to do something, you get a tool that does it. Knowledge that executes.</p><p><strong>Layer 3: Communities for discussion.</strong> Reddit, Discord, Dev.to. When you need opinions, validation, or to talk through a problem with humans who&#8217;ve been there, this is where you go. LLMs can tell you <em>how</em> to use a library; humans tell you <em>whether</em> you should.</p><p><strong>Layer 4: Deep expertise for analysis.</strong> Blogs, Substacks, video courses, conference talks. Long-form content that explores ideas in depth, with personality and opinion. This is where the experienced practitioners share hard-won knowledge that doesn&#8217;t fit a Q&amp;A format.</p><p>Here&#8217;s what my workflow looks like now: basic syntax question &#8594; Claude. Need to connect to an API &#8594; MCP server. &#8220;Is this the right architectural approach?&#8221; &#8594; Reddit or Discord. Deep dive on tradeoffs &#8594; find a practitioner&#8217;s blog post.</p><p>This architecture is more sophisticated than Stack Overflow ever was. It&#8217;s specialized, distributed, and each layer does what it&#8217;s good at. The Q&amp;A site tried to be everything; the new ecosystem lets each component excel at its purpose.</p><h2>The counter-arguments</h2><p>Fair criticism exists. Let me address it directly.</p><p><strong>&#8220;Knowledge is fragmented now.&#8221;</strong> True. Your answer might be on Reddit, Discord, a GitHub issue, a blog post, or an MCP server. That&#8217;s friction Stack Overflow didn&#8217;t have. But this is the story of the entire internet&#8212;from centralized portals to distributed everything. We adapted before; we&#8217;ll adapt again.</p><p><strong>&#8220;We&#8217;re losing archival permanence.&#8221;</strong> Discord conversations disappear. Reddit threads get buried. The 24 million Stack Overflow Q&amp;As were searchable and permanent. This is a real loss. But the community that created those answers was already gone. The archive remains; the contribution stopped years ago.</p><p><strong>&#8220;Developers are talking </strong><em><strong>differently</strong></em><strong>, not </strong><em><strong>more</strong></em><strong>.&#8221;</strong> Probably fair. I can&#8217;t prove total knowledge exchange increased. What I can show is that multiple platforms are thriving while Stack Overflow collapses. The activity went somewhere.</p><p><strong>&#8220;Quality control without voting?&#8221;</strong> Reddit has karma. Discord servers have curation. LLMs let you iterate until you get a useful answer. None of these are perfect, but neither was Stack Overflow&#8217;s system&#8212;which surfaced answers based on who posted first and had the most reputation.</p><h2>The bigger picture</h2><p>Stack Overflow was a toll booth on the highway of developer knowledge. For a decade, if you wanted an answer to a programming question, you went through the booth. You tolerated the closure votes, the duplicate flags, the reputation games, because there wasn&#8217;t a better alternative.</p><p>LLMs removed the toll booth.</p><p>Developers didn&#8217;t stop traveling. They stopped paying.</p><p>What we&#8217;re witnessing <em>isn&#8217;t</em> the death of developer communication. It&#8217;s the unbundling of a monopoly. Stack Overflow tried to be the single source of truth for all technical questions. That model was always fragile&#8212;it just took a sufficient technological shock to reveal it.</p><p>The new ecosystem is messier. More distributed. Harder to search&#8212;though agentic coding infrastructure is changing that quickly. (I&#8217;d argue you could learn nearly as much from my <a href="https://github.com/bobmatnyc/mcp-skillset">mcp-skillset</a> as from Stack Overflow. Better organized, semantic search, also built from community contributions. Without the BS.) But it&#8217;s also more human, more specialized, and better matched to how people actually learn and communicate.</p><h2>The sentiment shift</h2><p>One last data point. The <a href="https://survey.stackoverflow.co/2025/">2025 Stack Overflow Developer Survey</a> showed 84% of developers using AI tools&#8212;but sentiment was mixed. Only 60% viewed AI positively, down from over 70%. Forty-six percent actively distrusted AI accuracy.</p><p>That was 2025. Since then, models like Claude Opus 4.5 have made the generative AI question moot. The accuracy concerns that fed developer skepticism are evaporating. When an AI tool can reliably write, debug, and ship production code, the &#8220;will I use this?&#8221; question becomes &#8220;how do I use this effectively?&#8221;</p><p>The holdouts are running out of reasons to hold out.</p><p>Stack Overflow&#8217;s collapse isn&#8217;t a tragedy. A platform that optimized for definitive answers got replaced by tools that provide them faster. The discussion, community, and deep expertise went elsewhere&#8212;to platforms that were better at providing those things all along.</p><p>Good riddance. The future is tools for answers and humans for judgment.</p><div><hr></div><p><em>I&#8217;m Bob Matsuoka, writing about agentic coding and AI-powered development at <a href="https://hyperdev.substack.com/">HyperDev</a>. For more on how AI is reshaping developer tools, read my analysis of <a href="https://hyperdev.matsuoka.com/p/your-ide-is-a-comfort-blanket">Your IDE Is a Comfort Blanket</a> or <a href="https://hyperdev.matsuoka.com/p/the-age-of-the-cli-part-1">The Age of the CLI</a>. Hat tip to <a href="https://www.linkedin.com/in/alexzoghlin/">Alex Zoghlin</a> for sharing Peter Coy&#8217;s article.</em></p>]]></content:encoded></item><item><title><![CDATA[Your IDE Is a Comfort Blanket]]></title><description><![CDATA[And It&#8217;s Smothering You]]></description><link>https://hyperdev.matsuoka.com/p/your-ide-is-a-comfort-blanket</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/your-ide-is-a-comfort-blanket</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Tue, 10 Feb 2026 13:31:36 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!Hkvt!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!Hkvt!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!Hkvt!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png 424w, https://substackcdn.com/image/fetch/$s_!Hkvt!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png 848w, https://substackcdn.com/image/fetch/$s_!Hkvt!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png 1272w, https://substackcdn.com/image/fetch/$s_!Hkvt!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!Hkvt!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png" width="1184" height="864" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:864,&quot;width&quot;:1184,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1600054,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/187322464?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!Hkvt!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png 424w, https://substackcdn.com/image/fetch/$s_!Hkvt!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png 848w, https://substackcdn.com/image/fetch/$s_!Hkvt!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png 1272w, https://substackcdn.com/image/fetch/$s_!Hkvt!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F1dcf1a57-0044-47f2-b109-815975308f76_1184x864.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a><figcaption class="image-caption">The IDE Comfort Blanket</figcaption></figure></div><h2>TL;DR</h2><p>&#8226; Traditional IDE features (autocomplete, debugging, refactoring) actually <em>help</em> developers learn, according to a controlled UC San Diego eye-tracking study. The IDE itself isn&#8217;t the villain.<br>&#8226; AI code generation layered on top of IDEs is producing the first measurable evidence of cognitive atrophy: 19% slower with AI tools while <em>believing</em> they were 20% faster (METR study), 41% more bugs (Uplevel), 30% more static analysis warnings (Carnegie Mellon).<br>&#8226; The perception-reality gap spans roughly 40 percentage points. Developers, external ML experts, and managers all predicted AI would speed things up. Everyone was wrong in the same direction.<br>&#8226; The deeper problem isn&#8217;t deskilling experienced developers. It&#8217;s &#8220;never-skilling&#8221; an entire generation whose learning period coincides with ubiquitous AI assistance. HackerRank reports lead developer hiring grew 22% YoY while entry-level grew only 7%.<br>&#8226; CLI-based agentic tools and Specification-Driven Development (SDD) / Ticket-Driven Development (TkDD) workflows force a different cognitive mode: thinking <em>before</em> coding, specifying intent, supervising execution. The IDE&#8217;s tight feedback loop encourages the opposite: accept, move on, don&#8217;t think too hard.</p><p>I&#8217;ve been thinking about something that keeps showing up in my conversations with CTOs and engineering leads. It usually sounds like this: &#8220;My senior engineers love Claude Code. My mid-level engineers refuse to leave Cursor. And my juniors can&#8217;t function without inline AI suggestions.&#8221;</p><p>That pattern bothered me enough to spend time researching the issue. What I found changes how I think about the CLI-vs-IDE debate. Turns out it isn&#8217;t about tool preferences or terminal elitism. The question is whether the comfortable, suggestion-rich environment of modern IDEs is actively undermining the cognitive skills that matter most in an era of agentic AI.</p><p>Here&#8217;s what the evidence says: it depends on which layer you&#8217;re talking about. And the distinction matters more than most developers realize.</p><div><hr></div><h2>The IDE didn&#8217;t make you dumb (but it set the stage)</h2><p>Let&#8217;s start with what might be a surprising finding. A <a href="https://cseweb.ucsd.edu/~mcoblenz/assets/pdf/fse24-autocomplete.pdf">2024 UC San Diego study</a> ran a between-subjects experiment with 32 programmers using an unfamiliar Gmail Java API. Participants with traditional autocomplete enabled scored significantly higher on post-study knowledge tests (mean ~38 vs ~32 points, p &#8776; 0.0079) and completed tasks 8.2% faster. The learning benefit was equivalent to roughly 7.2 years of programming experience.</p><p>That&#8217;s a big deal. Traditional autocomplete works like a searchable index. It presents options. You still choose, you still think. The study found autocomplete didn&#8217;t even reduce keystrokes significantly. Its value came from serving as an efficient information-delivery mechanism, cutting documentation reading time by 16 minutes.</p><p>So, to the the surprise of this crotchety &#8220;learn-coding-before-the-IDE&#8221; developer, the IDE itself isn&#8217;t the problem. IntelliSense, syntax highlighting, integrated debugging, refactoring tools: these function as cognitive augmentation. They help you find information faster while you&#8217;re building understanding. The <a href="https://dl.acm.org/doi/10.1145/3660765">ACM published this research</a> and the authors were careful to distinguish between these features and what came next.</p><p>The warning they included reads like prophecy now: &#8220;As AI-based autocomplete tools, such as Copilot, become more popular, it will be important to re-evaluate the learning implications, since these tools may reduce the cognitive involvement of programmers.&#8221;</p><p>That re-evaluation has arrived. And the results are ugly.</p><h2>AI code generation crosses the line</h2><p>James Prather&#8217;s research group ran <a href="https://juholeinonen.com/assets/pdf/prather2024widening.pdf">21 laboratory sessions with eye-tracking at ICER 2024</a>, studying how novice programmers interact with generative AI tools. They found something concerning: AI tools compound existing metacognitive difficulties and introduce entirely new failure modes they labeled Interruption, Mislead, and Progression.</p><p>Students with strong metacognitive skills benefited from AI assistance. Students who already struggled were pushed further behind, finishing with what the researchers called an &#8220;illusion of competence.&#8221; They believed they understood code they couldn&#8217;t reproduce independently. The gap between strong and weak learners <em>widened</em>. That&#8217;s the opposite of what educational tools are supposed to do.</p><p>A <a href="https://arxiv.org/html/2211.03622v3">Stanford security study</a> found developers using AI assistants wrote significantly less secure code and were simultaneously more confident it was secure. Let that sink in. Worse outcomes. Higher confidence.</p><p><a href="https://arxiv.org/abs/2310.02059">Research on Copilot-generated code in GitHub projects</a> found that 48%+ of AI-generated code contains security vulnerabilities. Actual CWEs in production repositories.</p><h2>The 40-point perception gap</h2><p>The single most striking finding comes from <a href="https://metr.org/blog/2025-07-10-early-2025-ai-experienced-os-dev-study/">METR&#8217;s 2025 randomized controlled trial</a>. Sixteen experienced open-source developers tackled 246 real-world tasks on mature repositories (averaging 22,000+ stars and a million lines of code) using Cursor Pro with Claude 3.5/3.7 Sonnet.</p><p>The result: developers were <a href="https://www.infoworld.com/article/4020931/ai-coding-tools-can-slow-down-seasoned-developers-by-19.html">19% slower with AI tools</a>. Before starting, they predicted a 24% speedup. Afterward, they <em>still</em> believed they&#8217;d been 20% faster. External ML experts had predicted a 38% speedup. Everyone was wrong in the same direction, and the gap between perception and reality spanned roughly 40 percentage points.</p><p>As <a href="https://www.seangoedecke.com/impact-of-ai-study/">Sean Goedecke noted</a> in his analysis of the METR study, this wasn&#8217;t about bad tools or bad developers. It was about the cognitive overhead of evaluating, correcting, and integrating AI-generated code eating the time savings from not typing it yourself.</p><p>This pattern shows up everywhere you look. <a href="https://cloud.google.com/blog/products/devops-sre/announcing-the-2024-dora-report">Google&#8217;s DORA 2024 report</a>, surveying 39,000 professionals, found every 25% increase in AI adoption correlated with a 1.5% decrease in delivery throughput and a 7.2% decrease in delivery stability. Seventy-five percent of developers reported feeling more productive. The measurements said otherwise.</p><p>A <a href="https://x.com/rohanpaul_ai/status/2005012475360739624">Carnegie Mellon difference-in-differences study</a> of 807 GitHub repositories adopting Cursor found a transient velocity spike (3-4x more lines added in month one) followed by persistent quality degradation: static analysis warnings up 30%, code complexity up 41%. <a href="https://www.gitclear.com/ai_assistant_code_quality_2025_research">GitClear&#8217;s analysis of 211 million changed lines</a> found code duplication blocks increased eightfold during 2024 and refactoring declined from 25% to under 10% of changed lines.</p><p>More code. Worse code. And developers who thought they were crushing it.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!dCSj!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!dCSj!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png 424w, https://substackcdn.com/image/fetch/$s_!dCSj!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png 848w, https://substackcdn.com/image/fetch/$s_!dCSj!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png 1272w, https://substackcdn.com/image/fetch/$s_!dCSj!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!dCSj!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png" width="1184" height="864" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/f337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:864,&quot;width&quot;:1184,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1137378,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/187322464?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!dCSj!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png 424w, https://substackcdn.com/image/fetch/$s_!dCSj!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png 848w, https://substackcdn.com/image/fetch/$s_!dCSj!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png 1272w, https://substackcdn.com/image/fetch/$s_!dCSj!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2Ff337d27e-8dc3-48dc-8c79-1b42ba0d0287_1184x864.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>Your brain on autocomplete</h2><p>The cognitive science explains the mechanism clearly enough. Betsy Sparrow&#8217;s landmark <a href="https://www.science.org/doi/10.1126/science.1207745">2011 </a><em><a href="https://www.science.org/doi/10.1126/science.1207745">Science</a></em><a href="https://www.science.org/doi/10.1126/science.1207745"> paper on &#8220;Google Effects on Memory&#8221;</a> demonstrated that when people expect future access to information, they have lower recall of the information itself but enhanced recall of <em>where to find it</em>. The internet becomes a transactive memory partner. You remember the path to knowledge, not the knowledge.</p><p>Applied to programming: developers who rely on autocomplete may remember that a method exists in the dropdown rather than what it does. For traditional autocomplete, the UC San Diego study suggests this tradeoff is acceptable or even beneficial. But AI code generation goes much further. It doesn&#8217;t just tell you what methods exist. It writes entire implementations you may never fully comprehend.</p><p>A <a href="https://www.mdpi.com/2075-4698/15/1/6">2025 study of 666 participants published in MDPI</a> found a significant negative correlation (r = &#8722;0.75) between frequent AI tool usage and critical thinking abilities, mediated by cognitive offloading. Younger participants (17-25) showed higher AI dependence and lower critical thinking scores. Higher education served as a protective buffer, but the feedback loop was clear: AI usage increases cognitive offloading, which reduces critical thinking, which increases AI dependency.</p><p>Robert Bjork&#8217;s concept of <a href="https://sites.edb.utexas.edu/slam/70-2/">&#8220;desirable difficulties&#8221;</a> provides the theoretical basis for why removing struggle from programming does harm. When you type code from memory instead of accepting a suggestion, you engage deeper encoding through the generation effect. When you debug manually instead of clicking a fix-it button, you build stronger mental schemas. Research on productive failure shows students who struggle before receiving instruction outperform those who receive direct instruction first.</p><p>A <a href="https://www.frontiersin.org/journals/medicine/articles/10.3389/fmed.2026.1765692/abstract">2026 </a><em><a href="https://www.frontiersin.org/journals/medicine/articles/10.3389/fmed.2026.1765692/abstract">Frontiers in Medicine</a></em><a href="https://www.frontiersin.org/journals/medicine/articles/10.3389/fmed.2026.1765692/abstract"> paper</a> distinguishes between &#8220;deskilling&#8221; (losing existing abilities) and what they call &#8220;never-skilling.&#8221; That second concept is the one that keeps me up at night. An entire generation of developers whose foundational learning period coincides with ubiquitous AI assistance may never develop the mental schemas that experienced developers take for granted. The FAA now recommends more manual flying to counter autopilot-induced skill decay. Endoscopists using AI for polyp detection saw detection rates drop from 28% to 22% when AI was turned off. This pattern shows up in every profession where automation handles the thinking.</p><h2>DHH could feel it in his fingers</h2><p>The industry voices on this are converging, even from people you wouldn&#8217;t expect to agree.</p><p><a href="https://thenewstack.io/dhh-on-ai-vibe-coding-and-the-future-of-programming/">David Heinemeier Hansson</a>, the creator of Ruby on Rails, put it viscerally in his 2025 Lex Fridman interview: &#8220;I don&#8217;t let AI drive my code. I&#8217;ve tried that, I&#8217;ve tried the Cursors and the Windsurfs, and I don&#8217;t enjoy that way of writing. I can literally feel competence draining out of my fingers.&#8221; He keeps AI output in a separate window to prevent passive consumption and insists on doing the typing himself because &#8220;you learn with your fingers.&#8221;</p><p>His specific example stuck with me. He discovered he was repeatedly asking AI for the same Bash conditional syntax. By not typing it, he wasn&#8217;t learning it. His analogy: &#8220;You&#8217;re not going to get fit by watching fitness videos. You have to do the sit-ups.&#8221;</p><p><a href="https://en.wikipedia.org/wiki/Casey_Muratori">Casey Muratori</a>, whose &#8220;Clean Code, Horrible Performance&#8221; video demonstrated up to 15x performance penalties from IDE-friendly abstraction patterns, argues that modern development practices actively pessimize software by hiding how CPUs actually work. His Performance-Aware Programming course exists explicitly to teach what IDE abstractions conceal. <a href="https://en.wikipedia.org/wiki/Jonathan_Blow">Jonathan Blow&#8217;s 2019 talk &#8220;Preventing the Collapse of Civilization&#8221;</a> frames the issue in starker terms: each generation of developers inherits diluted knowledge, and the accumulated abstraction layers represent civilizational risk.</p><p>The pragmatic middle ground comes from developers like <a href="https://frontendmasters.com/teachers/the-primeagen/">ThePrimeagen</a>, who built &#8220;99,&#8221; a Neovim AI plugin explicitly designed for &#8220;people without skill issues,&#8221; deliberately restricting AI to specific, developer-controlled areas rather than giving it full autonomy. His philosophy: AI assists, it doesn&#8217;t replace. Zed Shaw, author of the &#8220;Learn Code the Hard Way&#8221; series, <a href="https://news.ycombinator.com/item?id=8635884">advises beginners to avoid IDEs entirely during initial learning</a>: &#8220;If you take the easy tool-based route, then you&#8217;re dependent on the tool you use.&#8221;</p><p>And <a href="https://news.ycombinator.com/item?id=8635884">HN being HN</a>, one commenter nailed the practical consequence: &#8220;If I had a Bitcoin for every IDE superstar programmer who couldn&#8217;t navigate his way around the build system, I wouldn&#8217;t have to write software for a living.&#8221;</p><h2>The survey data tells the generational story</h2><p>The <a href="https://survey.stackoverflow.co/2025/ai">Stack Overflow 2025 Developer Survey</a> (49,000+ respondents) quantifies the split. Early-career developers use AI tools daily at 55.5% compared to 47.3% for developers with 10+ years of experience. More significantly, <a href="https://survey.stackoverflow.co/2025">46% of developers now actively distrust AI output</a>, exceeding the 33% who trust it. Only 3% report high trust. Positive sentiment toward AI tools has declined from over 70% in 2023 to 60% in 2025. Experienced developers are the most skeptical: lowest &#8220;highly trust&#8221; rate (2.6%), highest &#8220;highly distrust&#8221; rate (20%).</p><p><a href="https://www.hackerrank.com/reports/developer-skills-report-2025">HackerRank&#8217;s 2025 report</a>, drawing on 26 million developers and 3 million assessments, reveals the hiring consequence: lead developer hiring grew 22% year-over-year while entry-level hiring grew only 7%. The report explicitly cites employer concerns about whether early-career developers can code without heavy AI assistance. Stanford data shows employment among software developers aged 22-25 fell nearly 20% between 2022 and 2025.</p><p>Meanwhile, <a href="https://blog.jetbrains.com/research/2025/10/state-of-developer-ecosystem-2025/">JetBrains&#8217; 2025 State of Developer Ecosystem</a> found 68% of developers expect AI proficiency to become a job requirement, and <a href="https://github.blog/news-insights/octoverse/octoverse-a-new-developer-joins-github-every-second-as-ai-leads-typescript-to-1/">GitHub&#8217;s Octoverse 2025</a> reports that nearly 80% of new developers use Copilot within their first week. AI-assisted coding is the default learning environment for an entire generation, and we have precisely zero longitudinal studies on what that does to skill development.</p><p>Remember <a href="https://en.wikipedia.org/wiki/Vibe_coding">&#8220;vibe coding&#8221;</a>? <a href="https://x.com/karpathy/status/1886192184808149383?lang=en">Andrej Karpathy coined it</a> in February 2025: &#8220;fully give in to the vibes, embrace exponentials, and forget that the code even exists.&#8221; The <a href="https://stackoverflow.blog/2025/12/29/developers-remain-willing-but-reluctant-to-use-ai-the-2025-developer-survey-results-are-here/">Stack Overflow survey found 72% of developers say vibe coding plays no role in their professional work</a>. <a href="https://futurism.com/artificial-intelligence/inventor-vibe-coding-doesnt-work">Karpathy himself retreated</a>, admitting his &#8220;Nanochat&#8221; project was &#8220;basically entirely hand-written&#8221; because AI agents &#8220;just didn&#8217;t work well enough.&#8221;</p><h2>The abstraction argument is older than you think (and this time it&#8217;s different)</h2><p><a href="https://www.joelonsoftware.com/2002/11/">Joel Spolsky&#8217;s 2002 &#8220;Law of Leaky Abstractions&#8221;</a> remains the foundational text: &#8220;All non-trivial abstractions, to some degree, are leaky.&#8221; His most underappreciated line: &#8220;Abstractions save us time working, but they don&#8217;t save us time learning.&#8221;</p><p>Every abstraction boundary in computing history has produced this same anxiety. When <a href="https://thehistory.tech/first-fortran-program-1957/">FORTRAN arrived in 1957</a>, assembly programmers viewed it as a crutch. <a href="http://www.pbm.com/~lindahl/real.programmers.html">Ed Post&#8217;s satirical 1983 essay &#8220;Real Programmers Don&#8217;t Use Pascal&#8221;</a> captured the gatekeeping pattern so precisely it reads as prophecy of today&#8217;s Vim-vs-IDE debates. Each transition involved genuine loss of low-level understanding, genuine productivity gains, gatekeeping rhetoric from incumbents, and eventual normalization.</p><p>But the calculator analogy that defenders of AI coding tools love to invoke breaks down on closer inspection. <a href="https://www.semanticscholar.org/paper/A-Meta-Analysis-of-the-Effects-of-Calculators-on-in-Ellington/583aa0edf4abe9a09f4df46b87620f42b2d59f54">A 2003 meta-analysis of 54 studies</a> found calculator use did not hinder mathematical skill development. However, as cognitive scientist <a href="https://medium.com/bits-and-behavior/more-than-calculators-why-large-language-models-threaten-public-education-480dd5300939">Amy Jo Ko argues</a>, LLMs differ because they replace entire cognitive processes, not just computation. Calculators don&#8217;t hallucinate. They don&#8217;t generate plausible-but-wrong solutions. The better analogy would be handheld calculators that routinely display 2+2=5 with complete confidence.</p><p>The strongest counterargument is that every prior generation of abstraction-skeptics was ultimately wrong. The FORTRAN skeptics lost. The structured programming skeptics lost. IDE skeptics, broadly, lost. <a href="https://lp.jetbrains.com/cs-learning-curve-report-2024/">JetBrains&#8217; learning curve survey</a> found learners who use IDEs encounter fewer obstacles, get stuck less often, and handle version control more easily. But the question isn&#8217;t whether IDEs helped. It&#8217;s whether AI code generation is another step on the same escalator or a qualitatively different kind of abstraction that crosses from augmenting cognition to replacing it.</p><p>Based on what I&#8217;ve seen in the research, I think it&#8217;s the latter. And I think the IDE is where developers are most likely to experience this crossing without noticing it.</p><h2>Why this matters for CLI and specification-driven workflows</h2><p>Here&#8217;s where this connects to the broader argument I&#8217;ve been building about CLI-based agentic tools and the shift toward <a href="https://hyperdev.matsuoka.com/p/the-other-shoe-will-drop">Specification-Driven Development (SDD)</a>.</p><p>IDE-integrated AI tools optimize for the wrong cognitive mode. They sit <em>inside</em> your editor, constantly suggesting, constantly completing, making it effortless to accept code you haven&#8217;t thought through. The tight feedback loop that makes IDEs feel productive is the same loop that enables the accept-and-move-on behavior the research keeps flagging. The entire UX is designed to keep you writing code faster, not thinking about code more carefully.</p><p>CLI-based agentic tools and SDD/TkDD workflows force a different cognitive mode entirely. When you&#8217;re working with Claude Code from the terminal, you can&#8217;t just tab-accept a suggestion mid-line. You have to think about what you want before you ask for it. You write specifications. You decompose tasks into tickets. You define acceptance criteria. Then you supervise execution and review results.</p><p>This is where I see the distinction between SDD and what I call <a href="https://hyperdev.matsuoka.com/">Ticket-Driven Development (TkDD)</a>. SDD gives you the strategic framework: specs are the primary artifact, not code. TkDD gives you the <em>workflow mechanics</em>: every unit of work lives in a ticket that captures not just the requirement but the evolution of thinking during human-AI collaboration. The ticket becomes the forcing function that makes you articulate intent before the agent writes a single line.</p><p>I use <a href="https://github.com/bobmatnyc/mcp-ticketer">mcp-ticketer</a> for this daily. Before an agent touches code, I&#8217;ve written a ticket that specifies what I want, why I want it, what the constraints are, and how I&#8217;ll know it&#8217;s done. That process of articulation is exactly the &#8220;desirable difficulty&#8221; that Bjork&#8217;s research says builds deeper understanding. It&#8217;s the sit-ups DHH was talking about. The IDE workflow lets you skip the sit-ups. TkDD makes you do them.</p><p>Think about Boris Cherny&#8217;s workflow. The Anthropic staff engineer who created Claude Code uses Plan mode to iterate on architecture until satisfied, then switches to auto-accept mode where Claude &#8220;can usually 1-shot it.&#8221; He runs 10-15 concurrent sessions. That&#8217;s not editing code in an IDE. That&#8217;s specifying, supervising, and reviewing. The cognitive work happens <em>before</em> the code exists, not <em>while</em> it&#8217;s being suggested to you inline.</p><p>Multi-agent orchestration amplifies this effect. When you&#8217;re running five Claude Code instances across git worktrees through tmux, your job is architectural thinking and quality review. There&#8217;s no autocomplete to accept. There&#8217;s no inline suggestion to wave through. You&#8217;re operating at the specification and supervision layer, which is precisely the cognitive level the research says matters most for building and maintaining deep understanding.</p><div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!qAwH!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!qAwH!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png 424w, https://substackcdn.com/image/fetch/$s_!qAwH!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png 848w, https://substackcdn.com/image/fetch/$s_!qAwH!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png 1272w, https://substackcdn.com/image/fetch/$s_!qAwH!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!qAwH!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png" width="1184" height="864" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:864,&quot;width&quot;:1184,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:1481971,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:true,&quot;topImage&quot;:false,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/187322464?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!qAwH!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png 424w, https://substackcdn.com/image/fetch/$s_!qAwH!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png 848w, https://substackcdn.com/image/fetch/$s_!qAwH!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png 1272w, https://substackcdn.com/image/fetch/$s_!qAwH!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F2c61f293-9bb6-4bee-ad43-6edb5650cc5c_1184x864.png 1456w" sizes="100vw" loading="lazy"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><h2>The line between tool and crutch</h2><p>The evidence doesn&#8217;t support the claim that IDEs themselves have made software engineers less capable. Traditional IDE features function as cognitive augmentation that helps developers access information faster while building understanding.</p><p>What the evidence <em>does</em> support, with increasing conviction, is that AI code generation represents a qualitative break from prior tooling. The convergence of findings (19% slowdown masked by perceived speedup, 41% increase in bugs, 30% rise in static analysis warnings, a &#8722;0.75 correlation between AI usage and critical thinking, and the widening gap between strong and weak learners) points to a tool category that degrades understanding while creating an illusion of competence.</p><p>The danger isn&#8217;t that experienced developers will forget how to code. It&#8217;s that the next generation won&#8217;t learn how to think about code at a level deeper than &#8220;accept suggestion.&#8221; IDEs don&#8217;t cause this problem, but they&#8217;re the delivery mechanism. The inline, always-on, friction-free suggestion environment of modern IDE-based AI is precisely optimized to bypass the cognitive processes that build expertise.</p><p>CLI-based agentic workflows and the SDD/TkDD paradigm aren&#8217;t just different tools. They&#8217;re different cognitive modes. They require you to think before you prompt, specify before you execute, and review with genuine comprehension rather than a quick scan of inline diffs.</p><p>That&#8217;s not terminal elitism. That&#8217;s responding to what the research actually shows: the developers who&#8217;ll thrive in the next phase are the ones who can think at the level of specifications, architecture, and agent supervision. Not the ones who got really fast at pressing Tab.</p><div><hr></div><p><em>I&#8217;m Bob Matsuoka, writing about agentic coding and AI-powered development at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p><p><em><strong>Related reading:</strong></em></p><ul><li><p><em><a href="https://hyperdev.matsuoka.com/p/the-other-shoe-will-drop">The Other Shoe Will Drop</a> &#8212; The economics of AI-assisted development and specification-driven workflows</em></p></li><li><p><em><a href="https://hyperdev.matsuoka.com/p/whats-in-my-toolkit-august-2025">What&#8217;s In My Toolkit: August 2025</a> &#8212; My daily CLI-based agentic workflow</em></p></li><li><p><em><a href="https://hyperdev.matsuoka.com/p/tkdd-ticket-driven-development-and">TkDD: Ticket-Driven Development</a> &#8212; Why tickets are the forcing function for AI collaboration</em></p></li><li><p><em><a href="https://hyperdev.matsuoka.com/p/the-age-of-the-cli-part-2">The Age of the CLI, Part 2</a> &#8212; From nanny coding to fire-and-check-in</em></p></li></ul>]]></content:encoded></item><item><title><![CDATA[Breaking: Opus 4.6 and Agent Teams]]></title><description><![CDATA[Anthropic&#8217;s Multi-Agent Coding Push]]></description><link>https://hyperdev.matsuoka.com/p/article-opus-46-and-agent-teams</link><guid isPermaLink="false">https://hyperdev.matsuoka.com/p/article-opus-46-and-agent-teams</guid><dc:creator><![CDATA[Robert Matsuoka]]></dc:creator><pubDate>Thu, 05 Feb 2026 23:56:47 GMT</pubDate><enclosure url="https://substackcdn.com/image/fetch/$s_!4JC8!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png" length="0" type="image/jpeg"/><content:encoded><![CDATA[<div class="captioned-image-container"><figure><a class="image-link image2 is-viewable-img" target="_blank" href="https://substackcdn.com/image/fetch/$s_!4JC8!,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png" data-component-name="Image2ToDOM"><div class="image2-inset"><picture><source type="image/webp" srcset="https://substackcdn.com/image/fetch/$s_!4JC8!,w_424,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png 424w, https://substackcdn.com/image/fetch/$s_!4JC8!,w_848,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png 848w, https://substackcdn.com/image/fetch/$s_!4JC8!,w_1272,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!4JC8!,w_1456,c_limit,f_webp,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png 1456w" sizes="100vw"><img src="https://substackcdn.com/image/fetch/$s_!4JC8!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png" width="1456" height="971" data-attrs="{&quot;src&quot;:&quot;https://substack-post-media.s3.amazonaws.com/public/images/761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png&quot;,&quot;srcNoWatermark&quot;:null,&quot;fullscreen&quot;:null,&quot;imageSize&quot;:null,&quot;height&quot;:971,&quot;width&quot;:1456,&quot;resizeWidth&quot;:null,&quot;bytes&quot;:2535546,&quot;alt&quot;:null,&quot;title&quot;:null,&quot;type&quot;:&quot;image/png&quot;,&quot;href&quot;:null,&quot;belowTheFold&quot;:false,&quot;topImage&quot;:true,&quot;internalRedirect&quot;:&quot;https://hyperdev.matsuoka.com/i/187036881?img=https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png&quot;,&quot;isProcessing&quot;:false,&quot;align&quot;:null,&quot;offset&quot;:false}" class="sizing-normal" alt="" srcset="https://substackcdn.com/image/fetch/$s_!4JC8!,w_424,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png 424w, https://substackcdn.com/image/fetch/$s_!4JC8!,w_848,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png 848w, https://substackcdn.com/image/fetch/$s_!4JC8!,w_1272,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png 1272w, https://substackcdn.com/image/fetch/$s_!4JC8!,w_1456,c_limit,f_auto,q_auto:good,fl_progressive:steep/https%3A%2F%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F761ca7a3-eb03-40fa-8afa-0a37a6789fec_1536x1024.png 1456w" sizes="100vw" fetchpriority="high"></picture><div class="image-link-expand"><div class="pencraft pc-display-flex pc-gap-8 pc-reset"><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container restack-image"><svg role="img" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke-width="1.5" stroke="var(--color-fg-primary)" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><g><title></title><path d="M2.53001 7.81595C3.49179 4.73911 6.43281 2.5 9.91173 2.5C13.1684 2.5 15.9537 4.46214 17.0852 7.23684L17.6179 8.67647M17.6179 8.67647L18.5002 4.26471M17.6179 8.67647L13.6473 6.91176M17.4995 12.1841C16.5378 15.2609 13.5967 17.5 10.1178 17.5C6.86118 17.5 4.07589 15.5379 2.94432 12.7632L2.41165 11.3235M2.41165 11.3235L1.5293 15.7353M2.41165 11.3235L6.38224 13.0882"></path></g></svg></button><button tabindex="0" type="button" class="pencraft pc-reset pencraft icon-container view-image"><svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-maximize2 lucide-maximize-2"><polyline points="15 3 21 3 21 9"></polyline><polyline points="9 21 3 21 3 15"></polyline><line x1="21" x2="14" y1="3" y2="10"></line><line x1="3" x2="10" y1="21" y2="14"></line></svg></button></div></div></div></a></figure></div><p>Anthropic dropped Opus 4.6 today (February 5, 2026), and buried in the announcement is what could be the most significant development in agentic coding since Claude Code launched: <strong>Agent Teams</strong>.</p><p>Multiple Claude instances working in parallel on a shared codebase, coordinating autonomously, with no active human intervention.</p><p>I haven&#8217;t tested it yet. But based on what Anthropic published today, this expands the ceiling of what&#8217;s possible with AI-powered development.</p><h2>What Agent Teams Actually Is</h2><p>Agent Teams is a research preview feature in Claude Code that lets you run multiple Claude instances simultaneously, each working on different aspects of a project.</p><p>The architecture (<a href="https://code.claude.com/docs/en/agent-teams">official docs</a>):</p><ul><li><p><strong>One lead session</strong> coordinates the work</p></li><li><p><strong>Multiple agent instances</strong> run independently with their own context windows</p></li><li><p><strong>Shared task list</strong> that agents can assign themselves work from</p></li><li><p><strong>Direct agent-to-agent communication</strong> for coordination</p></li><li><p><strong>Parallel execution</strong> on read-heavy tasks like codebase reviews</p></li></ul><p>Enable it with: <code>CLAUDE_CODE_EXPERIMENTAL_AGENT_TEAMS=1</code></p><p>This isn&#8217;t subagents (which work within a single session and return results to the parent). These are independent Claude Code sessions that can communicate and coordinate directly.</p><h2>The C Compiler Stress Test</h2><p>Before releasing Agent Teams publicly, Anthropic researcher Nicholas Carlini (<a href="https://www.anthropic.com/engineering/building-c-compiler">published writeup</a>) stress-tested the system by tasking 16 agents with building a C compiler from scratch, capable of compiling the Linux kernel.</p><p>The results:</p><ul><li><p><strong>Nearly 2,000 Claude Code sessions</strong> over two weeks</p></li><li><p><strong>2 billion input tokens</strong> and 140 million output tokens consumed</p></li><li><p><strong>$20,000 in API costs</strong></p></li><li><p><strong>100,000 lines of Rust code</strong> produced</p></li><li><p><strong>Successfully compiles Linux 6.9</strong> on x86, ARM, and RISC-V</p></li><li><p><strong>99% pass rate</strong> on most compiler test suites including GCC torture tests</p></li><li><p><strong>Can compile and run Doom</strong> (the ultimate developer litmus test)</p></li></ul><p>Carlini describes this as &#8220;clean-room implementation&#8221; - Claude had no internet access, only the Rust standard library.</p><p>The compiler has limitations (can&#8217;t handle 16-bit x86 real mode, cheats by calling GCC for that phase). But the point isn&#8217;t whether the compiler is production-ready. The point is <strong>16 AI agents autonomously built a 100,000-line compiler that actually works</strong>.</p><p>That&#8217;s a different order of magnitude than &#8220;Claude helped me refactor a module.&#8221;</p><h2>What Changed in Opus 4.6</h2><p>Agent Teams is the headline, but Opus 4.6 includes several major upgrades:</p><p><strong>1M Token Context Window</strong></p><p>First time for Opus-class models. Not just &#8220;more tokens&#8221; - the retrieval quality matters more than the capacity. On MRCR v2 (finding specific information buried in massive context):</p><ul><li><p>Opus 4.6: 76.0%</p></li><li><p>Sonnet 4.5: 18.5%</p></li></ul><p><strong>Context Compaction</strong></p><p>For long-running sessions, automatically summarizes older conversation turns to free up context space. Like git squash for conversation history - keeps summaries of earlier work, full detail on recent turns.</p><p><strong>Adaptive Thinking with Effort Controls</strong></p><p>Four settings: low, medium, high (default), max. Model adjusts reasoning depth based on task complexity. Trade latency and cost for quality when you need it, run faster on simpler tasks.</p><p><strong>Same Pricing</strong></p><p>$5 input / $25 output per million tokens. Identical to Opus 4.5. (Premium pricing $10/$37.50 for requests over 200K tokens using the full 1M context.)</p><h2>Available Now, Everywhere</h2><p>This isn&#8217;t an announcement with a waitlist. Opus 4.6 is live:</p><ul><li><p>Claude.ai web interface</p></li><li><p>Claude API (<code>claude-opus-4-6</code>)</p></li><li><p>Claude Code (with Agent Teams in research preview)</p></li><li><p>GitHub Copilot (gradual rollout)</p></li><li><p>AWS Bedrock</p></li><li><p>Major cloud platforms</p></li></ul><p>That&#8217;s unusual. Most AI releases do staged rollouts. Anthropic shipped everywhere simultaneously.</p><h2>The Benchmarks (With Usual Caveats)</h2><p>Anthropic claims (<a href="https://www.anthropic.com/claude/opus">official Opus page</a>) Opus 4.6 leads or matches competitors across most benchmark categories:</p><p><strong>Terminal-Bench 2.0</strong> (agentic coding): 65.4% - Anthropic&#8217;s highest score <strong>GDPval-AA</strong> (real-world professional tasks): 144 Elo points ahead of GPT-5.2 <strong>Humanity&#8217;s Last Exam</strong> (complex reasoning): Leads all frontier models <strong>BigLaw Bench</strong>: 90.2% - highest score from any Claude model <strong>Zero-day vulnerability discovery</strong>: 500+ previously unknown high-severity vulnerabilities found in open-source code</p><p>Standard disclaimer: Anthropic&#8217;s benchmarks, specific test sets, real-world performance varies.</p><p>Worth noting: OpenAI released GPT-5.3 Codex 27 minutes after Opus 4.6&#8217;s announcement, claiming 77.3% on Terminal-Bench 2.0. The benchmark lead didn&#8217;t last half an hour.</p><h2>What This Could Mean for Agentic Development</h2><p>If Agent Teams works as described, it could change the fundamental economics of AI-assisted development.</p><p><strong>Before</strong>: One agent, sequential processing. Ask it to review a PR, it goes file by file.</p><p><strong>After</strong>: Multiple agents working in parallel. One reviews frontend, one reviews API, one checks tests, one updates documentation - simultaneously.</p><p>The cost structure changes too. Agent Teams bills each instance separately, so you&#8217;re paying for multiple concurrent sessions. But if three agents working in parallel complete a task in one-third the time, the token economics might still favor the parallel approach.</p><p><strong>The real question: Does coordination overhead eat the parallel gains?</strong></p><p>With human teams, adding developers to a project doesn&#8217;t scale linearly - coordination costs increase. Brooks&#8217; Law: &#8220;Adding manpower to a late software project makes it later.&#8221;</p><p>Do AI agent teams suffer the same coordination penalties, or do they coordinate more efficiently than humans?</p><p>I don&#8217;t know. I haven&#8217;t tested it yet.</p><h2>The OpenAI Response</h2><p>Twenty minutes after Anthropic announced Opus 4.6, OpenAI released GPT-5.3 Codex - a specialized developer-focused model.</p><p>The timing is either competitive coincidence or coordinated counter-programming. Either way, it signals where both companies see the competitive battlefield: <strong>autonomous, multi-agent coding workflows</strong>.</p><p>This isn&#8217;t about which model writes better individual functions. It&#8217;s about which platform enables teams of AI agents to autonomously execute complex, multi-day software projects.</p><h2>Security and Safety Considerations</h2><p>Anthropic published a system card claiming Opus 4.6 has low rates of harmful behaviors and the lowest over-refusal rates of any recent Claude model.</p><p>The cybersecurity implications cut both ways. Opus 4.6 found 500+ previously unknown high-severity vulnerabilities (<a href="https://www.axios.com/2026/02/05/anthropic-claude-opus-46-software-hunting">Axios reporting</a>) in open-source code - which is excellent for defenders trying to secure their software. It&#8217;s also concerning for what adversaries could do with that capability.</p><p>Anthropic developed six new cybersecurity probes to detect potentially harmful uses and implemented real-time detection tools to block suspected malicious traffic. They acknowledge this &#8220;will create friction for legitimate research and some defensive work.&#8221;</p><h2>What I&#8217;m Testing Next</h2><p>I haven&#8217;t used Agent Teams yet. But here&#8217;s what I want to find out:</p><p><strong>1. Coordination efficiency</strong></p><p>Do agent teams actually complete complex tasks faster than sequential agents, or does coordination overhead cancel the parallel gains?</p><p><strong>2. Cost dynamics</strong></p><p>At what task complexity does paying for multiple concurrent sessions become economically viable compared to one longer session?</p><p><strong>3. Integration with Claude-MPM</strong></p><p>I already orchestrate multiple specialized agents through Claude-MPM. How does Agent Teams interact with or replace that orchestration layer?</p><p><strong>4. Task decomposition quality</strong></p><p>How well does the lead agent break down complex work into parallelizable subtasks? Does it create artificial dependencies or find genuine parallelism?</p><p><strong>5. Conflict resolution</strong></p><p>What happens when multiple agents need to modify the same files? How does the system handle merge conflicts and coordination failures?</p><p>I&#8217;ll report back once I&#8217;ve actually run Agent Teams on real projects.</p><h2>The Bottom Line</h2><p>Opus 4.6 represents a major capability expansion in agentic coding. Agent Teams raises the ceiling on what&#8217;s possible - from &#8220;AI helps me code&#8221; to &#8220;AI agent teams autonomously execute multi-week software projects.&#8221;</p><p>Whether it actually delivers on that potential in production environments remains to be seen. The C compiler demonstration is impressive, but building a greenfield compiler is different from maintaining a legacy enterprise codebase with 15 years of technical debt.</p><p>The real test: Can Agent Teams handle the messy, ambiguous, poorly-documented, politically-fraught reality of actual software development? Or does it only shine on clean-room projects with clear specifications?</p><p>I&#8217;ll find out. But the potential is clear: we&#8217;ve moved from individual AI coding assistants to coordinated AI development teams.</p><p>This release is not an incremental improvement. This could be a significant shift in how autonomous development works.</p><div><hr></div><p><em>I&#8217;m Bob Matsuoka, writing about agentic coding and AI-powered development at <a href="https://hyperdev.substack.com/">HyperDev</a>.</em></p>]]></content:encoded></item></channel></rss>