Jump to content

Boole's rule: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Better organization so TOC is reasonable
Citation bot (talk | contribs)
Added issue. | Use this bot. Report bugs. | Suggested by Dominic3203 | Category:Numerical analysis | #UCB_Category 116/235
 
(31 intermediate revisions by 11 users not shown)
Line 6: Line 6:
==Formula==
==Formula==
===Simple Boole's Rule===
===Simple Boole's Rule===

It approximates an integral:
It approximates an integral:
<math display="block"> \int_{a}^{b} f(x)\,dx </math>

by using the values of {{mvar|f}} at five equally spaced points:{{sfn|Boole|1880|p=47|loc=Eq(21)}}
: <math> \int_{x_1}^{x_5} f(x)\,dx </math>
<math display="block">\begin{align}

& x_0 = a\\
by using the values of {{mvar|f }} at five equally spaced points:{{sfn|Boole|1880|p=47|loc=Eq(21)}}
& x_1 = x_0 + h \\

& x_2 = x_0 + 2h \\
: <math>\begin{align}
& x_1 \\
& x_3 = x_0 + 3h \\
& x_2 = x_1 + h \\
& x_4 = x_0 + 4h = b
& x_3 = x_1 + 2h \\
& x_4 = x_1 + 3h \\
& x_5 = x_1 +4h
\end{align}</math>
\end{align}</math>


It is expressed thus in [[Abramowitz and Stegun]]:{{sfn|Davis|Polonsky|1983}}
It is expressed thus in [[Abramowitz and Stegun]]:{{sfn|Davis|Polonsky|1983}}
<math display="block"> \int_{x_0}^{x_4} f(x)\,dx = \frac{2 h}{45}\bigl[ 7f(x_0) + 32 f(x_1) + 12 f(x_2) + 32 f(x_3) + 7f(x_4) \bigr] + \text{error term}</math>

: <math> \int_{x_1}^{x_5} f(x)\,dx = \frac{2 h}{45}\bigl[ 7f(x_1) + 32 f(x_2) + 12 f(x_3) + 32 f(x_4) + 7f(x_5) \bigr] + \text{error term}</math>

where the error term is
where the error term is
<math display="block"> -\,\frac{8f^{(6)}(\xi)h^7}{945} </math>
for some number {{tmath|\xi}} between {{tmath|x_0}} and {{tmath|x_4}} where {{nowrap|1=945 = 1 × 3 × 5 × 7 × 9}}.


It is often known as Bode's rule, due to a typographical error that propagated from Abramowitz and Stegun.{{sfn|Weisstein}}
: <math> -\,\frac{8}{945} h^7 f^{(6)}(c) </math>

for some number {{mvar|c}} between {{math|''x''<sub>1</sub>}} and {{math|''x''<sub>5</sub>}}. ({{nowrap|1=945 = 1 × 3 × 5 × 7 × 9}}.)

It is often known as Bode's rule, due to a typographical error that propagated from [[Abramowitz and Stegun]].{{sfn|Weisstein}}


The following constitutes a very simple implementation of the method in [[Common Lisp]] which ignores the error term:
The following constitutes a very simple implementation of the method in [[Common Lisp]] which ignores the error term:
Line 57: Line 49:


=== Composite Boole's Rule ===
=== Composite Boole's Rule ===
In cases where the integration is permitted to extend over equidistant sections of the interval <math>[a, b]</math>, the composite Boole's rule might be applied. Given <math>N</math> divisions, where <math>N</math> [[Modulo|mod]] <math>4 = 0</math>, the integrated value amounts to:{{sfn|Sablonnière|Sbibih|Tahrichi|2010|p=852}}

In cases where the integration is permitted to extend over equidistant sections of the interval <math>[a, b]</math>, the composite Boole's rule might be applied. Given <math>N</math> divisions, the integrated value amounts to:{{sfn|Ubale|2012}}


<math display=block>
<math display=block>
Line 68: Line 59:
+ 12\left(\sum_{i \in \{2, 6, 10, \ldots, N-2\}} f(x_i)\right)
+ 12\left(\sum_{i \in \{2, 6, 10, \ldots, N-2\}} f(x_i)\right)
+ 14\left(\sum_{i \in \{4, 8, 12, \ldots, N-4\}} f(x_i)\right)
+ 14\left(\sum_{i \in \{4, 8, 12, \ldots, N-4\}} f(x_i)\right)
\right)
\right) + \text{error term}
</math>
</math>


The following Common Lisp code implements the aforementioned formula:
where the error term is similar to above. The following Common Lisp code implements the aforementioned formula:


<syntaxhighlight lang="lisp">
<syntaxhighlight lang="lisp">
Line 101: Line 92:


==Notes==
==Notes==
{{reflist|20em}}
{{reflist}}


==References==
==References==
{{sfn whitelist|CITEREFDavisPolonsky1983|CITEREFWeisstein}}
* {{cite book
* {{cite book
|last= Boole
|last= Boole
Line 115: Line 107:
|publisher=[[Macmillan Publishers|Macmillan and Company]]
|publisher=[[Macmillan Publishers|Macmillan and Company]]
}}
}}

* {{AS ref|25, eqn 25.4.14|886|first1=Philip J. |last1=Davis |link1=Philip J. Davis |first2=Ivan |last2=Polonsky}}
* {{AS ref|25, eqn 25.4.14|886|first1=Philip J. |last1=Davis |link1=Philip J. Davis |first2=Ivan |last2=Polonsky}}

