summaryrefslogtreecommitdiff
path: root/examples/integrate.hs
blob: 3a03da691f1c5952a123e96306cf71da330580e6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
-- Numerical integration
import Numeric.GSL

quad f a b = fst $ integrateQAGS 1E-9 100 f a b  

-- A multiple integral can be easily defined using partial application
quad2 f y1 y2 g1 g2 = quad h y1 y2
  where
    h y = quad (flip f y) (g1 y) (g2 y)

volSphere r = 8 * quad2 (\x y -> sqrt (r*r-x*x-y*y)) 
                        0 r (const 0) (\x->sqrt (r*r-x*x))

-- wikipedia example
exw = quad2 f 7 10 (const 11) (const 14)
  where
    f x y = x**2 + 4*y

main = do
    print $ quad (\x -> 4/(x^2+1)) 0 1
    print pi
    print $ volSphere 2.5
    print $ 4/3*pi*2.5**3
    print $ exw