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);
}
});
|