Skip to content

Perlis Thompson Principle

andychu edited this page Aug 7, 2021 · 94 revisions

UNDER CONSTRUCTION

The Perlis-Thompson Principle is an idea in software architecture. It's arguably the most important one, because it explains the evolution and scaling of the largest and longest-lived software systems, like Unix and the Web. It also suggests where they fall short.

I wrote 4 blog posts that mention it, starting in July 2021, but the series isn't done yet:

Definitions

Here's a literal translation of what Perlis and Thompson said:

Write software where everything is an X (e.g. a string, pointer, cons cell, table, vector, window, etc.)

They say to use a single data structure, or single notion. However I think that is too absolute, and there are caveats.

Here's a revised, short definition of the principle:

Software with fewer concepts composes, scales, and evolves more easily.

Here's a long definition:

Consider using fewer concepts, data structures, and types in foundational software like programming languages and operating systems.

This style allows for more composition and ad hoc reuse. It scales in multiple dimensions. It evolves gracefully (and messily) over decades.

When introducing a new concept, define a way to reduce it to an existing concept.

Key Concepts / Terms / Slogans

  • "Everything is an X"
  • Writing O(M + N) code instead of O(M * N). Huge difference!
  • Coding the Perimeter vs. Coding the Area (from the Unix vs. Google video)

The "Narrow Waist": A Special Case of the Perlis-Thompson Principle

What Is it? What are other names for it?

It relates to data structures, interchange formats, and network protocols. But not "concepts" or "notions" in general, like Unix processes.

It's also known as:

Prominent Examples of Narrow Waists

This idea spans operating systems, networking, and programming languages.

  • TCP/IP is a narrow waist between physical issues like wired/wireless and application protocols like the web, e-mail, IRC, Usenet, etc.
    • The narrow waist of the Internet has arguably moved to HTTP over time, with e-mail, chat, Usenet-style discussions all migrating to web apps
  • An operating system API like POSIX is a narrow waist between applications and hardware
  • LLVM is a narrow waist between programming languages and computer architectures
  • Pandoc is a narrow waist between document formats. Instead of writing O(N^2) document converters, you design an IR, and write N translators to the IR, and N translators from* the IR.
  • Byte streams / Unix-style text are a narrow waist between storage/networking abstractions and application-specific schemas
  • SQL is a Narrow Waist (Jamie Brandon)

What Isn't a Narrow Waist?

Just to show the the concept isn't vacuous:

  • MS Word files or Excel spreadsheets. These formats are too complicated, to the point that they're tied to specific applications. A CSV file is a (bad) narrow waist -- you export it from Excel so you can read it into other applications.
  • JPEG. It's optimized for small size and display. To support other operations, like various kinds of editing, it's converted to a format that's easier to work with.

Textbook References (TODO)

  • TODO: There should be a networking textbook that talks about narrow waists / hourglass
  • TODO: There should also be a compiler textbook. I know I've seen a diagram of IRs as a waist between programming languages and CPU architectures.

Not sure about OS textbooks, but the concept definitely applies there too.

Links on Narrow Waists

  • HTTP: An Evolvable Narrow Waist For a Future Internet (PDF, 2010). This and Van Jacobsen's Named Data Networking introduced me to the concept of a narrow waist. (Even though it's in both networking and compiler textbooks.)
  • My HN Comment on the Kubernetes-Multics analogy (2021): I trace the narrow waist to Kleinrock via Brewer, but there might be a more original reference
  • Unix vs. Google (2016): a video by Kevin Greer. Has visualizations of Unix vs. Multics: coding the area vs. coding the perimeter. O(M * N) problems.
  • Always Bet on Text (Graydon Hoare, 2014). 196 HN Comments.
    • Text is everything. My thoughts on this are quite absolute: text is the most powerful, useful, effective communication technology ever, period.
    • It can be indexed and searched efficiently, even by hand. It can be translated. It can be produced and consumed at variable speeds. It is asynchronous. It can be compared, diffed, clustered, corrected, summarized and filtered algorithmically. It permits multiparty editing.
    • This is a restatement of what Perlis said: It's better to have 100 functions on 1 data structure than 10 functions and 10 data structures.

The Networking Community Explicitly Thinks In Terms of the Narrow Waist / Hourglass

It doesn't appear that the operating systems community does! And definitely not the "cloud" operating system vendors.

Links on The Perlis-Thompson Principle in General

Common threads here: either "everything is an X", or explicit nonlinear codebase scaling problems -- O(M * N) or O(N^2).

I've been thinking about this for a long time!

Counterpoints / Fallacies

The Perlis-Thompson Principle goes against the intuition of many programmers. They are weighing the tradeoffs from a code perspective, not a systems perspective. Those perspectives can lead to opposite conclusions.

  • A Case Against Text Protocols (2020). My "Unix text as a narrow waist" comment argues against a common misunderstanding. Text is the reason we have good tools. As an example, it doesn't make sense to make an WASM editor and WASM version control system. Instead the binary WASM format is projected on to text, and we use text editors and SCMs like git.
  • On the Missed Opportunities of Static Types (2021). There is a tradeoff: more types give you some easy safety checks, but can inhibit composition!
  • FFI Fallacy on the Vale Programming Language (2020)
    • People who advocate "standardized" RPC systems are often attached to a similar fallacy.
    • A function in C is not a function in Python is not a function in Rust. You need a lowest common denominator, or you require O(N^2) glue. I remember someone actually writing to write a specific R-Java bridge rather than using IPC.
  • Programmer's Critique of Missing Structure of Operating Systems (2020). A long article lamenting the repetitiveness of parsing a plethora of data formats. It's reaching toward ideas like a single-level store.
    • My response: This could be done in an "application framework". The problem is nobody can agree on the lowest common denominator. There's no reason to think that putting more code in the kernel will solve this problem.
    • An operating system has two "sides": one part faces the hardware, and one part faces applications. He wants the OS to do more work for applications. I think a tighter goal for the operating system is to proivde a minimal abstraction to virtualize and share hardware, while providing safety and isolation. It should make applications "possible"; making applications "easy" and factoring into shared libraries is a separate job.
  • Shells Should Shell Out (2021). I question the two-tiered design of PowerShell, Elvish, and nushell. cmdlets aren't processes. They need semantic rules to convert between internal and external representations.
    • Argument: The lowest common denominator between a PowerShell script and an Elvish script is a Bourne shell script :) Byte streams are the lowest common denominator.

Related

Clone this wiki locally