Tom Blomfield

Partner at Y Combinator. Co-founded Monzo and GoCardless. Based in San Francisco.

The Age Of Abundance

Apr 1, 2025

I wrote a Twitter post at the weekend that caused a bit of a stir.

Like any good post optimized for engagement, a lot of the respondents got very riled up and called me rude names. In some software engineering circles, it was not highly regarded.

The most basic form of this response was essentially "LLMs can't (and will never) write real production-grade code."

A slightly more sophisticated version was "as the cost of producing code goes down, the demand will rise exponentially, and so the total market for code-writing will actually expand." And the demand-side of low-cost, high-quality software is practically unlimited, unlike food.

Haven't you heard of Jevons' paradox?


I want to address these two points in order, but a quick note about my intentions first.

I think that technological progress truly offers a path to a better world for all of humanity; I dream of a future state of shared abundance.

Technology clearly accelerates human progress and makes a measurable difference to the lives of most people in the world today. A simple example is cancer survival rates, which have gone from 50% in 1975 to about 75% today. That number will inevitably rise further because of human ingenuity and technological acceleration.

Of course those benefits aren't shared equally around the world. A point I will return to later.

I also love software engineering and building things. I have spent my entire career on it. I don't want software engineers (or anyone, really) to lose their jobs. It's an incredibly painful process and I think it will result in extreme societal disruption.

This is the central point I'm trying to make: Technological progress is accelerating very rapidly and I don't think most people are prepared for that future.


Ok, so let's take the two points in order.

  1. LLMs aren't (and never will be) good enough to replace X.

ChatGPT was launched at the end of 2022. Anthropic's Claude was launched in March 2023. We had GPT architectures before this date, but I'd argue this is when the technology became readily available to most people. Early adopters jumped on it and quickly realized that hallucinations were rife and the answers weren't always useful as a result.

That was about two years ago. The progress since then has been nothing short of astonishing. Gains in AI are accelerating much faster than Moore's Law.

The progress in coding-specific models in the last few months alone has been wild. With Claude 3.5 Sonnet's launch in June 2024, Anthropic explicitly targeted agentic coding and tool use, and that investment has paid off.

Today, tools like Windsurf, Cursor and Claude Code feel like they give professional software engineers superpowers. Tools for non-developers like Lovable and Replit Agent aren't far behind.

Gemini 2.5 Pro was released just days ago, and already seems to be another step up. Cursor and Windsurf are already scrambling to incorporate this new model into their product.

People who tried and dismissed AI coding products even six months ago need to re-evaluate their assumptions. Last month, I probably spent 80-100 hours using these tools. They are genuinely astonishing.

I rebuilt my personal blog, set up hosting and domains and migrated it from Tumblr, all in a couple of hours. I built RecipeNinja.ai and incorporated an interactive voice agent that will generate recipes and navigate around the site for you. It's about 35,000 lines of code; every single line was written by AI. It is still a relatively small project, but one that would have taken me several months to hand-code. I've also built a number of other personal tools and games. I am easily 10x more productive with these new tools.

I know the immediate response will be "that's just a small toy project, you don't have any experience as a professional developer on large, legacy codebases." I don't want to spend too long trying to convince you of my nerd credentials, but I founded and coded most of the first version of gocardless.com (alongside @harrymarr and @hirokitakeuchi) before founding monzo.com. I have been part of some very large software projects.

Here's the thing; a single human can't understand a 10M-line software project on their own. And so they break it down into composable modules, test and document each part separately. Then you can reason about the modules at a higher level of abstraction. That's how AI will deal with larger codebases too.

These coding tools seemed like toys, but that is how every new product feels at the start. The complaints that the coding tools routinely expose private API keys in front-end code or don't write scalable production-ready code were absolutely true at one point. But that has not been my experience in the last month.

These tools are now very good. You can drop a medium-sized codebase into Gemini 2.5's 1 million-token context window and it will identify and fix complex bugs. The architectural patterns that these coding tools implement (when prompted appropriately) will easily scale websites to millions of users. I tried to expose sensitive API keys in front-end code just to see what the tools would do, and they objected very vigorously.

They are not perfect yet. But there is a clear line of sight to them getting very good in the immediate future. Even if the underlying models stopped improving altogether, simply improving their tool use will massively increase the effectiveness and utility of these coding agents. They need better integration with test suites, browser use for QA, and server log tailing for debugging. Pretty soon, I expect to see tools that allow the LLMs to to step through the code and inspect variables at runtime, which should make debugging trivial.

At the same time, the underlying models are not going to stop improving. they will continue to get better, and these tools are just going to become more and more effective. My bet is that the AI coding agents quickly beat top 0.1% of human performance, at which point it wipes out the need for the vast majority software engineers.

In the near future, I can imagine a software team that is entirely composed of AI agents. You will have a long-running "product manager" or architectural agent that sets the direction of the product and breaks it down into individual steps. Individual coding agents will take tasks and execute them before passing the code over to a QA agent that tests it against a set of pre-written integration and user-acceptance tests. You may have specific agents that review everything for scalability and security and then pass suggestions to the product manager. Once the software is live with customers, any feedback will be sent into a customer service agent which will distill it and pass it back to the product manager. These recursive, iterative loops will happen thousands of times an hour, 24 hours a day.

Of course there will be human review of and guidance of these iterations, at least at first. But at some point in the next five years, I expect some (obviously not all) coding teams to be entirely self-directing. The idea that a human will need to handwrite code in future will seem very quaint. People might still do it for fun, just like we drive classic cars today.

Of course, it will take some companies longer to adopt the AI coding tools; folks who are sensitive about exposing their codebase or data to OpenAI or Anthropic for whatever reason. Companies will be reticent to trust the AI with very large, mission-critical codebases - like banks or spacecraft for example. But I think even that will change as the AI proves itself to be better than human developers over time.

"The AI will never be good enough to write real production code" is clearly a losing proposition. From a survey of my Twitter replies, that argument seems to be made by software developers who are scared and angry about the prospect of losing their jobs.

If you are a professional software engineer, I strongly urge you to spend 10-20 hours getting up to speed with the latest tools. I don't know if they'll offer much protection in the long-term, but they are going to make you dramatically more productive this year.

  1. Jevons' Paradox will save us.

A more sophisticated objection than "The AI isn't smart enough to code" is Jevons' paradox.

Jevons' paradox states that as technological progress lowers the cost of a resource, consumption rises. That greater demand ultimately offsets—or even exceeds—the initial cost reduction.

Other people noted that the potential demand for low-cost, high-quality software is much greater than the demand for a physical resource like food. We can only consume so many calories, but there are always more problems to solve with software. Perhaps my farming metaphor was poorly chosen.

I agree with that entirely. I think we're going to have a lot more software in the future. Normal, non-technical people will be able to summon up a new custom-written software program to solve a trivial daily task much the same way they might use a spreadsheet to make a list or do simple sums today.

