KEMBAR78
MATLAB Basics for EEE Students | PDF | Interpolation | Matrix (Mathematics)
0% found this document useful (0 votes)
364 views73 pages

MATLAB Basics for EEE Students

MATLAB can be used for numerical computation, visualization, and programming. It has three main types of windows: Command, Figure, and Editor. The Command window is used for direct commands, Figure window displays plots, and Editor writes and edits M-files (MATLAB programs). MATLAB works with matrices and vectors, has built-in functions for math operations, and can generate plots and graphs. It also allows for user-defined functions and control flow structures like if/else statements and loops.

Uploaded by

TowsifTaher
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
364 views73 pages

MATLAB Basics for EEE Students

MATLAB can be used for numerical computation, visualization, and programming. It has three main types of windows: Command, Figure, and Editor. The Command window is used for direct commands, Figure window displays plots, and Editor writes and edits M-files (MATLAB programs). MATLAB works with matrices and vectors, has built-in functions for math operations, and can generate plots and graphs. It also allows for user-defined functions and control flow structures like if/else statements and loops.

Uploaded by

TowsifTaher
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 73

Department of Electrical & Electronic Engineering

Bangladesh University of Engineering & Technology


EEE 212: Numerical Technique Laboratory
Experiment 1 & 2: Introduction to MATLAB
# MATLAB works with three types of windows on your computer screen. These are the
Command window, the Figure window and the Editor window. The Figure window only
pops up whenever you plot something. The Editor window is used for writing and editing
MATLAB programs (called M-files) and can be invoked in Windows from the pull-down
menu after selecting File | New | M-file.
# Create a folder of your group name in C drive.
# Open MATLAB 6.5. In "current directory'' select your folder.
# From the "file" menu start a new m-file. Always write your program in m-file & save it. The
file/function/variable name must start with a letter and cannot contain space. The name can be a
mix of letters, digits, and underscores. (e.g., vector_A, but not vector-A (since "-" is a reserved
char). must not be longer than 31 characters.
# You can also write any command or program in "command window".
# Function "clear all" removes all variables, globals, functions and MEX links. Write clear all at
the beginning of your m-file.
# Write "clc" in command window to clear the command window, "clg" to clear graphics window.
# MATLAB is case sensitive. e.g., NAME, Name, name are 3 distinct variables.
# Write "help function_name" in command window after the ">>" sign to see the description of the
function. For example, type "help sin" to know about sin functions in MATLAB. You can also use
help in the menubar.
Explore MATLABs lookfor and help capability by trying the following:
>> lookfor keywords
>> help
>> help plot
>> help ops
>> help arith

Special Characters:
There are a number of special reserved characters used in MATLAB for various purposes. Some of
these are used as arithmetic operators, namely, +, -, *, / and \. While others perform a multitude of
purposes:

% -- anything after % (and until end of line) is treated as comments, e.g.,

Page 1 of 11:Expt 1 & 2

>> x = 1:2:9; % x = [1 3 5 7 9];

; -- delimits statements; suppresses screen output, e.g.,

>> x = 1:2:9; y = 2:10; % two statements on the same line

... -- statement continuation, e.g.,

>> x = [ 1 3 5 ...
7 9]; % x = [1 3 5 7 9] splitted into 2 lines

: -- range delimiter, e.g.,

>> x = [1:2:9]; % x=[1,3,5,7,9]


' -- matrix transposition, e.g.,
>> x = [1:2:9]'; % x changed from row vector to column vector
If the vector/matrix is complex, results in complex conjugation and matrix
transposition.

, -- command delimiter, e.g.,

>> x = [1:2:9], y = [1:9] % two statements on the same line

. -- precede an arithmetic operator to perform an elemental operation,


instead of matrix operation, e.g.,

>> x = 3:3:9
x=
3

>> y = 3*ones(3,1)'
y=
3

>> z =x./y
z=
1

Page 2 of 11:Expt 1 & 2

* -- "wild card", e.g.,

>> clear A* % clears all variables that start with A.


Note that many of these characters have multiple functionalities (function overloading) depending
on the context, e.g., "*" is used for scalar multiply, matrix multiply and "wild card" as seen above.

Arithmetic Operations & Built in functions:


#Example1. Find y = exp(52 / 3 pi ) .
Solution: In m-file write the following command
clear all;
a=5^2;
b=3*pi;
y=exp(a/b);
disp(y)
#Save the file and run the program from Debug menu. Type y in command window and
press enter.
# Remove ; from all the lines and run the program.
# Write each line in command window and press enter after each line.
# Variable names are assigned to expressions by using equal sign. For example, a=5^2;
here a is the variable that store the value of 5^2 or 25.
# See the list of built in functions from help menu. Some built in functions are
abs() cos() sin() exp() log() real() sqrt() floor() ceil()
#Exercise 1. Find the value of y = ln(sinh(exp(543 / 6* pi)))
Matrices:
# Write A= [1 2 3; 4 5 6; 7 6 3] in command window and press enter. It is a 33 matrix.
# Write A(1,3) in command window to view the 3rd element in 1st row. The first parameter within
bracket denotes row and the second parameter denotes column.
# Z=zeros(2,3) creates a 23 matrix of zeros. Similarly ones(), eye() create special types of
matrices.
# Write A=0:0.3:3 in command window. 0 is the starting value, 3 is the end value and 0.3 is the
step value.
# Write help size, help prod and help length in command window.
# Exercise 2: Find the size, and length of following matrices
A=[1 2 3; 4 5 6;7 6 54; 65 23 45]
B=7:1:13.5
# Write A(1:2,2:3) in command window. Write A([1 2],[2 3]). These are different ways to select a
submatrix of a matrix.
Page 3 of 11:Expt 1 & 2

#A(1,1)=sin(5); assign a new value to an element of A.

Matrix Operations:
# All arithmetic operations can be performed on matrices.
# Operations can be performed on each element or on whole matrix. For example,
>> x = 3:3:9
>> y = 3*ones(3,1)'
>> z =x./y
# Some operations are performed on square matrices only.
# + - * / ^ (algebraic/matrix definitions)
.+ .- .* ./ .^ (element by element operation)
Additionally,
" ' " performs matrix transposition; when applied to a complex matrix, it includes elemental
conjugations
followed
by
a
matrix
transposition
\ and .\ perform matrix and elemental left division
#Exercise 3. A=[2 3; 4 5]; B=[3 4; 6 7];
Find A+B, A*B, A.*B,A/B,A\B, A.^2,A./B
Graphics:
# MATLAB can produce 2 and 3 dimensional plots.
MATLAB is an interactive environment in which you can program as well as visualize your
computations. It includes a set of high-level graphical functions for:

Line plots(plot, plot3, polar)


Bar graphs(bar, barh, bar3, bar3h, hist, rose, pie, pie3)
Surface plots(surf, surfc)
Mesh plots(mesh, meshc, meshgrid)
Contour plots(contour, contourc, contourf)
Animation(moviein, movie)

#Example 2.
x=0:0.1:pi;
y=cos(x);
plot(y);
plot(x,cos(x),r);
plot(x,y,x,y.^2);

Page 4 of 11:Expt 1 & 2

#Example 3.
x=0:0.1:pi;
y=cos(x);
plot(y);
hold on
plot(x,cos(x),r);
#Example 4.
x=linspace(0,7);
y=exp(x);
subplot(2,1,1), plot(x,y);
subplot(2,1,2), semilogy(x,y);
# Example 5.
x = magic(3);
bar(x);
grid

#Exercise 4. Plot the following functions in the same window y1=sin x, y2=sin 2x, y3=sin 3x,
y4=sin 4x where x varies from 0 to pi.

Loops & Conditionals:


#MATLAB has the following flow control constructs:
if statements
switch statements
for loops
while loops
break statements
The if, for, switch and while statements need to terminate with an end statement.
Example:
#Example 6. IF:
x=-3;
if x>0
a=10;
elseif x<0
a=11;
elseif x= = 0
a=12;
else
a=14;

Page 5 of 11:Expt 1 & 2

end
What is the value of a after execution of the above code?

#Example 7. WHILE:
x=-10;
while x<0
x=x+1;
end
What is the value of x after execution of the above loop?
#Example 8. FOR loop:
x=0;
for i=1:10
x=x+1;
end
What is the value of x after execution of the above loop?
Defining matrices via the vector technique
Using the for loop in MATLAB is relatively expensive. It is much more efficient to perform the
same task using the vector method. For example, the following task
for j=1:n
for i=1:m
A(i,j) = B(i,j) + C(i,j);
end
end
can be more compactly and efficiently represented (and computed) by the vector method as
follows:
A(1:m,1:n) = B(1:m,1:n) + C(1:m,1:n);
If the matrices are all of the same size (as is the case here), then the above can be more succinctly
written as
A = B + C;
For sufficiently large matrix operations, this latter method is vastly superior in performance.

Page 6 of 11:Expt 1 & 2

#Example 9. BREAK:
The break statement lets you exit early from a for or a while loop:
x=-10;
while x<0
x=x+2;
if x = = -2
break;
end
end
What is the value of x after execution of the above loop?

Relational Operators
Symbol Meaning
<=
Lessthanequal
<
Less than
>=
Greater than equal
>
Greater than
==
Equal
=
Not equal

Logical Operators
Symbol Meaning
&
AND
|
OR

NOT
Defining functions:
# In MATLAB there is scope for user-defined functions.
Suggestion: Since MATLAB distinguishes one function from the next by their file names, name files
the same as function names to avoid confusion. Use only lowercase letter to be consistent with
MATLAB's convention.
# To define a function, start a new M-file
The first line of M-file should be
function variable_name=function_name(parameters);
variable_name is the name of variable whose value will be returned.
function_name is user defined according to the rules stated previously.

Page 7 of 11:Expt 1 & 2

#Example 10:
function y=cal_pow(x);
y=1+x^2;
end
# Save this function as cal_pow.
# Start another new M-file .This will be our main file.
# Write the following commands and run the file:
clear all;
x=0:1:3;
t=length(x);
for i=1:t
val(i)=cal_pow(x(i));
end
plot(x,val);
Do the following:
# Exercise 5. Write a program to compute the variance of an array x . The variance is defined to
be:
2
1 N
= ( xi x )
N i =1
where x is the average of the array x .
(a) For x , use all the integers from 1 to 1000.
(b) Create x by built in function rand.
# Exercise 6 . Define the matrices
A=[17 2 3 4; 5 6 7 8; 9 10 11 12; 13 14 15 16]
B=[ 2 3 4 5 ; 6 7 8 9 ; 10 11 12 13 ; 14 15 16 17 ]
C=[ 1 2 3 ; 4 5 6 ; 7 8 9 ]
y=[ 4 3 2 1 ]'
Note the transpose ' on the y-vector which makes y a column vector.
a) Compute AB and BA. Is matrix multiplication commutative?
b) Compute AC. Why do you get an error message?
c) Solve the following system of equations:

17x1+2x2+3x3+4x4 = 4
5x1+6x2+7x3+8x4 = 3

Page 8 of 11:Expt 1 & 2

9x1+10x2+11x3+12x4 = 2
13x1+14x2+15x3+16x4 = 1
# Exercise 7 . Solve the following circuit to find i1, i2, and i3.

R1

R2

1ohm i2

2ohm

R3
i1
V1

3ohm

V2

7Vdc
6Vdc

R5
i3
R4

1ohm

2ohm

Ans: i1= 3 amp, i2= 2 amp, i3= 3 amp.


# Exercise 8. An N-point Kaiser window is given by
1
2 2

I 0 1 ( n )

, n = 0, 1,.........N 1
w(n) =
I0 ( )

where = ( N 1)

for linear phase FIR filter, N

is the filter length and is the Kaiser

