Today I LearnedRSS

Everything from 2025

2025-10-24
Lecture Friday: Simple Made Easy

I love this simple versus easy distinction. He's right, we do throw those two terms around interchangeably in software development and being clear between the two is critical to improve our communication. I'm not as much a simple software advocate. Simple is great and has a lot of maintainability and reliability improvements it imparts but it certainly balances against secure, performant, and time to deliver for me. See Rust and Other Interesting Things or Data-Oriented Design and C++ for more details. But having this language, the ability to talk clearly about choosing the easy path sometimes or instead refining it to be simple by detangling two things that have been complected. That's very useful to discuss trade-offs with colleagues.

The saddest part of this talk is that the table he builds, of programming language constructs that are complex verses simple. That table is never really explained well in the talk. This is like a two week cram course cut down to fit in an hour. If you don't already know what he means by managed refs or polymorphism a la carte, you're stuck. Or at least it took me many years to appreciate this table fully and I assume others are in the same boat. I don't think a TIL post is the right format to go into details either, but I'll backlog an item to create a blog post about that table in detail sometime soon (famous last words).

2025-10-22
Don't Look Up: There Are Sensitive Internal Links in the Clear on GEO Satellites

Having listened to a few conference talks about satellite ops/sec and having talked/read/listened to/from hams who do AmSat stuff, this isn't really unknown. Lots of them talk about, for example, secret frequencies and protocols that let them read and write arbitrary memory on the satellite to enable emergency recovery. Essentially intentional remote code execution to help save the millions of dollars spent putting the thing beyond reach of repair.

This is however the first work I know of that's really spent the time to detail all the really fun stuff going on. For me, this paper is far less about the conclusions and far more about documenting all the obfuscation techniques, protocols, and worth knowing specifications to get you up to speed on what's going on up there in case you want to have a listen and try decoding some of this stuff yourself.

It's not as bad as Firesheep, which is what it took for the web industry to start taking cryptography seriously for inter-device communication. Maybe they don't need something that bad to get their act together? Though the automotive industry is facing the Flipper Zero and they're still dragging their feet and largely sticking their heads in the sand.

I'm not going to say this is a simple solved problem. Space makes deterministic computing much less reliable and redundancy much more expensive. I'm not aware of any cryptographers working on RadHard crypto algorithms and protocols though. Granted, I didn't look too deeply through the literature. Could be an open research problem. Essentially you'd have to design a cryptography system that can remain secure in the presence of some limited probability of arbitrary bit flips of the source code and runtime. Bonus points for doing it in low compute environments like those found on cube sats.

Cars have no excuse like cosmic rays though. Come on, it's well past 1994.

2025-10-20
Your Passwords Don't Need So Many Fiddly Characters, NIST Says

The original source material for this piece is NIST SP800-63 which contains all the actual specifications. The Malwarebytes labs post is just more fun which helps get the relevant bits across. Bureaucracies move glacially slow but the standard has finally been updated. Complexity rules, enforced scheduled password changes, and rotation history tracking do not lead to better security. We have fairly overwhelming evidence of this at this point. In passwords, length always wins.

Of course passwords are still completely lost on most people so you get idiotic headlines like Complicated Passwords Make You Less Safe, Experts Now Say. No, using a bigger character set still improves security. Nobody is saying you should stop using complicated passwords. We're saying adding arbitrary rules for users to follow just makes people frustrated while at best not meaningfully improving security and in many cases, actively making it worse.

People just do the most obvious things to satisfy your pointless rules. I need an uppercase, lowercase, number and symbol, better use Welcome2025!. If you've ever set this password for anyone, please stop. Stop it right now. You are single handedly undermining the security of your company. Very few people who you give that to ever change it. It's probably the most obvious password in the history of passwords along with qwertyuiop, monkey123, and Lisa1969.

Final note, use a password manager. I'll even let you use one that syncs to the cloud if that's what it takes to get you using one. Let it generate huge 60 character passwords full of symbols for you and stop trying to remember them all.

2025-10-17
Lecture Friday: #NoEstimates

You can usually embrace this even in an organization that demands estimates. To me, a line manager's key job is insulating the workers from the business so they can get things done. The key tool at your disposal is scope. I remember watching this talk a long time ago and in the time since it's combined with a few other ideas I've read about death marches. That's when everybody working on the project knows the deadline is literally never going to work, and yet you all keep marching. A simple way to unpack that involves thinking of projects as being a combination of cost, time, scope, and quality. You can only control three. Trying to control all four leads to a death march.

If you just work by starting with a deadline, a lot of it slots into place. A point at which we need to ship/demo/whatever then you can work backwards. Using projection, not estimation, you can spot things are slipping early, often earlier than estimators realize, and you need to either move the deadline or cut scope. Reducing scope is usually easier than you think. Your customer doesn't know all the cool things you wanted to build. They only know what you put in their hands. If you agreed to more, you can talk it out. Focus on what's most important. This happens all the time and it's not the big deal many people make it out to be. Also, for big projects, iterate. Don't just promise the whole thing in a year. Promise a part in a month or two. That's a great way to get feedback early and fix things before they're fully load bearing.

Not only that, just counting tickets really does give you a projection that's fairly accurate. I've used it before when estimates had months and my calculations showed years. Years later, I was right. When estimates can be as much as 200% wrong and projection is usually within 20%, it's insane not to switch.

This works because a ticket represents one unit of work from start to finish. There's a bunch of overhead in starting, testing, shipping, and so on. So each unit tends to scope about the same amount of work. That is, roughly one chunk of work someone wants to finish before doing another thing or the amount of complexity they can manage in one go. It also means it doesn't matter who's scoping as long as they're scoped together. They'll bucket into roughly the same size. What size doesn't matter too much. Just that they're about one unit of work.

This really does work. It's how I manage my team. The entire process can be summed up as make an ordered list of things to do and then do it. Repeat. It really doesn't need to be more complicated. Simultaneously, any process missing one of those components is doomed. The most often missed part is ordered list. If you have a vague sense of priority you'll end up with all sorts of informal channels of power attempting to pick their own winner among the work to be done.

I could drone on but I'm certainly not right about what will work best for your team. There's a lot of things to try, but here I'd suggest mostly, try less. Try cutting things. It's too easy to add and too hard to remove. Do the hard thing and see what happens. You can always add it back if you all worked better before. You'll probably find that more substantive things will start getting done but you feel like less is happening. That's because everyone will be busy doing instead of talking about doing.

2025-10-14
Founder Mode, Hackers, And Being Bored By Tech

Pretty neatly sums it up. The software industry has always had faces, people for whom the entire point of technology is to make the cover of some magazine, arms crossed, looking smug for the camera. To find themselves an interview so they can stroke their ego in public.

Focus on these losers long enough and that'll be all that's left. The stories we tell sculpt the future we see. These days the story is that if you work hard enough, some techbro can buy your work to claim it as their own so they can climb atop their pile of stolen valor like a dragon's hoard. If you refuse, they'll just light a pile of Saudi investment money on fire to undercut you and drive you out of business. Guess who this story really appeals to and attracts to the industry. Guess who it drives away.

Early Woz got me hyped, Aaron drove it home, Ken and Rob gave me a tradition to inherit, and at least a dozen more have done their part too. I consider myself a proud hacker. Not a great one mind you, just proud. Take it apart and put it back together purely for the discovery and fun it brings. Make it do things you shouldn't be able to because the limitations drive creativity.

If you listen to the story though, that's antithetical to the point of technology. I should only care about it in so far as it generates capital. Exponential growth. Unicorn. Sell that baby and become rich beyond your wildest dreams.

I make money to have time to play with the technology, not the other way 'round.

2025-10-10
Lecture Friday: Add ALL The Things: Abstract Algebra Meets Analytics

This is a pretty great introduction to group theory from the prospective of a distributed systems programmer. Really useful stuff. It starts by mentioning abelian groups offhandedly in order to poke fun at the impenetrability of the jargon of group theory compared to how easy it is to understand the concepts involved. If you understand idempotency, you already have an intuitive understanding of things like commutativity (which is what items in an abelian group share). If you don't, this talk makes it really easy to understand what properties resilient distributed systems tend to try and design upon and why.

2025-10-09
The Hype is the Product

Yeah, I think that elegantly sums it up. We're in so deep on economy as speculation at this point that basically nothing about a company matters beyond attracting investment. It's companies looking to get in on yield farming. It means the economy is mostly a measure of how compelling the collection of FOMO stories seem. This is why you've got runaway. If your FOMO story aligns with a lot of other companies stories, this only further boosts the FOMO.

Cryptocurrencies showed that the economy as an exchange of goods and services was only incidental, not explicit to generating the needed speculation. Making and selling (or more likely renting out) things is now only there as props in telling these stories to earn the real money. That is, people giving you heaps of cash in exchange for stock. Basically anything you can invent by typing numbers into a spreadsheet that buyers can trade amongst themselves will work. Stock these days fits the bill because you don't have to pay dividends. Why not? The story goes that if you did that, you wouldn't be growing as fast. Conveniently this reinforces the FOMO narrative.

Whenever someone whinges that the stock market is up or down and somebody inevitably retorts back that the stock market isn't the economy, I'm actually starting to think they're wrong. The stock market really has become the economy. Anyone with power has so much money tied up in the stock market, that to them, their ideas, what they think is important, the stock market weighs heavily in every decision. Everyday people aren't like this, they need bread and circuses which are becoming ever increasingly more expensive (because doing that makes the stock go up). But to those setting policy direction in government and companies, the stock market really does drive their entire outlook.

Look, if 99.9999% or more of your wealth was in this one vehicle, most people really would do everything they could to prevent their wealth decreasing even if it meant destroying people and the planet to do it. You're only going to live 30-50 more years tops. Problems for later generations or suckers less fortunate are superficial compared to your retirement portfolio.

2025-10-03
Lecture Friday: Become A Wikipedian In 30 Minutes

If you've never edited Wikipedia, give it a go. It's way simpler than you probably think it is, especially for the often undervalued work of citing sources or fixing grammar and/or punctuation. You're likely going to read a bunch of Wikipedia anyway. Take the extra few minutes to help fix problems when you see them.

2025-10-02
Way Too Many Ways To Wait On A Child Process With A Timeout

A great run through many of the noodly little details of Unix processes, signals, alarms, select, poll, and more. Includes a go through the self-pipe trick which I hadn't thought about until now, but is a neat way to simplify. I'm really happy when someone explains something by working a solution to a problem with all the trade-offs left in. Doubly so when the explanation also includes all the hairy bits of the implementations instead of leaving them as a stumbling exercise to the reader.

2025-09-29
AI as Normal Technology

About a decade ago when Waymo was making all sorts of headlines, I was talking to someone who thought we had the same timeline in mind. That it wouldn't be long until every truck driver would be out of work, so let's armchair politician what that'll mean and what should be done. I laughed and said, yeah, probably around 2050. At the time he thought I was nuts and I didn't bother to explain why. Today we're still at least a decade or more away but at least we've surpassed a hundred bodies on the road to self driving.

I bring this up because I think it's too easy for people to convince themselves that isolating oneself in a cave can lead to super intelligence and that intelligence is all you need to control and shape the world around you. It's the same flawed assumptions that have some thinking you'll put your brain in a jar at some point or that you could upload your conciousness to a computer. I'm sure you were endlessly bullied as a kid for liking computers and being an antisocial recluse, but I'm sorry to inform you, it doesn't work like that. None of this works like that.

In reality, technologies, even ones that go on to reshape civilisations, act over decades. Humans have a tendency to highly overestimate short term impacts of technology and end up completely blindsided by the long term changes these technologies bring. When I got on the internet everyone was talking about how it would cut out the pointless middlemen of markets and bring people closer together in a global village. In reality, it has been a key part of doing almost the opposite. Over the last couple decades the internet has played no small part in ushering in a golden age of monopolies and grifters all while disillusioning people of centrism, leading us back to the age of unified visions, and with that, a renewed interest in political violence.

It's not to say that technologies do the opposite of what people worry they will. That's far too reductive. It's that even revolutionary technologies like electricity, fire, steel, or the wheel act over decades, not years. Why? Well for that it takes an article like the above. Reality is extremely complicated and detailed. To understand all the ways reality slows down the adoption of these technologies, it requires more work than I'm doing in a TIL post.

2025-09-26
Lecture Friday: Email vs Capitalism, or, Why We Can't Have Nice Things

The guts of email are from a different era. Always love when people dig into it to share with everyone. Always learn your history. It's invaluable for helping you not say really dumb things in front of those who not only know the history, but those who were there. You may not get it all perfect, but much like learning to speak someone's native language, when you're at least trying it opens a whole lot of good will.

I will warn you, it ends with a, "That end's the part that's going up on Youtube." *cut to black*

Now I really want to know what was talked about after. It's a great talk, as all of Dylan's tend to be.

2025-09-19
Lecture Friday: Life of a Pixel

