I see this a lot. It's exciting to work on shiny new $x app, and productive, but it's most likely productive because it's new, not because it's $x. The old code base has accumulated complexity that the new one doesn't have.
Let's take an example, if hacker news added a new feature that allowed people to delete their account, then you have to decide what to do:
- do you delete the user's comments?
- if yes, what do you do about people replying to that comment?
- do you delete the user's submissions?
- if yes, what do you do anout people commenting on the thread?
- do you downvote the submission / comments that the user upvoted?
- do you unflag the submission / comments that the user flagged?
- do you keep a copy of their yc applications?
- do you keep their email address along with their karma, so that if they open a new account with the same address, their karma will be restored?
As you can see, adding a single feature means that you have to figure out how it is going to play with all the other features. That's what the author means when he says: that makes the cost of implementing the N+1 feature closer to N than 1.
Another example is how adding a new programming language feature can make every other feature more complicated as you consider how the interactions should work.
This is especially true as you think about how all the tools (formatters, debuggers, etc) should work.
So “free code” tends to be “free as in puppy” rather than “free as in beer”.
This whole topic makes me a little sad, as I thought the improving tools and techniques would vastly increase developer productivity over the many years I've been involved in software development. Instead it appears complexity is winning so far.
I didn't see as much about what is happening on industry wide scales over decades
We still hit some pretty fundamental limits when making a feature-rich product though.
My eyes have been opened. I am enlightened.
"Features interact — intentionally — and that makes the cost of implementing the N+1 feature closer to N than 1."
(When explaining to folks why it takes longer to build something in the CRM than as a standalone app - you realize the standalone just won't work with 10 critical features, right?)
"What I found is that advocates for these new technologies tended to confuse the productivity benefits of working on a small code base (small N essential complexity due to fewer feature interactions and small N cost for features that scale with size of codebase) with the benefits of the new technology itself — efforts using a new technology inherently start small so the benefits get conflated."
This describes like 20% of the articles that make it on hacker news. Or maybe 20% of the ones I read. Might be a personal problem.
"So 'free code' tends to be 'free as in puppy' rather than 'free as in beer'."
Anyone debugging js build chains or trying to fix ng1 performance after you get out of the toy app stage can probably relate.
"Bill wanted (still wants) a breakthrough in how we build rich productivity apps. He expected that the shape of that breakthrough would be to build a highly functional component that would serve as the core engine for all the applications. For a time he believed that Trident (the core engine for Internet Explorer) could become that component. That model leads you to invest in building a more and more functional component that represents more and more of the overall application (and therefore results in more of the cost of building each application being shared across all applications).
This view that I have described here of increasing feature interaction causing increasing essential complexity leads to the conclusion that such a component would end up suffering from the union of all the complexity and constraints of the masters it needs to serve. Ultimately it collapses of its own weight. The alternate strategy is to emphasize isolating complexity, creating simpler functional components, and extracting and refactoring sharable components on an ongoing basis."
It is super common to see people want to do Big Framework Up Front design for applications, and then find out that the framework makes things slower for the primary use case than the old, "crappy" way, aside from the cost/opportunity cost of spending all that time on a framework instead of business value. I guess it makes me feel a little better than Bill Gates also suffers from that delusion.
I just spend several days trying to build a deb package for a opensource native C project (fontforge).
It was no walk in the park either.
Anyone know of good places to find other similar high quality content about software development? I really appreciate when experts are able to effectively communicate the most important pieces of their painstakingly acquired mental models of complex topics.
Is this not essentially what electron is?
"The battle we are fighting is over who controls the next generation applications and system architecture, APIs and services" Shirish Nadkarni 1991
"Bill wanted (still wants) a breakthrough in how we build rich productivity apps. He expected that the shape of that breakthrough would be to build a highly functional component that would serve as the core engine for all the applications. For a time he believed that Trident (the core engine for Internet Explorer) could become that component."
So we should all code in machine code? Perhaps what this shows is that all languages are very similar. Haskell, clojure, java, C#, C++, Rust, C etc they all are statement or expression oriented and data structure oriented. So, until I see languages that explore the rules/constraints and relations(similar to "out of the pit tar") I will remain unconvinced of this "all languages are the same" because assembly certainly isn't the same as java.
I couldn't agree more.
(Which doesn't mean I didn't like or don't agree with the article.)
> Google Apps have been announcing some variant of offline editing for almost 8 years now and it is still semi-functional. The other “real soon now” promise is “better compatibility with Office”. This has the flavor of the laundry detergent claims of “now with blue crystals”! The claim of “better” is hard to argue with but history would seem to indicate they are not getting any closer to actually being compatible, especially as Office continues to evolve
It's a bit difficult when they're on purpose embracing complexity and cost of the current format, and keeping it closed source. The fact that Google is able to achieve its own network effects with a different format should actually encourage Google to not support Office, ever.
For us, users, we should ensure Google docs stays compatible with open format like ".odt"
For example, once upon a time screws were made however anyone wished to make them (and railways were whatever width the company wished.)
"In 1918 Congress passed a law establishing an organization called the National Screw Thread Commission, with the goal of ascertaining consistent standards for screws. The goal of this effort, which you might guess given the timing of the law's passage, is military-related: As you might guess, the military uses a lot of screws, and inconsistencies were apparently bad enough after World War I that Congress had to do something about it.
John Q. Tilson, a Connecticut congressman, argued that the measure was necessary due to the problems a lack of consistent screw thread were creating. He also made the case for businesses—who he argues also will benefit from screw compatibility."