Financial.IRR not calculated in C#
You need to provide a good Guess value as the 2nd parameter to this API. The default value of 0.1 fails for your inputs.
Try this:
double tmpIrr = Financial.IRR(ref tmpCashflows, 0.3);
and you should get back an IRR of -0.2987
It looks like the API handles only specific cases of inputs and fails on others for any guess. This is an IRR API Bug for Microsoft acknowledged here.
You're better off calculating IRR using a 3rd party reliable library,if Guess becomes an issue.
http://connect.microsoft.com/VisualStudio/feedback/details/781299/microsoft-visualbasic-financial-irr-doesnt-solve-for-irr-correctly-in-certain-cases-with-any-guess
The reason you get an Argument is not valid
exception is because the IRR cannot be calculated for the default Guess value of 0.1. Note that the given values satisfy the condition of one negative value (payment) and one positive value. (receipt)
Internally, **Microsoft.VisualBasic.Financial.IRR**
goes through the input values and tries to calculate the IRR over 40 iterations. It never encounters the breaking condition for valid IRR and hence finally throws this error.
Note that Excel gives a value of -30%.
At the same time, trying the IRR for an array like
tmpCashflows = new double[] { -100, 200, 300 };
double tmpIrr = Microsoft.VisualBasic.Financial.IRR(ref tmpCashflows);
gives an IRR of 2.0 or 200%. (both via code and Excel)