Well, the rule "For money, always decimal" isn't applied inside the Microsoft development team, because if it was:
Namespace: Microsoft.VisualBasic
Assembly: Microsoft.VisualBasic (in Microsoft.VisualBasic.dll)
Financial.IPmt
and all the other methods would receive/return decimal
and not double
as it is.
Now I wonder if I can use these methods without worry with round mistakes?
Should I use some other libraries to work with finances? If yes, could you point me some good ones (for C#
use) ?
You can use this class:
The rule to use
decimal
for money is helpful because most currencies have decimal units. By using decimal arithmetic, you avoid introducing and accumulating round-off error.Financial Class functions use floating-point for a few reasons:
Pmt
and rounding may determine the nominal monthly payment, but once that amount is determined, balance accumulation -- payments made, interest charges applied, etc. -- happens indecimal
. Also, late or advance payments, payment holidays, and other such non-uniformities would invalidate the projected amortization provided by the financial functions.Here's an interesting discussion regarding exactly this topic: http://www.vbforums.com/showthread.php?t=524101
About 1/3 of the way down someone explains that it uses Double because the VB.NET functions were implemented to work exactly the same as VB6. VB6 doesn't have a decimal type, which is why it uses double.
So, it seems that if accuracy is important, you should not use these functions.
The answers to this question have some promising alternatives - just ignore the accepted answer that suggests using the VB library.The previously linked question has been deleted, so here are some of the suggestions I was referencing (note: I have not tried these, YMMV)
Implementations of excel financial functions in F# - can be used from any .NET language, does not require F# reference
QuantLib may be able to be exported/generated for C#. See this SO question/answer for more info