Here's the problem. That increased demand will be met with increased supply -- from rapidly scaling AI. I just don't think there will be any point in a human writing code for very much longer. My guess is that AI will soon be provably and obviously better at basically every facet of it. We will still have senior software engineers supervising the AI for many years because it makes humans feel safer. But they will eventually be like the conductors on self-driving trams; they are mainly there to make people feel better. This is the point that makes software engineers really angry, I think.

I think once we hit the tipping point where the AI is provably better at a given job, the societal change will be very, very rapid. I prefer self-driving Waymos over Uber or Lyft today. They're abudant in San Francisco and they're awesome. Data shows they cause 81% fewer injuries than human drivers. Put another way, humans cause 5x more accidents driving the same distance in these same cities. The technology is clearly better than humans today.

However, the global rollout of self-driving Waymos is slow because Google has to manufacture millions of very expensive self-driving cars equiped with LiDAR. The rollout of AI for knowledge work doesn't have those physical constraints in quite the same way, although the main bottlenecks in the medium term are going to be energy supply and GPUs. Closing a call center to replace the team with AI service agents will take a handful of days.

I think software engineering is just the canary in the coal mine. These same advances will happen across all knowledge work - doctors, lawyers, accountants, auditors, architects, engineers. The cost of accessing world-class medical or legal advice will come down to a $20/month subscription to OpenAI or Anthropic. There are already thousands of examples of people solving their own medical issues or getting legal advice from AI where expensive human professionals have failed. I'm not saying the AI doctor or AI lawyer can replace humans today - of course not. I am saying it is practically inevitable that the AI becomes better than humans at these jobs given enough time. That time period is shorter than most people believe.

In the short and medium-term, I can see service-heavy industries like boutique lawyers, doctors, accountants, or wealth managers actually becoming more profitable. I think they will be run by a small handful of senior partners, with the back-office administrative staff replaced very quickly with AI. Existing clients, especially older clients, will still prefer face-to-face human contact, so I think that senior partners in these industries are protected for 20 years until their client base dies off. But I think that the junior and mid-level lawyers, paralegals or accountants who are doing the bulk of the actual work are going to quickly bear the brunt of job losses.

To counter some obvious objections; clearly, physical work is protected for now. We will still need medical technicians to take readings from medical devices or surgeons to perform procedures. I think robotics is probably 10 years behind AI and the rollout will be much more constrained by physical manufacturing. But that's a topic for another blog post.

Some industries will have gatekeepers. Professions like medicine and law are highly regulated, and they're not going to give up the keys to the kingdom that easily. Regulators will likely insist a human doctor signs a prescription for medicine, even if the AI is writing out that prescription. It's like the conductor on the tram.

We're already seeing this

About a quarter of the recent YC batch wrote 95%+ of their code using AI. The companies in the most recent batch are the fastest-growing ever in the history of Y Combinator. This is not something we say every year. It is a real change in the last 24 months. Something is happening.

Companies like Cursor, Windsurf, and Lovable are getting to $100M+ revenue with astonishingly small teams. Similar things are starting to happen in law with Harvey and Legora. It is possible for teams of five engineers using cutting-edge tools to build products that previously took 50 engineers. And the communication overhead in these teams is dramatically lower, so they can stay nimble and fast-moving for much longer.

The big tech companies have dramatically slowed their hiring of entry- and mid-level software engineers and data scientists in the last year.

So what?

I think we face a future that is both amazing and incredibly frightening. Anyone who can afford a subscription will have access to extremely high-quality knowledge work at incredibly low cost. In time, you will be able to talk to a world-class oncologist about your cancer or have complex taxes filed for just a few dollars.

The costs of running all kinds of businesses will come dramatically down as the expenditure on services like software engineers, lawyers, accountants, and auditors drops through the floor. Businesses with real moats (network effect, brand, data, regulation) will become dramatically more profitable. Businesses without moats will be cloned mercilessly by AI and a huge consumer surplus will be created.

I think there will be a small handful of AI-enabled law firms or accountants or architects with the best technology that will service 80% of the market in each jurisdiction at a very low cost. There will be a few holdouts providing "handcrafted legal advice", but I think they will be the minority share of the market. We've seen this pattern in technology over and over again. The benefits accrue to a small handful of dominant companies which have an advantage in product or technology or distribution.

I don't know for sure whether these dominant players will be incumbents or newcomers in each industry. My guess is mostly newcomers. The ability to iterate quickly is overwhelmingly the most important factor in growing a successful business today, and big companies are too burdened down with thousands of people.

In the short and medium-term, I think it's very likely we see an explosion of indie hackers making $1m/year from side projects, with perhaps less need to raise VC funding.

I think the real winners in the immediate future will be those high-agency people who are good at noticing problems that people or companies have and then obsessively building solutions using the latest tools. One of YC's mantras is "Make something people want." Figuring out what people want will be a much more valuable skill once the "making" bit is freely available to all.

I also worry there's also a more distant, dystopian future where AI scours the world for any and all valuable ideas and quickly builds new startups to immediately capture that value. There may be no need for indie hackers or founders to even come up with ideas.

My main immediate worry in any of these futures is that the gains will accrue to a very small number of high-agency people who know how to use the new tools and build these new businesses. Lots of people who took low-risk whitecollar jobs are in for a huge shock. I don't say this gleefully; I am genuinely very worried and saddened by this possible future.

Will there be new jobs we can't yet imagine, or will everyone have practically unlimited free time? My bet is the former, although I don't know what the jobs are yet. I think it will result in incredible societal disruption until we figure out a new paradigm.

Figuring out how we distribute the world's resources in an age of intellectual (but not material) abundance is an unsolved question. There will still be limited resources. Property is finite. While we're still bound to one planet, so are physical resources. Electricity will be a limiting factor for a long time.

I'm extremely hopeful for the future. I think we may be able to cure basically every known disease. We may dramatically extend the human lifespan. This future could be very positive for humanity.

I'm also extremely worried. I think the short-term impact on hundreds of millions of people is going to be very profound, and I don't think many people are prepared.

RIP Tumblr - Vibecoding a new blog

Mar 29, 2025

I had a couple of hours on a train yesterday and I wanted to try out Claude Code. I've been playing with Cursor and Windsurf a lot in the past month and I wanted to see how it stacks up.

My list of side projects has long included "Get off Tumblr", so this felt like the perfect opportunity.

I don't have very much to report. It basically just worked. First, Claude wrote a script to scrape (the old) tomblomfield.com and turn all the blog posts into markdown files.

It then built a simple site structure using Next.js and decided to host it on Vercel. The site is statically generated, so it should be blazing fast. There are no database calls at all.

I use Github to store all the markdown files, so I get version control for free. Tiptap is my WYSIWYG editor and I create/update posts by making simple calls to the Github API.

