KEMBAR78
Assignment On Bisection Method GIVEN ON 06/10/2020: Program | PDF | Interval (Mathematics) | Zero Of A Function
0% found this document useful (0 votes)
220 views13 pages

Assignment On Bisection Method GIVEN ON 06/10/2020: Program

The document describes problems involving the bisection method to solve nonlinear equations. Problem 1 involves using bisection to find the square root of a number and comparing to the built-in sqrt function. Problem 2 uses bisection to determine the wavelength where Planck's law of spectral radiance is maximized. Problem 3 uses bisection to find the angle corresponding to the first secondary maximum in Fraunhofer diffraction from a single slit. The problems include the relevant theory, programs written in FORTRAN, and discussions of the results.

Uploaded by

Rahul
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)
220 views13 pages

Assignment On Bisection Method GIVEN ON 06/10/2020: Program

The document describes problems involving the bisection method to solve nonlinear equations. Problem 1 involves using bisection to find the square root of a number and comparing to the built-in sqrt function. Problem 2 uses bisection to determine the wavelength where Planck's law of spectral radiance is maximized. Problem 3 uses bisection to find the angle corresponding to the first secondary maximum in Fraunhofer diffraction from a single slit. The problems include the relevant theory, programs written in FORTRAN, and discussions of the results.

Uploaded by

Rahul
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/ 13

ASSIGNMENT ON BISECTION METHOD

GIVEN ON 06/10/2020

Problem No. 1 Write down the nonlinear algebraic equation, the solution
of whichleads to square root of a real numberR. Write a FORTRAN Program
using Bisection method which computes (√2.123) and compare your result
with the inbuilt sqrt function.

THEORY: If there is a functionf(x),which is continuous in an interval [a,b]


such that f(a)∗f(b)<0
According to mean value theorem, there exists at least one root within the
interval[a,b].Bisection method is based on halving the interval [a,b] to a
smallerone so as to keep the root within a smaller interval.
We have to divide the interval [a,b] into two subintervals [a,c]and [c,b]
where c=(a+b)/2
Now,we have to compute the product [f(a)∗f(c)]. If the product is negative,
root of the function f(x), will lie within the smaller interval [a,c]. Otherwise,
positive value of the product ensures that the root lies within the interval [c,b].
Further, this smaller interval is to be divided into two subintervals and the
process will continue until the root of the function is found out with desired
accuracy.
Here, the function is
f(x)= x**2 – 2.123 [x**2=2.123]

PROGRAM
program bisection
real*8:: a,b,c,count,f_anal

write(*,*) "the two intervals are"


read(*,*) a,b
if (f(a)*f(b) >= 0) then
stop
end if

c= (a+b)/2.0
count=1

do
if (f(a)*f(c) < 0) then
b=c
c= (a+b)/2.0
else if (f(c)*f(b) < 0) then
a=c
c=(a+b)/2.0
count= count+1
if (count > 50) then
exit
end if
if (abs(f(c))<0.000001) goto 1
endif
enddo

1 write(*,*)"the numerical solution f is"


print*, c
write(*,*)”no of iterations are”
print*, count

!FOR ANALYTICAL SOLUTION


f_anal = sqrt (2.123)
write(*,*)"The analytical solution f_anal is"
print*, f_anal

end program bisection

function f(x)
real*8:: x
f= (x**2-2.123)
return
end
COMPILATION AND EXECUTION COMMAND
gfortran bisection1.f90
./a.out

OUTPUT:

DISCUSSIONS.

1. The difference in the two outputs(i.e. the numerical and the analytical
solutions) occurs after the 7th decimal place, which shows the numerical
solution is quite accurate,due to double precision of the numerical solutions
and precision of in built square function is in single precision.

2. While writing the program, we have to make sure that in no case both the
intervals falls at the same side of the root or we will fall in an infinitre loop.
Therefore, I have set a counter which stops if the loop exceeds more the 50
times and we dont fall in that infinite loop.
Problem No. 2 Planck’s law for the spectral radiance of a body at
absolute temperature T is given by

B(λ, T ) =((2hc^2)/((λ^5)*(exp(hc/λKB*T)-1)))

where the symbols have their usual meanings. Write a Program to plot the
function with λ for T = 5000K. Use Bisection method to determine the value of
λ correct upto eight decimal places for which B is maximum.

(A)

COMMAND
gnuplot

PROGRAM
GRAPH

(B)

THEORY: If there is a functionf(x),which is continuous in an interval [a,b]


such that f(a)∗f(b)<0
According to mean value theorem, there exists at least one root within the
interval[a,b].Bisection method is based on halving the interval [a,b] to a
smallerone so as to keep the root within a smaller interval.
We have to divide the interval [a,b] into two subintervals [a,c]and [c,b]
where c=(a+b)/2
Now,we have to compute the product [f(a)∗f(c)]. If the product is negative,
root of the function f(x), will lie within the smaller interval [a,c]. Otherwise,
positive value of the product ensures that the root lies within the interval [c,b].
Further, this smaller interval is to be divided into two subintervals and
the process will continue until the root of the function is found out
with desired accuracy.
Now, we know the function for Spectral Radiance is
B(λ, T ) =((2hc^2)/((λ^5)*(exp(hc/λKB*T)-1)))
Now to find the value of λ for which the B( λ,T) is maximum when we need to
find the dB/dλ = 0 and set the transcendented equation.

