练习 2.14 2.7 2.8 ~ 2.16 未完...

原创 2016年06月01日 14:18:19
#lang racket


;: 区间加法
(define (add-interval x y)
  (make-interval (+ (lower-bound x) (lower-bound y))
                 (+ (upper-bound x) (upper-bound y))))

;: 区间乘法
(define (mul-interval x y)
  (let (
        (p1 (* (lower-bound x) (lower-bound y)))
        (p2 (* (lower-bound x) (upper-bound y)))
        (p3 (* (upper-bound x) (lower-bound y)))
        (p4 (* (upper-bound x) (upper-bound y))))
    (make-interval (min p1 p2 p3 p4)
                   (max p1 p2 p3 p4))))
;: 区间除法
(define (div-interval x y)
  (mul-interval x
                (make-interval (/ 1.0 (upper-bound y))
                               (/ 1.0 (lower-bound y)))))

;: 练习  2.7
(define (make-interval a b) (cons a b))

;: 答安
(define (upper-bound x)
  (let ((a (car x))
        (b (cdr x)))
    (if (> a b)
        a
        b)))

(define (lower-bound x)
  (let ((a (car x))
        (b (cdr x)))
    (if (> a b)
        b
        a)))
;: 测试
(define x (make-interval 3 5))
(upper-bound x)
(lower-bound x)

;:练习2.8 两个区间的差
;: 差的最小值 =-?
;: 差的最大值 =-?
(define (sub-interval x y)
  (make-interval (- (lower-bound x) (lower-bound y))
                 (- (upper-bound x) (upper-bound y))))

;: 练习 2.9 区间的宽带 =上界下界之差的一半
;: 宽度
(define (width-interval x)
  (/ 2 ( + (upper-bound x)
           (lower-bound x))))

;: 对于+法
;(define (add-interval x y)
;  (make-interval (+ (lower-bound x) (lower-bound y))
;                 (+ (upper-bound x) (upper-bound y))))

(define a (make-interval '1 '2))
(define b (make-interval '3 '4))

;(add-interval a b) =>
;  (make-interval (+ (lower-bound a) (lower-bound b))
;                 (+ (upper-bound a) (upper-bound b))))
;=>(make-interval (+ '1 '3) (+ '2 '4))
;=> 宽度= (/ 2
;          (- (+ '2 4)
;             (+ '1 '3)))
;: '2 - '1 + '4 - '3 / 2                   => 
;: (('2 - '1) + ('4 - '3)) / 2             =>
;: (/ 2 (+ (- '2 '1)
;:         (- '4 '3)))                     =>  
版权声明:知行合一

相关文章推荐

数据结构与算法分析Java版练习2.8

package ch02; import java.util.Arrays; import java.util.Random; /** * 练习2.8 假设需要生成前N个整数的一个随机转换。例如...

二人军棋(未完)

  • 2007-01-22 22:27
  • 525KB
  • 下载

<Programming_in_Lua> 笔记(未完)

学习Tips: http://blog.codingnow.com/cloud/LuaTips Lua提供的机制是C所不擅长的,比如:高级语言、动态结构、简洁、易于测试和 调试等。正因为如此,Lu...

sql优化(未完).txt

  • 2011-06-08 22:15
  • 10KB
  • 下载

一天之内学AngularJS--权威指南(未完)

英文原文:Ultimate guide to learning AngularJS in one day一天之内学AngularJS–权威指南AngularJs 是什么?Angular是基于javaS...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)