Monday, December 9, 2013

Newton Raphson Method to solve non-linear equations

Introduction

It is one of the most widely used methods of solving equation as it is more rapidly convergent than other methods. Starting from single initial estimate, x0, that is not too far from a root, we move along the tangent to its intersection with the x-axis, and take that as the next approximation. This is continued as
x_{n+1} = x_n - \frac{f(x_n)}{f'(x_n)} \,
until either the successive x-values are sufficiently close or the value of the function is sufficiently near zero.


Newton Raphson Method in Codes

/*A program to find a root of function using Newton Raphson Method */

#include<stdio.h>
#include<math.h>

float f(float x)
{
    return x*sin(x) + cos(x);
}

float g(float x)
{
    return x*cos(x);        /* Derivative of function f(x) */
}

int main()
{
    float x0, x1, a, b, c;

    printf("Enter the 'a' and 'b' of interval (a,b)\n\n");
    scanf("%f%f",&a,&b);

    x0= (a+b)/2;

    for(c=0;c<20;c++)     /* The loop is repeated just 20 times as this method is expected to give root in 5/10 steps generally */
    {
        if(g(x0)==0)
            printf("\n\nErooooooooorrrrrr");
        else
            x1 = x0 - f(x0) / g(x0);

        x0=x1;
    }

    printf("\n\nThe required root is %f\n\n",x0);
    return 0;

}

Friday, December 6, 2013

Roots by Bisection Method

Introduction

Bisection method is one of the most ancient and surely the simplest method to find the root of a function. But it is relatively time consuming method. First, we must know an interval in which a root lies. Root is found by repeatedly bisecting an interval. Successive values converge on a root of function f(x) when we begin with a pair of values that bracket the root. Let's take the interval (x1, x2) , x3 is halfway between x1 and x2, x4 is halfway between x2 and x3. We always take the next x-value as the midpoint of the last pair that bracket the root : these values bracket the root when there is sign change of f(x) at the two points. We repeat the process until we converge to the root.



Using C programming language to solve a function by Bisection Method


/*  To determine the root of a function by Bisection Method */

#include<stdio.h>
#include<math.h>

float f(float x)
{
    return x*sin(x) + cos(x);                   /* A continuous equation between given interval*/
 
}


int main()
{
    float a,b,c,d,e;

    printf("\nEnter  the interval (a,b)\n");
    scanf("%f%f",&a,&b);

    printf("\nEnter the tolerance value\n");
    scanf("%f",&d);

    do
    {
        c = (a+b)/2;
        if(f(c) * f(a) < 0)
            b=c;
        else
            a=c;
    }while( fabs(a-b)>d||f(c)==0);

    printf("Root is %f",c);

    return 0;

}