handball/src/test/run-pass/sqrt.scm

25 lines
522 B
Scheme
Raw Normal View History

2021-12-27 20:43:12 +00:00
#lang scheme
; We dont have closures at the time of writing, but each func gets its own env
; http://sarabander.github.io/sicp/html/1_002e1.xhtml#g_t1_002e1_002e7
(define (sqrt-iter guess x)
(if (good-enough? guess x) guess (sqrt-iter (improve guess x) x)))
2021-12-27 20:43:12 +00:00
(define (improve guess x)
(average guess (/ x guess)))
(define (average x y)
2021-12-27 20:43:12 +00:00
(/ (+ x y) 2))
(define (square x)
(* x x))
2021-12-27 20:43:12 +00:00
(define (good-enough? guess x)
(< (abs (- (square guess) x)) 0.001))
(define (sqrt x)
(sqrt-iter 1.0 x))
(display (sqrt 2))