明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2003|回复: 1

Chebyshev 求积分的 lisp 代码

  [复制链接]
发表于 2011-11-14 19:17:12 | 显示全部楼层 |阅读模式
本帖最后由 vormittag 于 2011-11-15 10:37 编辑

在论坛上看到highflybird大师写过用 lisp 求积分的代码,主要使用了Romberg 积分、Simpson 积分、自适应积分和变步长积分
原贴地址如下:
[原创]用LISP求积分
http://bbs.mjtd.com/forum.php?mod=viewthread&tid=82704&fromuid=398403

近日自己学习了一下 Chebyshev 积分和 Legendre-Gauss 积分,先写了一个 Chebyshev 积分法,代码如下:
感觉效率并不是很高,希望大师多加指点。
  1. (defun f(x) (+ (* x x) (sin x)))

  2. (defun chebyshev (func a b eps / aa bb v m ep)
  3.   (setq c  '(-0.8324975 -0.3745414 0.0 0.3745414 0.8324975)
  4.       m  1
  5.       ep (1+ eps)
  6.       p  1e35
  7.       h  (- b a)
  8.   );setq
  9.   (while (> ep eps)  
  10.     (setq g  0
  11.         aa (- a h)
  12.     );setq
  13.     (repeat m
  14.       (setq aa (+ aa h)
  15.             bb (+ aa h)
  16.           g  (+ (apply '+ (mapcar '(lambda(x) (func (+ (* (- bb aa) 0.5 x) (* (+ bb aa) 0.5)))) c)) g)
  17.       );setq
  18.     );repeat
  19.     (setq g  (* g h 0.2)
  20.         ep (/ (abs (- g p)) (1+ (abs g)))
  21.         p  g
  22.         m  (1+ m)
  23.         h  (/ (- b a) m)
  24.     );setq
  25.   )
  26.   g
  27. )

点评

不错  发表于 2011-11-14 20:17

评分

参与人数 2明经币 +2 金钱 +50 收起 理由
highflybir + 1 + 30 很好!值得学习。
jicqj + 1 + 20 赞一个!

查看全部评分

"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2011-11-15 09:49:46 | 显示全部楼层
卡卡,真的很帅。不知道效率怎么样。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-9-8 12:24 , Processed in 0.199110 second(s), 33 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表