window parameter. N can be odd or even. I 0 ( ) is the zero order modified Bessel function of the
first kind, which is defined by the following infinite series:
2

( x / 2) L
I o ( x) = 1 +
L !
L =1
Recommended upper limit of series that is Lmax=32.

Empirical formulas for finding N and : If the transition width (normalized) and stop band
attenuation are and respectively then
A = 20 log( );
A8

N = floor
+ 1 ; %%% N should be of integer type. See what does built in matlab
2.285

function floor do.

Page 9 of 11:Expt 1 & 2

0.1102( A 8.7), A > 50

= 0.5842( A 21) 0.4 + 0.07886( A 21), 21 A 50


0.0, A < 21

The impulse response, hD (n) for low pass filter is given below:

hD ( n) =

2 fc

sin((n N21 )2f c )


' n
(n N21 )2f c
2 fc ,
n=

N 1
2
N 1
2

Design a linear phase low pass FIR filter using the Kaiser window to satisfy the following amplitude
response specifications:

Sampling frequency, Fs
Ideal cutoff frequency, Fc
Transition width, F
Pass band ripple,

1 kHz
250 Hz
50 Hz
0.001

(a) Write M-file to plot impulse response h(n) = hD (n).w(n) vs. n of the filter.
(b) Plot magnitude (in dB) and phase response (in degrees) vs. analog frequency. To do this
necessary codes are given at the end of this sessional sheet.

N.B.

fc =

Fc
Fs

F
Fs
Follow the algorithm below to write the codes for Kaiser Window FIR low pass filter impulse
response:
= 2 f = 2

1. Enter the inputs Fs , Fc , F , and Lm.


2. Evaluate f c , , A, N , , and I 0 ( ). Create a matlab subprogram to calculate I 0 ( ) as
calculation of zero order modified Bessel function of the first kind will be needed several
times.
3. For each value of n , evaluate

I 0 ( x); x = 1

( n )

, w(n) and hD (n). Now calculate h(n).

4. Now make a plot h(n) .

%%%finding filter magnitude and phase response in frequency domain

Page 10 of 11:Expt 1 & 2

NFFT=1024;
hfir=fft(hFIR,NFFT); %%%%% hFIR=calculated h(n) earlier
k=0:NFFT-1;
%waxis=2*pi*1/NFFT.*k;
faxis=1/NFFT.*k;
magresdB=20*log10(abs(hfir));
subplot(312),plot(faxis(1:NFFT/2+1)*Fs,magresdB(1:NFFT/2+1))
grid on;
xlabel('Frequency (Hz)')
ylabel('Magnitude response (dB)')
subplot(313),plot(faxis(1:NFFT/2+1)*Fs,(unwrap(angle(hfir(1:NFFT/2+1))))*180/pi)
grid on;
xlabel('Frequency (Hz)')
ylabel('Phase response (degrees)')
%%%finding magnitude and phase response by freqz built in function
% figure
% freqz(hFIR,1);

Reference Books:
1. Numerical Methods using MATLAB
by
John H. Mathews and Kurtis D. Fink
2.Engineering problem solving with MATLAB
by
D. M. Etter

Revised by,
Emran Md. Amin

Page 11 of 11:Expt 1 & 2

Department of Electrical and Electronic Engineering


Bangladesh University of Engineering and Technology
EEE 212: Numerical Technique Laboratory
Experiment 3: Interpolation
Introduction:
Forming a polynomial:
A polynomial, p(x) of degree n in MATLAB is stored as a row vector, p, of length n+1.
The components represent the coefficients of the polynomial and are given in the
descending order of the power of x, that is
p = [an an-1 .. a1 a0]
is interpreted as
p(x) = anxn+ an-1xn-1+ ..+ a1x+a0
In MATLAB the following commands are used to evaluate a polynomial:
polyval, poly, roots, conv etc.
Exercise 1: Construct a polynomial such that C(x)= A(x)*B(x)
Where A(x)= 3x2+2x-4 and B(x)= 2x3-2
Also find the roots of A(x), B(x) and C(x).

Interpolation:
In the mathematical subfield of numerical analysis, interpolation is a method of
constructing new data points from a discrete set of known data points.
In engineering and science one often has a number of data points, as obtained by
sampling or some experiment, and tries to construct a function which closely fits those
data points. This is called curve fitting. Interpolation is a specific case of curve fitting, in
which the function must go exactly through the data points.
Definition:
Given a sequence of n distinct numbers xk called nodes and for each xk a second number
yk, we are looking for a function f so that

A pair xk,yk is called a data point and f is called the interpolant for the data points.

3-1

For example, suppose we have a table like this, which gives some values of an unknown
function f. The data are given in the table:
Table 1
x
0
1
2
3
4
5
6

f(x)
0
0.8415
0.9093
0.1411
-0.7568
-0.9589
-0.2794

The plot can be shown as:


.

What value does the function have at, say, x = 2.5? Interpolation answers questions like
this.

Types of interpolation:
A. Linear interpolation
One of the simplest methods is linear interpolation. Consider the above example of
determining f(2.5). We join the data points by linear interpolation and get the following
plot:

3-2

Noe we can get f(2.5). Since 2.5 is midway between 2 and 3, it is reasonable to take f(2.5)
midway between f(2) = 0.9093 and f(3) = 0.1411, which yields 0.5252.
Generally, linear interpolation takes two data points, say (xa,ya) and (xb,yb), and the
interpolant is given by

This formula can be interpreted as a weighted mean.


Linear interpolation is quick and easy, but it is not very precise.
Exercise 2. Plot the curve corresponding to table1 using linear interpolation.
Exercise 3. y = sin( x); x = 0 :10; x(i) = 0 : 0.25 :10; Construct the interpolant y and plot.

B. Polynomial interpolation
Polynomial interpolation is a generalization of linear interpolation. Note that the linear
interpolant is a linear function. We now replace this interpolant by a polynomial of higher
degree.
Consider again the problem given above. The following sixth degree polynomial goes
through all the seven points:
f(x) = 0.0001521x6 0.003130x5 + 0.07321x4 0.3577x3 + 0.2255x2 + 0.9038x

Substituting x = 2.5, we find that f(2.5) = 0.5965.

3-3

Generally, if we have n data points, there is exactly one polynomial of degree n1 going
through all the data points. The interpolation error is proportional to the distance between
the data points to the power n.
However, polynomial interpolation also has some disadvantages. Calculating the
interpolating polynomial is relatively very computationally expensive Furthermore,
polynomial interpolation may not be so exact after all, especially at the end points.
a. Lagrange Polynomial:

The Lagrange interpolating polynomial is the polynomial P ( x) of degree (n 1) that


passes through the n points
,
, ...,
, and is
given by

where

Written explicitly,

When constructing interpolating polynomials, there is a tradeoff between having a better


fit and having a smooth well-behaved fitting function. The more data points that are used
in the interpolation, the higher the degree of the resulting polynomial, and therefore the
greater oscillation it will exhibit between the data points. Therefore, a high-degree
interpolation may be a poor predictor of the function between points, although the
accuracy at the data points will be "perfect."
For

points,

3-4

Note that the function P( x) passes through the points


,

, as can be seen for the case

Algorithm for the Lagrange Polynomial: To construct the Lagrange polynomial

of degree n, based on the n+1 points


coefficient polynomials for degree n are:

for

for

. The Lagrange

So, for a given x and a set of (N+1) data pairs, (xi, fi), i= 0, 1, . .. N:
Set SUM=0
DO FOR i=0 to N
Set P=1
DO FOR j=0 to N
IF j~=i
Set P=P*(x-x(j))/(x(i)-x(j))
End DO(j)
Exercise 4. Write a MATLAB program implementing Lagrange Polynomial.
Exercise 5. Construct a Lagrange interpolating polynomials for the data points given in
table 1.

3-5

b. Newton polynomial:
To construct and evaluate the Newton polynomial of degree n that passes through the
n + 1 points ( xk , yk ) = ( xk , f ( xk )) for k = 0,1,KKK n :

This polynomial Pn(x) is said to be a Newton Polynomial with n centers x0, x1 to xn-1. It
involves sums of products of linear factors upto

an(x-x0)(x-x1)(x-x2)(x-xn-1)
Construction for n = 1.

Use the two points

Algorithm:

To construct and evaluate the Newton polynomial of degree n that passes through the
n + 1 points ( xk , yk ) = ( xk , f ( xk )) , for k = 0,1,KKK n :

where

.
So for a given set of (N+1) data pairs, (xk,yk), k= 0 to N
DO FOR j= 2 to (N+1)
DO FOR k= j to (N+1)

3-6

Compute D(k,j)= (D(k,j-1)-D(K-1,j-1))/(x(k)-x(k-j+1))


END DO(k)
END DO(j)
Exercise 6. Write a MATLAB Program implementing the algorithm of Newton
polynomial.
Exercise 7. Construct a Newton interpolating polynomials for the data points given in
table 1.

Note: There are some functions in MATLAB which perform interpolation of data in
different ways e.g. interp1, interp2 etc.

Revised by,
Emran Md. Amin

3-7

Bangladesh University of Engineering and Technology


Department of Electrical and Electronic Engineering
EEE 212
Numerical Technique Laboratory
Experiment No 4
Curve Fitting
Introduction:
Data is often given for discrete values along a continuum. However we may require
estimates at points between the discrete values. Then we have to fit curves to such
data to obtain intermediate estimates. In addition, we may require a simplified version
of a complicated function. One way to do this is to compute values of the function at a
number of discrete values along the range of interest. Then a simpler function may be
derived to fit these values. Both of these applications are known as curve fitting.
There are two general approaches of curve fitting that are distinguished from each
other on the basis of the amount of error associated with the data. First, where the data
exhibits a significant degree of error, the strategy is to derive a single curve that
represents the general trend of the data. Because any individual data may be incorrect,
we make no effort to intersect every point. Rather, the curve is designed to follow the
pattern of the points taken as a group. One approach of this nature is called least
squares regression.
Second, where the data is known to be very precise, the basic approach is to fit a
curve that passes directly through each of the points. The estimation of values
between well known discrete points from the fitted exact curve is called interpolation.

Figure 1: (a) Least squares linear regression (b) linear interpolation (c) curvilinear
interpolation
1

Least squares Regression:


Where substantial error is associated with data, polynomial interpolation is
inappropriate and may yield unsatisfactory results when used to predict intermediate
values. A more appropriate strategy for such cases is to derive an approximating
function that fits the shape or general trend of the data without necessarily matching
the individual points. Now some criterion mush be devised to establish a basis for the
fit. One way to do this is to derive a curve that minimizes the discrepancy between the
data points and the curve. A technique for accomplishing this objective is called least
squares regression, where the goal is to minimize the sum of the square errors
between the data points and the curve. Now depending on whether we want to fit a
straight line or other higher order polynomial, regression may be linear or polynomial.
They are described below.
Linear regression:
The simplest example of least squares regression is fitting a straight line to a set of
paired observations: (x1, y1), (x2, y2), , , ,(xn, yn). The mathematical expression for
straight line is
ym=a0+a1x
Where a0 and a1 are coefficients representing the intercept and slope and ym is the
model value. If y0 is the observed value and e is error or residual between the model
and observation then
e=y0-ym=y0 - a0 - a1x
Now we need some criteria such that the error e is minimum and also we can arrive at
a unique solution (for this case a unique straight line). One such strategy is to
minimize the sum of the square errors. So sum of square errors
n

i =1

i =1

i =1

S r = ei2 = ( yi ,observed yi ,mod el ) 2 = ( yi a0 a1 xi ) 2 ..1


To determine the values of a0 and a1, equation (1) is differentiated with respect to each
coefficient.

