Solved

Finding NPV (net present value) with PHP

Posted on 2011-03-09
9
1,226 Views
Last Modified: 2012-05-11
Hello Experts!

I need some help finding NPV from an array of reruns.

Let say i have an array containing 20 years of payments with array[0] being the capital outlay.

Array ( [0] => -29669.45 [1] => 84862.5 [2] => 84913.414741969 [3] => 84964.360031128 [4] => 85015.335885805 [5] => 85066.342324338 [6] => 85117.379365077 [7] => 85168.447026381 [8] => 85219.545326622 [9] => 85270.674284183 [10] => 85321.833917456 [11] => 85373.024244847 [12] => 85424.245284771 [13] => 85475.497055654 [14] => 85526.779575933 [15] => 85578.092864059 [16] => 85629.436938489 [17] => 85680.811817695 [18] => 85732.21752016 [19] => 85783.654064375 [20] => 85835.121468845 [21] => 354928.55 ) 

Open in new window


Now... let say i wanted to find the net present value in year 10 with a ROR or discount rate of 8.15%

How would I do that?

My current script:
function npv($rate, $values, $year) {
    for ($i=0;$i<=$year;$i+=1) {
        $npv = $values[$year - $i] + $npv / (1 + $rate);
    }
    return '$'.number_format($npv,2,'.',',');
}

echo npv(.0815, $paymentArray, 10);

Open in new window


Any Ideas would be awesome!
0
Comment
Question by:Cybervanes
  • 4
  • 4
9 Comments
 
LVL 2

Author Comment

by:Cybervanes
ID: 35088104
I'm sorry this should have been worth 500 points...
0
 
LVL 5

Expert Comment

by:SinghAmandeep
ID: 35092427
0
 
LVL 2

Author Comment

by:Cybervanes
ID: 35093422
That was no help. Unless I'm missing somthing... Did you look at that page?
0
Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 
LVL 37

Expert Comment

by:TommySzalapski
ID: 35097417
In your code is $rate 8.15 or .0815? It needs to be .0815; if it isn't use $rate/100.
Also, you should not be dividing by (1+$rate) you should multiply by (1-$rate).
If I understand the question correctly, that should be all you need to get it working right.
0
 
LVL 37

Expert Comment

by:TommySzalapski
ID: 35097441
Scratch that second part. The division is fine. What is your code doing that you think it shouldn't?
0
 
LVL 2

Author Comment

by:Cybervanes
ID: 35098103
I'm noting getting the same figures that i do when using excel's internal NPV function.
0
 
LVL 37

Accepted Solution

by:
TommySzalapski earned 500 total points
ID: 35098298
Ah, I see it. The value that's 10 years old needs to be divided by the rate 10 times. Or (1+rate)^10
If you do this
$npv = ($values[$year - $i] + $npv) / (1 + $rate);
then it should work, since you are already running backward through the array.

By the way, I would do the for loop like this, but it either way is the same.
    for ($i=$year;$i>=0;$i-=1) {
        $npv = ($values[$i] + $npv) / (1 + $rate);
    }

Actually, if array[0] is the capital outlay, shouldn't you run through starting at 0 and going to $year?
0
 
LVL 37

Expert Comment

by:TommySzalapski
ID: 35098338
Er... That last line might not make sense. I don't know NPV that well, I'm just good at figuring formulas out. Doing it the way I suggested matched Excel perfectly.
0
 
LVL 2

Author Closing Comment

by:Cybervanes
ID: 35099178
Thanks!
0

Featured Post

Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Moving from Mcrypt to OpenSSL 18 45
parse url to form? 7 25
mysql query for sum() 3 27
Permutation and Combination - Number of selection of r things 2 21
This article seeks to propel the full implementation of geothermal power plants in Mexico as a renewable energy source.
Lithium-ion batteries area cornerstone of today's portable electronic devices, and even though they are relied upon heavily, their chemistry and origin are not of common knowledge. This article is about a device on which every smartphone, laptop, an…
Explain concepts important to validation of email addresses with regular expressions. Applies to most languages/tools that uses regular expressions. Consider email address RFCs: Look at HTML5 form input element (with type=email) regex pattern: T…
I've attached the XLSM Excel spreadsheet I used in the video and also text files containing the macros used.

790 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question