I added Posthog for analytics, so I can finally see how many people are actually reading these posts. My old Google Analytics implementation on my old site broke at least 5 years ago and I never got around to fixing it.

All-in, it cost me $15 in Claude credits and about 3 hours of my time to migrate off Tumblr and onto a custom blog.

As for Claude Code vs Windsurf or Terminal? Claude Code feels more like a junior developer that you give instructions to and come back a few minutes later to see the results. It's more of a black box. I prefer watching Windsurf think through each step with more verbose output, and I actually like the fact that it's part of an IDE so I can navigate to files quickly and make tiny tweaks to my code. I'm just not as comfortable in a terminal 🤷‍♂️. Professional software engineers might feel differently.

Overall, I am more and more convinced that people and companies are going to be able to point an LLM at an existing SaaS product and simply say "build me a version of this site".

Because this site is built for n=1 users, it can be super simple. Adding hundreds of configuration options to support thousands of different use-cases is what makes software bloated and difficult to maintain.

If you're only building for yourself, you can get away with <1% of the code.

Vibecoding A Production App

Mar 20, 2025

TL;DR I built and launched a recipe app with about 20 hours of work - recipeninja.ai

Background: I’m a startup founder turned investor. I taught myself (bad) PHP in 2000, and picked up Ruby on Rails in 2011. I’d guess 2015 was the last time I wrote a line of Ruby professionally. I’ve built small side projects over the years, but nothing with any significant usage. So it’s fair to say I’m a little rusty, and I never really bothered to learn front end code or design.

In my day job at Y Combinator, I’m around founders who are building amazing stuff with AI every day and I kept hearing about the advances in tools like Lovable, Cursor and Windsurf. I love building stuff and I’ve always got a list of little apps I want to build if I had more free time.

About a month ago, I started playing with Lovable to build a word game based on Articulate (it’s similar to Heads Up or Taboo). I got a working version, but I quickly ran into limitations - I found it very complicated to add a supabase backend, and it kept re-writing large parts of my app logic when I only wanted to make cosmetic changes. It felt like a toy - not ready to build real applications yet.

But I kept hearing great things about tools like Windsurf. A couple of weeks ago, I looked again at my list of app ideas to build and saw “Recipe App”. I’ve wanted to build a hands-free recipe app for years. I love to cook, but the problem with most recipe websites is that they’re optimized for SEO, not for humans. So you have pages and pages of descriptive crap to scroll through before you actually get to the recipe. I’ve used the recipe app Paprika to store my recipes in one place, but honestly it feels like it was built in 2009. The UI isn’t great for actually cooking. My hands are covered in food and I don’t really want to touch my phone or computer when I’m following a recipe.

So I set out to build what would become RecipeNinja.ai

For this project, I decided to use Windsurf. I wanted a Rails 8 API backend and React front-end app and Windsurf set this up for me in no time. Setting up homebrew on a new laptop, installing npm and making sure I’m on the right version of Ruby is always a pain. Windsurf did this for me step-by-step. I needed to set up SSH keys so I could push to GitHub and Heroku. Windsurf did this for me as well, in about 20% of the time it would have taken me to Google all of the relevant commands.

I was impressed that it started using the Rails conventions straight out of the box. For database migrations, it used the Rails command-line tool, which then generated the correct file names and used all the correct Rails conventions. I didn’t prompt this specifically - it just knew how to do it. It one-shotted pretty complex changes across the React front end and Rails backend to work seamlessly together.

To start with, the main piece of functionality was to generate a complete step-by-step recipe from a simple input (“Lasagne”), generate an image of the finished dish, and then allow the user to progress through the recipe step-by-step with voice narration of each step. I used OpenAI for the LLM and ElevenLabs for voice. “Grandpa Spuds Oxley” gave it a friendly southern accent.

Recipe summary:

image


And the recipe step-by-step view:

image

I was pretty astonished that Windsurf managed to integrate both the OpenAI and Elevenlabs APIs without me doing very much at all. After we had a couple of problems with the open AI Ruby library, it quickly fell back to a raw ruby HTTP client implementation, but I honestly didn’t care. As long as it worked, I didn’t really mind if it used 20 lines of code or two lines of code. And Windsurf was pretty good about enforcing reasonable security practices. I wanted to call Elevenlabs directly from the front end while I was still prototyping stuff, and Windsurf objected very strongly, telling me that I was risking exposing my private API credentials to the Internet. I promised I’d fix it before I deployed to production and it finally acquiesced.

I decided I wanted to add “Advanced Import” functionality where you could take a picture of a recipe (this could be a handwritten note or a picture from a favourite a recipe book) and RecipeNinja would import the recipe. This took a handful of minutes.

Pretty quickly, a pattern emerged; I would prompt for a feature. It would read relevant files and make changes for two or three minutes, and then I would test the backend and front end together. I could quickly see from the JavaScript console or the Rails logs if there was an error, and I would just copy paste this error straight back into Windsurf with little or no explanation. 80% of the time, Windsurf would correct the mistake and the site would work. Pretty quickly, I didn’t even look at the code it generated at all. I just accepted all changes and then checked if it worked in the front end.

After a couple of hours of work on the recipe generation, I decided to add the concept of “Users” and include Google Auth as a login option. This would require extensive changes across the front end and backend - a database migration, a new model, new controller and entirely new UI. Windsurf one-shotted the code. It didn’t actually work straight away because I had to configure Google Auth to add `localhost` as a valid origin domain, but Windsurf talked me through the changes I needed to make on the Google Auth website. I took a screenshot of the Google Auth config page and pasted it back into Windsurf and it caught an error I had made. I could login to my app immediately after I made this config change. Pretty mindblowing. You can now see who’s created each recipe, keep a list of your own recipes, and toggle each recipe to public or private visibility. When I needed to set up Heroku to host my app online, Windsurf generated a bunch of terminal commands to configure my Heroku apps correctly. It went slightly off track at one point because it was using old Heroku APIs, so I pointed it to the Heroku docs page and it fixed it up correctly.

I always dreaded adding custom domains to my projects - I hate dealing with Registrars and configuring DNS to point at the right nameservers. But Windsurf told me how to configure my GoDaddy domain name DNS to work with Heroku, telling me exactly what buttons to press and what values to paste into the DNS config page. I pointed it at the Heroku docs again and Windsurf used the Heroku command line tool to add the “Custom Domain” add-ons I needed and fetch the right Heroku nameservers. I took a screenshot of the GoDaddy DNS settings and it confirmed it was right.

I can see very soon that tools like Cursor & Windsurf will integrate something like Browser Use so that an AI agent will do all this browser-based configuration work with zero user input.

I’m also impressed that Windsurf will sometimes start up a Rails server and use curl commands to check that an API is working correctly, or start my React project and load up a web preview and check the front end works. This functionality didn’t always seem to work consistently, and so I fell back to testing it manually myself most of the time.

When I was happy with the code, it wrote git commits for me and pushed code to Heroku from the in-built command line terminal. Pretty cool!

I do have a few niggles still. Sometimes it’s a little over-eager - it will make more changes than I want, without checking with me that I’m happy or the code works. For example, it might try to commit code and deploy to production, and I need to press “Stop” and actually test the app myself. When I asked it to add analytics, it went overboard and added 100 different analytics events in pretty insignificant places. When it got trigger-happy like this, I reverted the changes and gave it more precise commands to follow one by one.

The one thing I haven’t got working yet is automated testing that’s executed by the agent before it decides a task is complete; there’s probably a way to do it with custom rules (I have spent zero time investigating this). It feels like I should be able to have an integration test suite that is run automatically after every code change, and then any test failures should be rectified automatically by the AI before it says it’s finished.

Also, the AI should be able to tail my Rails logs to look for errors. It should spot things like database queries and automatically optimize my Active Record queries to make my app perform better. At the moment I’m copy-pasting in excerpts of the Rails logs, and then Windsurf quickly figures out that I’ve got an N+1 query problem and fixes it. Pretty cool.

Refactoring is also kind of painful. I’ve ended up with several files that are 700-900 lines long and contain duplicate functionality. For example, list recipes by tag and list recipes by user are basically the same.

Recipes by user:

image

This should really be identical to list recipes by tag, but Windsurf has implemented them separately.

Recipes by tag:

image


If I ask Windsurf to refactor these two pages, it randomly changes stuff like renaming analytics events, rewriting user-facing alerts, and changing random little UX stuff, when I really want to keep the functionality exactly the same and only move duplicate code into shared modules. Instead, to successfully refactor, I had to ask Windsurf to list out ideas for refactoring, then prompt it specifically to refactor these things one by one, touching nothing else. That worked a little better, but it still wasn’t perfect

Sometimes, adding minor functionality to the Rails API will often change the entire API response, rather just adding a couple of fields. Eg It will occasionally change Index Recipes to nest responses in an object { “recipes”: [ ] }, versus just returning an array, which breaks the frontend. And then another minor change will revert it. This is where adding tests to identify and prevent these kinds of API changes would be really useful. When I ask Windsurf to fix these API changes, it will instead change the front end to accept the new API json format and also leave the old implementation in for “backwards compatibility”. This ends up with a tangled mess of code that isn’t really necessary. But I’m vibecoding so I didn’t bother to fix it.

Then there was some changes that just didn’t work at all. Trying to implement Posthog analytics in the front end seemed to break my entire app multiple times. I tried to add user voice commands (“Go to the next step”), but this conflicted with the eleven labs voice recordings. Having really good git discipline makes vibe coding much easier and less stressful. If something doesn’t work after 10 minutes, I can just git reset head –hard. I’ve not lost very much time, and it frees me up to try more ambitious prompts to see what the AI can do. Less technical users who aren’t familiar with git have lost months of work when the AI goes off on a vision quest and the inbuilt revert functionality doesn’t work properly. It seems like adding more native support for version control could be a massive win for these AI coding tools.

Another complaint I’ve heard is that the AI coding tools don’t write “production” code that can scale. So I decided to put this to the test by asking Windsurf for some tips on how to make the application more performant. It identified I was downloading 3 MB image files for each recipe, and suggested a Rails feature for adding lower resolution image variants automatically. Two minutes later, I had thumbnail and midsize variants that decrease the loading time of each page by 80%. Similarly, it identified inefficient N+1 active record queries and rewrote them to be more efficient. There are a ton more performance features that come built into Rails - caching would be the next thing I’d probably add if usage really ballooned.

Before going to production, I kept my promise to move my Elevenlabs API keys to the backend. Almost as an afterthought, I asked asked Windsurf to cache the voice responses so that I’d only make an Elevenlabs API call once for each recipe step; after that, the audio file was stored in S3 using Rails ActiveStorage and served without costing me more credits. Two minutes later, it was done. Awesome.

At the end of a vibecoding session, I’d write a list of 10 or 15 new ideas for functionality that I wanted to add the next time I came back to the project. In the past, these lists would’ve built up over time and never gotten done. Each task might’ve taken me five minutes to an hour to complete manually. With Windsurf, I was astonished how quickly I could work through these lists. Changes took one or two minutes each, and within 30 minutes I’d completed my entire to do list from the day before. It was astonishing how productive I felt. I can create the features faster than I can come up with ideas.

Before launching, I wanted to improve the design, so I took a quick look at a couple of recipe sites. They were much more visual than my site, and so I simply told Windsurf to make my design more visual, emphasizing photos of food. Its first try was great. I showed it to a couple of friends and they suggested I should add recipe categories - “Thai” or “Mexican” or “Pizza” for example. They showed me the DoorDash app, so I took a screenshot of it and pasted it into Windsurf. My prompt was “Give me a carousel of food icons that look like this”. Again, this worked in one shot. I think my version actually looks better than Doordash 🤷‍♂️

Doordash:

image

My carousel:

image


I also saw I was getting a console error from missing Favicon. I always struggle to make Favicon for previous sites because I could never figure out where they were supposed to go or what file format they needed. I got OpenAI to generate me a little recipe ninja icon with a transparent background and I saved it into my project directory. I asked Windsurf what file format I need and it listed out nine different sizes and file formats. Seems annoying. I wondered if Windsurf could just do it all for me. It quickly wrote a series of Bash commands to create a temporary folder, resize the image and create the nine variants I needed. It put them into the right directory and then cleaned up the temporary directory. I laughed in amazement. I’ve never been good at bash scripting and I didn’t know if it was even possible to do what I was asking via the command line. I guess it is possible.

image

After launching and posting on Twitter, a few hundred users visited the site and generated about 1000 recipes. I was pretty happy! Unfortunately, the next day I woke up and saw that I had a $700 OpenAI bill. Someone had been abusing the site and costing me a lot of OpenAI credits by creating a single recipe over and over again - “Pasta with Shallots and Pineapple”. They did this 12,000 times. Obviously, I had not put any rate limiting in.

Still, I was determined not to write any code. I explained the problem and asked Windsurf to come up with solutions. Seconds later, I had 15 pretty good suggestions. I implemented several (but not all) of the ideas in about 10 minutes and the abuse stopped dead in its tracks. I won’t tell you which ones I chose in case Mr Shallots and Pineapple is reading. The app’s security is not perfect, but I’m pretty happy with it for the scale I’m at. If I continue to grow and get more abuse, I’ll implement more robust measures.

