File: simpsn.mac

package info (click to toggle)
maxima 5.47.0-9
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 193,104 kB
  • sloc: lisp: 434,678; fortran: 14,665; tcl: 10,990; sh: 4,577; makefile: 2,763; ansic: 447; java: 328; python: 262; perl: 201; xml: 60; awk: 28; sed: 15; javascript: 2
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)))$