dB/dλ = ((2hc^2)*(-5)/((λ^6)*(exp(hc/λKB*T)-1))) +
((2hc^2/λ^5)*(((h**2c**2/λ**3*KB*2*T*2)*exp(h*c/λ*KB*T))/((exp(h*c/
KB*λ*T))^2))

Which is set to be equal to zero, for finding the maximun value of B.


And after simplifying, we get,

dB/dλ = 5- (exp(x)*x)/(exp(x)-1) = 0
where, x= (h*c/(λ*KB*t))

Therefore, λ(max)= (h*c/(x*KB*T))


We can find the value of λ(max) in this way

Here, the function is f(x)= 5 – (exp(x)*x/(exp(x)-1)

PROGRAM
program bisection2
real*8 ::a,b,c,h,vel,T,KB
real:: count,W,f

2 write(*,*) "the two intervals are"


read(*,*) a,b

if (f(a)*f(b) >= 0) then


stop
end if
c= (a+b)/2.0
count=1

do
if (f(a)*f(c) < 0) then
b=c
c= (a+b)/2.0
else if (f(c)*f(b) < 0) then
a=c
c=(a+b)/2.0
count= count+1
if (count > 50) then
goto 2
end if
if (abs(f(c))<0.0000001) goto 1
endif
enddo

1 write(*,*)"the numerical solution f is"


print*, c
print*,'no of iteration is ', count

!Calculation of wavelength W
h = 6.262*10.0**(-34)
vel= 3.0 *10.0**(8)
T= 5000
KB= 1.38*10.0**(-23)
W= ((h*vel)/(c*T*KB))
Write(*,*) "The value of wavelength for which B is maximum is"
print*, W

end program bisection2

function f(x)
real*8:: x
f= (5-(exp(x)*x/(exp(x)-1)))
return
end
COMPILATION AND EXECUTION COMMAND
gfortran bisection1.f90
./a.out

OUTPUT:
DISCUSSIONS.
1. The value of maximum B is thus,
B(λ, T ) =((2hc^2)/((λ^5)*(exp(hc/λKB*T)-1)))

= 3.58568326*10^9 W·sr−1·m−3

2. I could not calculate the value of B(max) directly from the program
because of the order of power of constants.
Problem No. 3 Fraunhofer diffraction pattern due to a single slit is
displayed on a screen. Intensity distribution on the screen shows secondary maxima
on either side of the central maximum,the direction of which are determined by
x = tan x
where x is related to angle of diffraction. Solve the above equation using Bisection
method to find x that corresponds to first secondary maximum.Take π/2 and 3π/2
as initial guess values as x in
this case lies between them (see below Figure).

THEORY: If there is a functionf(x),which is continuous in an interval [a,b]


such that f(a)∗f(b)<0
According to mean value theorem, there exists at least one root within the
interval[a,b].Bisection method is based on halving the interval [a,b] to a
smallerone so as to keep the root within a smaller interval.
We have to divide the interval [a,b] into two subintervals [a,c]and [c,b]
where c=(a+b)/2
Now,we have to compute the product [f(a)∗f(c)]. If the product is negative,
root of the function f(x), will lie within the smaller interval [a,c]. Otherwise,
positive value of the product ensures that the root lies within the interval [c,b].
Further, this smaller interval is to be divided into two subintervals and the
process will continue until the root of the function is found out with desired
accuracy.
Here, the function is
f(x)= x-tan(x)
or f(x)= x*cos(x) – sin(x)

Here, the function tan(x) is converted to sin(x)/cos(x) to make the function


solved in the bisection method continuos.

PROGRAM
program bisection3
real*8::a,b,c,pi,count

pi= acos(-1.)
a=pi/2
b=3*pi/2

write(*,*) "the two intervals are"


print*,'a=',a
print*,'b=',b

if (f(a)*f(b) >= 0) then


stop
end if

c= (a+b)/2.0
count=1

do
if (f(a)*f(c) < 0) then
b=c
c= (a+b)/2.0
else if (f(c)*f(b) < 0) then
a=c
c=(a+b)/2.0
count= count+1
if (count > 50) then
exit
end if
if (abs(f(c))<0.0001) goto 1
endif
enddo

1 write(*,*)"the numerical solution f is"


print*, c
write(*,*) “ “
write(*,*)”no of iterations”
print*, count

end program bisection3

function f(x)
real*8:: x
f= (x*cos(x)-sin(x))
return
end

COMPILATION AND EXECUTION COMMAND


gfortran bisection3.f90
./a.out
OUTPUT

DISCUSSIONS.
1. From the graph in the question, we can understand that roots of the
function is found where the y=x and y=tan(x) intersects.

2. Between every pi intervals, we can find a root of the function

3. The roots are the points where the secondary maxima is formed during
Grating Diffraction.

You might also like