summaryrefslogtreecommitdiff
path: root/src/scenes/lambda_reduction_example.tsx
blob: 8f2436a8b12dd0dba4e619a1c0a1877ffaeb3d34 (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
43
44
45
46
47
import { Layout, makeScene2D } from "@motion-canvas/2d";
import {
  Direction,
  beginSlide,
  createRef,
  slideTransition,
} from "@motion-canvas/core";
import { LambdaReducer } from "../components/lambda_reducer";
import { baseDefinitions } from "../utils/lambdas";

export default makeScene2D(function* (view) {
  const lambdaReducer = createRef<LambdaReducer>();
  const layout = createRef<Layout>();

  view.add(
    <Layout layout ref={layout} direction="column" alignItems="center" gap={50}>
      <LambdaReducer
        ref={lambdaReducer}
        lambdaTerm={"(succ zero)"}
        definitions={baseDefinitions}
      ></LambdaReducer>
    </Layout>
  );

  yield* slideTransition(Direction.Right);
  yield* beginSlide("Example Reductions");

  for (let i = 0; !lambdaReducer().isDone(); i++) {
    yield* lambdaReducer().step(0.5);
    yield* beginSlide("1 Next Step " + i);
  }

  const one = lambdaReducer().getCode();
  const reduceToTwo = createRef<LambdaReducer>();
  layout().add(
    <LambdaReducer
      ref={reduceToTwo}
      lambdaTerm={`(succ ${one})`}
      definitions={baseDefinitions}
    ></LambdaReducer>
  );

  for (let i = 0; !reduceToTwo().isDone(); i++) {
    yield* reduceToTwo().step(0.5);
    yield* beginSlide("2 Next Step " + i);
  }
});