Overall, I am astonished how productive Windsurf has made me in the last two weeks. I’m not a good designer or frontend developer, and I’m a very rusty rails dev. I got this project into production 5 to 10 times faster than it would’ve taken me manually, and the level of polish on the front end is much higher than I could’ve achieved on my own.  Over and over again, I would ask for a change and be astonished at the speed and quality with which Windsurf implemented it. I just sat laughing as the computer wrote code.

The next thing I want to change is making the recipe generation process much more immediate and responsive. Right now, it takes about 20 seconds to generate a recipe and for a new user it feels like maybe the app just isn’t doing anything.

Instead, I’m experimenting with using Websockets to show a streaming response as the recipe is created. This gives the user immediate feedback that something is happening. It would also make editing the recipe really fun - you could ask it to “add nuts” to the recipe, and see as the recipe dynamically updates 2-3 seconds later. You could also say “Increase the quantities to cook for 8 people” or “Change from imperial to metric measurements”.

I have a basic implementation working, but there are still some rough edges. I might actually go and read the code this time to figure out what it’s doing!

I also want to add a full voice agent interface so that you don’t have to touch the screen at all. Halfway through cooking a recipe, you might ask “I don’t have cilantro - what could I use instead?” or say “Set a timer for 30 minutes”. That would be my dream recipe app!

Tools like Windsurf or Cursor aren’t yet as useful for non-technical users - they’re extremely powerful and there are still too many ways to blow your own face off. I have a fairly good idea of the architecture that I want Windsurf to implement, and I could quickly spot when it was going off track or choosing a solution that was inappropriately complicated for the feature I was building. At the moment, a technical background is a massive advantage for using Windsurf. As a rusty developer, it made me feel like I had superpowers.

But I believe within a couple of months, when things like log tailing and automated testing and native version control get implemented, it will be an extremely powerful tool for even non-technical people to write production-quality apps. The AI will be able to make complex changes and then verify those changes are actually working. At the moment, it feels like it’s making a best guess at what will work and then leaving the user to test it. Implementing better feedback loops will enable a truly agentic, recursive, self-healing development flow. It doesn’t feel like it needs any breakthrough in technology to enable this. It’s just about adding a few tool calls to the existing LLMs. My mind races as I try to think through the implications for professional software developers.

Meanwhile, the LLMs aren’t going to sit still. They’re getting better at a frightening rate. I spoke to several very capable software engineers who are Y Combinator founders in the last week. About a quarter of them told me that 95% of their code is written by AI. In six or twelve months, I just don’t think software engineering is going exist in the same way as it does today. The cost of creating high-quality, custom software is quickly trending towards zero.

You can try the site yourself at recipeninja.ai




Here’s a complete list of functionality. Of course, Windsurf just generated this list for me 🫠

RecipeNinja: Comprehensive Functionality Overview

Core Concept: the app appears to be a cooking assistant application that provides voice-guided recipe instructions, allowing users to cook hands-free while following step-by-step recipe guidance.

Backend (Rails API) Functionality

User Authentication & Authorization

  • Google OAuth integration for user authentication
  • User account management with secure authentication flows
  • Authorization system ensuring users can only access their own private recipes or public recipes

Recipe Management

  1. Recipe Model Features:
  • Unique public IDs (format: “r_” + 14 random alphanumeric characters) for security
  • User ownership (user_id field with NOT NULL constraint)
  • Public/private visibility toggle (default: private)
  • Comprehensive recipe data storage (title, ingredients, steps, cooking time, etc.)
  • Image attachment capability using Active Storage with S3 storage in production
  1. Recipe Tagging System:
  • Many-to-many relationship between recipes and tags
  • Tag model with unique name attribute
  • RecipeTag join model for the relationship
  • Helper methods for adding/removing tags from recipes
  1. Recipe API Endpoints:
  • CRUD operations for recipes
  • Pagination support with metadata (current_page, per_page, total_pages, total_count)
  • Default sorting by newest first (created_at DESC)
  • Filtering recipes by tags
  • Different serializers for list view (RecipeSummarySerializer) and detail view (RecipeSerializer)

Voice Generation

  1. Voice Recording System:
  • VoiceRecording model linked to recipes
  • Integration with Eleven Labs API for text-to-speech conversion
  • Caching of voice recordings in S3 to reduce API calls
  • Unique identifiers combining recipe_id, step_id, and voice_id
  • Force regeneration option for refreshing recordings
  1. Audio Processing:
  • Using streamio-ffmpeg gem for audio file analysis
  • Active Storage integration for audio file management
  • S3 storage for audio files in production

Recipe Import & Generation

  1. RecipeImporter Service:
  • OpenAI integration for recipe generation
  • Conversion of text recipes into structured format
  • Parsing and normalization of recipe data
  • Import from photos functionality

Frontend (React) Functionality

User Interface Components

  1. Recipe Selection & Browsing:
  • Recipe listing with pagination
  • Real-time updates with 10-second polling mechanism
  • Tag filtering functionality
  • Recipe cards showing summary information (without images)
  • “View Details” and “Start Cooking” buttons for each recipe
  1. Recipe Detail View:
  • Complete recipe information display
  • Recipe image display
  • Tag display with clickable tags
  • Option to start cooking from this view
  1. Cooking Experience:
  • Step-by-step recipe navigation
  • Voice guidance for each step
  • Keyboard shortcuts for hands-free control:
  • Arrow keys for step navigation
  • Space for play/pause audio
  • Escape to return to recipe selection
  • URL-based step tracking (e.g., /recipe/r_xlxG4bcTLs9jbM/classic-lasagna/steps/1)

State Management & Data Flow

  1. Recipe Service:
  • API integration for fetching recipes
  • Support for pagination parameters
  • Tag-based filtering
  • Caching mechanisms for recipe data
  • Image URL handling for detailed views
  1. Authentication Flow:
  • Google OAuth integration using environment variables
  • User session management
  • Authorization header management for API requests

Progressive Web App Features

  • PWA capabilities for installation on devices
  • Responsive design for various screen sizes
  • Favicon and app icon support

Deployment Architecture

  1. Two-App Structure:
  • cook-voice-api: Rails backend on Heroku
  • cook-voice-wizard: React frontend/PWA on Heroku
  1. Backend Infrastructure:
  • Ruby 3.2.2
  • PostgreSQL database (Heroku PostgreSQL addon)
  • Amazon S3 for file storage
  • Environment variables for configuration
  1. Frontend Infrastructure:
  • React application
  • Environment variable configuration
  • Static buildpack on Heroku
  • SPA routing configuration
  1. Security Measures:
  • HTTPS enforcement
  • Rails credentials system
  • Environment variables for sensitive information
  • Public ID system to mask database IDs

This comprehensive overview covers the major functionality of the Cook Voice application based on the available information. The application appears to be a sophisticated cooking assistant that combines recipe management with voice guidance to create a hands-free cooking experience.

What Is Founder Mode

Oct 6, 2024