S r
= 2 ( yi a0 a1 xi )
a0
S r
= 2 ( yi a0 a1 xi )xi
a1
Setting these derivatives equal to zero will result in a minimum Sr. If this is done, the
equations can be expressed as
0 = yi a0 a1 xi

0 = yi xi a0 xi a1 xi2

Now realizing that

= na0 , we can express the above equations as a set of two

simultaneous linear equations with two unknowns a0 and a1.


na0 + ( xi )a1 = yi
( xi )a0 + ( xi2 )a1 = xi yi

from where
a1 =

n xi yi xi yi
n xi2 ( xi ) 2

a0 = y a1 x
Where y and x are the means of y and x respectively

Example 1:
Fit a straight line to the x and y values of table 1

x
1
2
3
4
5
6
7

Table 1:
y
0.5
2.5
2.0
4.0
3.5
6.0
5.5

Ans: a0=0.071142857, a1=0.8392857

%program for fitting a straight line


%entering no. of observed points
n=input('How many points ');
%taking input
for i=1:n
x(i)=input('');
y(i)=input('');
end
%calculating coefficients
sumx=0;
sumy=0;
sumxy=0;
sumxsq=0;
for i=1:n
sumx=sumx+x(i);
sumy=sumy+y(i);
sumxy=sumxy+x(i)*y(i);
sumxsq=sumxsq+x(i)^2;
end
format long ;
%calculating a1 and a0
a1=(n*sumxy-sumx*sumy)/(n*sumxsq-sumx^2)
a0=sumy/n-a1*sumx/n
%plotting observed data
plot(x,y,'o')
hold on;
%plotting fitted data
ym=a0+a1.*x;
plot(x,ym);

Polynomial Regression:
In some cases, we have some engineering data that cannot be properly represented by
a straight line. We can fit a polynomial to these data using polynomial regression.

Figure 2: (a) Data that is ill-suited for linear least squares regression (b) indication
that a parabola is preferable
The least squares procedure can be readily extended to fit the data to a higher order
polynomial. For example, we want to fit a second order polynomial
ym=a0 + a1x+ a2x2
For this case the sum of the squares of residuals is
n

S r = ( yi a0 a1 xi a2 xi2 ) 2 2
i =1

Taking derivative of equation (2) with respect to unknown coefficients a0, a1 and a2
S r
= 2 ( yi a0 a1 xi a2 xi2 )
a0
S r
= 2 xi ( yi a0 a1 xi a2 xi2 )
a1
S r
= 2 xi2 ( yi a0 a1 xi a2 xi2 )
a2
These equations can be set equal to zero and rearranged to develop the following set
of normal equations:

na0 + ( xi )a1 + ( xi2 )a2 = y i

( xi )a0 + ( xi2 )a1 + ( xi3 )a2 = xi yi

( xi2 )a0 + ( xi3 )a1 + ( xi4 )a2 = xi2 yi


5

Now a0, a1 and a2 can be calculated using matrix inversion.

Exercise 2:
Fit a second order polynomial to the data given in table 2

x
0
1
2
3
4
5

Table 2
y
2.1
7.7
13.6
27.2
40.9
61.1

Ans: a0=2.47857, a1=2.35929, a2=1.86071

Linearization of Nonlinear Relationships:


Linear regression is a powerful technique for fitting a best line to data. However it is
dependent on the fact that the relationship between the dependent and independent
variables should be linear. This is always not the case. In those cases, we use
polynomial regression. In some cases, transformation can be used to express the data
in a form that is compatible with linear regression.
One example is the exponential model
y = a1eb1x ..3

Where a1 and b1 are constants.


Another example of a nonlinear model is the simple power equation
y = a2 xb2 ..4

Where a2 and b2 are constants.


Nonlinear regression techniques are available to fit these equations to experimental
data directly. However, a simpler alternative is to use mathematical manipulations to
transform the equations into linear forms. Then simple linear regression can be used
to fit the equations to data.
For example equation (3) can be linearized by taking its normal logarithm to yield
ln y = ln a1 + b1 x
Thus a plot of lny vs x will yield a straight line with a slope of b1 and an intercept of
lna1
Equation (4) can be linearized by taking its base10 logarithm to give

log y = b2 log x + log a2

Thus a plot of logy vs logx will yield a straight line with a slope of b2 and an intercept
of loga2

Exercise 3:
Fit the equation y = a2 xb2 to the data given in Table 3

x
1
2
3
4
5

Table 3
y
0.5
1.7
3.4
5.7
8.4

Ans: a2=0.5, b2=1.75


Hints: find logx and logy for all points. Using these converted points, using linear
regression find slope b2 and intercept loga2. Then find a2 and b2.

Revised by,
Emran Md. Amin

Department of Electrical and Electronic Engineering

Bangladesh University of Engineering and Technology


Course No.: EEE212
Exp. No.:05 Solution of Simultaneous Linear Algebraic Equations
Objective
Systems of linear algebraic equations occur often in diverse fields of science and engineering
and is an important area of study. In this experiment we will be concerned with the different
techniques of finding solution of a set of n linear algebraic equations in n unknowns.

Concept of linear equations and their solution


A set of linear algebraic equations looks like this:

a11 x1 + a12 x2 + ...a1N xN = b1


a21 x1 + a22 x2 + ...a2 N xN = b2

aM 1 x1 + aM 2 x2 + ...aMN xN = bM

(1)

Here the N unknowns xj , j = 1, 2, . . .,N are related by M equations. The coefficients aij with i
= 1, 2, . . .,M and j = 1, 2, . . .,N are known numbers, as are the right-hand side quantities bi, i
= 1, 2, . . .,M.

Existence of solution
If N = M then there are as many equations as unknowns, and there is a good chance of solving
for a unique solution set of xjs. Analytically, there can fail to be a unique solution if one or
more of the M equations is a linear combination of the others (This condition is called row
degeneracy), or if all equations contain certain variables only in exactly the same linear
combination(This is called column degeneracy). (For square matrices, a row degeneracy
implies a column degeneracy, and vice versa.) A set of equations that is degenerate is called
singular.
Numerically, at least two additional things can go wrong:
While not exact linear combinations of each other, some of the equations may be so close to
linearly dependent that round off errors in the machine renders them linearly dependent at
some stage in the solution process. In this case your numerical procedure will fail, and it can
tell you that it has failed.
Accumulated round off errors in the solution process can swamp the true solution. This
problem particularly emerges if N is too large. The numerical procedure does not fail
algorithmically. However, it returns a set of xs that are wrong, as can be discovered by direct
substitution back into the original equations. The closer a set of equations is to being singular,
the more likely this is to happen.

Matrices
Equation (1) can be written in matrix form as

Ax=b
(2)
Here the raised dot denotes matrix multiplication, A is the matrix of coefficients, x is the
column vector of unknowns and b is the right-hand side written as a column vector,

Page 1 of 6

a11
a
A = 21
...

aM 1

a12
a22
...
aM 2

... a1N
... a2 N
... ...

... aMN

x1
x
x= 2
..

xN

b1
b
b= 2
..

bM

Finding Solution
There are so many ways to solve this set of equations. Below are some important methods.
(1) Using the backslash and pseudo-inverse operator
In MATLAB, the easiest way to determine whether Ax = b has a solution, and to find such a
solution when it does, is to use the backslash operator. Exactly what A \ b returns is a bit
complicated to describe, but if there is a solution to A x = b, then A \ b returns one.
Warnings: (1) A \ b returns a result in many cases when there is no solution to A x = b. (2)
A \ b sometimes causes a warning to be issued, even when it returns a solution. This means
that you can't just use the backslash operator: you have to check that what it returns is a
solution. (In any case, it's just good common sense to check numerical computations as you
do them.) In MATLAB this can be done as follows:
Using backslash operator:
x = A\b;
You can also use the pseudo-inverse operator:
x=pinv(A)*b; % it is also guaranteed to solve Ax = b, if Ax = b has a solution.
As with the backslash operator, you have to check the result.
(2) Using Gauss-Jordan Elimination and Pivoting
To illustrate the method let us consider three equations with three unknowns:
a11 x1 + a12 x2 + a13 x3 = a14
a21 x1 + a22 x2 + a23 x3 = a24

(A)
(B)
(C)
a31 x1 + a32 x2 + a33 x3 = a34
Here the quantities bi, i = 1, 2, . . .,Ms are replaced by aiN+1, where i=1,2, .M for simplicity
of understanding the algorithm.
The First Step is to eliminate the first term from Equations (B) and (C). (Dividing (A) by a11
and multiplying by a21 and subtracting from (B) eliminates x1 from (B) as shown below)
a
a
a
a
(a21 11 a21 ) x1 + (a22 12 a21 ) x2 + (a23 13 a21 ) x3 = (a24 14 a21 )
a11
a11
a11
a11
a
Let, 21 = k2 , then
a11
(a21 k2 a11 ) x1 + (a22 k2 a12 ) x2 + (a23 k2 a13 ) x3 = (a24 k2 a14 )
a
Similarly multiplying equation (A) by 31 = k3 and subtracting from (C), we get
a11
(a31 k3a11 ) x1 + (a32 k3 a12 ) x2 + (a33 k3a13 ) x3 = (a34 k3 a14 )
Observe that (a21 k2 a11 ) and (a31 k3 a11 ) are both zero.

Page 2 of 6

In the steps above it is assumed that a11 is not zero. This case will be considered later in this
experiment.
The above elimination procedure is called triangularization.
Algorithm for triangularizing n equations in n unknowns:
1
for i = 1 to n and j = 1 to (n + 1) in steps of 1 do read aij endfor

for k = 1 to (n 1) in steps of 1 do
for i = (k + 1) to n in steps of 1 do
u aik / akk
for j = k to (n + 1) in steps of 1 do
aij aij uakj endfor
endfor
endfor
The reduced equations are:
a11 x1 + a12 x2 + a13 x3 = a14
a22 x2 + a23 x3 = a24
a32 x2 + a33 x3 = a34
The next step is to eliminate a32 from the third equation. This is done by multiplying second
equation by u = a32 / a22 and subtracting the resulting equation from the third. So, same
algorithm can be used.
Finally the equations will take the form:
a11 x1 + a12 x2 + a13 x3 = a14
a22 x2 + a23 x3 = a24
a33 x3 = a34
The above set of equations are said to be in triangular (Upper) form.
From the above upper triangular form of equations, the values of unknowns can be obtained
by back substitution as follows:
x3 = a34 / a33
x2 = (a24 a23 x3 ) / a22
x2 = (a14 a12 x2 a13 x3 ) / a11
Algorithmically, the back substitution for n unknowns is shown below:
1
xn an ( n +1) / ann
2
3
4
5
6

2
3
4
5

for i = (n 1) to 1 in step of -1 do
sum 0
for j = (i + 1) to n in steps of 1 do
sum sum + aij x j endfor

xi (ai ( n +1) sum) / aii


endfor

Exercise 1. Given the simultaneous equations shown below (i) triangularize them (ii) use
back substitution to solve for x1 , x2 , x3 .

Page 3 of 6

2 x1 + 3x2 + 5 x3 = 23
3 x1 + 4 x2 + x3 = 14
6 x1 + 7 x2 + 2 x3 = 26
For generalization, you will have to write a program for triangularizing n equations in n
unknowns with back substitution.
Pivoting
In the triangularization algorithm we have used,
u aik / akk
Here it is assumed that akk is not zero. If it happens to be zero or nearly zero, the algorithm
will lead to no results or meaningless results. If any of the akk is small it would be necessary

to reorder the equations. It is noted that the value of akk would be modified during the
elimination process and there is no way of predicting their values at the start of the procedure.
The elements akk are called pivot elements. In the elimination procedure the pivot should not
be zero or a small number. In fact for maximum precision the pivot element should be the
largest in absolute value of all the elements below it in its column, i.e. akk should be picked
up as the maximum of all amk where, m k
So, during the Gauss elimination, amk elements should be searched and the equation with the
maximum value of amk should be interchanged with the current position. For example if
during elimination we have the following situation:
x1 + 2 x2 + 3 x3 = 4
0.3 x2 + 4 x3 = 5
8 x2 + 3 x3 = 6
As 8 > 0.3, 2 and 3 equations should be interchanged to yield:
nd

rd

x1 + 2 x2 + 3 x3 = 4
8 x2 + 3 x3 = 6
0.3 x2 + 4 x3 = 5
It should be noted that interchange of equations does not affect the solution.
The algorithm for picking the largest element as the pivot and interchanging the equations is
called pivotal condensation.
Algorithm for pivotal condensation
1
max akk
2
3
4

pk
for m = (k + 1) to n in steps of 1 do
if ( amk > max) then

max amk

6
7

pm
endif

8
9

endfor
if ( p ~ = k )
for q = k to (n + 1) in steps of 1 do

Page 4 of 6

10

temp akq

11

akq a pq

12

a pq temp
endfor

endif
Exercise 2. Modify the MATLAB program written in exercise 1 to include pivotal
condensation.
Exercise 3. Try to solve the following systems of equations (i) Gauss-Jordan elimination (ii)
Gauss-Jordan elimination with pivoting
2 x1 + 4 x2 6 x3 = 4
x1 + x2 + 6 x3 = 7
(A)

x1 + 5 x2 + 3 x3 = 10

(B)

x1 + 3x2 + 2 x3 = 5

x1 + 2 x2 + 9 x3 = 2
x1 2 x2 + 3 x3 = 10

4 x1 + 8 x2 + 4 x3 = 8
(C)

x1 + 5 x2 + 4 x3 3 x4 = 4
x1 + 4 x2 + 7 x3 + 2 x4 = 10

x1 + 3 x2 2 x4 = 4
(3) Using Gauss-Seidel Iterative Method
There are several iterative methods for the solution of linear systems. One of the efficient
iterative methods is the Gauss-Seidel method.
Let us consider the system of equations:
4 x1 x2 + x3 = 7
4 x1 8 x2 + x3 = 21
2 x1 + x2 + 5 x3 = 15
The Gauss-Seidel iterative process is suggested by the following equations:
7 + x2k x3k
x1k +1 =
4
21 + 4 x1k +1 + x3k
x2k +1 =
8
15 + 2 x1k +1 x2k +1
x3k +1 =
5
0
0
0
The very first iteration, that is x2 , x3 ,.....xn (for n equations) are set equal to zero and x11 is
calculated. The main point of Gauss-Seidel iterative process to observe is that always the
latest approximations for the values of variables are used in an iteration step.
Exercise 4. Solve the following equations using Gauss-Seidel iteration process:
4 x y = 15
8 x1 3 x2 = 10
(B)
(A)
x + 5y = 9
x1 + 4 x2 = 6

5 x1 x2 + x3 = 10
(C)

2 x + 8 y z = 11

2 x1 + 8 x2 x3 = 11

(A)

x1 + x2 + 4 x3 = 3

Page 5 of 6

5 x y + z = 10
x + y + 4z = 3

It is to be noted that in some cases the iteration diverges rather than it converges. Both the
divergence and convergence can occur even with the same set of equations but with the
change in the order. The sufficient condition for the Gauss-Seidel iteration to converge is
stated below.
The Gauss-Seidel iteration for the solution will converge (if there is any solution) if the
matrix A (as defined previously) is strictly diagonally dominant matrix.
A matrix A of dimension N N is said to be strictly diagonally dominant provided that
N

akk > akj for k = 1, 2,...N


j =1
j k

Revised by,
Emran Md. Amin

Page 6 of 6

Bangladesh University of Engineering and Technology


Department of Electrical and Electronic Engineering
EEE 212
Numerical Technique Laboratory
Experiment No 6
Numerical Differentiation
Introduction:
We are familiar with the analytical method of finding the derivative of a function
when the functional relation between the dependent variable y and the independent
variable x is known. However, in practice, most often functions are defined only by
tabulated data, or the values of y for specified values of x can be found experimentally.
Also in some cases, it is not possible to find the derivative of a function by analytical
method. In such cases, the analytical process of differentiation breaks down and some
numerical process have to be invented. The process of calculating the derivatives of a
function by means of a set of given values of that function is called numerical
differentiation. This process consists in replacing a complicated or an unknown
function by an interpolation polynomial and then differentiating this polynomial as
many times as desired.

Forward Difference Formula:


All numerical differentiation are done by expansion of Taylor series

f ( x + h) = f ( x) + f ( x)h +

f ( x)h 2 f ( x)h3
+
+ ..(1)
2
6

From (1)

f ( x) =

f ( x + h) f ( x )
+ O(h) ..(2)
h

Where, O(h) is the truncation error, which consists of terms containing h and higher
order terms of h.
Exercise 1:

Given f(x) =ex, find f (1) using h=10-1, 10-2,,,, upto 10-10. Find out the error in each
case by comparing the calculated value with exact value.

6-1

Central Difference Formula (of order O (h2)):


f ( x + h) = f ( x) + f ( x)h +

f ( x)h 2 f (c1 )h 3
....... .(3)
+
2
6

f ( x h) = f ( x) f ( x)h +

f ( x)h 2 f (c 2 )h 3
....... (4)

2
6

Using (3) and (4)

f ( x) =

f ( x + h) f ( x h)
+ O(h 2 ) .(5)
2h

Where, O(h 2 ) is the truncation error, which consists of terms containing h2 and
higher order terms of h.
Exercise 2:

Given f(x) =ex, find f (1) using h=10-1, 10-2,,,, up to 10-10. Use equation (5). Find out
the error in each case by comparing the calculated value with exact value.

Central Difference Formula (of order O (h4)):


Using Taylor series expansion it can be shown that
f ( x) =

f ( x + 2h) + 8 f ( x + h) 8 f ( x h) + f ( x 2h)
+ O(h 4 ) .(6)
12h

Here the truncation error reduces to h4


Exercise 3:

Given f(x) =sin (cos (1/x)) evaluate f (1 / 2 ) . Start with h =1 and reduce h to 1/10 of
previous step in each step. If Dn+1 is the result in (n+1) th step and Dn is the result in
nth step then continue iteration until |Dn+1-Dn|>=|Dn-Dn-1| or |Dn-Dn-1| <tolerance. Use
equation (6) for finding D.

6-2

Richardsons Extrapolation:
We have seen that
f ( x) =

f ( x + h) f ( x h)
+ O(h 2 )
2h

Which can be written as


f ( x + h) f ( x h)
+ Ch 2
2h
Or, f ( x) D0 (h) + Ch 2 .(7)
f ( x)

If step size is converted to 2h

f ( x) D0 (2h) + 4Ch 2 .(8)


Using (7) and (8)
f ( x)

4 D0 (h) D0 (2h) f 2 + 8 f1 8 f 1 + f 2
.(9)
=
3
12h

Equation (9) is same as equation (6)


The method of obtaining a formula for f ( x) of higher order from a formula of
lower order is called extrapolation. The general formula for Richardsons
extrapolation is
f ( x) = Dk (h) + O(h 2 k + 2 ) =

4k Dk 1 (h) Dk 1 (2h)
+ O (h 2 k + 2 ) (10)
4k 1

Algorithm for Richardson Approximation:

%Input-f(x) is the input function


%
-delta is the tolerance for error
%
-toler is the tolerance for relative error
%Output-D is the matrix of approximate derivatives
%
-err is the error bound
%
-relerr is the relative error bound
%
-n is the coordinate for best approximation
Define
err=1
relerr=1
h=1
j=1

6-3

Compute D(1,1)=(f(x+h)-f(x-h))/(2h)
While relerr > toler & err > delta &j <12
Compute
h=h/2;
D(j+1,1)=(f(x+h)-f(x-h))/(2h)
DO For k=1:j
Compute D(j+1,k+1)=D(j+1,k)+ (D(j+1,k)-D(j,k))/((4^k)-1)
END DO(k)
Compute
err=|D(j+1,j+1)-D(j,j)|
relerr==2err/(|D(j+1,j+1)|+|D(j,j)|+eps)
j=j+1
END While

Exercise 4:

1 5
Given f(x) =sin (x3-7x2+6x+8) evaluate f (
) . Use Richardsons extrapolation.
2
Approximation should be accurate up to 13 decimal places.

Revised by,
Emran Md. Amin

6-4

Department of Electrical and Electronic Engineering

Bangladesh University of Engineering and Technology


Course No.: EEE212
Numerical Integration

Exp. No.:07

Introduction
There are two cases in which engineers and scientists may require the help of numerical
integration technique. (1) Where experimental data is obtained whose integral may be
required and (2) where a closed form formula for integrating a function using calculus is
difficult or so complicated as to be almost useless. For example the integral
3
x t
(t ) = t
dt.
0 e 1
Since there is no analytic expression for ( x) , numerical integration technique must be used
to obtain approximate values of ( x) .
Formulae for numerical integration called quadrature are based on fitting a polynomial
through a specified set of points (experimental data or function values of the complicated
function) and integrating (finding the area under the fitted polynomial) this approximating
function. Any one of the interpolation polynomials studied earlier may be used.
Some of the Techniques for Numerical Integration
Trapezoidal Rule
Assume that the values of a function f ( x) are given at x1, x1+h, x1+2h x1+nh and it is
required to find the integral of f ( x) between x1 and x1+nh. The simplest technique to use
would be to fit straight lines through f(x1), f(x1+h) and to determine the area under this
approximating function as shown in Fig 7.1.
f(x)

f3
f4
f2
f1
x1

x1+h x1+2h x1+3h x1+4h x1+5h


Fig. 7.1 Illustrating trapezoidal rule

For the first two points we can write:


x1 + h

f ( x)dx =

x1

h
( f1 + f 2 )
2

This is called first-degree Newton-Cotes formula.


From the above figure it is evident that the result of integration between x1 and x1+nh is
nothing but the sum of areas of some trapezoids. In equation form this can be written as:
x1 + nh
n
( f i + fi +1 )
f
x
dx
h
(
)
=

x
2
i
=
1
1

1/4

The above integration formula is known as Composite Trapezoidal rule.


The composite trapezoidal rule can explicitly be written as:
x1 + nh
h
x f ( x)dx = 2 ( f1 + 2 f 2 + 2 f3 + ......2 f n + f n+1 )
1
Simpsons 1/3 Rule
This is based on approximating the function f(x) by fitting quadratics through sets of three
points. For only three points it can be written as:
x1 + 2 h
h
x f ( x)dx = 3 ( f1 + 4 f 2 + f3 )
1

This is called second-degree Newton-Cotes formula.


It is evident that the result of integration between x1 and x1+nh can be written as
x1 + nh
h
n1 3 ( fi + 4 fi +1 + fi + 2 )
x f ( x)dx = i =1,3,5,...,
1
h
( f1 + 4 f 2 + 2 f3 + 4 f 4 + 2 f5 + 4 f 6 + ... 4 f n + f n +1 )
3
In using the above formula it is implied that f is known at an odd number of points (n+1 is
odd, where n is the no. of subintervals).
=

Simpsons 3/8 Rule


This is based on approximating the function f(x) by fitting cubic interpolating polynomial
through sets of four points. For only four points it can be written as:
x1 + 3 h
3h
x f ( x)dx = 8 ( f1 + 3 f 2 + 3 f3 + f 4 )
1

This is called third-degree Newton-Cotes formula.


It is evident that the result of integration between x1 and x1+nh can be written as
x1 + nh
h
n2 3 ( fi + 3 fi +1 + 3 fi +2 + fi +3 )
x f ( x)dx = i =1,4,7,...,
1
3h
( f1 + 3 f 2 + 3 f3 + 2 f 4 + 3 f5 + 3 f 6 + 2 f 7 + ... + 2 f n 2 + 3 f n 1 + 3 f n + f n +1 )
8
In using the above formula it is implied that f is known at (n+1) points where n is divisible
by 3.
An algorithm for integrating a tabulated function using composite trapezoidal rule:
Remarks: f1, f2,, fn+1 are the tabulated values at x1, x1+h,x1+nh (n+1 points)
=

1
2
3
4
5

Read h
for i = 1 to n + 1 Read fi endfor
sum ( f1 + f n +1 ) / 2
for j = 2 to n do
sum sum + f j

6
7

endfor
int egral h . sum
write int egral
stop

2/4

Ex. 1. Integrate the function tabulated in Table 7.1 over the interval from x=1.6 to x=3.8
using composite trapezoidal rule with (a) h=0.2, (b) h=0.4 and (c) h=0.6
Table 7.1
X
f(x)
X
f(x)
1.6
4.953
2.8
16.445
1.8
6.050
3.0
20.086
2.0
7.389
3.2
24.533
2.2
9.025
3.4
29.964
2.4
11.023
3.6
36.598
2.6
13.468
3.8
44.701
The data in Table 7.1 are for f ( x) = e x . Find the true value of the integral and compare this
with those found in (a), (b) and (c).
Ex. 2. (a) Integrate the function tabulated in Table 7.1 over the interval from x=1.6 to
x=3.6 using Simpsons composite 1/3 rule.
(b) Integrate the function tabulated in Table 7.1 over the interval from x=1.6 to
x=3.4 using Simpsons composite 3/8 rule.
An algorithm for integrating a known function using composite trapezoidal rule:
If f(x) is given as a closed form function such as f ( x) = e x cos x and we are asked to
integrate it from x1 to x2, we should decide first what h should be. Depending on the value of
h we will have to evaluate the value of f(x) inside the program for x=x1+nh where n=0,1,
2,.n and n = ( x2 x1 ) / h .
1
h = ( x2 x1 ) / n
2
x x1
sum f ( x)
3
4
for i = 2 to n do
5
x x+h
6
sum sum + 2 f ( x)
endfor
7
x x2
8
sum sum + f ( x)
h
9
int egral . sum
2
write int egral
10
stop
Ex. 3. (a) Find (approximately) each integral given below using the composite trapezoidal
rule with n = 12 .
4

(i)

2 1
(1 + x ) dx

(ii)

x e

2 x

dx

(b) Find (approximately) each integral given above using the Simpsons
1/3 and 3/8 rules with n = 12 .

composite

Adaptive Integration
When f(x) is a known function we can choose the value for h arbitrarily. The problem is that
we do not know a priori what value to choose for h to attain a desired accuracy (for example,
for an arbitrary h sharp picks of the function might be missed). To overcome this problem, we

3/4

can start with two subintervals, h = h1 = ( x2 x1 ) / 2 and apply either trapezoidal or Simpsons
1/3 rule. Then we let h2 = h1 / 2 and apply the formula again, now with four subintervals and
the results are compared. If the new value is sufficiently close, the process is terminated. If
the 2nd result is not close enough to the first, h is halved again and the procedure is repeated.
This is continued until the last result is close enough to its predecessor. This form of
numerical integration is termed as adaptive integration.
The no. of computations can be reduced because when h is halved, all of the old points at
which the function was evaluated appear in the new computation and thus repeating
evaluation can be avoided. This is illustrated below.

k=1
k=2
k=3
k=4
o = New points
= Old points

An algorithm for adaptive integration of a known function using trapezoidal rule:


Read x1 , x2 , e
Remark: The allowed error in integral is e
1
h x2 x1
2
3
S1 ( f ( x1 ) + f ( x2 )) / 2
I1 h . S1
4
5
i 1
Repeat
x x1 + h / 2
6
7
for j = 1 to i do
8
S1 S1 + f ( x)
9
x x+h
endfor
10
i 2i
h h/2
11
12
I 0 I1
13
I1 h . S1
14
until I1 I 0 e . I1
15

write I1 , h, i
stop
2
Ex. 4. Evaluate the integral of xe 2 x between x=0 and x=2 using a tolerance value sufficiently
small as to get an answer within 0.1% of the true answer, 0.249916.

Ex. 5. Evaluate the integral of sin 2 (16 x) between x = 0 and x = / 2 . Why the result is
erroneous? How can this be solved? (The correct result is / 4 )

4/4

Revised by,
Emran Md. Amin

5/4

Department of Electrical and Electronic Engineering


Bangladesh University of Engineering and Technology
EEE 212: Numerical Technique Laboratory
Experiment 8: Solutions to Non-linear Equations
Bisection method:
The Bisection method is one of the simplest procedures for finding root of a function in a
given interval.
The procedure is straightforward. The approximate location of the root is first determined
by finding two values that bracket the root (a root is bracketed or enclosed if the function
changes sign at the endpoints). Based on these a third value is calculated which is closer
to the root than the original two value. A check is made to see if the new value is a root.
Otherwise a new pair of bracket is generated from the three values, and the procedure is
repeated.

Consider a function d ( x) and let there be two values of x , xlow and xup ( xup > xlow ),
bracketing a root of d ( x) .
Steps:
1. The first step is to use the brackets xlow and xup to generate a third value that is

closer to the root. This new point is calculated as the mid-point between xlow and,
x +x
namely xmid = low up . The method therefore gets its name from this bisecting
2
of two values. It is also known as interval halving method.
2. Test whether xmid is a root of d ( x) by evaluating the function at xmid .
3. If xmid is not a root,
a. If d ( xlow ) and d ( xmid ) have opposite signs i.e. d ( xlow ) . d ( xmid ) <0,
root is in left half of interval.
8-1

b. If d ( xlow ) and d ( xmid ) have same signs i.e. d ( xlow ) . d ( xmid ) >0,
root is in right half of interval.
4. Continue subdividing until interval width has been reduced to a size
where = selected x tolerance.

Algorithm: Bisection Method


Input xLower, xUpper, xTol
yLower = f(xLower) (* invokes fcn definition *)
xMid = (xLower + xUpper)/2.0
yMid = f(xMid)
iters = 0 (* count number of iterations *)
While ( (xUpper - xLower)/2.0 > xTol )
iters = iters + 1
if( yLower * yMid > 0.0) Then xLower = xMid
Else xUpper = xMid
Endofif
xMid = (xLower + xUpper)/2.0
yMid = f(xMid)
Endofwhile
Return xMid, yMid, iters (* xMid = approx to root *)
Exercise 1. Find the real root of the equation d ( x) = x 5 + x + 1 using Bisection Method.
xlow = -1, xup =0 and = selected x tolerance = 10 4 .

Note: For a given x tolerance (epsilon), we can calculate the number of iterations
directly. The number of divisions of the original interval is the smallest value of n
xup xlow
xup xlow
n
that satisfies:

or

2n
xup xlow
.
Thus n log 2

In our previous example, xlow = -1, xup =0 and = selected x tolerance = 10 4 .


So we have n = 14 .

False-Position Method (Regula Falsi)


A shortcoming of the bisection method is that, in dividing the interval from xlow to
xup into equal halves, no account is taken of the magnitude of f ( xlow ) and f ( xup ) . For

example, if f ( xlow ) is much closer to zero than f ( xup ) , it is likely that the root is closer
to xlow than to xup . An alternative method that exploits this graphical insight is to join
f ( xlow ) and f ( xup ) by a straight line. The intersection of this line with the x axis
represents an improved estimate of the root. The fact that the replacement of the curve by

8-2

a straight line gives the false position of the root is the origin of the name, method of
false position, or in Latin, Regula Falsi. It is also called the Linear Interpolation Method.

Using similar triangles, the intersection of the straight line with the x axis can be
estimated as

f ( xlow ) f ( xup )
=
x xlow x xup
That is x = xup

f ( xup )( xlow xup )

f ( xlow ) f ( xup )
This is the False Position formulae. The value of x then replaces whichever of the two
initial guesses, xlow or xup , yields a function value with the same sign as f (x) . In this
way, the values of xlow and xup always bracket the true root. The process is repeated until
the root is estimated adequately.
Exercise 2. Find the root of the equation d ( x) = x5 + x + 1 using False Position Method.
xlow = -1, xup =0 and = selected x tolerance = 10 4 . (Develop the algorithm by yourself.

It is very similar to Bisection Method).

Newton Raphson Method:


If f (x) , f (x) and f (x) are continuous near a root x , then this extra information
regarding the nature of f (x) can be used to develop algorithms that will produce
sequences {x k } that converge faster to x than either the bisection or false position
method. The Newton-Raphson (or simply Newton's) method is one of the most useful
and best-known algorithms that relies on the continuity of f (x) and f (x) .

8-3

The attempt is to locate root by repeatedly approximating f (x) with a linear function at
each step. If the initial guess at the root is x k , a tangent can be extended from the point
[xk , f ( xk )] . The point where this tangent crosses the x axis usually represents an
improved estimate of the root.

f (x)
Slope = f ( x k )

f ( xk )

x k +1

xk

The Newton-Raphson method can be derived on the basis of this geometrical


interpretation. As in the figure, the first derivative at x is equivalent to the slope:
f ( xk ) 0
f ( x k ) =
x k x k +1
which can be rearranged to yield
f ( xk )
f ( x k )
which is called the Newton Raphson formulae.
x k +1 = x k

8-4

So the Newton-Raphson Algorithm actually consists of the following steps:


1. Start with an initial guess x0 and an x-tolerance .
f ( xk )
2. Calculate x k +1 = x k
k = 0,1,2,K
f ( x k )

Algorithm - Newtons Method


Input x0, xTol
iters = 1
dx = -f(x0)/fDeriv(x0) (* fcns f and fDeriv *)
root = x0 + dx
While (Abs(dx) > xTol)
dx = -f(root)/fDeriv(root)
root = root + dx
iters = iters + 1
End of while
Return root, iters
Exercise 3. Use the Newton Raphson method to estimate the root of f ( x) = e x 1 ,
employing an initial guess of x0 = 0. The tolerance is = 10 8 .

The Secant Method:


The Newton-Raphson algorithm requires two functions evaluations per iteration,
f ( x k ) and f ( x k ) . Historically, the calculation of a derivative could involve
considerable effort. Moreover, many functions have non-elementary forms (integrals,
sums etc.), and it is desirable to have a method for finding a root that does not depend on
the computation of a derivative. The secant method does not need a formula for the
derivative and it can be coded so that only one new function evaluation is required per
iteration.
The formula for the secant method is the same one that was used in the Regula Falsi
method, except that the logical decisions regarding how to define each succeeding term
are different.
In the Secant method, the derivative can be approximated by a backward finite divided
difference, as in the figure,
f ( x k )

f ( x k 1 ) f ( x k )
x k 1 x k

8-5

f (x)
f ( xk )

f ( x k 1 )

x k 1

Using Newton-Raphson method,


f ( xk )
x k +1 = x k
f ( x k )
Substituting f ( x k ) ,
x k +1 = x k

f ( x k )( x k 1 x k )
f ( x k 1 ) f ( x k )

Notice that the approach requires initial estimates of x .

Algorithm - Secant Method


Input xk, xkMinus1, xTol, maxiters
iters = 1
yk =f(xk) (* invokes function f *)
ykMinus1 = f(xkMinus1)
root = (xkMinus1*yk - xk*ykMinus1)/(yk - ykMinus1)
8-6

xk

ykPlus1 = f(root)
While( (Abs(root - xk) > xTol) and (iters < maxiters) )
xkMinus1 = xk
ykMinus1 = yk
xk = root
yk = ykPlus1
root = (xkMinus1*yk - xk*ykMinus1)/(yk - yk Minus1)
ykPlus1 = f(root)
iters = iters + 1
Endofwhile
Return root, ykPlus1, iters
Exercise 4. Find the root of the equation f ( x) = 3 x + sin( x) e x , starting values are 0
and 1. The tolerance limit is 0.0000001.

Revised by,
Emran Md. Amin

8-7

Department of Electrical and Electronic Engineering


Bangladesh University of Engineering and Technology
EEE 212: Numerical Technique Laboratory
Experiment 9: Solutions to Linear Differential Equations
In mathematics, a differential equation is an equation in which the derivatives of a
function appear as variables. Differential equations have many applications in physics
and chemistry, and are widespread in mathematical models explaining biological, social,
and economic phenomena.
Differential equations are divided into two types:
a. An Ordinary Differential Equation (ODE) only contains function of one
variable, and derivatives in that variable.
b. A Partial differential Equation (PDE) contains multivariate functions and their
partial derivatives.
The order of a Differential equation is that of the highest derivative that it contains. For
instance, a first-order Differential equation contains only first derivatives.
A linear differential equation of order n is a differential equation written in the
following form:
dn y
d n 1 y
dy
an ( x) n + an 1 ( x) n 1 + KKK + a1 ( x) + a0 ( x) y = f ( x)
dx
dx
dx
where an ( x) 0 .
Initial value problem:
A problem in which we are looking for the unknown function of a differential equation
where the values of the unknown function and its derivatives at some point are known is
called an initial value problem (in short IVP).
If no initial conditions are given, we call the description of all solutions to the differential
equation the general solution.

Methods of solving the Ordinary Differential Equations:


1. Eulers Method:
Let y ( x) = f ( x, y ( x))
y ( x0 ) = y0
Here f ( x, y ) is a given function, y0 is a given initial value for y at x = x0 .

9-1

The unknown in the problem is the function y ( x) .


Our goal is to determine (approximately) the unknown function y ( x) for x > x0 . We are
told explicitly the value of y ( x0 ) , namely y0 . Using the given differential equation, we
can also determine exactly the instantaneous rate of change of y at x0 . The basic idea is
simple. This differential equation tells us how rapidly the variable y is changing and the
initial condition tells us where y starts
y ( x0 ) = f ( x0, y ( x0 )) = f ( x0 , y0 ).

If the rate of change of y ( x) were to remain f ( x0 , y0 ) for all time, then y ( x) would be
exactly y0 + f ( x0 , y0 )( x x0 ) . The rate of change of y ( x) does not remain f ( x0 , y0 ) for
all time, but it is reasonable to expect that it remains close to f ( x0 , y0 ) for x close to x0 .
If this is the case, then the value of y ( x) will remain close to y0 + f ( x0 , y0 )( x x0 ) for x
close to x0 . So pick a small number h and define
x1 = x0 + h
y1 = y0 + f ( x0 , y0 )( x1 x0 ) = y0 + f ( x0 , y0 )h
By the above argument
y ( x1 ) y1
Now we start over. We now know the approximate value of y at x1 . If y ( x1 ) were
exactly y1 , then the instantaneous rate of change of y at x1 would be exactly f ( x1 , y1 ) . If
this rate of change were to persist for all future value of x , y ( x) would be exactly
y1 + f ( x1 , y1 )( x x1 ) .
As y ( x1 ) is only approximately y1 and as the rate of change of y ( x) varies with x , the
rate of change of y ( x) is only approximately f ( x1 , y1 ) and only for x near x1 . So we
approximate y ( x) by y1 + f ( x1 , y1 )( x x1 ) for x bigger than, but close to, x1 . Defining
x2 = x1 + h = t0 + 2h
y2 = y1 + f ( x1 , y1 )( x2 x1 ) = y1 + f ( x1 , y1 )h
We have y ( x2 ) y2
We just repeat this argument. Define, for n = 0,1, 2,3KKK
xn = x0 + nh
Suppose that, for some value of n , we have already computed an approximate value
yn for y ( xn ) . Then the rate of change of y ( x) for x close to xn is
f ( x, y ( x)) f ( xn , y ( xn )) y ( xn , yn )
and, again for x near xn ,
y ( x) = yn + f ( xn , yn )( x xn ) .

9-2

Hence
y ( xn +1 ) yn +1 = yn + f ( xn , yn )h
This algorithm is called Euler's Method. The parameter h is called the step size.
Exercise 1. Use Eulers method to solve the IVP y =

x y
on [0,3] with y (0) = 1 .
2

1 1
1
Compare solutions for h = 1, , and .
2 4
8
x/2
2+ x .
The exact solution is y = 3e
Exercise 2. Consider the following circuit:

In this circuit, R = 20 K , C = 10 F , E = 117V and Q(0)=0 . Find


Q for t = 0 to t = 3sec .

2. The Improved Euler's Method


Euler's method is one algorithm that generates approximate solutions to the initial value
problem
y ( x) = f ( x, y ( x))
y ( x0 ) = y0
In applications, f ( x, y ) is a given function and x0 and y0 are given numbers. The
function y ( x) is unknown. Denote by ( x) the exact solution for this initial value
problem. In other words ( x) is the function that obeys the following relation exactly.
( x) = f ( x, ( x))
( x0 ) = y0
Fix a step size h and define xn = x0 + nh . We now derive another algorithm that
generates approximate values for at the sequence of equally spaced values
x0 , x1 , x2 ,KKK We shall denote the approximate values yn with yn = ( xn )
By the fundamental theorem of calculus and the differential equation, the exact solution
obeys

9-3

( xn +1 ) = ( x ) +

xn+1

( x)dx = ( x

)+

xn

xn +1

f ( x, ( x))dx

xn

Fix any n and suppose that we have already found y0 , y1 , y2 ,KKK , yn . Our algorithm
for computing yn +1 will be of the form
yn +1 = yn + approximate value for

xn+1

f ( x, ( x))dx

xn

In fact Euler's method is of precisely this form. In Euler's method, we approximate


f ( x, ( x)) for xn x xn +1 by the constant f ( xn , yn ) . Thus Euler's approximate value
for
xn +1

xn

f ( x, ( x))dx =

xn +1

f ( xn , yn )dx = f ( xn , yn )h

xn

The area of the complicated region 0 y f ( x, ( x)) ; xn x xn +1 (represented by the


shaded region under the parabola in the left half of the figure below) is approximated by
the area of the rectangle 0 y f ( xn , yn ) ; xn x xn +1 (the shaded rectangle in the
right half of the figure below).

Our second algorithm, the improved Euler's method, gets a better approximation by
attempting to approximate by the trapezoid on the right below rather than the rectangle on
the right above. The exact area of this trapezoid is the length h of the base multiplied by

9-4

1
[ f ( xn , ( xn )) + f ( xn +1 , ( xn+1 ))] , of the heights of the two sides. Of course
2
we do not know ( xn ) or ( xn +1 ) exactly. Recall that we have already found
y0 , y1 , y2 ,KKK , yn and are in the process of finding yn +1 . So we already have an
approximation for ( xn ) , namely yn , but not for ( xn +1 ) . Improved Euler uses
( xn +1 ) ( xn ) + ( xn )h yn + f ( xn , yn )h
1
in approximating
[ f ( xn , ( xn )) + f ( xn+1 , ( xn+1 ))] . Altogether Improved Euler's
2
xn +1
1
approximate value for f ( x, ( x))dx = [ f ( xn , yn ) + f ( xn +1 , yn + f ( xn , yn )h)] h
2
xn
the average,

so that the improved Euler's method algorithm is


1
y ( xn +1 ) yn +1 = yn + [ f ( xn , yn ) + f ( xn +1 , yn + f ( xn , yn )h) ] h
2
The general step is
pn +1 = yn + hf ( xn , yn ) ,
xn +1 = xn + h ,
h
yn +1 = yn + ( f ( xn , yn ) + f ( xn +1 , pn +1 ))
2
Exercise 3. Solve exercise 1 and 2 using Improved Eulers method.

Revised by,
Emran Md. Amin

9-5

Department of Electrical and Electronic Engineering


Bangladesh University of Engineering and Technology
EEE 212: Numerical Technique Laboratory
Experiment 10: Solutions to Nonlinear Differential Equations
Introduction:
A linear ordinary differential equation (ODE) of order n is a differential equation
written in the following form:
dn y
d n 1 y
dy
an ( x) n + an 1 ( x) n 1 + KKK + a1 ( x) + a0 ( x) y = f ( x)
dx
dx
dx
where an ( x) 0 .
This ODE is called linear because there are no products or nonlinear functions of the
dependant variable y and its derivatives. When the product or nonlinear function of
dependant variable and its derivatives are present in any ODE, ODE is termed as
Nonlinear ODE. The practical importance of linear ODEs is that they can be solved
analytically. In contrast, most nonlinear ODEs cannot be solved exactly. In the
precomputer era, one tactic to solve nonlinear ODEs was to linearize them. The motion
of a swinging pendulum by Newtons second law is given by

d 2 g
+ sin = 0 . is the
d 2t l

angle of displacement of the pendulum, g is the gravitational constant ad l is the


pendulum length. This is a nonlinear ODE because of nonlinear function sin . For
smaller displacement [ sin

is considered for this case] the above ODE becomes

linear. But if we are interested for larger displacement then Numerical Techniques offer a
viable option for obtaining solutions.
In this experiment, we will study two methods for solving ODE of Initial value
problem (IVP) type and one method for solving ODE of Boundary value problem (BVP)
type.
Initial Value Problem: For an n order ODE n conditions are required. If all the
conditions are specified at the same value of the independent variable, then we are
dealing with Initial Value Problem.

Page 1 of 12

Boundary Value Problem: For an n order ODE n conditions are required. If all the
conditions are specified at the extreme points of the system, then we are dealing with
Boundary Value Problem.
Taylor Series Method:
The Taylor expansion is

h 2 f ( x) h3 f ( x)
f ( x + h) = f ( x) + hf ( x) +
+
+ .......
2!
3!
The Taylor Series Method is of general applicability, and it is the standard to which we
compare the accuracy of the various other numerical methods for solving an IVP. It can
be devised to have any specified degree of accuracy. We start by reformulating Taylors
theorem in a form that is suitable for solving differential equations.
Assume that y (t ) C N +1 [t0 , b] and that y (t ) has a Taylor series expansion of

order N about the fixed value t = tk [t0 , b]

(1)

y (tk + h) = y (tk ) + hTN (tk , y (tk )) + O(h N +1 ),

where
N

(2)

TN (tk , y (tk )) =
j =1

y ( j ) (tk ) j 1
h
j!

and y ( j ) (t ) = f ( j 1) (t , y (t )) denotes the ( j 1) st total derivative of the function f with


respect to t . The formulas for the derivatives can be computed recursively:
(3)

y (t ) = f
y (t ) = f t + f y y = ft + f y f
y (3) (t ) = ftt + 2 fty y + f y y + f yy ( y ) 2
= ftt + 2 f ty f + f y ( ft + f y f ) + f yy f 2

and in general,
(4)

y N (t ) = P ( N 1) f (t , y (t ))

where P is the derivative operator


p= + f
.
y
t

Page 2 of 12

The approximate numerical solution to the IVP y (t ) = f (t , y ) over [t0 , tM ] is


derived by using formula (1) on each subinterval [tk , t k +1 ]. The general step for Taylors
method of order N is
yk +1 = yk + d1 h +

(5)

d hN
d 2 h 2 d3 h3
+
+ ........... + N
,
2!
3!
N!

where d j = y ( j ) (tk ) for j = 1, 2,....., N at each step k = 0,1,......., M 1 .


The Taylor method of order N has the property that the final global error (FGE)
is of the order O(h N +1 ) ; hence N can be chosen as large as necessary to make this error
as small as desired. If the order N is fixed, it is theoretically possible to a priori
determine the step size h so that the FGE will be as small as desired.
Exercise 1: Use the Taylor method of order N = 4 to solve linear differential equation
y = (t 2 y ) on time interval [0, 3] with y (0) = 1 . Compare the solutions for

1 1
1
h = 1, , and .
2 4
8
Compare

the

solution

with

the

exact

solution

[at

the

given

condition

y (t ) = e t + t 2 2t + 2 ].
Comment on step size on solution.

Runge-Kutta Method:

The Taylor methods in the preceding section have the desirable feature that the FGE is of
the order O (h N ) , and N can be chosen large so that this error is small. However, the
shortcomings of the Taylor methods are the a priori determination of N and the
computation of the higher derivatives, which can be very complicated. Each Runge-Kutta
method is derived from an appropriate Taylor method in such a way that the FGE is of
O (h N ) . A trade-off is made to perform several function evaluations at each step and

eliminate the necessity to compute the higher derivatives. These methods can be
constructed for any order N . The Runge-Kutta method of order N = 4 is most popular.
It is a good choice for common purposes because it is quite accurate, stable, and easy to

Page 3 of 12

program. Most authorities proclaim that it is not necessary to go to a higher-order


method because the increased accuracy is offset by additional computational effort. If
more accuracy is required, then either a smaller step size or an adaptive step size method
should be used.
The fourth-order Runge-Kutta method (RK4) simulates the accuracy of the Taylor
series method of order N = 4 . The method is based on computing yk +1 as follows:
(1)

yk +1 = yk + w1k1 + w2 k2 + w3 k3 + w4 k4 ;

where k1 , k2 , k3 and k4 have the form


(2)

k1 = hf (tk , yk ),
k2 = hf (tk + a1h, yk + b1k1 ),
k3 = hf (tk + a 2 h, yk + b2 k1 + b3 k2 ),
k4 = hf (tk + a 3 h, yk + b4 k1 + b5 k2 + b6 k3 ),

By matching coefficients with those of the Taylor series method of order N = 4 so that
the local truncation error is of order O (h5 ) , Runge-Kutta were able to obtain the
following system of equations:
(3)

b1 = a1 ,
b2 + b3 = a2,
b4 + b5 + b6 = a3 ,
w1 + w2 + w3 + w4 = 1,
1
w2 a1 + w3a2 + w4 a3 = ,
2
1
w2 a12 + w3a22 + w4 a32 = ,
3
1
w2 a13 + w3 a23 + w4 a33 = ,
4
1
w3 a1b3 + w4 (a1b5 + a2b6 ) = ,
6
1
w3 a1a2b3 + w4 a3 (a1b5 + a2b6 ) = ,
8
1
w3 a12b3 + w4 (a12b5 + a22b6 ) = ,
12
1
w4 a1b3b6 = .
24

Page 4 of 12

The system involves 11 equations in 13 unknowns. Two additional conditions must be


supplied to solve the system. The most useful choice is

(4)

a1 =

1
and b2 = 0. Then the solution of the remaining variables is
2

1
1
1
(5) a2 = , a3 = 1, b1 = , b3 = , b4 = 0, b5 = 0, b6 = 1,
2
2
2
1
1
1
1
w1 = , w2 = , w3 = , w4 = .
6
3
3
6
The values in (4) and (5) are substituted into (2) and (1) to obtain the formula for
the standard Runge-Kutta method of order N = 4 , which is stated as follows. Start with
the initial point (t0 , y0 ) and generate the sequence of approximations using
(6)

yk +1 = yk +

h( f1 + 2 f 2 + 2 f 3 + f 4 )
6

where

(7)

f1 = f (tk , yk ),
h
h

f 2 = f t k + , yk + f 1 ,
2
2

h
h

f 3 = f t k + , yk + f 2 ,
2
2

f 4 = f ( tk + h, yk + hf 3 ) .

The complete developments of the equations in (7) can be found in any advanced text.

Exercise 2: Use the RK4 method to solve the differential equation in Exercise 1.
Also compare the obtained solution with Taylor method and exact.

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
For h=1/4 necessary matlab codes are given below:
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
clear;
%format long;
a=0;
b=1.4;

Page 5 of 12

ya=0;
h=1/4;
%M=14;
%h=( b-a)/M;
M=ceil(( b-a)/h);
T=zeros(1, M+1) ;
Y_T= zeros(1, M+1) ;
Y_RK= zeros(1, M+1) ;

T=a:h:b;
Y_T(1)=ya;
Y_RK(1)=ya;
%%%%TAYLOR METHOD%%%%%%%%
for j=1:M
D=df(T(j), Y_T(j));
Y_T(j+1)=Y_T(j)+h*(D(1)+h*(D(2)/2+h*(D(3)/6+h*(D(4)/24))));
end
%R=[T' Y_T'];
%%%%RK4 METHOD%%%%%%
for j=1:M
k1=h*f(T(j), Y_RK(j));
k2=h*f(T(j)+h/2, Y_RK(j)+k1/2);
k3=h*f(T(j)+h/2, Y_RK(j)+k2/2);
k4=h*f(T(j)+h, Y_RK(j)+k3);
Y_RK(j+1)=Y_RK(j)+(k1+2*k2+2*k3+k4)/6;
end
%R=[T' Y_RK'];
%%%%%%%%%%%%%%%%%%%
R=[T' Y_T' Y_RK'];
%%%%%%%%%%%%%%%%%%%%
function z=df(t,y)

Page 6 of 12

z=[(t^2-y) (2*t-t^2+y) (2-2*t+t^2-y) (-2+2*t-t^2+y)];


%%%%%%%%%%%%%%%%%%%%%
function z=f(t,y)
z= t^2-y;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

RK method for Systems of Differential Equations:


Consider the following initial value problem
dx
= f (t , x, y )
dt
dy
= g (t , x, y )
dt
with
x(t0 ) = x0
y (t0 ) = y0 .
The above represents a system of differential equations.
The RK formulas of order N = 4 are:
h( f1 + 2 f 2 + 2 f3 + f 4 )
6
h( g1 + 2 g 2 + 2 g3 + g 4 )
yk +1 = yk +
6

xk +1 = xk +

where
f1 = f (tk , xk , yk ), g1 = g (tk , xk , yk ),
h
h
h
h
h
h

f 2 = f tk + , xk + f1 , yk + g 1 , g 2 = g tk + , xk + f1 , yk + g 1 ,
2
2
2
2
2
2

h
h
h
h
h
h

f3 = f tk + , xk + f 2 , yk + g 2 , g3 = g tk + , xk + f 2 , yk + g 2 ,
2
2
2
2
2
2

f 4 = f ( tk + h, xk + hf 3 , yk + hg3 ) , g 4 = g ( tk + h, xk + hf3 , yk + hg3 ) .

Higher Order Differential Equations:


Higher-order differential equations involve the higher derivatives x(t ), x(t ), and so on.
They arise in mathematical models for problems in physics and engineering. For
example,
mx(t ) + cx(t ) + kx(t ) = g (t )
represents a mechanical system in which a spring with spring constant k restores a

Page 7 of 12

displaced mass m . Damping is assumed to be proportional to the velocity, and the


function g (t ) is an external force. It is often the case that the position x(t0 ) and velocity
x(t0 ) are known at a certain time t0 .
By solving for the second derivative, we can write a second-order initial value
problem in the form
(1)

x(t ) = f (t , x(t ), x(t )) with x(t0 ) = x0 and x(t0 ) = y0 .

The second-order differential equation can be reformulated as a system of two first order
equations if we use the substitution

(2)

x(t ) = y (t ).

Then x(t ) = y(t ) and the differential equation in (1) becomes a system:

(3)

dx
=y
dt
dy
= f (t , x, y )
dt
with
x(t0 ) = x0
y (t0 ) = y0 .

Any order differential equation can be converted into first order differential equation and
any numerical method can be used to solve it.

Exercise 3: Consider the second order initial value problem


x(t ) + 4 x(t ) + 5 x(t ) = 0 with x(0) = 3 and x(0) = 5.
(a) Write down the equivalent system of two first order differential equations.
(b) Write m-file using RK4 method to solve the reformulated problem over time
interval [0,5] using M = 50 subintervals of width h = 0.1 .
(c) Compare the numerical solution with true solution:
x(t ) = 3e 2t cos(t ) + e 2t sin(t ) .

Page 8 of 12

%%%%%%%%Necessary matlab code for Exercise 3%%%%%


clear;
%

- a and b are the endpoints of the interval

- Za=[x(a) y(a)] are the initial conditions

- M is the number of steps

%Output - T is the vector of steps


%

- Z=[x1(t).. .xn(t)]; where xk(t) is the approximation

to the kth dependent variable

a=0;
b=5;
Za=[3 -5];
M=50
h=(b-a)/M;
T=zeros(1, M+1);
Z=zeros(M+1,length(Za));
T=a:h:b;
Z(1, :)=Za;
for j=1:M
k1=h*F3(T(j),Z(j,:));
k2=h*F3(T(j)+h/2,Z(j,:)+k1/2);
k3=h*F3(T(j)+h/2,Z(j,:)+k2/2);
k4=h*F3(T(j)+h,Z(j,:)+k3);
Z(j+1,:)=Z(j,:)+(k1+2*k2+2*k3+k4)/6;
end
R=[T' Z]%%%%Z(:,1) is the desired solution i.e. value of x(t)
%%%%%%%%%
function Z=F3(t,Z)
x=Z(1);
y=Z(2);
Z=[y, -5*x-4*y];
%%%%%%%%%%%%%%%%%%%%

Page 9 of 12

Boundary Value Problem:


Another type of differential equation has the form
x(t ) = f (t , x, x)

(1)

for a t b,

with the boundary conditions

x(a) = and x(b) = .

(2)

This is called a boundary value problem.


The conditions that guarantee that a solution to (1) exists should be checked
before any numerical scheme is applied; otherwise a list of meaningless output may be
generated. The general conditions are stated in the following theorem.

Boundary Value Theorem: Assume that f (t , x, y ) is continuous on the region

R = {(t , x, y ) : a t b, < x < , < y < }


f

= f x (t , x, y ) and f

and

that

= f y (t , x, y ) are continuous on R . If there exists a constant

M > 0 for which f x and f y satisfy

(3)

f x (t , x, y ) > 0 for all (t , x, y ) R and

(4)

f y (t , x, y ) M for all (t , x, y ) R,

then the boundary value problem


x = f (t , x, x) with x(a) = and x(b) =

(5)

has a unique solution x = x(t ) for a t b.


The notation y = x(t ) has been used to distinguish the third variable of the function f (t , x, x) . Finally, the special case of linear differential equations is worthy of
mention.
Linear

Boundary

Value

f (t , x, y ) = p (t ) y + q(t ) x + r (t ) and
f

= q(t ) and f

Problem:

that

Assume
and

that
its

f has
partial

the

form

derivatives

= p(t ) are continuous on R . If there exists a constant M > 0 for

which p (t ) and q (t ) satisfy

Page 10 of 12

(6)

q (t ) > 0 for all t [a, b]

and
(7)

| p (t ) | M = max{| p(t )|},


a t b

then the linear boundary value problem

(8)

x(t ) = p(t ) x(t ) + q (t ) x(t ) + r (t ) with x(a) = and x(b) =

has a unique solution x = x(t ) for a t b.


Reduction to Two IVPs: Linear Shooting Method

Finding the solution of a linear boundary problem is assisted by the linear structure of the
equation and the use of two special initial value problems. Suppose that u (t ) is the unique
solution to the IVP.
(9)

u = p(t )u(t ) + q(t )u (t ) + r (t ) with u (a) = and u (a ) = 0.

Furthermore, suppose that v(t ) is the unique solution to the IVP.

(10)

v = p(t )v(t ) + q(t )v(t ) with v(a) = 0 and v(a) = 1.

Then the linear combination

(11)

x(t ) = u (t ) + Cv(t )

is a solution to x(t ) = p (t ) x(t ) + q (t ) x(t ) + r (t ) as seen by the computation

x = u + Cv = p(t )u(t ) + q (t )u (t ) + r (t ) + p (t )Cv(t ) + q(t )Cv(t )


= p (t )(u (t ) + Cv(t )) + q(t )(u (t ) + Cv(t )) + r (t )
= p (t ) x(t ) + q (t ) x(t ) + r (t )
The solution x(t ) in equation (11) takes on the boundary values

(12)

x(a ) = u (a ) + Cv(a ) = + 0 =
x(b) = u (b) + Cv(b).

Imposing the boundary condition x(b) = in (12) produces C = ( u (b)) / v(b).


Therefore, if v(b) 0 , the unique solution to (8) is
(13)

x(t ) = u (t ) +

u (b)
v(b)

v(t ).

Exercise 4:

(a) Write the RK4 method m-file to solve the following boundary value problem

Page 11 of 12

2t
2
x(t )
x(t ) + 1 with x(0) = 1.25 and x(4) = 0.95 over the time interval [0, 4].
2
1+ t
1+ t2
(b) Compare the numerical solution with true solution:

x(t ) =

1
1
x(t ) = 1.25 + 0.4860896526t 2.25t 2 + 2t arctan(t ) ln(1 + t 2 ) + t 2 ln(1 + t 2 ).
2
2

Revised by,
Emran Md. Amin

Page 12 of 12

Department of Electrical & Electronic Engineering


Bangladesh University of Engineering & Technology
EEE 212: Numerical Technique Laboratory
Experiment 11:Solution of partial differential equation
Partial Differential Equation
A partial differential equation (PDE) is an equation involving functions and their partial
derivatives; for example, the wave equation

In general, partial differential equations are much more difficult to solve analytically than are
ordinary differential equations. They may sometimes be solved using a Bcklund transformation,
characteristics, Green's function, integral transform, Lax pair, separation of variables, or
numerical methods such as finite differences.
Fortunately, partial differential equations of second-order are often amenable to analytical
solution. Such PDEs are of the form

F is a function of x, y, u,

u u
, .
x y

Linear second-order PDEs are then classified according to the properties of the matrix

as elliptic, hyperbolic, or parabolic.


If is a positive definite matrix, i.e.,
and Poisson's equation are examples.

, the PDE is said to be elliptic. Laplace's equation

holds in for 0 < x < 1 and 0 < y < 1.

Boundary conditions are

u ( x,0) = f 1( x) for 0 x 1, u ( x,1) = f 2( x) for 0 x 1,


u (0, y ) = f 3( y ) for 0 y 1, u (1, y ) = f 4( y ) for 0 y 1

, the PDE is said to be hyperbolic. The wave equation in one dimension for a
If det
vibrating string is an example of a hyperbolic partial differential equation.

u tt ( x, y ) = u xx ( x, t ) for 0 < x < L and 0 < t < .

Initial-boundary conditions are used to give


u ( x,0) = f ( x) for 0 x L, ut ( x,0) = g ( x) for 0 < x < L
u (0, t ) = 0, u ( L, t ) = 0 for 0 t <
, the PDE is said to be parabolic. The heat conduction equation and other diffusion
If det
equations are examples.
k

2T T
=
t
x 2

Initial-boundary conditions are used to give


T ( x,0) = f ( x) for 0 x L
T (0, t ) = c1, T ( L, t ) = c 2 for 0 t

Finite Difference Method:

In mathematics, a finite difference is like a differential quotient, except that it uses finite
quantities instead of infinitesimal ones.
The derivative of a function f at a point x is defined by the limit

.
If h has a fixed (non-zero) value, instead of approaching zero, this quotient is called a finite
difference.
Another important aspect is that finite differences approach differential quotients as h goes to
zero. Thus, we can use finite differences to approximate derivatives. This is often used in
numerical analysis, especially in numerical ordinary differential equations and numerical partial
differential equations, which aim at the numerical solution of ordinary and partial differential
equations respectively. The resulting methods are called finite-difference methods.
For example, consider the ordinary differential equation

The Euler method for solving this equation uses the finite difference

to approximate the differential equation by

The last equation is called a finite-difference equation. Solving this equation gives an
approximate solution to the differential equation.
The error between the approximate solution and the true solution is determined by the error that is
made by going from a differential operator to a difference operator. This error is called the
discretization error or truncation error (the term truncation error reflects the fact that a
difference operator can be viewed as a finite part of the infinite Taylor series of the differential
operator).
The finite Different Method (FDM) consists of transforming the partial derivatives in difference
equations over a small interval.
Assuming that u is function of the independent variables x and y , we can divided the x-y plan in
mesh points equal to x = h and y = k , as showed bellow :

We can evaluate u at point P by :


uP = u(ih,jk) = ui,j
The value of the second derivative at P could also be evaluated by:

d 2 u 1 du
du
[ ( x + x)
=
x]
2
x dx
dx
dx
d 2 u 1 u ( x + 2x) u ( x + x) u ( x + x) u ( x)
[
]
=

x
x
dx 2 x

The value of the first derivative at P can be evaluated by three approximations:


1) Central difference:

2) Forward difference:

3) Backward difference:

The forward difference is the difference equation that would be used on the left boundary, when
the function proceeds to the right. This is most common when the function is set to exist in the
first quadrant only. The backward difference would be used to evaluate functions at the opposite
boundary, where the function would have no reference outside of this boundary. Therefore the
difference may only be evaluated at the boundary and what we know about the function prior to
that point.
The central difference is usable everywhere in between. The central difference requires
information in front of, and behind the location being evaluated. Whereas the forward and
backward differences are evaluated with the information on only one side of the location being
evaluated.
Elliptic Equation: Laplacian Difference Equation

Laplace equation for heat conduction is :


T xx + T yy = 0
Applying central differences based on grid scheme as shown in previous figure

T xx =
T yy =

Ti +1, j 2Ti , j + Ti 1, j
Ti , j +1

x 2
.
2Ti , j + Ti , j 1
y 2

Substituting these equations in laplace equation and assuming x = y , the equation becomes
Ti +1, j + Ti 1, j + Ti , j +1Ti , j 1 4Ti , j = 0 .
To solve this equation we can apply Gauss-seidel approach, which is known as Liebmanns
method. The equation is expressed as
Ti , j =

Ti +1, j + Ti 1, j + Ti , j +1Ti , j 1
4

Explicit Method : Implicit Method in a PDE of Parabolic type

