File: simpsn.mac

package info (click to toggle)
maxima 5.27.0-3
  • links: PTS
  • area: main
  • in suites: wheezy
  • size: 120,648 kB
  • sloc: lisp: 322,503; fortran: 14,666; perl: 14,343; tcl: 11,031; sh: 4,146; makefile: 2,047; ansic: 471; awk: 24; sed: 10
file content (10 lines) | stat: -rw-r--r-- 317 bytes parent folder | download | duplicates (16)
1
2
3
4
5
6
7
8
9
10

traprule(f,a,b,n):=
   (b-a)/n * ((apply(f,[b])+apply(f,[a]))/2 +
   sum(apply(f,[a+(b-a)/n*i]),i,1,n-1))$

simpson(f,a,b,n):=
    block ([nn : ceiling (n / 2)],
   (1/6)*(b-a)/nn * (apply(f,[a])+apply(f,[b]) +
   4*sum(apply(f,[a+(b-a)/(2*nn)*(2*i-1)]),i,1,nn)
 + 2*sum(apply(f,[a+(b-a)/(2*nn)*(2*i)]),i,1,nn-1)))$