We held a YC event a couple of months ago where Brian Chesky from Airbnb gave a passionate talk about his experience running Airbnb over the last 17 years. He believed that as Airbnb hired more professional managers, he lost a close connection with the details of the end product and the company suffered as a result.

It clearly touched a nerve with a lot of people present. It was uncomfortable to realize that I made many of the same mistakes when I ran my startup, yet somehow comforting to know I was in good company.

Paul Graham wrote an essay about a few weeks later, the now-famous Founder Mode, which I want to explore today.

Leaders in “manager mode” will “treat subtrees of the org chart as black boxes. You tell your direct reports what to do, and it’s up to them to figure out how. But you don’t get involved in the details of what they do.”

On the other hand “there are things founders can do that managers can't” - this is “founder mode” - and it’s left largely undefined. PG’s essay is perhaps best read as an invitation to founders to compare notes to discover a better way of running companies at scale.

But the essay left me questioning whether “founder mode” and “manager mode” are useful labels. They certainly generated a lot of controversy online, but if you hire bad executives and let them run your company with minimal intervention or oversight, you’re in for a bad time whether you’re a founder or not. 

And, empirically, we can point to numerous examples of both founders and hired CEOs who have either been extremely successful or totally useless. Whether someone is a founder seems largely orthogonal to whether they’re a competent leader. 

Maybe my quibble is just a semantic one - these labels distract from the debate. I do believe there is a really interesting question here - how do good leaders stay in the detail and run great companies at scale? Are there areas where founders really do have a persisting advantage?  And that’s what I want to explore in more detail here.

I think the general pattern that Brian was identifying was the following. A young, inexperienced founder with limited management experience is running a rapidly scaling company. Famous VCs invest a lot of money and join the board. Headcount passes 100 and quickly grows beyond 1000. The VCs (who often have never run anything themselves) encourage the founder to hire “executives” with “scaling experience”.

The founder is told to “empower” these executives, who typically then implement techniques that worked for them at previous companies. But, too often, these techniques fail in the new company. The founder is too nervous to intervene - these people are supposed to be “experts” - or is rebuffed by the experienced executives for “micromanaging”. Things don’t go well, and the company slowly stagnates. The founder gets sad and eventually quits or is pushed out.

Now, it’s very common to hire executives who are ineffective. Every CEO has that experience. But it’s not sensible to give those executives unverified trust and free reign from day one. I don’t think any competent CEO should treat “subtrees of the org chart as black boxes”. 

As a leader, of course you constantly need to do skip-level meetings with people further down in the organization. You need to have your finger on the pulse of the company and be able drill down into each area when necessary.

The process of building and maintaining trust between a CEO and an exec involves the CEO repeatedly going incredibly deep on niche subjects, verifying that the exec really knows what’s going on in their department, and has a good grasp on the problems. As the exec builds trust, these deep-dives can become less frequent, but they never totally disappear. If the exec repeatedly doesn’t have a good grasp of the details as you dive deep into their domain, you quickly realize that you need to replace them.

To do this, leaders need an extremely detailed and nuanced understanding of their business. There’s a cliched idea of clueless MBAs jumping from company to company, treating them as black boxes that might as well be making widgets. They clearly don’t have the domain expertise to dive into any kind of detail. This is not a successful way to run a company.

Over time, and without constant pruning, companies do seem to accumulate layers of management who do very little. These managers spend their time coordinating people, trying to establish consensus, and padding out their promotion packets to ascend to the next rung of the corporate ladder. Instead, I believe that great leaders have to be able to dig into the details, have an incredibly high bar for quality, and ultimately do great IC work themselves. Great managers have to manage the work - they should primarily be responsible for quality and speed of output. Managing people must be secondary to managing the product.

At Monzo, we experimented with some pretty wacky management structures at times. There was a period when our middle managers were basically just responsible for “pastoral care” of each employee. They were not connected at all with the output that the ICs were producing. It was totally insane and overlapped with our period of lowest productivity by far.

As you scale a company, you do have to figure out which executives you can trust with what kind of work, and delegate decisions to them appropriately. The limiting factor in any scaling company is usually management bandwidth. I believe one of the best articulations of this idea is Keith Rabois’s Barrels vs Ammunition (at 14:32, but the whole video is excellent)

If you think about people, there are two categories of high-quality people: there is the ammunition, and then there are the barrels. You can add all the ammunition you want, but if you have only five barrels in your company, you can literally do only five things simultaneously.

Finding those barrels that you can shoot through — someone who can take an idea from conception to live and it’s almost perfect — are incredibly difficult to find. This kind of person can pull people with them. They can charge up the hill. They can motivate their team, and they can edit themselves autonomously.

Once someone demonstrates “barrel-like” ability, you should quickly put more on their plate. Often, the best leaders at your company will have been promoted from within, over a period of several years. They’ve established huge amounts of trust and have deep domain knowledge. Constantly micromanaging these people is a waste of your time and will actually limit the great work your company can do. You must empower them.

On the other hand, trying to hire in senior executives from outside the company is fraught with difficulty. Sadly, many really are just “professional fakers”. These people have run hundreds of job interviews in their career and are experts at “managing up” to a CEO. This makes standard interviews almost entirely useless. Instead, I would try to pick previous projects they’ve run and dig into as much detail as you can. See how granular they can go on the problems they encountered, the decisions they made and the results they achieved. I would do a very large number of reference checks - try to find bosses, peers and subordinates and talk to them in detail about the person you are about to hire. Every time I failed to do detailed reference checks on an executive hire, I deeply regretted it. Spend significant time with the person before hiring them. I spent about a year meeting TS Anil (the now-CEO) before hiring him at Monzo, and 9 months meeting with Sujata, the COO. They are two of the best executive hires I ever made, and I’m sad I didn’t get to work with them for longer. 

Once you’ve hired someone, you need to ensure they’re doing a good job before giving them free-reign in your company. Are they really a “barrel”? Sadly, at least 50% of executive hires don’t work out. It’s essential that you identify these people early and weed them out. And the way you do this is dive deep with them into their domain and see if they can keep up. When a CEO takes their eye off the details, the career politicians and bureaucrats thrive.

I’ve heard from many founders that their senior managers - C levels and VPs - react badly when young founders want to dig into the details. They seem to say “You hired us to be the experts here. Now you need to get out of the way while we run the company.” As PG’s essay says, “Founders feel like they’re being gaslit from both sides — by the [VCs] telling them they have to run their companies like managers, and by the [execs] working for them when they do.” They “hire professional fakers and let them drive the company into the ground.” This is also the pattern that Brian identified in his talk, and I think it’s absolutely destructive. 

