Extreme Optimization > Mathematics Library for .NET > QuickStart Samples > ChebyshevExpansions QuickStart Sample (C#)

Extreme Optimization Mathematics Library for .NET

ChebyshevExpansions QuickStart Sample (C#)

Illustrates approximating functions using the ChebyshevSeries class in the Extreme.Mathematics.Curves namespace in C#.

VB.NET code Back to QuickStart Samples

using System;

namespace Extreme.Mathematics.QuickStart.CSharp
{
    // The ChebyshevSeries class resides in the Extreme.Mathematics.Curves 
    // namespace.
    using Extreme.Mathematics.Curves;
    // The RealFunction delegate resides in the 
    // Extreme.Mathematics namespace.
    using Extreme.Mathematics;

    /// <summary>
    /// Illustrates the use of the ChebyshevSeries class 
    /// in the Extreme.Mathematics.Curve namespace of the Extreme Optimization 
    /// Mathematics Library for .NET.
    /// </summary>
    class ChebyshevExpansions
    {
        /// <summary>
        /// The main entry point for the application.
        /// </summary>
        [STAThread]
        static void Main(string[] args)
        {
            // Chebyshev polynomials form an alternative basis
            // for polynomials. A Chebyshev expansion is a 
            // polynomial expressed as a sum of Chebyshev 
            // polynomials.
            //
            // Using the ChebyshevSeries class instead of 
            // Polynomial can have two major advantages:
            //   1. They are numerically more stable. Higher
            //      accuracy is maintained even for large problems.
            //   2. When approximating other functions with
            //      polynomials, the coefficients in the
            //      Chebyshev expansion will tend to decrease
            //      in size, where those of the normal polynomial
            //      approximation will tend to oscillate wildly.

            // Index variable.
            int index;

            //
            // Constructing Chebyshev expansions
            //

            // Chebyshev expansions are defined over an interval.
            // The first constructor requires you to specify the
            // boundaries of the interval, and the coefficients
            // of the expansion.
            double[] coefficients = new double[] {1, 0.5, -0.3, 0.1};
            ChebyshevSeries chebyshev1 = 
                new ChebyshevSeries(0, 2, coefficients);
            // If you omit the boundaries, they are assumed to be
            // -1 and +1:
            ChebyshevSeries chebyshev2 = 
                new ChebyshevSeries(coefficients);

            // 
            // Chebyshev approximations
            //

            // A third constructor creates a Chebyshev 
            // approximation to an arbitrary function. For more
            // about the RealFunction delegate, see the
            // FunctionDelegates QuickStart Sample.
            //
            // Chebyshev expansions allow us to obtain an 
            // excellent approximation at minimal cost.
            //
            // The following creates a Chebyshev approximation
            // of degree 7 to Cos(x) over the interval [0, 2]:
            RealFunction cos = 
                new RealFunction(Math.Cos);
            ChebyshevSeries approximation1 =
                ChebyshevSeries.GetInterpolatingPolynomial(cos, 0, 2, 7);
            // The coefficients of the expansion are available through
            // the indexer property of the ChebyshevSeries object:
            Console.WriteLine("Chebyshev approximation of cos(x):");
            for(index = 0; index <= 7; index++)
                Console.WriteLine("  c{0} = {1}", index,
                    approximation1[index]);

            // The largest errors are approximately at the
            // zeroes of the Chebyshev polynomial of degree 8:
            for(index = 0; index <= 8; index++)
            {
                double zero = 1 + Math.Cos(index * Constants.Pi / 8);
                double error = approximation1.ValueAt(zero)
                    - Math.Cos(zero);
                Console.WriteLine(" Error {0} = {1}", index, error);
            }

            //
            // Least squares approximations
            //

            // We will now calculate the least squares polynomial
            // of degree 7 through 33 points.
            // First, calculate the points:
            double[] xValues = new double[33];
            double[] yValues = new double[33];
            for(index = 0; index <= 32; index++)
            {
                double angle = index * Constants.Pi / 32;
                xValues[index] = 1 + Math.Cos(angle);
                yValues[index] = Math.Cos(xValues[index]);
            }
            // Next, define a ChebyshevBasis object for the
            // approximation we want: interval [0,2] and degree
            // is 7.
            ChebyshevBasis basis = new ChebyshevBasis(0, 2, 7);
            // Now we can calculate the least squares fit:
            ChebyshevSeries approximation2 = (ChebyshevSeries)
                basis.LeastSquaresFit(xValues, yValues, xValues.Length);
            // We can see it is close to the original 
            // approximation we found earlier:
            for(index = 0; index <= 7; index++)
                Console.WriteLine("  c{0} = {1}", index,
                    approximation2[index]);

            Console.Write("Press Enter key to exit...");
            Console.ReadLine();
        }
    }
}
Overview
Introduction
Features
Documentation
QuickStart Samples
Sample Applications
Downloads
Get it now!
Download trial version
How to Buy
Search

"The Extreme Optimization Statistics Library for .NET is a major boon for those doing statistical work in .NET. I strongly recommend this product."
- Marc Brooks

"I have made it my mission to institutionalize the value of good API design.  I strongly believe that this is key to making developers more productive and happy on our platform. It is clear that you value good API design in your work, and take to heart developer productivity and synergy with the .NET framework."
- Brad Abrams,
Lead Program Manager, Microsoft.

This is a partial list of companies who are using our libraries:
ABB Robotics
Allstate
Applied Materials
Arcam
Astra Schedule
Babson College
Canadian Council on Learning
Canyon Associates
Caxton Associates
CECity
Constellation Energy
CreditSights
DeepOcean
Duke University
Dynamotive
Elecsoft
Engelhard Corporation
Epcor
Equipoise Software
Galileo International
GAM UK
Gammex
GlaxoSmithKline
Global Matrix
The Hartford
Infinera Corporation
Intel
JDS Uniphase
LaBranche & Co.
Learning & Skills Council
Jacobs Consultancy
Litman Gregory
Lucas Systems
Malvern Instruments
Medrio
Merck & Co.
Mintera.
Monitor Software
MorningStar
NanoString Technologies
Paletta Invent
Parametric Portfolio Associates
Prosanos
RATA Associates
RiskShield
Ramboll
Standard & Poor's
Strategic Analysis Corporation
Univ. of Alicante
Univ. of South Carolina
vielife
Xerox
US Army