Skip to main content

Factorial of a number using Stirling's(Gosper) Approximation using Matlab

Problem

Find the factorial of a number using Modified Stirling's formula(Gospers). Also print the difference upto 5 decimals between the result from the factorial function in Matlab and the result you get from approximations.The relation to find the factorial of a number using the Stirling's formula is given by:
Modified Stirlings approximation(Gospers formula) using Matlab
Gospers formula(Modified Stirling formula)
To know more about Stirling's formula or Gospers formula then go to: Stirling's Approximation - Math.Wolfram

Solution

We will solve this problem using Matlab functions. This is similar to our previous post Velocity of a moving fluid using Matlab. But the little difference between the previous post and this post is that we are required to print the difference upto five decimals of the difference between the factorial function in matlab and the above formula.
It should be remembered that we are asked indirectly to print the modulus of the difference. To know about modulus of a number then please do check out mathcenter website
Program is written in a simple manner so that it is easy to understand, also explanation section is written to make a detailed explanation of the program. Please do check out explanation section if you want a detailed explanation of the program. To solve this problem some of the concepts you need to know are as follows:
1) Matlab functions
2) Matlab comments
3) Matlab Variables
4) factorial of a number
5) abs function
6) fprintf in Matlab

Program

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
function gosper = stirlings(n)
%This function will calculate the factorial of a
%number using the modified stirlings formula or 
%gospers formula
%Use this function as follows:
%>> stirlings(n)
%Where n is the number you want the value of the factorial

gosper = sqrt((2*n+(1/3))*pi)*((n^n)*exp(-n));

real = factorial(n);

difference = abs(gosper - real);

fprintf('The difference between real and gosper approximation is: \n');
fprintf('%.5f\n',difference);
end
I have saved this file as stirlings.m on my local computer.

Explanation

Line 1: We have initiated the function with the return value gosper and the name as stirlings whose parameter(s) are only a number.
Line 2-7: They are matlab comments and they can also be called as the documentation of the function. You can get the documentation of the function by typing the following in the command window:

>> help stirlings
And the result will be as follows:
factorial of a number using stirlings approximation using Matlab
Stirlings approximation using Matlab
Line 9: We are creating a variable named gosper and storing the value of the matlab equivalent of the given equation in the question. To know why I have made many parenthesis around each number then you need to understand about Matlab operator precedence.
Line11: I am calculating the value of the factorial using the factorial function of the Matlab.
Line 13: The difference between the value of the factorial function and the value of the value calculated from the gospers formula is calculated. I have also added the modulus of to the number so that we only get a positive value of the number. Read about the abs function in Matlab to know more about the modulus of a number using matlab.
Line15-16 the difference is printed using fprintf function. 

Input/Output

Difference between the factorial function and stirlings formula output
Modified Stirlings approximation using Matlab

Try it yourself

1)Write a program to ask the user to give two options. Option 1 stating that the value of the factorial is calculated using unmodified stirlings formula and Option 2 using modified stirlings formula. According to the user input calculate the same. Stirling formula. Stirlings formula is as follows:
Stirlings approximation formula
Stirlings formula for factorial of a number
Comment your program so that it will be useful for others.

Final Note

I have tried to explain every part in this post so that it is easy for everyone to understand. If you have any doubt or couldn't understand anything then please do comment below or do contact me. Contact me from here: contact me.
The above program was high lighted using hilite.me.
Keywords: stirlings, gosper, approximation, factorial, abs function

Popular posts from this blog

Making a quiz web app with python and flask

Edit : When you are creating a web app with h tml templates, then y ou will have to sa ve the html file in templates folder in the Current Wor ki ng Directory( CWD). If you save the file in the C W D directl y you will get a TemplateNotFound error. Thank you Udhay for pointing it out.   In this post we will create a quiz website using python . I will be using the flask framework . After reading this tutorial you will learn form submission , flask templates , python code in flask templates , shuffling the questions and options with the random module and few others.  Please note that this tutorial is not big as it seems to be. Some of the code has been rewritten to maintain consistency and also font size is somewhat big so that your eyes won't get stressed reading this tutorial. Also the content has not occupied the full width of the page. In this tutorial I am assuming that you are having a very basic understanding of the flask framework . Please refer the documentation

Problem 11 Project Euler Solution with python

Largest product in a grid In the 20×20 grid below, four numbers along a diagonal line have been marked in red. 08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08 49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00 81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65 52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91 22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80 24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50 32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70 67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21 24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72 21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95 78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92 16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57 86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58 19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40 04 52 08 83 97 35 99 16 07

Problem 60 Project Euler Solution with python

Prime pair sets The primes 3, 7, 109, and 673, are quite remarkable. By taking any two primes and concatenating them in any order the result will always be prime. For example, taking 7 and 109, both 7109 and 1097 are prime. The sum of these four primes, 792, represents the lowest sum for a set of four primes with this property. Find the lowest sum for a set of five primes for which any two primes concatenate to produce another prime. This problem is j u st a brute force problem. If you have come here because you don't know the limit upto which you will h ave to gener ate the prime numbers t hen go ahe ad and t r y with 10,000 . When I first start ed solving the problem I chose 1 million(beca use most of the problem s on project E uler have this limit ), but it took very long for the computer to fin d the solution. After searching on the internet then I found many people choosing 10, 000 so I have changed my in put f rom 1 million to 10000 and the output was f ast. He