I have to say that this generally wasn’t my experience - I had access to all metrics from across the company, on dozens of pages of real time dashboards. I’d frequently roam the office and sit next to a random employee and start talking to them about their work. Teams would often have their dashboards up on walls and I loved digging into what the data was showing. I had an obsession with extremely granular metrics - it cost us £4.40 to onboard a single customer, split between KYC cost, debit card manufacturing, postage and packaging. Our CAC varied between £10.50 and £14.00 depending on channel. Our NPS started at +78 and declined to +71 (and we spent a really long time trying to figure out why). The average customer transacted on their Monzo card 7.4 times a week, with an average spend of £14.10 per transaction. They deposited £600 month (which grew to £950 after 18 months of using Monzo) and they opened the app 22 times per week. I could go on and on - I was obsessed with these metrics. 

We insisted that everyone at Monzo - including the entire senior management team - do customer service for one day a month. This was a great way to make sure everyone stayed closely connected to the issues customers really cared about. We stopped doing this in about year 4 or 5, and it seemed to coincide with a sharp reduction in the pace of execution.

Sadly, I hired a number of bad executives, but the techniques above generally allowed me to identify them pretty quickly, and we ended up firing a lot of senior people. There were certainly times when I was too busy and didn’t have the time, or I didn’t feel like I had the expertise to really dive in. Certain teams’ work was so alien to me that I couldn’t effectively go deep. In retrospect, they were also the lowest performing teams when I was there.

I think that the final part of successful leadership is the ability to make hard decisions in the absence of complete information. At some point or another, companies will encounter these bet-the-company moments, and maybe this is one area that founders do have an advantage over professional managers. Having the moral authority to take a really hard decision comes with the founder title. Zuckerberg’s decision to go all-in on mobile 2012 is an example of this. Professional managers inevitably have a level of risk aversion due to the insecurity of their job position - if it goes wrong, the founder is less likely to lose their job. Zuckerberg’s bet on the Metaverse would probably have gotten a professional CEO fired.

But there are relatively few of these bet-the-company decisions. Everything slows to a crawl if the CEO needs to be consulted every time a decision needs to be made. You want your (competent) execs and your top ICs to be making great decisions every day - and you as the CEO should dive in only occasionally to spot-check these decisions. This is how you scale leadership. 

I’ve worked at a startup where the founder CEO came in every Monday with a new idea. He seemed to spend every weekend talking to investors and then turned up with heaps of enthusiasm for a new initiative. But we never had time to actually make progress on the idea before he’d change his mind again. This kind of leadership thrash is depressingly common with inexperienced founder-CEOs. 

I encountered a similar thing at my own company - I learned that I had to be really careful about sharing half-formed opinions and ideas, especially with less experienced team members (and as the company grew past 1000 people). I would sometimes get enthusiastic about a new half-formed product idea, or make an off-the-cuff remark about something I found interesting. Without intending to, I’d derail an entire team for weeks. You need to be deliberate and intentional about CEO-level interventions when you’re running a company of thousands.

I learned that if I wanted the company to focus, I had to have a singular message that I repeated endlessly. I would write a 3-4 page letter to the entire company about every 6 months, outlining the one or two things we needed to focus on. At our weekly all-hands, I would just repeat the same message in different ways. I think I said “fix unit economics” several thousand times in 2018. It became a meme at the company. But it worked.

I sat in every weekly product review meeting with my CPO and CTO, even as we got to 2000 team-members. Our main input to the teams was typically to try to cut scope and launch faster. 

I learned to save my open-ended product brainstorming for a much smaller group - VP Marketing, VP Design, CPO, CTO, and a couple of very senior engineering ICs. We’d meet every 2-3 weeks and spend a couple of hours jamming on the kinds of things we could build in future. These meetings were the most fun I had at Monzo. Some of these became a core part of the product, others were just a fun way to blow off steam without distracting the company.

I’m not saying I have all the answers here - and I was far from a perfect CEO. I don’t think I really ever figured out how to balance the extremely onerous regulatory constraints of running a bank with a desire to move quickly and delight our customers. Especially as we grew past 500 people, I think we lost a lot of the early intensity and focus that I loved so much. We raised hundreds of millions of dollars, so when new employees turned up to a fancy office with catered lunches they believed they had joined a company like Google, and everything slowed down. 

Personally, I was in the detail to such an extent that I couldn’t ever really disconnect from the company. I treated every criticism of Monzo as an attack on me personally. I found it impossible to keep a sense of perspective or any balance in my life, and ultimately I burned out. I believe this is the biggest danger for founders once they’ve hit product-market-fit.

I return to the original questions - how do good leaders stay in the detail and run great companies at scale? Are there areas where founders really do have a persisting advantage?  I’ve shared some of my views here - I would insist that all CEOs stay connected to the details of their product, have an incredibly high bar for quality, manage for output, and delegate only to the extent that your leaders have earned your trust. Don’t feel embarrassed about the way you want to run your company.

I would love to hear how others run their companies, whether you’re founders or not.

Taking Risk

May 17, 2024

I just spent a week talking with some exceptional students from three of the UK’s top universities; Cambridge, Oxford and Imperial College. Along with UCL, these British universities represent 4 of the top 10 universities in the world. The US - a country with 5x more people and 8x higher GDP - has the same number of universities in the global top 10.

On these visits, I was struck by the world-class quality of technical talent, especially in AI and biosciences. But I was also struck by something else. After their studies, most of these smart young people wanted to go and work at companies like McKinsey, Goldman Sachs or Google.

I now live in San Francisco and invest in early-stage startups at Y Combinator, and it’s striking how undergraduates at top US universities start companies at more than 5x the rate of their British-educated peers. Oxford is ranked 50th in the world, while Cambridge is 61st. Imperial just makes the list at #100. I have been thinking a lot about why this is. The UK certainly doesn’t lack the talent or education, and I don’t think it’s any longer about access to capital.

People like to talk about the role of government incentives, but San Francisco politicians certainly haven’t done much to help the startup ecosystem over the last few years, while the UK government has passed a raft of supportive measures.

Instead, I think it’s something more deep-rooted - in the UK, the ideas of taking risk and of brazen, commercial ambition are seen as negatives. The American dream is the belief that anyone can be successful if they are smart enough and work hard enough. Whether or not it is the reality for most Americans, Silicon Valley thrives on this optimism.

The US has a positive-sum mindset that business growth will create more wealth and prosperity and that most people overall will benefit as a result. The approach to business in the UK and Europe feels zero-sum. Our instinct is to regulate and tax the technologies that are being pioneered in California, in the misguided belief that it will give us some kind of competitive advantage.

Young people who consider starting businesses are discouraged and the vast majority of our smart, technical graduates take “safe” jobs at prestigious employers. I am trying to figure out why that is.

___

Growing up, every successful adult in my life seemed to be a banker, a lawyer or perhaps a civil engineer, like my father. I didn’t know a single person who programmed computers as a job. I taught myself to code entirely from books and the internet in the late 1990s. The pinnacle of my parents’ ambition for me was to go to Oxford and study law.

