Depois de discutirmos o exercício 1.29 …
Funções de alta-ordem, função que recebem funções como argumentos são formas bastante ricas para construção de abstrações. Métodos gerais de computação podem ser implementados idenpendentemente da função particular envolvida. Como primeiro exemplo, temos o método para encontrar a raiz de uma equação usando intervalo médio.
(define (close-enough? x y)
(< (abs (- x y)) 0.001))
(define (search f neg-point pos-point)
(let ((midpoint (average neg-point pos-point)))
(if (close-enough? neg-point pos-point)
midpoint
(let ((test-value (f midpoint)))
(cond ((positive? test-value)
(search f neg-point midpoint))
((negative? test-value)
(search f midpoint pos-point))
(else midpoint))))))
(define (half-interval-method f a b)
(let ((a-value (f a))
(b-value (f b)))
(cond ((and (negative? a-value) (positive? b-value))
(search f a b))
((and (negative? b-value) (positive? a-value))
(search f b a))
(else
(error "Values are not of opposite sign" a b)))))Exemplos de uso do método half-interval-method seguem abaixo:
(half-interval-method sin 2.0 4.0)ou ainda
(half-interval-method (lambda (x) (- (* x x x) (* 2 x) 3))
1.0
2.0)Outro procedimento de alta-ordem interessante é o método para
encontrar o fixed-point de uma função, isto é, o
(define tolerance 0.00001)
(define (fixed-point f first-guess)
(define (close-enough? v1 v2)
(< (abs (- v1 v2)) tolerance))
(define (try guess)
(let ((next (f guess)))
(if (close-enough? guess next)
next
(try next))))
(try first-guess))O fixed-point da equação
(fixed-point (lambda (y) (+ (sin y) (cos y)))
1.0)Finalmente, podemos reinterpretar o problema de achar a raiz de um
número como um problema de fixed-point dado que a raiz de um número
(define (sqrt x)
(fixed-point (lambda (y) (/ x y))
1.0))No entanto, esta definição tem um problema, não converge. Se o
primeiro chute for
Uma solução simples para este problema é aplicar uma transformação na
equação
(define (sqrt x)
(fixed-point (lambda (y) (average y (/ x y)))
1.0))O próximo passo natural é generalizar este procedimento de transformação de funções para cálculo do fixed-point, vide final do capítulo 1.