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

Extreme Optimization Mathematics Library for .NET

OptimizationInND QuickStart Sample (C#)

Illustrates the use of the Brent and Golden Section optimizer classes in the Extreme.Mathematics.Optimization namespace for one-dimensional optimization in C#.

VB.NET code Back to QuickStart Samples

using System;

namespace Extreme.Mathematics.QuickStart.CSharp
{
    // The optimization classes reside in the
    // Extreme.Mathematics.Optimization namespace.
    using Extreme.Mathematics.Optimization;
    // Function delegates reside in the Extreme.Mathematics
    // namespace.
    using Extreme.Mathematics;
    // Vectors reside in the Extreme.Mathematics.LinearAlgebra
    // namespace.
    using Extreme.Mathematics.LinearAlgebra;

    /// <summary>
    /// Illustrates unconstrained optimization in multiple dimensions
    /// using classes in the Extreme.Mathematics.Optimization 
    /// namespace of the Extreme Optimization Mathematics Library 
    /// for .NET.
    /// </summary>
    class OptimizationInND
    {
        /// <summary>
        /// The main entry point for the application.
        /// </summary>
        [STAThread]
        static void Main(string[] args)
        {
            //
            // Objective function
            //

            // The objective function must be supplied as a
            // MultivariateRealFunction delegate. This is a method 
            // that takes one Vector argument and returns a real number.
            // See the end of this sample for definitions of the methods 
            // that are referenced here.
            MultivariateRealFunction f = 
                new MultivariateRealFunction(fRosenbrock);

            // The gradient of the objective function can be supplied either
            // as a MultivariateVectorFunction delegate, or a
            // MultivariateVectorFunction delegate. The former takes
            // one vector argument and returns a vector. The latter
            // takes a second vector argument, which is an existing
            // vector that is used to return the result.
            FastMultivariateVectorFunction g = 
                new FastMultivariateVectorFunction(gRosenbrock);

            // The initial values are supplied as a vector:
            GeneralVector initialGuess = new GeneralVector(-1.2, 1);
            // The actual solution is [1, 1].

            //
            // Quasi-Newton methods: BFGS and DFP
            //

            // For most purposes, the quasi-Newton methods give
            // excellent results. There are two variations: DFP and
            // BFGS. The latter gives slightly better results.

            // Which method is used, is specified by a constructor
            // parameter of type QuasiNewtonMethod:
            QuasiNewtonOptimizer bfgs = 
                new QuasiNewtonOptimizer(QuasiNewtonMethod.Bfgs);

            bfgs.InitialGuess = initialGuess;
            bfgs.ExtremumType = ExtremumType.Minimum;

            // Set the ObjectiveFunction:
            bfgs.ObjectiveFunction = f;
            // Set either the GradientFunction or FastGradientFunction:
            bfgs.FastGradientFunction = g;
            // The FindExtremum method does all the hard work:
            bfgs.FindExtremum();

            Console.WriteLine("BFGS Method:");
            Console.WriteLine("  Solution: {0}", bfgs.Extremum);
            Console.WriteLine("  Estimated error: {0}", bfgs.EstimatedError);
            Console.WriteLine("  # iterations: {0}", bfgs.IterationsNeeded);
            // Optimizers return the number of function evaluations
            // and the number of gradient evaluations needed:
            Console.WriteLine("  # function evaluations: {0}", bfgs.EvaluationsNeeded);
            Console.WriteLine("  # gradient evaluations: {0}", bfgs.GradientEvaluationsNeeded);

            //
            // Conjugate Gradient methods
            //

            // Conjugate gradient methods exist in three variants:
            // Fletcher-Reeves, Polak-Ribiere, and positive Polak-Ribiere.

            // Which method is used, is specified by a constructor
            // parameter of type ConjugateGradientMethod:
            ConjugateGradientOptimizer cg = 
                new ConjugateGradientOptimizer(ConjugateGradientMethod.PositivePolakRibiere);
            // Everything else works as before:
            cg.ObjectiveFunction = f;
            cg.FastGradientFunction = g;
            cg.InitialGuess = initialGuess;
            cg.FindExtremum();

            Console.WriteLine("Conjugate Gradient Method:");
            Console.WriteLine("  Solution: {0}", cg.Extremum);
            Console.WriteLine("  Estimated error: {0}", cg.EstimatedError);
            Console.WriteLine("  # iterations: {0}", cg.IterationsNeeded);
            Console.WriteLine("  # function evaluations: {0}", cg.EvaluationsNeeded);
            Console.WriteLine("  # gradient evaluations: {0}", cg.GradientEvaluationsNeeded);

            //
            // Powell's method
            //

            // Powell's method is a conjugate gradient method that
            // does not require the derivative of the objective function.
            // It is implemented by the PowellOptimizer class:
            PowellOptimizer pw = new PowellOptimizer();
            pw.InitialGuess = initialGuess;
            // Powell's method does not use derivatives:
            pw.ObjectiveFunction = f;
            pw.FindExtremum();

            Console.WriteLine("Powell's Method:");
            Console.WriteLine("  Solution: {0}", pw.Extremum);
            Console.WriteLine("  Estimated error: {0}", pw.EstimatedError);
            Console.WriteLine("  # iterations: {0}", pw.IterationsNeeded);
            Console.WriteLine("  # function evaluations: {0}", pw.EvaluationsNeeded);
            Console.WriteLine("  # gradient evaluations: {0}", pw.GradientEvaluationsNeeded);

            //
            // Nelder-Mead method
            //

            // Also called the downhill simplex method, the method of Nelder 
            // and Mead is useful for functions that are not tractable 
            // by other methods. For example, other methods
            // may fail if the objective function is not continuous.
            // Otherwise it is much slower than other methods.

            // The method is implemented by the NelderMeadOptimizer class:
            NelderMeadOptimizer nm = new NelderMeadOptimizer();

            // The class has three special properties, that help determine
            // the progress of the algorithm. These parameters have
            // default values and need not be set explicitly.
            nm.ContractionFactor = 0.5;
            nm.ExpansionFactor = 2;
            nm.ReflectionFactor = -2;

            // Everything else is the same.
            nm.AbsoluteTolerance = 1e-15;
            nm.InitialGuess = initialGuess;
            // The method does not use derivatives:
            nm.ObjectiveFunction = f;
            nm.FindExtremum();

            Console.WriteLine("Nelder-Mead Method:");
            Console.WriteLine("  Solution: {0}", nm.Extremum);
            Console.WriteLine("  Estimated error: {0}", nm.EstimatedError);
            Console.WriteLine("  # iterations: {0}", nm.IterationsNeeded);
            Console.WriteLine("  # function evaluations: {0}", nm.EvaluationsNeeded);

            Console.Write("Press Enter key to exit...");
            Console.ReadLine();
        }

        // The famous Rosenbrock test function.
        static double fRosenbrock(Vector x)
        {
            double p = (1-x[0]);
            double q = x[1] - x[0]*x[0];
            return p*p + 105 * q*q;
        }

        // Gradient of the Rosenbrock test function.
        static Vector gRosenbrock(Vector x, Vector f)
        {
            // Always assume that the second argument may be null:
            if (f == null)
                f = new GeneralVector(2);
            double p = (1-x[0]);
            double q = x[1] - x[0]*x[0];
            f[0] = -2*p - 420*x[0]*q;
            f[1] = 210*q;
            return f;
        }
    }
}
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