SICP_2.50-2.51

 1 #lang sicp
 2 
 3 (#%require sicp-pict)
 4 
 5 (define (origin-frame frame)
 6   (car frame))
 7 
 8 (define (edge1-frame frame)
 9   (cadr frame))
10 
11 (define (edge2-frame frame)
12   (caddr frame))
13 
14 (define (make-vect a b)
15   (cons a b))
16 
17 (define (xcor-vect v)
18   (car v))
19 
20 (define (ycor-vect v)
21   (cdr v))
22 
23 (define (add-vect v1 v2)
24   (make-vect (+ (xcor-vect v1)
25                 (xcor-vect v2))
26              (+ (ycor-vect v1)
27                 (ycor-vect v2))))
28 
29 (define (sub-vect v1 v2)
30   (make-vect (- (xcor-vect v1)
31                 (xcor-vect v2))
32              (- (ycor-vect v1)
33                 (ycor-vect v2))))
34 
35 (define (scale-vect s v1)
36   (make-vect (* s (xcor-vect v1))
37              (* s (ycor-vect v1))))
38 
39 (define (frame-coord-map frame)
40   (lambda (v)
41     (add-vect
42      (origin-frame frame)
43      (add-vect (scale-vect (xcor-vect v)
44                            (edge1-frame frame))
45                (scale-vect (ycor-vect v)
46                            (edge2-frame frame))))))
47 ;;;;;;;;;;;;;;;;;;;2.50
48 (define (transform-painter painter origin corner1 corner2)
49   (lambda (frame)
50     (let ((m (frame-coord-map frame)))
51       (let ((new-origin (m origin)))
52         (painter
53          (make-frame new-origin
54                      (sub-vect (m corner1) new-origin)
55                      (sub-vect (m corner2) new-origin)))))))
56 
57 (define (flip-horiz painter)
58   (transform-painter painter
59                      (make-vect 1.0 0.0)
60                      (make-vect 0.0 0.0)
61                      (make-vect 1.0 1.0)))
62 
63 (define (roate90 painter)
64   (transform-painter painter
65                      (make-vect 1.0 0.0)
66                      (make-vect 1.0 1.0)
67                      (make-vect 0.0 0.0)))
68 
69 (define (roate180 painter)
70   (transform-painter painter
71                      (make-vect 1.0 1.0)
72                      (make-vect 0.0 1.0)
73                      (make-vect 1.0 0.0)))
74 
75 (define (roate270 painter)
76   (transform-painter painter
77                      (make-vect 0.0 1.0)
78                      (make-vect 0.0 0.0)
79                      (make-vect 1.0 1.0)))
80 
81 ;;;;;;;;;;;;;;;;;2.51
82 (define (my-below painter1 painter2)
83   (let ((split-point (make-vect 0.0 0.5)))
84     (let ((paint-up
85            (transform-painter painter2
86                                split-point
87                               (make-vect 1.0 0.5)
88                               (make-vect 0.0 1.0)))
89           (paint-bottom
90            (transform-painter painter1
91                               (make-vect 0.0 0.0)
92                                (make-vect 1.0 0.0)
93                                split-point)))
94       (lambda (frame)
95         (paint-up frame)
96         (paint-bottom frame)))))
97 
98 (define (my-below2 painter1 painter2)
99   (roate270 (beside (roate90 painter1) (roate90 painter2))))

 

1.理解painter是个过程接受frame参数,即在frame中画painter

 

2.frame-coord-map 中将一个单位正方形中的点映射到一个新框架中

 

3.transform-painter 则是将painter映射到一个新框架中返回的也是一个过程,也可以理解为返回一个painter

转载于:https://www.cnblogs.com/tclan126/p/6431103.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"SICP中文版"是指计算机科学经典教材《Structure and Interpretation of Computer Programs》(计算机程序的构造和解释)的中文翻译PDF版。这本教材由麻省理工学院的Harold Abelson和Gerald Jay Sussman等人编写,是计算机科学领域中一本重要的教材。 "SICP中文版PDF"提供了更方便的学习方式。无论是学生、程序员还是计算机科学爱好者,都可以在任何时候通过电子设备访问和学习这本教材。使用PDF格式的好处是可以在不同的平台上都能打开和阅读,而不受限于特定的操作系统或设备。 通过"SICP中文版PDF",读者可以学习计算机科学的基本原理和概念,如过程、数据抽象、递归、高阶函数、并发等。这本教材以Scheme语言为示例,帮助读者理解计算机程序的结构、设计和解释。通过逐步的案例和练习,读者可以锻炼解决问题和编写高质量代码的能力。 "SICP中文版PDF"也提供了沟通和讨论的平台。读者可以通过在线社群或论坛,与其他人分享学习心得、解答疑问和参与讨论。这为读者提供了一个学习交流的机会,促进了学习者之间的互动和共同成长。 总之,"SICP中文版PDF"是一本经典的计算机科学教材的中文翻译版本,使得更多的读者可以方便地学习和掌握其中的知识。无论是对于计算机科学专业的学生还是对计算机科学感兴趣的人,这本教材都是一本很好的参考书,并提供了丰富的实例和练习,让读者深入理解计算机程序的核心概念和设计原则。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值