summaryrefslogtreecommitdiff
path: root/src/scenes/boolean_encoding.tsx
blob: 60a0ea9425fa0084e63b365e2a3a8cb4f13a57b2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
import { Layout, Txt, makeScene2D } from "@motion-canvas/2d";
import {
  Direction,
  beginSlide,
  createRef,
  slideTransition,
} from "@motion-canvas/core";
import { theme } from "../theme";

const boolE = [
  "true = λ t . λ f . t",
  "false = λ t . λ f . f",
  "if = λ b . λ x . λ y . b x y",
  "not = λ b . b false true",
  "and = λ b . λ c . b c false",
];

export default makeScene2D(function* (view) {
  const numerals = createRef<Txt>();

  view.add(
    <Layout layout direction="column" alignItems="center">
      <Txt fontSize={40} fontFamily={theme.font} fill={theme.text.hex}>
        Boolean Encoding
      </Txt>
      <Txt
        ref={numerals}
        fontSize={30}
        fontFamily={theme.font}
        fill={theme.text.hex}
      ></Txt>
    </Layout>
  );

  yield* slideTransition(Direction.Right);
  yield* beginSlide("The Lambda Calculus - Boolean Encoding");

  for (const bool of boolE) {
    yield* numerals().text(numerals().text() + "\n\n" + bool, 1);
    yield* beginSlide("boolean - " + bool);
  }
});