이 문제는 연습문제 3.74에서 만든 make-zero-crossings 프로시저가
잡 신호(noisy signal)에 대비하지 못한다는 것을 알게 되어
그것을 보완하고자 평균을 구해 일을 수행하도록 하였습니다.
하지만 거기에 맞게 프로시저를 만들었지만 생각에 맞는 프로시저가 아닙니다.
무엇이 잘못되었고 수정하는 것이 이 문제입니다.
처음에는 무엇이 잘못되었는지 알 수 없어 고생하였습니다.
그래서 천천히 살펴보다가 이런 생각이 들었습니다.
'평균을 구할 때 앞에서 구한 평균과 지금 값을 비교하는 것이 아니라
기존에 들어왔던 것끼리 평균을 구해야 하는 것이 아닐까?'
그렇게 생각하고 hint에 나오는 인자 수를 늘려 만들었습니다.

일단 잘 되네요.^^
하지만 이것이 Louis가 저지른 오류를 수정한 결과인지는 잘 모르겠습니다.
확신을 가지고 수행한 것이 아니라 추측을 통해 수정한 것이기 때문입니다.
참조
해럴드 애빌슨, 김재우 역, <컴퓨터 프로그램의 구조와 해석>, 인사이트, 2007, pp. 450
; stream
(define true (= 0 0))
(define false (= 1 0))
(define (cons-stream a b)
(cons a (delay b)))
(define the-empty-stream '())
(define stream-null? null?)
(define (stream-car stream) (car stream))
(define (stream-cdr stream) (force (cdr stream)))
; section 3.5
(define (stream-ref s n)
(if (= n 0)
(stream-car s)
(stream-ref (stream-cdr s) (- n 1))))
(define (stream-for-each proc s)
(if (stream-null? s)
'done
(begin (proc (stream-car s))
(stream-for-each proc (stream-cdr s)))))
(define (display-stream s)
(stream-for-each display-line s))
(define (display-line x)
(newline)
(display x))
(define (stream-enumerate-interval low high)
(if (> low high)
the-empty-stream
(cons-stream
low
(stream-enumerate-interval (+ low 1) high))))
(define (stream-filter pred stream)
(cond ((stream-null? stream) the-empty-stream)
((pred (stream-car stream))
(cons-stream (stream-car stream)
(stream-filter pred
(stream-cdr stream))))
(else (stream-filter pred (stream-cdr stream)))))
(define (memo-proc proc)
(let ((already-run? false) (result false))
(lambda ()
(if (not already-run?)
(begin (set! result (proc))
(set! already-run? true)
result)
result))))
(define (scale-stream stream factor)
(stream-map (lambda (x) (* x factor)) stream))
; exercise 3.50
(define (stream-map proc . argstreams)
(if (stream-null? (car argstreams))
the-empty-stream
(cons-stream
(apply proc (map stream-car argstreams))
(apply stream-map
(cons proc (map stream-cdr argstreams))))))
;;;SECTION 3.5.2
(define (add-streams s1 s2)
(stream-map + s1 s2))
(define ones (cons-stream 1 ones))
(define integers (cons-stream 1 (add-streams ones integers)))
; exercise 3.54
(define (mul-streams s1 s2)
(stream-map * s1 s2))
; exercise 3.55
(define (partial-sums S)
(cons-stream (stream-car S) (add-streams (stream-cdr S)
(partial-sums S))))
; exercise 3.56
(define (merge s1 s2)
(cond ((stream-null? s1) s2)
((stream-null? s2) s1)
(else
(let ((s1car (stream-car s1))
(s2car (stream-car s2)))
(cond ((< s1car s2car)
(cons-stream s1car (merge (stream-cdr s1) s2)))
((> s1car s2car)
(cons-stream s2car (merge s1 (stream-cdr s2))))
(else
(cons-stream s1car
(merge (stream-cdr s1)
(stream-cdr s2)))))))))
; print-stream-n
(define (print-stream-n S n l)
(define (iter i)
(if (= i n)
'done
(begin (display (stream-ref S i))
(display " ")
(if (= (remainder (+ i 1) l) 0)
(newline))
(iter (+ i 1)))))
(iter 0))
; exercise 3.59
(define (div-streams s1 s2)
(stream-map / s1 s2))
(define (integrate-series coff_stm)
(let ((integrate_s (cons-stream 1 ; 상수 c
(div-streams coff_stm integers))))
(stream-cdr integrate_s)))
(define exp-series
(cons-stream 1 (integrate-series exp-series)))
(define cosine-series
(cons-stream 1
(integrate-series (scale-stream sine-series -1))))
(define sine-series
(cons-stream 0
(integrate-series cosine-series)))
; exercise 3.60
(define (mul-series s1 s2)
(cons-stream (* (stream-car s1) (stream-car s2))
(add-streams (mul-series (stream-cdr s1) s2)
(scale-stream (stream-cdr s2) (stream-car s1)))))
; exercise 3.61
(define (invert-unit-series S)
(define X
(cons-stream 1
(scale-stream (mul-series (stream-cdr S) X) -1)))
X)
; exercise 3.62
; s1 / s2
(define (div-series s1 s2)
(if (= 0 (stream-car s2))
(error "Divide by zero" s2)
(mul-series s1 (invert-unit-series s2))))
; exercise 3.74
;(define (make-zero-crossings input-stream last-value)
; (cons-stream
; (sign-change-detector (stream-car input-stream) last-value)
; (make-zero-crossings (stream-cdr input-stream)
; (stream-car input-stream))))
(define zero-crossings (make-zero-crossings sense-data 0 0))
(define zero-crossings-2
(stream-map sign-change-detector sense-data (cons-stream 0 sense-data)))
; make the procedure and stream
(define (sign-change-detector b a)
(let ((ab (* a b)))
(cond ((< ab 0)
(if (< a 0)
1
-1))
((= ab 0) ; 0은 양수로 취급.
(if (= a 0)
(sign-change-detector b 1)
(sign-change-detector 1 a)))
(else 0)))) ; ab > 0
(define sense-data
(cons-stream 1 (cons-stream 2 (cons-stream 1.5 (cons-stream 1 (cons-stream 0.5 (cons-stream -0.1 (cons-stream -2 (cons-stream -3 (cons-stream -2 (cons-stream -0.5 (cons-stream 0.2 (cons-stream 3 (cons-stream 4 sense-data))))))))))))))
; exercise 3.75
(define (make-zero-crossings input-stream last-value last-avpt)
(let ((avpt (/ (+ (stream-car input-stream) last-value) 2)))
(cons-stream (sign-change-detector avpt last-avpt)
(make-zero-crossings (stream-cdr input-stream)
(stream-car input-stream)
avpt))))
; execute
(print-stream-n zero-crossings 13 13)
- SICP Exercise 연습문제 3.78 (0)2008/07/29
- SICP Exercise 연습문제 3.77 (0)2008/07/29
- SICP Exercise 연습문제 3.76 (0)2008/07/29
- SICP Exercise 연습문제 3.75 (0)2008/07/29
- SICP Exercise 연습문제 3.74 (0)2008/07/29
- SICP Exercise 연습문제 3.73 (0)2008/07/29
- SICP Exercise 연습문제 3.72 (0)2008/07/27
글에 잘못된 점, 다른 점, 부족한 점이 있다면 지적해주세요.
댓글, 트랙백, 메일 모두 고맙습니다.







댓글을 달아 주세요