* {{cite journal
* {{cite journal
| last1 = Ubale
| last1 = Sablonnière
| first1 = P. V.
| first1 = P.
| year = 2012
| last2 = Sbibih
| first2 = D.
| title = Numerical Solution of Boole's Rule in Numerical Integration by Using General Quadrature Formula
| last3 = Tahrichi
| url = https://www.scipress.com/BSMaSS.2.1.pdf
| first3 = M.
| journal = The Bulletin of Society for Mathematical Services and Standards
| volume = 2
| date = 2010
| title = Error estimate and extrapolation of a quadrature formula derived from a quartic spline quasi-interpolant
| pages = 1{{ndash}}4
| journal = BIT Numerical Mathematics
| doi = 10.18052/www.scipress.com/BSMaSS.2.1
| volume = 50
| access-date = December 21, 2022
| issue = 4
| pages = 843{{ndash}}862
| doi = 10.1007/s10543-010-0278-0
}}
}}

* {{MathWorld |title=Boole's Rule|id=BoolesRule}}
* {{MathWorld |title=Boole's Rule|id=BoolesRule}}
{{Numerical integration}}

{{DEFAULTSORT:Boole's Rule}}
{{DEFAULTSORT:Boole's Rule}}
[[Category:Integral calculus]]
[[Category:Numerical analysis]]
[[Category:Numerical integration (quadrature)]]
[[Category:Numerical integration (quadrature)]]
[[Category:Articles with example Lisp (programming language) code]]

Latest revision as of 16:51, 28 September 2024

In mathematics, Boole's rule, named after George Boole, is a method of numerical integration.

Formula

[edit]

Simple Boole's Rule

[edit]

It approximates an integral: by using the values of f at five equally spaced points:[1]

It is expressed thus in Abramowitz and Stegun:[2] where the error term is for some number between and where 945 = 1 × 3 × 5 × 7 × 9.

It is often known as Bode's rule, due to a typographical error that propagated from Abramowitz and Stegun.[3]

The following constitutes a very simple implementation of the method in Common Lisp which ignores the error term:

(defun integrate-booles-rule (f x1 x5)
  "Calculates the Boole's rule numerical integral of the function F in
   the closed interval extending from inclusive X1 to inclusive X5
   without error term inclusion."
  (declare (type (function (real) real) f))
  (declare (type real                   x1 x5))
  (let ((h (/ (- x5 x1) 4)))
    (declare (type real h))
    (let* ((x2 (+ x1 h))
           (x3 (+ x2 h))
           (x4 (+ x3 h)))
      (declare (type real x2 x3 x4))
      (* (/ (* 2 h) 45)
         (+ (*  7 (funcall f x1))
            (* 32 (funcall f x2))
            (* 12 (funcall f x3))
            (* 32 (funcall f x4))
            (*  7 (funcall f x5)))))))

Composite Boole's Rule

[edit]

In cases where the integration is permitted to extend over equidistant sections of the interval , the composite Boole's rule might be applied. Given divisions, where mod , the integrated value amounts to:[4]

where the error term is similar to above. The following Common Lisp code implements the aforementioned formula:

(defun integrate-composite-booles-rule (f a b n)
  "Calculates the composite Boole's rule numerical integral of the
   function F in the closed interval extending from inclusive A to
   inclusive B across N subintervals."
  (declare (type (function (real) real) f))
  (declare (type real                   a b))
  (declare (type (integer 1 *)          n))
  (let ((h (/ (- b a) n)))
    (declare (type real h))
    (flet ((f[i] (i)
            (declare (type (integer 0 *) i))
            (let ((xi (+ a (* i h))))
              (declare (type real xi))
              (the real (funcall f xi)))))
      (* (/ (* 2 h) 45)
         (+ (*  7 (+ (f[i] 0) (f[i] n)))
            (* 32 (loop for i from 1 to (- n 1) by 2 sum (f[i] i)))
            (* 12 (loop for i from 2 to (- n 2) by 4 sum (f[i] i)))
            (* 14 (loop for i from 4 to (- n 4) by 4 sum (f[i] i))))))))

See also

[edit]

Notes

[edit]

References

[edit]
  • Boole, George (1880) [1860]. A Treatise on the Calculus of Finite Differences (3rd ed.). Macmillan and Company.
  • Davis, Philip J.; Polonsky, Ivan (1983) [June 1964]. "Chapter 25, eqn 25.4.14". In Abramowitz, Milton; Stegun, Irene Ann (eds.). Handbook of Mathematical Functions with Formulas, Graphs, and Mathematical Tables. Applied Mathematics Series. Vol. 55 (Ninth reprint with additional corrections of tenth original printing with corrections (December 1972); first ed.). Washington D.C.; New York: United States Department of Commerce, National Bureau of Standards; Dover Publications. p. 886. ISBN 978-0-486-61272-0. LCCN 64-60036. MR 0167642. LCCN 65-12253.
  • Sablonnière, P.; Sbibih, D.; Tahrichi, M. (2010). "Error estimate and extrapolation of a quadrature formula derived from a quartic spline quasi-interpolant". BIT Numerical Mathematics. 50 (4): 843–862. doi:10.1007/s10543-010-0278-0.
  • Weisstein, Eric W. "Boole's Rule". MathWorld.