Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: downloads/boost_1_34_1/libs/numeric/interval/examples/horner.cpp @ 30

Last change on this file since 30 was 29, checked in by landauf, 17 years ago

updated boost from 1_33_1 to 1_34_1

File size: 1.2 KB
Line 
1/* Boost example/horner.cpp
2 * example of unprotecting rounding for a whole function computation
3 *
4 * Copyright 2002-2003 Guillaume Melquiond
5 *
6 * Distributed under the Boost Software License, Version 1.0.
7 * (See accompanying file LICENSE_1_0.txt or
8 * copy at http://www.boost.org/LICENSE_1_0.txt)
9 */
10
11#include <boost/numeric/interval.hpp>
12#include <iostream>
13
14// I is an interval class, the polynom is a simple array
15template<class I>
16I horner(const I& x, const I p[], int n) {
17
18  // initialize and restore the rounding mode
19  typename I::traits_type::rounding rnd;
20
21  // define the unprotected version of the interval type
22  typedef typename boost::numeric::interval_lib::unprotect<I>::type R;
23
24  const R& a = x;
25  R y = p[n - 1];
26  for(int i = n - 2; i >= 0; i--) {
27    y = y * a + (const R&)(p[i]);
28  }
29  return y;
30
31  // restore the rounding mode with the destruction of rnd
32}
33
34template<class T, class Policies>
35std::ostream &operator<<(std::ostream &os,
36                         const boost::numeric::interval<T, Policies> &x) {
37  os << "[" << x.lower() << ", " << x.upper() << "]";
38  return os;
39}
40
41int main() {
42  typedef boost::numeric::interval<double> I;
43  I p[3] = { -1.0, 0, 1.0 };
44  I x = 1.0;
45  std::cout << horner(x, p, 3) << std::endl;
46  return 0;
47}
Note: See TracBrowser for help on using the repository browser.