Might as well hunker down and learn how the mono-browser works. It's not as sad as it sounds. In many ways, the talk is all about the problem domain of browsers with footnotes into the Chromium codebase and not the other way around. Also of note, it's a little old, but only so much changes so fast and a lot of the foundation isn't going anywhere fast.

2025-09-12
Lecture Friday: 13 Ways Designers Screw Up Client Presentations

This goes far beyond designers. If you can't sell your work, you're in a dead end career. Full stop. Not just to customers, though that helps, no. The number of developers I know who are stuck in their career because they've never learned to sell their work within the organization is staggering. It's easily one of the two biggest things between senior developers and staff developers (the other being focus). The myth that great work sells itself needs to be seen for just that, a myth. Mike's here to help you with that.

Also, this talk is wonderful. It leans heavily on the old school preaching rhetoric. It's entirely captivating when done right. Once you've sat through this lecture to learn the material, sit through it again and take notes on the style. See what you can incorporate in your own speeches to take them to the next level.

2025-09-10
Writing a Low-Level Sound System — You Can Do It!

We need so much more of this in software development. The practice of just telling people to use some library or other has hurt the field so much. You reinvent the wheel to learn how the wheel works, to improve the wheel, to design a wheel that works bettor for the problem you're actually working on, to apply lessons learned on different problems and cross pollinate innovations. Don't reinvent the wheel is probably the single least self-aware statement in history. The wheel is probably the single most reinvented piece of technology humans have ever used.

In any case, this is an excellent introduction to writing your own sound system. The downside is that every operating system has their own audio system, and the largest ones have nearly half a dozen different audio systems each. The one thing the libraries can do for you is try to cover over all the different audio systems. The problem is that not knowing how they work under the hood leaves your knowledge hollow. So study up. Write to them directly. Learn their idiosyncrasies. There's great insights on trade-offs in there.

2025-09-05
Lecture Friday: Programming Vehicles in Games

By vehicle he means car, but the idea that there's limits to how much you can simulate in realtime for a game is absolutely true. Love that he shares a great base model for a vehicle though. A fantastic resource for anyone starting on a car in games. You'll have to play around with the feel until you get something better for your game, but a good starting point to understand the basics none the less.

There's also a webpage version for quick reference.

2025-09-03
Use One Big Server

Sadly, nobody gets fired for choosing IBM AWS.

2025-08-31
Resolving the Great Undo-Redo Quandary

While editing, you undo a bunch of stuff to copy a previous version forward for editing but accidentally type a letter and loose everything. Pain. Sadness. Regret.

How can we solve this as a programmer? As the user goes through undo, you're maintaining a redo buffer anyway (assuming you're using state delta transforms). If they edit anything in the past, just first append the redo buffer to the undo buffer, then apply the change and clear the redo buffer. Now they can undo the accidental change and keep undoing all the way back to the future. Easy!

2025-08-29
Lecture Friday: Designing Dope Distributed Systems for Outer Space with High-Fidelity Simulation

Strange Loop truly was an amazing conference. All the talks there are worth your time. This one is no different.

He's right by the way, this is so sci-fi. Like this is some seriously good software development that's set to make a significant difference and you're what? Optimizing ad placement? I mean, hopefully not, but maybe evaluate if what you're doing is a net positive on society.

Anyway, thoughts. For a long time I've been frustrated at the frankly awful state of quality assurance in software development. Fuzzing is the only testing I really consider as testing at this point. The simulator here often reminded me of Jepsen, since the sensor simulator here is essentially able to sweep through all sorts of scenarios looking for edge cases and issues. Not just crashes, but all sorts of anomalies that go on to affect the entire system over time. Memory leaks, floating point rounding errors, various forms of resource exhaustion.

You may say, what about test driven development? I'll refer you to An External Replication on the Effects of Test-driven Development Using a Multi-site Blind Analysis Approach.

Well why is fuzzing better? Please see The Relevance of Classic Fuzz Testing: Have We Solved This One?.

Why don't developers just do that then? Well, it takes more time and effort and a desire to do a great job instead of check the box. Table driven unit tests that assert add(2, 2) == 4 using a swath of mocks do occasionally find some issues so you can convince yourself it's "good enough." Doing it robustly of course costs more time and money. That in turn means teams under pressure have to systematically pick between building product or building tests. Product building wins because given the conflict, companies only really care about quality in so far as the market forces them to. It's why most developers I've talked to just let AI write tests for their code now. I haven't seen a study yet on this, but I wouldn't be surprised if the results show teams doing this have higher post release fault rates than the status quo (though I could be wrong).

