内容简介:Do you think Computer ScienceAre you feeling that you are doingAre you feeling a bit
Do you think Computer Science equals building websites and mobile apps?
Are you feeling that you are doing repetitive and not so intelligent work?
Are you feeling a bit sick about reading manuals and copy-pasting code and keep poking around until it works all day long ?
Do you want to understand the soul of Computer Science ?
If yes, read SICP!!!
In last article we talked about the integral
procedure. In this article, we talk about how to use it to solve differential equations.
First let’s make sure we understand the math. Actually we do not need to open your 1000 page calculus textbook and start reading from page 1. To understand the example in the book we simply need to know how to solve that one differential equations:
y' = y
Let me put this in English: we are trying to find a function y, which the derivative of y is equal to y itself.
We do not even need to know how to solve this ourselves, there are many online tools to help us. So the result of this is
y = e^(x + C)
This is all the math we need to know to continue.
Next we will explain how to solve y' = y
using the integral
procedure.
There is a Henderson Figure given in the book:
To understand this figure, we can divide it into the upper part and the lower part.
The upper part says is just the integral
procedure. It takes in the stream of derivative of y
and output the stream of y
itself.
The lower part describes the equation y = y'
by using the stream map
function f(t) = t
.
Now let’s try out the solve
procedure from the book. y0 = 1
, dt = 0.001
.
(define (integral delayed-integrand initial-value dt) (define int (cons-stream initial-value (let ((integrand (force delayed-integrand))) (add-stream (scale-stream integrand dt) int)))) int) (define (solve f y0 dt) (define y (integral (delay dy) y0 dt)) (define dy (stream-map f y)) y) (stream-ref (solve (lambda (y) y) 1 0.001) 1000) ;Value: 2.716923932235896
Acually, by following the Henderson figure, we can figure out what the y
stream looks like by hand.
1
1 + dt
1 + dt + (1 + dt)dt
1 + dt + (1 + dt)dt + (1 + dt + (1 + dt)dt)dt
... ...
So we can simply write solve
in the following form:
(define (solve f y0 dt n) (define (s f y0 dt n r) (if (= n 0) r (s f y0 dt (- n 1) (+ r (* (f r) dt))))) (s f y0 dt n y0)) (solve (lambda (x) x) 1 0.001 1000) ;Value: 2.716923932235896
We can see that the result is the same.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
UML用户指南
[美] Grady Booch、James Rumbaugh、Ivar Jacobson / 邵维忠、麻志毅、马浩海、刘辉 / 人民邮电出版社 / 2006-6 / 49.00元
《UML用户指南》(第2版)是UML方面最权威的一本著作,三位作者是面向对象方法最早的倡导者,是UML的创始人。本版涵盖了UML 2.0。书中为具体的UML特征提供了参考,描述了一个使用UML进行开发的过程,旨在让读者掌握UML的术语、规则和语言特点,以及如何有效地使用这种语言,知道如何应用UML去解决一些常见的建模问题。《UML用户指南》(第2版)由7个部分组成,而且每章都描述了一个特定UML特......一起来看看 《UML用户指南》 这本书的介绍吧!