And so I did. While at university, the high-status thing was to work for a prestigious law firm, an investment bank or a management consultancy, and then perhaps move to Private Equity after 3 or 4 years. But while other students were getting summer internships, I launched a startup with two friends. It was an online student marketplace - a bit like eBay - for students. We tried to raise money in the UK in 2006, but found it impossible. One of my cofounders, Kulveer, had a full-time job at Deutsche Bank in London which he left to focus on the startup. His friends were incredulous - they were worried he’d become homeless. My two cofounders eventually got sick of trying to raise money in the UK and moved out to San Francisco. I was too risk-averse to join them - I quit the startup to finish my law degree and then became a management consultant - it seemed like the thing that smart, ambitious students should do. The idea that I could launch a startup instead of getting a “real” job seemed totally implausible.

But in 2011, I turned down a job at McKinsey to start a company, a payments business called GoCardless, with two more friends from university. We managed to get an offer of investment (in the US) just days before my start date at McKinsey, which finally gave me the confidence to choose the startup over a prestigious job offer. My parents were very worried and a friend of my father, who was an investment banker at the time, took me to one side to warn me that this would be the worst decision I ever made. Thirteen years later, GoCardless is worth $2.3bn.

I had a similar experience in 2016, when I was starting Monzo, I had to go through regulatory interviews before I was allowed to work as the CEO of a bank. We hired lawyers and consultants to run mock interviews - and they told me plainly that I was wasting my time. It was inconceivable that the Bank of England would authorise me, a 31 year old who’d never even worked in a bank, to act as the CEO of the UK’s newest bank. (It turned out they did.) So much of the UK felt like it was pushing against me as an aspiring entrepreneur. It was like an immune system fighting against a foreign body. The reception I got in the US was dramatically different - people were overwhelmingly encouraging, supportive and helpful. For the benefit of readers who aren’t from the UK, I hope it’s fair to say that Monzo is now quite successful as well.

___

I don’t think I was any smarter or harder working than many of the recent law graduates around me at Oxford. But I probably had an unusual attitude to risk. When we started GoCardless, we were 25 years old, had good degrees, no kids and supportive families. When fundraising was going poorly, we discussed using my parents’ garage as an office. McKinsey had told me to contact them if I ever wanted a job in future. I wonder if the offer still stands.

Of course, I benefitted from immense privilege. I had a supportive family whose garage I could have used as an office. I had a good, state-funded education. I lived in a safe, democratic country with free healthcare. And I had a job offer if things didn’t work out. And so the downside of the risks we were taking just didn’t seem that great.

But there’s a pessimism in the UK that often makes people believe they’re destined to fail before they start. That it’s wrong to even think about being different. Our smartest, most technical young people aspire to work for big companies with prestigious brands, rather than take a risk and start something of their own.

And I still believe the downside risk is small, especially for privileged, smart young people with a great education, a supportive family, and before they accumulate responsibilities like childcare or a mortgage. If you spend a year or two running a startup and it fails, it’s not a big deal - the job at Google or McKinsey is still there at the end of it anyway. The potential upside is that you create a product that millions of people use and earn enough money that you never have to work again if you don’t want to.

This view is obviously elitist - I’m aware it’s not attainable for everyone. But, as a country, we should absolutely want our smartest and hardest working people building very successful companies - these companies are the engines of economic growth. They will employ thousands of people and generate billions in tax revenues. The prosperity that they create will make the entire country wealthier. We need to make our pie bigger, not fight over the economic leftovers of the US. Imagine how different the UK would feel if Google, Microsoft and Facebook were all founded here.

___

When I was talking with many of these smart students this week, many asked me how these American founders get away with all their wild claims. They seem to have limitless ambition and make outlandish claims about their goals - how can they be so sure it will pan out like that? There’s always so much uncertainty, especially in scientific research. Aren’t they all just bullshitters? Founders in the UK often tell me “I just want to be more realistic,” and they pitch their business describing the median expected outcome, which for most startups is failure.

The difference is simple - startup founders in the US imagine the range of possible scenarios and pitch the top one percent outcome. When we were starting Monzo, I said we wanted to build a bank for a billion people around the world. That’s a bold ambition, and one it’s perhaps unlikely Monzo will meet. Even if we miss that goal, we’ve still succeeded in building a profitable bank from scratch that has almost 10 million customers.

And it turns out that this approach matches exactly what venture capitalists are looking for. It is an industry based on outlier returns, especially at the earliest stages. Perhaps 70% of investments will fail completely, and another 29% might make a modest return - 1x to 3x the capital invested. But 1% of investments will be worth 1000x what was initially paid. Those 1% of successes easily pay for all the other failures.

On the contrary, many UK investors take an extremely risk-averse view to new business - I lost count of the times that a British investor would ask for me a 3 year cash-flow forecast, and expect the company to break even within that time. UK investors spend too much time trying to mitigate downside risk with all sorts of protective provisions. US venture capital investors are more likely to ask “if this is wildly successful, how big could it be?”. The downside of early-stage investing is that you lose 1x your money - it’s genuinely not worth worrying much about. The upside is that you make 1000x. This is where you should focus your attention.

___

A thriving tech ecosystem is a virtuous cycle - there’s a flywheel effect that takes several revolutions to get up-to-speed. Early pioneers start companies, raise a little money and employ some people. The most successful of these might get acquired or even IPO. The founders get rich and become venture capital investors. The early employees start their own companies or become angel investors. Later employees learn how to scale up these businesses and use their expertise to become the executives of the next wave of successful growth-stage startups.

Skype was a great early example of this - Niklas Zenstrom, the co-founder, launched the VC Atomico. Early employees of Skype started Transferwise or became seed investors at funds like Passion Capital, which invested in both GoCardless and Monzo. Alumni of those two companies have created more than 30 startups between them. Matt Robinson, my cofounder at GoCardless, was one of the UK’s most prolific angel investors, before recently becoming a Partner at Accel, one of the top VCs in the world. Relative to 15 or 20 years ago, the UK tech ecosystem is flourishing - our flywheel is starting to accelerate. Silicon Valley has just had a 50 year head start.

There is no longer a shortage of capital for great founders in the UK (although most of the capital still comes from overseas investors). I just believe that people with the highest potential aren’t choosing to launch companies, and I want that to change.

___

I don’t think the world is prepared for the tidal wave of technological change that’s about to hit over the next handful of years. Primarily because of the advances in AI, companies are being started this year that are going to transform entire industries over the next decade.

It doesn’t seem hyperbolic to say that we should expect to see very significant breakthroughs in quantum computers, nuclear fusion, self-driving vehicles, space exploration and drug discovery in the next 10 or 20 years. I think we are about to enter the biggest period of transformation humanity has ever seen.

Instead of taking safe, well-paying jobs at Goldman Sachs or McKinsey, our young people should take the lead as the world is being rebuilt around us.