Extreme Optimization > QuickStart Samples > Basic Polynomials QuickStart Sample (C#)

Extreme Optimization QuickStart Samples

Basic Polynomials QuickStart Sample (C#)

Illustrates the basic use of the Polynomial class (Extreme.Mathematics.Curves namespace) in C#.

VB.NET code F# code Back to QuickStart Samples

using System;

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

    /// <summary>
    /// Illustrates the basic use of the Polynomial class in the 
    /// Extreme.Mathematics.Curve namespace.
    /// </summary>
    class BasicPolynomials
    {
        /// <summary>
        /// The main entry point for the application.
        /// </summary>
        [STAThread]
        static void Main(string[] args)
        {
            // All curves inherit from the Curve abstract base
            // class. The Polynomial class overrides implements all
            // the methods and properties of the Curve class,
            // and adds a few more.

            // Index variable.
            int index;

            //
            // Polynomial constructors
            //

            // The Polynomial class has multiple constructors. Each
            // constructor derives from a different way to define
            // a polynomial or parabola.

            // 1st option: a polynomial of a specified degree.
            Polynomial polynomial1 = new Polynomial(3);
            // Now set the coefficients individually. The coefficients
            // can be set using the indexer property. The constant term 
            // has index 0:
            polynomial1[3] = 1;
            polynomial1[2] = 1;
            polynomial1[1] = 0;
            polynomial1[0] = -2;
            // 2nd option: specify the coefficients in the constructor
            // as an array of doubles:
            double[] coefficients = new double[] {-2, 0, 1, 1};
            Polynomial polynomial2 = new Polynomial(coefficients);

            // In addition, you can create a polynomial that
            // has certain roots using the static FromRoots
            // method:
            double[] roots = new double[] {1, 2, 3, 4};
            Polynomial polynomial3 = Polynomial.FromRoots(roots);
            // Or you can construct the interpolating polynomial
            // by calling the static GetInterpolatingPolynomial
            // method. The parameters are two double arrays 
            // containing the x values and y values respectively.
            double[] xValues = new double[] {1, 2, 3, 4};
            double[] yValues = new double[] {1, 4, 10, 8};
            Polynomial polynomial4 = 
                Polynomial.GetInterpolatingPolynomial(xValues, yValues);

            // The ToString method gives a common string
            // representation of the polynomial:
            Console.WriteLine("polynomial3 = {0}", polynomial3.ToString());

            //
            // Curve Parameters
            //

            // The shape of any curve is determined by a set of parameters.
            // These parameters can be retrieved and set using the
            // indexer property of the Parameters collection. The number
            // of parameters for a curve is given by the Count property.
            //
            // For polynomials, the parameters are the coefficients
            // of the polynomial. The constant term has index 0:
            Console.WriteLine("polynomial1.Parameters.Count = {0}", 
                polynomial1.Parameters.Count);
            // Parameters can easily be retrieved:            
            Console.Write("polynomial1 parameters:");
            for(index = 0; index < polynomial1.Parameters.Count; index++)
                Console.Write("{0} ", polynomial1.Parameters[index]);
            Console.WriteLine();
            // We can see that polynomial2 defines the same polynomial 
            // curve as polynomial1:
            Console.Write("polynomial2 parameters:");
            for(index = 0; index < polynomial2.Parameters.Count; index++)
                Console.Write("{0} ", polynomial2.Parameter[index]);
            Console.WriteLine();
            Console.Write("polynomial2 parameters:");
            for(index = 0; index < polynomial2.Parameters.Count; index++)
                Console.Write("{0} ", polynomial2.Parameter[index]);
            Console.WriteLine();
            // Parameters can also be set:
            polynomial2.Parameter[0] = 1.0;

            // For polynomials and other classes that inherit from
            // the LinearCombination class, the parameters are also
            // available through the indexer property of the curve object itself.
            // The following is equivalent to the line above:
            polynomial2[0] = 1;

            // The degree of the polynomial is returned by
            // the Degree property:
            Console.WriteLine("Degree of polynomial3 = {0}", 
                polynomial3.Degree);

            //
            // Curve Methods
            //

            // The ValueAt method returns the y value of the
            // curve at the specified x value:
            Console.WriteLine("polynomial1.ValueAt(2) = {0}", polynomial1.ValueAt(2));

            // The SlopeAt method returns the slope of the curve
            // a the specified x value:
            Console.WriteLine("polynomial1.SlopeAt(2) = {0}", polynomial1.SlopeAt(2));

            // You can also create a new curve that is the 
            // derivative of the original:
            Curve derivative = polynomial1.GetDerivative();
            Console.WriteLine("Slope at 2 (derivative) = {0}", derivative.ValueAt(2));
            // For a polynomial, the derivative is a Quadratic curve
            // if the degree is equal to three:
            Console.WriteLine("Type of derivative: {0}",
                derivative.GetType().FullName);
            Console.Write("Derivative parameters: ");
            for(index = 0; index < derivative.Parameters.Count; index++)
                Console.Write("{0} ", derivative.Parameters[index]);
            Console.WriteLine();
            // If the degree is 4 or higher, the derivative is
            // once again a polynomial:
            Console.WriteLine("Type of derivative for polynomial3: {0}", 
                polynomial3.GetDerivative().GetType().FullName);

            // You can get a Line that is the tangent to a curve
            // at a specified x value using the TangentAt method:
            Line tangent = polynomial1.TangentAt(2);
            Console.WriteLine("Tangent line at 2:");
            Console.WriteLine("  Y-intercept = {0}", tangent.Parameters[0]);
            Console.WriteLine("  Slope = {0}", tangent.Parameters[1]);

            // For many curves, you can evaluate a definite
            // integral exactly:
            Console.WriteLine("Integral of polynomial1 between 0 and 1 = {0}",
                polynomial1.Integral(0, 1));

            // You can find the zeroes or roots of the curve
            // by calling the FindRoots method. Note that this
            // method only returns the real roots.
            roots = polynomial1.FindRoots();
            Console.WriteLine("Number of roots of polynomial1: {0}",
                roots.Length);
            Console.WriteLine("Value of root 1 = {0}", roots[0]);
            // Let's find polynomial3's roots again:
            roots = polynomial3.FindRoots();
            Console.WriteLine("Number of roots of polynomial3: {0}",
                roots.Length);
            Console.WriteLine("Value of root = {0}", roots[0]);
            Console.WriteLine("Value of root = {0}", roots[1]);
            // Root finding isn't an exact science. Note the 
            // round-off error in these values:
            Console.WriteLine("Value of root = {0}", roots[2]);
            Console.WriteLine("Value of root = {0}", roots[3]);

            // For more advanced uses of the Polynomial class,
            // see the AdvancedPolynomials QuickStart sample.

            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
Information
Resources
Contact Us
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