Simultaneously, the only metric people seem to think about when trying to enforce quality by policy (and not culture or incentives) is code coverage, which has two problems. First, code coverage is great at identifying likely problematic code. Code without tests statistically has a high chance of containing bugs (I remember reading something like 70% from one study I can't seem to find anymore). However, if code does have tests, the paper found it was basically no better than random chance as to whether or not it still had bugs. The specific numbers likely vary a bunch between codebases and teams, but the general problem persists. A policy of increasing code coverage may find some bugs, but is more likely (given the time pressures) to create a bunch of mediocre tests that losses the statistical power code coverage actually provides.

So now we get fuzzing for databases (because Kyle Kingsbury has made a career of taking distributed systems defects personally) and spaceships (because people hold public servants to mountainous standards), but you generally skip it for airplanes, security systems, and accounting software. You could spend a lot to have a high quality product, but it turns out people will buy the thing almost regardless of quality if you get the market capture and hostile interoperability right.

2025-08-28
How Not To Sort By Average Rating

Just use the lower bound of the Wilson score confidence interval for a Bernoulli parameter. I'll be honest, I didn't think of that one myself. Definitely something worth knowing about though.

And no, don't get me started on recsys. You almost certainly don't need one unless you're working for your CV instead of your users.

2025-08-27
Reservoir Sampling

I somehow find myself using Vitter's Algorithm constantly! That's the one the Wikipedia article refers to as "Algorithm R".

Here's a question, what's the fastest way to pick a random line from a really long file?

for line in file: if rand() < 1/++n: samp = line then print(samp).

Reservoir sampling is the magic of picking some fixed size set of items uniformly randomly from an unknown number of items in a single pass. It essentially scales the swap randomness by how many items you've gone through such that it's perfectly equal to the random frequency they would have had if you'd known the number of items you were sampling from to begin with.

2025-08-26
GCRA: Leaky Buckets Without the Buckets

Another algorithm worth knowing. You don't want a leaky bucket, you really want this. Much simpler to manage, code, and use.

2025-08-25
Fix Your Timestep!

Really insightful piece about switching from trying to update the physics using time steps equal to the frame delay (what I normally do) and instead switch to using fixed deltas to integrate under the variable frame rate. Great insight! I'm sure anyone doing physics over the network already knows this, but it was novel for me.

I'd always run into that problem where minimizing the application can cause minutes of frame delay until it's back on screen. I usually just drop the step if it's too big (i.e. pause). They even do that in their final algorithm. One thing I had to play with a bit was the lerp they did using the sub-delta. I worried they had an off by one error but no, they run the accumulator passed the end of the frame time properly. The only artifact is that the first frame has a non-uniform delta. This probably doesn't matter for just about every case, but is a bit interesting.

2025-08-24
How to not build the Torment Nexus

A long time ago, I decided not to build the Torment Nexus as best I could. It is still possible. It's not perfect. The pickings are slim, and you'll be surrounded by people who are indifferent to suffering. They'd be more than happy to start working on the Torment Nexus if it meant making a few extra bucks. However, there are some software companies out there that are still trying to build things that help society. I'll promise you this though, they won't be a massive company with high pay. You get those by squeezing society for everything you can.

2025-08-22
Lecture Friday: This Problem Changes Your Perspective On Game Dev

The early part is just a classic solution to the explore/exploit problem of optimization. This is just multi-armed bandits for humans.

One piece of knowledge to add is that the local minimum described is not actually a problem in high dimensional spaces (like the set of all possible games that could ever be created). The real problem becomes saddle points because it's usually that a few dimensions enter conflict while others are still free to roam but uninteresting in the current state. While the random jumps do help escape the saddle, one of the keys is focusing on something you're not focusing on. Try to move in a random direction by, say, introducing a new constraint or adding a feature from a completely different genre and seeing what happens. In a sense, add a brand new dimension you weren't paying attention to that will pull you in some direction and then see if you found a new path to a great game even if you get rid of the change that finally figured out what's better overall.

I also really enjoyed the bit about having people who are building different prototypes switch prototypes when each thinks they have something interesting. Get them each invested in the other idea instead of just designing their own. Fantastic idea. Way better than try and compromise or do both.

Overall, the boat metaphor makes a great way to remember all these points. Also, notice that absolutely none of this is limited to games. This is all about designing things with a coat of gamedev paint.

2025-08-18
True Stuff: Socrates vs. the Written Word

I often bring up this bit of Plato whenever someone shouts about kids on lawns. Great to know about in case someone starts droning on about the world they were born into being the only way things could possibly work.

2025-08-15
Lecture Friday: Juice It Or Lose It

Great talk showing a bunch of simple techniques you can use to take a video game up a level. But be careful with all these visual effects. It can become overwhelming for some people so it's always great if you can turn off unnecessary motion and flashing in the settings. Otherwise, great piece to quickly run through a number of the best little tricks.

2025-08-14
Metacrap: Putting the Torch to Seven Straw-men of the Meta-utopia

If you fell for or keep falling for ontology projects, semantic web, unified type systems, or other grand global metadata projects, this one's for you. Get ready to understand why it is, without a doubt, doomed to utterly fail from the start. Why there are very real systemic forces that will guarantee any large project on such a journey will end in ruin.

2025-08-13
Reflections on Trusting Trust

An absolute classic paper. Well worth the read. The essential concept is that a self hosted compiler (one that compiles itself from source code) is a system responsible for its own authenticity. You could add a backdoor to a build of the compiler that injects that backdoor when it compiles the compiler. The source code wouldn't need to contain that functionality going forward and nobody's reverse engineering the compiler to look for it. It could sit undetected. Seem too far fetched? Well, it kind of happened in LLVM.

2025-08-12
Testing Theories of American Politics: Elites, Interest Groups, and Average Citizens

Economic elites and organized groups representing business interests have substantial independent impacts on U.S. government policy, while average citizens and mass-based interest groups have little or no independent influence.

2025-08-01
Friday Lecture: Rust and Other Interesting Things

The Rust is fine, but the framework for thinking about software project values is fantastic. Love applying this every time I work on a system to solidify what matters, in what order, and thus better make trade-offs in the overall design. Also, shout out to OpenBSD!

2025-07-30
The Teensy Files

Really cool work creating the smallest ELF headers for a Linux binary.

There's also a recorded talk by the author explaining it all in a fun and succinct way.

2025-07-29
Replication of Quantum Factorisation Records with an 8-bit Home Computer, an Abacus, and a Dog

Oh, wow. Somebody call the coroner. It's not even smoke, it's just hot air.

I still like the idea of adding an extra post-quantum crypto routine into protocols like Signal did for applications where the extra compute is offset by long term privacy concerns of the data. Even still, given the likelihood that it's just more p-hacking, I'm definitely more worried about anyone even thinking of moving off of battle tested cryptography for post-quantum at this point.

Flip side, I definitely like the suggestion of some non-trivial primes for people to factor to better demonstrate the capabilities of these machines. Reminds me of a great paper I read, The quest to replace passwords: a framework for comparative evaluation of Web authentication schemes. Watching later papers start to use that framework for their password alternative research really seemed to slow down how often papers would invent both a solution and evaluation criteria at the same time. Fooling yourself is easy. That's why it helps to have others create the tests you aim to pass.

2025-07-28
Honey, AI Capex is Eating the Economy

If you expect a bubble pop, you should position yourself to take advantage of the implosion. I wonder what will be left to salvage. What can you do with hundreds of mostly empty data centers and going out of business priced floating point compute modules to repurpose for small scale operations? There will be a lot of spare power in the short run since many of these projects are bringing online significant energy capacity. Food for thought.

2025-07-25
Lecture Friday: Larry McEnerney analyses the Gettysburg Address

Another great lecture about writing, and in this case, speech writing, by Larry McEnerney.

2025-07-24
NIH Is Far Cheaper Than The Wrong Dependency

So much this. I've been banging my head against a wall explaining to developers that adding random things from the internet to production code is not a good long term plan for so long my mind is starting to mush.

I love calling this methodology Skyrim Driven Development after the sprawling modding scene for that game. Hundreds of thousands of mods, mostly compatible but with all sorts of weird edge cases, poor coding practices, and shoddy support. All that in an ecosystem where most people just blindly download and patch them into their game without any thought to the consequences.

Oh, is there an new pre-alpha framework written by an eager high school student in their parent's basement? Better use it to rewrite the mission critical system for the multimillion dollar business that's employing you.

Did installing something based entirely on the advice of Stack Overflow or an LLM cause problems? Just try adding and removing things randomly until it works again. Better chmod 777 * just in case.

Look this one says it improves things you didn't even know needed improving. Into the soup it goes.

Oh great, they changed the deal and now I need to pay for continued support. I mean, good on them for making money for their hard work, but damn the people at my company who signed us up for this.

Granted, your own developers building all sorts of action at a distance, implicit execution magic by themselves into the product is also hideously problematic. But at least all that code's in your control. You don't have to hope someone somewhere will keep working on it for free for you forever. Or constantly spend time fixing things some random person on the internet did to break your build for the third time this month.

Again, not all dependencies are bad. It's just that everything in engineering has trade-offs. There are ups and downs, and you must weigh them properly to make good products.

2025-07-22
Why Do Tree-based Models Still Outperform Deep Learning On Tabular Data?

At one point, "just use XGBoost", became a bit of a meme in the machine learning community. Now it's all LLM or bust, no matter how trivial the problem. I even had someone explain recently how they were using them to do binary classification…

All that waste kind of makes you wish people would just go back to spamming XGBoost. You'd likely get better results to boot.

2025-07-18
Lecture Friday: Introduction to Git

This is some great slow burn satire. Well worth the watch.

I know we all just accept it, but he's on point. Everyone just gets used to git through brute force memorization and aliases. The data structure can be learned, but it only somewhat helps. Fundamentally should you switch, or checkout, or branch, or merge, or rebase, or reset, or restore, or revert, or rerere, or like… what are we even doing? Most people toss like ten words into documenting their commits. Most times I ignore the commit messages because they contain almost no useful information and instead just look at the diff anyway. Some people write good stuff, but if it's 99% pointless, you learn to ignore it. So why are we even writing it? Git says you must. So we toss git a couple words and move on.

If you take a few minutes and try and look dispassionately at the situation, there's definitely room for improvement here but it's popular because it's subject to the collective action problem. Everyone has to use git because everyone else has to use it. I'd say it has about the same usability as GPG. Consider that PGP is dead and everyone just uses WhatsApp or Signal. There's always room for improvement.

Maybe GOT's on the right track? Try and reuse the protocols and data formats so power users can keep using git but fundamentally keep the complexity on the inside and just let it all fade into obscure details of an otherwise simple and easy to use workflow. We'll have to see. Until someone builds a path out of this, at least we can sit back and laugh.

2025-07-13
The Illusion of Thinking: Understanding the Strengths and Limitations of Reasoning Models via the Lens of Problem Complexity

This caused a huge splash so you may have already read it. I think it's generally full of excellent insights. There's been a lot of these types of papers experimenting on LLMs to really dissect them and try and understand how they work scientifically.

I am by no means going to claim to understand LLMs emergent behaviour. However, one thing I'm starting to consider is that this may just be what a type of lossy text compression looks like. I'll probably end up posting the keynote at some point, but I remember John Carmack once saying something to the effect of, "Procedural generation is just glorified compression." When you look at procedural generation from the perspective of a decompresser, they look very similar.

Think of it this way, a compressor is a program that takes some input and creates a different program which, when run through an interpreter (the decompresser), yields a result with desired properties mimicking the original data. That last bit may sound weird, but only if you focus on lossless compression. Lossy compression is where it really starts getting interesting. Lossless has a fairly high lower bound. Lossy, now that's an area where we get subjective and weird.

For example, keep dialing down the quality on the compression. When you do, you start to get less faithful artifacts, things that are derived from the original, that in some way bear statistical relation to the original, but who's form after decompression starts to take on a character of their own. Now imagine that an artist is working on the decompresser so that these artifacts are actually somewhat pleasing and desirable instead of the more typical ugly compression artifacts.

That in mind, doesn't procedural generation sound a lot like substituting the compressor for a human? They take a bunch of input data to craft a program which, when executed, yields a result with desired properties mimicking the original data. Like a level generator, the human is removing all the redundant level geometries and instead creating a statistical model that encodes all this redundant information. Now instead of decompressing to get all possible geometries at once, you instead sample, and decompress only part of the space.

With that in mind, LLMs start to sound an awful lot like a compression algorithm. You generate a large model who's data consists of all this statistical similarity from the original, and in the output you sample the space starting at a point (the prompt) and expand to generate a position in the space of all compressed inputs.

That would explain why they have problems counting the number of "R"s in strawberry or solving the Tower of Hanoi. Nobody's written the solutions in the mountains of input data. Why can they now count the number of letters? The companies behind these are doing all sorts of synthetic input data generation. Farms of people creating questions for answers Jeopardy style. Writing programs to procedurally generate more training data helps bulk out the relatively limited human generated work and add examples of things humans haven't bothered to publish.

This doesn't fully account for everything these models seem to be able to do, but the research on these models also seems somewhat limited still. Science is a very slow process of trying to constantly falsify information. It's trivial to declare them god or slight of hand, but it takes time to exhaustively search for a way they can't possibly be and then conclude that you've searched long and hard enough that it's unlikely they aren't. But you also keep an eye out for anyone who can figure out a way to show they aren't, just in case.

Regardless of what my understanding seems to suggest, my thanks to the researchers here for spending the time to better understand what's going on and give us some great insights into this emergent system.

2025-07-11
Lecture Friday: Burning Down the House: Carbon Politics, American Power, and the Almighty Dollar

More understanding for the seemingly sudden shifts and what they could mean. Mark Blyth has had a few works that seem to be slightly ahead of the mainstream, so I tend to really pay attention to what he's thinking about and why he thinks these things matter. Anyone telling you what's in store is very likely to get specifics wrong, but general trajectories are often easier to get right and prep for even if they turn out to not matter.

Also, this is probably one of the first question and answer periods for a talk that had any value what so ever. Some people in the audience there really trying to better understand these ideas and play with them together through dialogue. Not just grandstanding or asking about irrelevant things the person in the audience knows about.

I love when you couple this with the video friendlyjordies did about how Australia, having reelected their Labor government, is now perfectly set to do what America couldn't. Australia has Future Made in Australia, which has a lot of the same investment public-private partnerships the now abandoned IRA had. With the end of one, billions, if not trillions in private investment are potentially up for grabs. If not Canada, at least our sister state has a shot at the prize.

2025-07-10
You Can Choose Tools That Make You Happy

I maintain a website that I've built entirely by hand, being read by basically nobody, for no other reason than the joy it brings me and maybe the vein hope I can inspire someone to see what I see, or at the very least, consider reconsidering.

That said, yeah, get weird. Never fool yourself, you're the easiest to fool, but also never give in and never give up. As Bernard Shaw wrote, The reasonable man adapts himself to the world: the unreasonable one persists in trying to adapt the world to himself. Therefore all progress depends on the unreasonable man.

Nobody would have created many of the incredibly cool things we have if they'd stuck to what was easy and what already worked. They thought they saw what could work better and went for it. Many failed, some were right, a few even paid a high price for their dream. Most of the things around you are mealy an accident of history and incredibly hard work, not some divine truth. Reinvent things now and again for no other reason than you can. Do unconventional things for unconventional outcomes. To see what's possible, and to see if you really can make things better. Build your dreams, and maybe change the world. Probably not, but the avalanche starts with a single snowflake.

2025-07-09
Wikipedia: Norman Borlaug

Another one of those people I brought up in a conversation that I think more people should know about. There may not be anyone less well known who's had as big an impact as Norman Borlaug. If you're alive today, that's partly the fault of Norman Borlaug. Truly one of the greats.

2025-07-08
A Non-anthropomorphized View of LLMs

Less a learning and more a plea. It's so cringe listening to people talk about statistics like they're omnipotent, going to wipe out all life on earth, or obsolete the terrain for a map. Conversations become much more productive when sophists stop trying to bear witness to the next coming in the output of gradient descent. It's just a tool. It's not magic. Yes, this has significantly surpassed the state-of-the-art NLP models of just a few years ago. No, you shouldn't be using it in lieu of actually learning how statistics work and then picking the right model for the job.

As someone who's been using computational statistics and machine learning for about a decade, I'd years ago written off large parts of the literature as mostly non-replicable p-hacking by people running the software equivalent of the egg-drop experiment. So many "advances" boil down to either moving the goal post by making up a benchmark you're conveniently the best at, overfitting a model and declaring it state-of-the-art, Frankensteining an ensemble for a one percent improvement at ten times the cost, or one of a few other shenanigans researchers have been routinely pulling since AlexNet really shook things up.

As it turns out, I was right that Attention Is All You Need was, in fact, game changing. The game I wasn't really paying attention to was BERT, a model so bloated and of such limited utility, I thought it was mostly a joke at the time. Turns out, if you just keep going with the joke, well past reason, until your model begins to use so much energy that it competes with the fossil fuel industry to see who can cook the planet faster, there's some interesting and useful properties to the joke.

Just please stop telling me it's thinking or alive or concious, or any other biological adjective. We still have neither a scientific nor philosophical understanding of what thinking even is. It's just statistically likely unstructured data. Is it useful? Yeah, in some applications. Is it reliable? It's reliable enough for some applications. Is it efficient? Mostly no, but some applications don't yet seem to have efficient alternatives. Using it for those we do, seems pretty foolish given the situation.

Just try and stop it with the pareidolia.

2025-07-05
Handles Are The Better Pointers

Great breakdown on how to handle memory without uncontrolled malloc()/new everywhere. Instead, create a manager for a subsystem that has its own memory pool. It can then use array indices (either on the pool or a lookup structure) which it issues and accepts through its API.

I'd heard about the technique before elsewhere but this breaks it down and gives some great examples. You've already been doing this with files, windows, and other resources the operating system provides you, so you may even understand the idea intuitively. Either way, a great piece on the technique.

2025-07-04
Linux Is Dead, Long-Live Docker Monoculture

I'm the type of person to go listen to a live symphony orchestra once every few years. I went to a performance of a famous classic symphony that was preceded by the premier of a brand new symphony. A brand new symphony, delightful, and all I could think while listening was, oh, it's just a movie score.

When the only work for composers is scoring movies, new symphonies are going to sound a lot like movie scores.

When the only work for developers is SaaS, software's going to all start to look like web shit.

So now the Windows start menu is written in React, otherwise promising image viewers require setting up a database and docker, and developers expect you to install their applications by intentionally opening yourself to remote code execution.

Unless a market and/or business model is soon found to bring about a renascence of desktop application development, I'm finding I have to agree with Casey Muratori that gaming really will become the Irish Monasteries of software development.

2025-07-02
You MUST listen to RFC 2119

This is pretty funny. I love when someone pays an artist just to bring something fun into the world. I do it now and again but we can always use more of that.

Art and fun aside, if you don't know RFC 2199, now's your chance to learn one of the most influential RFCs ever written.

Already know that one by heart? Do you know about the related RFC 6919?

If you already know both of those, well then perhaps I could interest you in RFC 3339, what people usually mean when they say ISO 8601.

I could go on, but I won't.

2025-06-27
Lecture Friday: Making Impossible States Impossible

Not going to use Elm, nor do I condone trying to treat your type system as a formal specification language. However, there are a lot of data structures I often see that have all sorts of invalid states available. Mostly places where two or more pieces of data have to agree on a value or state. Structures that are begging for some incorrect logic to corrupt things and cause unhandled edge cases.

In almost every case, very simple changes to the structure of the data could completely eliminate the problems. If your familiar with normal forms, this will feel super familiar to you. Relational algebra transcends SQL databases because it started as math, and was later ported to a programming language to try and make it easier to approach. If your familiar with Entity Component Systems (ECS) from game engines, you will start to see how it's all interconnected. When you think in normal forms, both your data and logic improve.

2025-06-25
What LLMs Know About Their Users

I liked the analogy someone said a while ago, that LLMs would be able to make all texts interactive. One big body of text is a database. Obviously not an accurate mechanism to query the data, but who really cares about accuracy if you can sidestep those who'd thwart your aims at power?

As developers rushed to build the ultimate surveillance apparatus, we felt safe that at least access to the knowledge trapped in the database required some technical expertise. We the priesthood would be able to guard access to the troves of surveillance only for the aims of a better future. We could intervene and prevent sociopaths using the data to enact their control fantasies.

Turns out people with a lot of power really want to get a list of those who'd dare oppose them. Doesn't really matter how accurate it is. A list only 20% accurate works just as well for the goon squads.

2025-06-17
Geeks, MOPs, and Sociopaths in Subculture Evolution

This essay came up in a chat I was having with some people at work. It's a real depressing take on the topic, but worth a consideration if you've ever wondered why groups of people don't really exist in the real world anymore outside of capital generation.

There's more to it than capitalism fundamentally exploits everything to death as is portrayed in the piece. Sure that's one of the best modes to kill things. It doesn't fully explain why interest groups don't form much anymore though. This is one entry from the work, Meningness. I'm not fully sold on it all, but I think this presents a good picture of what any shared endeavour seems to experience as it grows and dies.

2025-06-13
Spanner: Google's Globally-Distributed Database

Recently had reason to briefly explain how Google Spanner works when I was discussing Amazon Aurora Limitless. I have no idea if Limitless implements the same tech as Spanner, but my guess is it's not entirely unreasonable. Again, I'm not talking about Limitless, I really don't know how it works. But someone was explaining it to me and it just sounded like Spanner.

2025-06-12
The Ultimate Insider Threat: North Korean IT Workers

Worth knowing if you're in the market for a job or hiring. The flip side of these scammers trying to get hired to infect your company with malware is running interviews for devs and having a technical interview involving running malware on your machine. They'll say it's something like a web API server you'll build a frontend against or something like that. They're hoping you use your employer's laptop to do it and either have a bunch of credentials on your machine, or if they're really fancy, they'll wait in the background and see what they can do over the next couple days. Even if it's just your personal laptop, expect to get extorted.

Stay vigilant out there.

2025-05-29
Wikipedia: Henry Dreyfuss

Henry Dreyfuss is responsible for so many of the designs of everyday objects you take for granted. I recently brought him up in a discussion I was having where we lamented the frankly appalling industrial design of many modern versions of things with pointless touchscreens, wireless radios, and impossible to use ergonomics. I humorously joked that Dreyfuss must be rolling in his grave.

2025-05-26
Cheating the Reaper in Go

I've always tried to explain to devs that you can do manual memory management in a garbage collected language. The simplest method is to just start using resource pools. The reason to manually manage memory is to prevent the garbage collector interrupting you randomly. If you have a lot of identical objects you're routinely allocating for a limited amount of time, I suggest you look into them.

Either way, I came across this piece discussing how you can dig deeper in Go if you want to get even more manual control of your memory in a garbage collected language. They show how you can effectively implement an arena allocator.

When would you want an arena allocator? Whenever you have a bunch of work you want to allocate for that has a single conclusion point where you want to delete it all and start again. Instead of randomly pausing and running mark-sweep, you can just set the memory index to zero when the work is done. It's perfect for work loops like web request handlers, scratch space during game update/render loops, and between processing files/records in large batch ETL jobs.

While I like manually controlling memory, I also like being lazy. I like the idea of structuring languages where you can nest manually controlled memory regions within an otherwise GC environment. Allowing you to reach for power tools when appropriate.

2025-05-22
Begging for Bounties and More Info Stealer Logs

Welcome to beg bounties. In our ongoing deterioration into a society predominantly defined by scams and cons, bug bounties are becoming an increasing target of malicious actors. In this case, one group of attackers have created huge pools of people infected with malware. They use that malware to steal login credentials to websites and build massive dossiers, colloquially referred to as stealer logs. These are passed around for pay in private channels for money until it gets shared in a channel with a leak. At that point these collections hit the web.

This is where our new bottom feeders enter the scene. Being essentially talentless and morally bankrupt, they search out these lists and then contact all the sites who have users with computers infected with malware (so basically any site with a big enough user base). When someone shows up with a list of legitimate user credentials for your site, you take notice. How'd they get them? Your worst fear, there's a problem in your site leaking credentials.

The reality is much more benign. They're available through a few well known internet forums. They then try to spin a tale about how you need to pay them thousands of monies for forwarding them to you. Even if one percent of companies react before they think, contact a few thousand companies and you can make bank before it becomes too obvious a scam.

2025-05-16
Lecture Friday: Elements of Programming Style

Loud sound at the 56 minute mark. The fire alarm goes off and it's quite loud because the recording is fairly soft.

I quite like the elements of style discussed here. The style rules presented tend to port fairly well as general concepts to any other language. For example, I now try and order the blocks of my conditionals to put the shorter block at the top, even when it requires negating the conditional as I first think of it.

I'm sure I've picked up a couple other techniques from here and I hope you will too.

2025-05-11
I'm Not Feeling The Async Pressure

Another piece to add to the long running debate on whether or not python's asyncio is worth it. My guess is in 3-5 years it'll become a regrettable complexity in the ecosystem when full lock free threading becomes generally available. Just in time for everyone to have significant investment in red versus blue functions that we can't easily backtrack on.

If language committees could stop adding everything just because it exists in another language C++ style, that would be great. In JavaScript's case, async was a worthwhile problem to add in order to solve the existing problem of having to live inside an event loop outside your control and simultaneously having access to anonymous functions. More specifically that given such a language, developers will instinctively nest lambda callbacks until they're in so deep they're forced to start using single spaces as indentation.

CSP like in Go takes a step forward by not color coding functions, but takes two steps back by having the standard library magically hard code which syscalls are blocking. The more I keep looking at the problem, the more I think I have to agree with Jeff Bonwick and Brian Cantrill who note how userspace multitasking will forever over promise and under deliver. How fundamentally, non-preemptive multitasking leads to an endless series of design problems you don't have if you just let your OS schedule you.

2025-05-02
Lecture Friday: How Much Math Is Knowable?

Great recap of many of the proofs we have about provability.

2025-05-01
Wikipedia: Great Stork Derby

Not the type of thing I usually share, but it kind of sticks with you.

2025-04-30
Rough Idling

Frustration at the state of software being interminably busy doing nothing of value.

2025-04-29
What's in OpenBSD 7.7?

What's in OpenBSD 7.7? Essentially just an AMD GPU driver with a small Unix OS wrapped around it at this point.

I've kind of wondered for a while when the graphics card will just subsume the motherboard like a reverse integrated graphics stack.

2025-04-25
Lecture Friday: Practical Data Oriented Design (DoD)

The thing that takes a bit to understand about Data Oriented Design is how the name implies it should be similar to some sort of code aesthetic like Object Oriented Programming. You go looking for the abstractions and intellectual virtues to structure code around but you never find any. It seems hard to understand because you keep trying to put it alongside philosophies like functional programming, procedural programming, and object oriented programming. The problem is it doesn't fit. You're comparing dogma to empiricism. It's like getting the intellectual tradition of Francis Bacon suddenly injected back into software development after a few decades concerned with moral purity and virtue. Turns out, you can measure things that matter to users and your code comes up wanting because you're not as good a developer as you think you are.

One of the things brought up is how booleans in structs destroy your performance, and how storing out of band works. This is exactly what loops to the bottom, conditionals to the top looks like in practice. Having two lists of monsters, one living, one dead, you move the "is alive" conditional above the loop and improve performance in a few ways. There's now less memory involved, so you get better data cache coherence, but you also remove the branch miss prediction penalties, and gain instruction cache coherence by doing all of one and then all of the other.

2025-04-23
Unstructured Thoughts on the Problems of OSS/FOSS

Great set of thoughts that bounce the problems around open source back and forth. I'm still lost in the quagmire. Can't say this really points the road beyond out. More thoughts on the table may be able to help us discern the way forward.

2025-04-15
Some Surprising Code Execution Sources In Bash

Works on bash and ksh. Zsh isn't impacted. So, it turns out [[ "${num}" -eq 42 ]] allows remote code execution. Yeah, I didn't know that one. For any non-trivial program you really should be using something other than a shell script. My dividing line continues to be arrays. If you need an array to solve the problem in a shell script, you really should be using a different language to solve the problem.

2025-04-14
A New Oral Culture

Interesting thoughts when you think about how it relates to project documentation.

2025-04-14
The Best Programmers I Know

Not much I learned from this one, but always worth sharing things for those getting started.

2025-04-10
🦕 RansomLook 🦖

Added this one to the links page, but you really need to be aware just how bad the problem with ransomware has become. We're talking hundreds of organizations a month.

2025-04-04
How to Report Bugs Effectively

The key to a good bug report is helping them recreate the problem. If you know how to reliably recreate it, a developer can usually fix the problem. So take the time to figure out the simplest way to cause the problem to happen before reporting it.

2025-04-01
13 Things I Would Have Told Myself Before Building An Autorouter

I always love someone rubbing real performance engineering work in the face of developers who think Rust or C++ just magically make your garbage code fast or those who think interpreted languages can't possibly be fast enough. Developer skill continues to be the dominant factor in real world application performance.

2025-03-30
Win32 Is The Only Stable ABI on Linux

This is just sad, but seemingly true. So many people in the POSIX ecosystem just don't take backward compatibility as seriously as you have to, in order to be treated as a platform. I can still run games compiled for Windows in the 90s just fine. Want to back test your website on old versions of Webkit known to exist in many IoT devices? Basically impossible given the state of API churn and system "innovation".

2025-03-27
From False Alarms to Real Threats: Protecting Cryptography Against Quantum

Yeah, there's a lot of hyperventilating about quantum computing. This at least tries to give a mostly realistic picture of where we are, what needs doing before it becomes a reality, and why getting started this early matters. The two principals are that the first group to get Shor's algorithm running at a realistic scale will most likely be sworn to national secrecy. Second, agencies with fat wallets are definitely sucking up and storing data streams likely to have juicy secrets worth the cost of storing for a decade or more.

2025-03-26
Teaching Smart People How to Learn

Colleague at work sent this my way. The 60's to the 90's truly had some great management philosophy and science going on before the dot-com-boom and big tech would come to dominate management discourse by fiat.

2025-03-24
Landrun

I love code sandboxes for services. Any tool that makes setting them up simpler is worth a look in my opinion. Haven't tested this out, but I'm keeping an eye on it.

2025-03-17
The End of US Democracy and the Implications for International Relations

Trying to situate the next few decades in the context of other country's backsliding helps understand what's likely in store. You won't be able to just vote for a reversal of what's likely to come to pass.

2025-03-13
Kings Over the Necessaries of Life

Great report picking apart many of the reasons for the price "shocks" we're seeing.

2025-02-26
Microsoft CEO Admits That AI Is Generating Basically No Value

lol

2025-02-18
How Complex Systems Fail

Classic insights on complex systems.

2025-02-14
CPU Benchmarks - Year on Year Performance

If you still think Moore's Law is going to save you, you're a decade out of date at this point. This marks the first time we've seen performance start to regress. It seems like we're starting to crest the S-curve on performance available on computers. The future is in squeezing the software, not the hardware.

2025-02-12
Dazed & Confused: A Large-Scale Real-World User Study of reCAPTCHAv2

ReCAPTCHA continues to get worse than it already is.

2025-02-11
SoK: Understanding Designs Choices and Pitfalls of Trusted Execution Environments

Trusted Execution Environments continue to be my computing enemy number one. Get your grubby little hands off my system. To that end, know thy enemy.

2025-02-07
Unexpected Benefits of Building Your Own Tools

Another take on why only using off the shelf tools will always struggle to do a fraction of what a set of tools built for purpose can achieve.

2025-02-06
Smooth Paths Using Catmull-Rom Splines

Another great curve worth understanding. While everyone reaches for bezier's first, these are interesting in the context of compressing freehand drawings and adding visually pleasing smoothing.

2025-01-24
Lecture Friday: The Ultimate Guide to JTBD

Colleague sent me Bob Moesta as a reference when we were talking about a few things. I love the 2x2 framework discussed when thinking about why people change products.

2025-01-23
Difference between Spline, B-Spline and Bezier Curves

A great primer on a few useful curves. You can never understand curve functions too deeply if you're working in computer graphics.

2025-01-22
Beware of Metacognitive Laziness: Effects of Generative Artificial Intelligence on Learning Motivation, Processes, and Performance

Worth keeping in mind. I'd love to see a replication and further extensions here to see what sort of effects were likely to see.

2025-01-21
Let's Talk About AI And End-to-End Encryption

Another step towards treating users like cattle instead of pets.

2025-01-09
Mistakes Engineers Make in Large Established Codebases

Another acolyte of Socrates. I like the idea that the ability to work on large legacy codebases is what separates senior developers from junior developers. I mean, it's self serving since I'm someone who works on such code bases. Either way, good food for thought on development.

2025-01-06
That's Not an Abstraction, That's Just a Layer of Indirection

Go look at abstract art. Now look at your abstraction. Well, those don't seem related at all…

They aren't. Your abstraction is just giving things names. Real abstraction moves away from the nature of the thing to be more precise. Relational algebra is an abstraction away from searching tuples of information. JSX is Javascript wearing an HTML skin suit. Knowing the difference is important.

2025-01-03
Why Events Are A Bad Idea (for high-concurrency servers)

Paper showing threads and events are just isomorphisms. They advocate for greater compiler support of threads, which is something I haven't really seen outside of language extensions like Cilk. I'd love to see what more we could do with the compiler to better signal context switching to the system rather than trying to outsmart it from our local point of view as we keep trying with userland threading.

2025-01-02
Python for Lisp Programmers

I've always thought Python was fairly lisp like if lisp was based on dictionaries instead of lists. Sure Python's syntax isn't expressed in terms of dictionaries, but the runtime generally is.

2025-01-01
Wikipedia: Amdahl's Law

It's important to understand that horizontal scalability is also limited. You can't just throw more cores at a problem. There are those tasks that are embarrassingly parallel, but they represent only a subset of interesting computations.