- AI is not going great
- Upgrading the Firmware on a Tulip
- Learning Code Through the Advent of Code Challenge
- Common Loki Misconfigurations
- Iterating Through a List in Ink
- Debugging Misconfigured Container Networks
- Minimum Viable EC2 in Terraform
- Storylets in Ink
- Interactive Fiction Tooling Overview
- In-Place Resizing for Digitalocean Droplets
- Unity Demonstrates the Importance of FOSS
- Target Labels in Prometheus
- My View of AI is the Same
- Verify DNS Ownership with TXT Records
- Sane Droplet Defaults
- Editing Made Easy with Vim
- Gatsby Gotchas
- Concatinating Default AWS Tags in Terraform
- Easily Updating the Default Github Branch
- Lifetimes in Rust
- Checking for Bad Links
- Maybe TypeScript and React is Bad
- Static Asset Management in React
- Bundler Down Time
- Using React Context for Localization
- JS Implementation of a Sticky Footer
- Custom Aliases
- Trying Out the 7drl Challenge
- Trash Opinions
- Building Your First Program in Rust
- Fixing mongod reports errors related to opening a socket
- Improving Open Source Maintenance
- Technical Interviewing Tips
- Housekeeping Note
- Dynamic Programming Basics
- The Oddity of Naming Conventions in Programming Languages
- An Experiment Using Machine Learning, Part 3
- Debugging with grep
- An Experiment Using Machine Learning, Part 2
- An Experiment Using Machine Learning, Part 1
- The Value of while
- National Day of Civic Hacking
- OpenAI and the Future of Humanity
- Creating a Whiteboard App in Django
- Creating Meaningful, Organized Information
- Towards A Critique of Social Media Feeds
- Setting up Routes in Django
- Developing a Messaging Component for Code for SF
- Dream Stream 2.0
- Keyed Collections in Javascript: Maps and Sets
- Blog Soft Relaunch
- Scraping with Puppeteer
- Looking Ahead to Dream Stream 2.0
- Solving West of Loathing's Soupstock Lode Puzzle
- Installing Ubuntu
- Interview with David Jickling Evaluation
- Compare Text Evaluation
- Dream Stream Evaluation
AI is not going great
It’s been awhile since I opined on AI. For those keeping score at home, I first wrote about OpenAI’s innovations back in 2018. At the time I was impressed with the demonstrations I saw, but also saw some real limitations that needed to be overcome. I revisited the topic two years ago where I said there were some valuable aspects of the technology, but there were good reasons to be skeptical about how transformative the technology would be. My hope was that it could be used to help empower human creativity as opposed to acting as a race to the bottom. I think in the two years since then we have enough information to see where things have gone, and unfortunately the race-to-the-bottom goals are winning. AI, more than anything else, is a tool for spam and cheap propaganda. Social media interactions are degrading, the ability to source hgih quality information on the internet is diminishing, and the overall reliability of outputs are decreasing. What we’ve gotten out of the deal is vibe coding, e.g. the ability to rapidly build apps that more or less work for toy projects. This is nice, but I think it is difficult to state how much less productive and well off we are as a society that we now need to contend with exponentially more spam in our web content.
The new dream among the AI booster set now is agentic AIs e.g. you use an AI prompt, and it takes that input, and runs it into some application that is able to actually do something useful for the user. Early results are not auspicious, but I have no doubt there will be some improvements along the way even if you can never fix the accuracy problem since LLMs are at their heart bullshit machines. I suspect at some point it will dawn on some of these developers that once they build a good enough application experience, they don’t actually need the AI at all, and we can get back to the business of building things that solve real-world problems. However in the meantime we do need to contend with the degraded information environment that has been unleashed on the world.