Consider the normalized heat equation in one dimension, with homogeneous Dirichlet boundary
conditions

(boundary condition)
(initial condition)
One way to numerically solve this equation is to approximate all the derivatives by finite
differences. We partition the domain in space using a mesh x0,...,xJ and in time using a mesh
t0,....,tN. We assume a uniform partition both in space and in time, so the difference between two
consecutive space points will be h and between two consecutive time points will be k. The points

will represent the numerical approximation of U(xj,tn).


Explicit method

Using a forward difference at time tn and a second-order central difference for the space
derivative at position xj we get the recurrence equation:

This is an explicit method for solving the one-dimensional heat equation.


We can obtain

from the other values this way:

where r = k / h2.
So, knowing the values at time n you can obtain the corresponding ones at time n+1 using this
recurrence relation.
are both 0.

and

must be replaced by the border conditions, in this example they

Using the explicit method, the elements u1 - u9 can be evaluated direclty over the subsequent
elements, which are the boundary condition 1.
This explicit method is known to be numerically stable and convergent whenever
The numerical errors are proportional to the time step and the square of the space step:

Implicit method

If we use the backward difference at time tn + 1 and a second-order central difference for the space
derivative at position xj we get the recurrence equation:

This is an implicit method for solving the one-dimensional heat equation.


We can obtain

from solving a system of linear equations:

This equation applies to all but the first and the last interior nodes which must be modified to
reflect the boundary conditions. Boundary condition at the left end ( j = 0 ) can be expressed as

T0l +1 = f 0 (t l +1 ) where f 0 (t l +1 ) is a function describing how the boundary value changes with
time. Now the difference equation for the fast interior node ( j = 1 ):

(1 + 2r )u1n +1 ru 2n +1 = u1n + rf 0 (t n +1 ) .
Similarly for last interior node( j = m )

(1 + 2r )u mn+1 ru mn+11 = u mn + rf m+1 (t n+1 )


where f m (t l +1 ) describes the change in boundary value at the right end.

However, if we were using the implicit method we will have a system of 9 simultaneous linear
equations, and obtain the 9 unknown values simultaneously.
The scheme is always numerically stable and convergent but usually more numerically intensive
then the explicit method as it requires solving a system of numerical equations on each time step.
The errors are linear over the time step and quadratic over the space step.
Problems:

Exercise 1. Using liebmans method solve for the temperature of the heated plate in the figure
below. The area of the plate is 4cm*4cm Assume x = y = 1cm and temperature inside the plate
is zero initially. The error should be less than 10%.

100 0c
50 0c

750c

0 0c
Exercise 2. Use the explicit method to solve for the temperature distribution of a long, thin rod
with a length of 10 cm and the following values:
x = 2cm , t = 0.1 sec .At t=0, the temperature of the rod is 0 and the boundary conditions are
fixed for all times at T(0)=1000 c and T(10)= 500 c. Obtain the heat distribution at t=4 sec.
Exerxise 3. Solve the problem in exercise 2 using implicit method.

Finite Element Method


Mathematically, the finite element method (FEM) is used for finding approximate solution
of partial differential equations (PDE) as well as of integral equations such as the heat
transport equation. The solution approach is based either on eliminating the differential

equation completely (steady state problems), or rendering the PDE into an equivalent
ordinary differential equation, which is then solved using standard techniques such as finite
differences, etc.
In solving partial differential equations, the primary challenge is to create an equation
which approximates the equation to be studied, but which is numerically stable, meaning
that errors in the input data and intermediate calculations do not accumulate and cause the
resulting output to be meaningless. There are many ways of doing this, all with
advantages and disadvantages. The Finite Element Method is a good choice for solving
partial differential equations over complex domains (like cars and oil pipelines) or when
the desired precision varies over the entire domain. For instance, in simulating the
weather pattern on Earth, it is more important to have accurate predictions over land than
over the wide-open sea, a demand that is achievable using the finite element method.

FEM is useful in solving PDEs for complex shapes as given above. The total
region is divided into small regions of certain geometric shapes(triangular in the above
cases). This is known as grid or mesh. The sizes of triangles can be different in different
parts. Usually small triangles are fitted where variation is more and large triangles are
fitted where variation is less.
MATLAB has a PDE toolbox where FEM can be applied to solve PDE in a
graphical interface.
# In comman window write pdetool & press enter.
# In menubar go to options-applications. Here you can set the type of equation
you want to solve.
# In Draw mode you can draw the region over which PDE is to be solved. You
can set the area limit by double clicking the region.
# Set Boundary mode and then specify the boundary conditions either from
menubar or by double clicking the boundary lines.
#Set PDE mode and through PDE specification you can define the constants in an
equation.

# Solve the equation and plot parameters.


Exercise 4. Select electrostatics from option menu and solve the following
problem. The area of this region is 4 1. = 3.9, = 10e 19. While specifying boundary
conditions set h=1, r=the boundary voltage. Plot electric potential and electric field of the
region.
0v

50v

0v

0v

Revised by,
Emran Md. Amin

You might also like