Settings

Theme

Show HN: Conway's Game of Life in TypeScript's type system

github.com

186 points by candleknight 2 years ago · 47 comments · 1 min read

Reader

TypeScript playground: https://www.typescriptlang.org/play?#code/KYDwDg9gTgLgBDAnmY...

dag11 2 years ago

In the typescript playground, the best way to see the output of any evolution number is to have it autocomplete a string literal!

Uncomment one of the PGunXX types that you want to see, then below it type this:

    const boardstr: PGun10 = ``;

Then put the cursor inside the two backticks and press Control+Space for intellisense autocomplete, and press enter on the first entry there. Then intellisense will put the computed board into a string literal, looking like:

    const boardstr: PGun10 = `............................................
    ........................xx..................
    ........................x..x................
    ..........x.x...............x......xx.......
    ........x...x..xxx..........x......xx.......
    .xx.....x...................x...............
    .xx....x....x.......xx..x..x................
    ........x.......x.x..x..xx..................
    ........x...x.....xxx.......................
    ..........x.x...............................
    ............................................`;
vishnumenon 2 years ago

Love it! Reminds me of the hilarious "Typing the technical interview" [1] and "Typescripting the technical interview" [2], a couple of my favorite blog posts of all time.

[0] https://aphyr.com/posts/342-typing-the-technical-interview

[1] https://www.richard-towers.com/2023/03/11/typescripting-the-...

hbn 2 years ago

Sometimes I think I don't understand TypeScript's type system and then I see something like this and I realize I know even less than I thought

  • awesomeMilou 2 years ago

    Any sufficiently capable type system will make it possible to implement a form of functional programming.

    These advanced type systems are essentially a form of pre-compile time scripting to assert certain guarantees about user defined types. It's the same mechanism that makes C++ templates turing complete.

  • bazoom42 2 years ago

    Typescript has conditional types, which means it can be used as a programming language itself. In theory you can write any arbitrary program - game of life is just an example. You have to define numbers and arithmetics from scratch though, so it is not very practical.

    Conditional types are probably rarely used in practial code, but it opens the door for a lot of geekery.

kiechu 2 years ago

It is year 2035. TypeScript type system gained conscious.

jhirshman 2 years ago

Nice work, Ruyi! You've definitely taken typescript mastery to a new level. It was great to have you intern with us.

If anyone else is interested in an internship or full-time position in typescript: https://www.uncountable.com/hiring/hn

heroku 2 years ago

Stop overcalculating a mess out of junk, learn Rust and see what a Typesystem should and shouldn't have to do.

brundolf 2 years ago

Cute :)

Any sufficiently advanced type system is indistinguishable from an interpreter!

calebegg 2 years ago

How do I run this/see the results? I'm a little lost.

  • aazo11 2 years ago

    Same here. I hit "run" but get an error

    • _jab 2 years ago

      Because it's all just types, there's nothing _to_ run. Instead, you'll want to hover your cursor over the `PGunX` types at the end of the file in the playground; this will cause the TS editor to compute that type and it should display a string corresponding to the board state.

brap 2 years ago

At this point, TypeScript should just let us define types using plain imperative TS code that will execute during static analysis. Might as well.

type MyType<T> = someFunc(T)

Of course these functions might be typed too…

  • phpnode 2 years ago

    this is exactly what I want from the Types as Comments proposal[0] as I think it's the only way that types can feasibly become part of the language. It's hard to imagine how all of the concepts TS introduces via special syntax can be covered otherwise.

    [0] https://tc39.es/proposal-type-annotations

    • brap 2 years ago

      I mean this seems like a nice proposal, but I guess I’m missing something, how does it relate to my comment?

      • phpnode 2 years ago

        That proposal aims to allow type annotations as part of JS, but to do that the parser needs to know when a type annotation starts (easy) and ends (hard), the only realistic ways that can be done at the moment is explicitly supporting all of the syntax TS introduces (which is bad for other type checkers) or restricting to a limited subset which would mean a lot of what TS supports would not be allowed, negating the usefulness of the proposal.

        What I'm saying is that if instead we said that all type annotations must follow existing JS grammar rules, with perhaps a couple of small additions, then we'd be able to support all sorts of complex type annotations in JS directly, using existing syntax. This would mean that TS's grammar would end up changing a bit, but that's a small price to pay for ongoing interoperability.

        For example, instead of

            type UserProperties = keyof typeof User;
        
        which is tied to TS's arbitrary syntax, and not supported in Flow, use

            type UserProperties = keyOf(typeOf(User));
    • quickthrower2 2 years ago

      That is a great idea. It also crystalizes the syntax so organisations other than MS can invest in building tooling as the target wont be as fast moving.

  • bafe 2 years ago

    I recently had the insight- surely induced by reading something on HN or listening to some podcast- that types are simply functions from the set of all possible "values" to a logical value...

    • brap 2 years ago

      Yeah, a type is really just a set (in the mathematical sense). And a set can be defined by a function to {0, 1}. I don’t know if this function has a formal name, byt you can think of it as a “is this value a member of the set?” function.

nimos 2 years ago

Ha! More performant than I'd have guessed. I tried commenting `PrintBoard<EvolveN<GosperGliderGun, 100>>` in and out and it took about 3 seconds (in the ts playground).

JoeAltmaier 2 years ago

SO many ways.

In college I did it in assembler (a couple hundred bytes of code) on a PDP11/34 and displayed the results on an oscilloscope screen :)

koolala 2 years ago

It can do a Y Combinator with types can't it?

maxbendick 2 years ago

I'm happy to see people learning the Curry–Howard isomorphism the fun way.

dmalvarado 2 years ago

I though I knew TypeScript pretty well, but I can barely read that.

Thaxll 2 years ago

I'm really confused, is it what TS is supposed to looks like?

thdespou 2 years ago

This is probably the slowest Game of Life ever.

nathanfig 2 years ago

I like having type hints, I really do- but I've definitely been on projects where TS began to feel a lot like a nerd snipe https://xkcd.com/356/

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection