VBA Code
Future Value
Write a function that returns the future value of an investment that is compounded n times a year.
Public Function FutureValue( _
ByVal PresentValue As Double, _
ByVal AnnualInterestRate As Double, _
ByVal NumberOfYears as Integer, _
ByVal NumberOfCompounds As Integer)
FutureValue = PresentValue * (1 + AnnualInterestRate / NumberOfCompounds) ^ (NumberOfCompounds * NumberOfYears)
End Function
Effective Interest Rate
Write a function that returns the annual effective interest rate given a nominal interest rate.
Public Function EffectiveInterestRate( _
ByVal NominalInterestRate As Double, _
ByVal NumberOfCompounds As Integer)
EffectiveInterestRate = ( (1 + NominalInterestRate) ^ NumberOfCompounds ) - 1
End Function
Effective Interest Rate
Write a function that returns the annual effective interest rate given a continuously componded nominal interest rate.
Public Function EffectiveInterestRateContinuous( _
ByVal NominalInterestRate As Double)
EffectiveInterestRateContinuous = VBA.Exp(NominalInterestRate) - 1
End Function
Net Present Value
Write a function that is equivalent to the Excel NPV worksheet function.
The first argument should be an array of cash flows.
The second argument should be the discount rate.
Public Function NetPresentValue( _
ByVal arCashFlows As Variant, _
ByVal DiscountRate As Double)
Dim I As Integer
For I = 1 to Application.Count(arCashFlows)
NetPresentValue = NetPresentValue + arCashFlows(i) / (1 + DiscountRate) ^ (I - 1)
Next i
End Function
??
Strategy to hedge interest rate risk
buy corporate bonds
sell equivalent amount of treasury bonds
Public Function BuySellHoldStrategy( _
ByVal rgePrices As Range, _
ByVal rgeClosingPrice As Range, _
ByVal iInterval As Integer) As String
Dim lrowno As Long
Dim inumber As Integer
Dim dbtotal As Double
Application.Volatile (True)
ReDim arresult(rgePrices.Rows.Count - 1)
For lrowno = 1 To (iInterval - 1)
arresult(lrowno - 1) = 0
Next lrowno
For lrowno = 1 To (rgePrices.Rows.Count - iInterval + 1)
dbtotal = 0
For inumber = 1 To iInterval
dbtotal = dbtotal + rgePrices(lrowno, 1).Offset(inumber - 1, 0).Value
Next inumber
If (dbtotal / iInterval) > rgeClosingPrice.Value Then
BuySellHoldStrategy = "Buy 50"
Exit Function
End If
Next lrowno
If Application.WorksheetFunction.StDev(rgePrices) + 2 > rgeClosingPrice.Value Then
BuySellHoldStrategy = "Sell 40"
Exit Function
End If
BuySellHoldStrategy = "Hold"
End Function
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrev