Price(Settlement: DateTime; Maturity: DateTime; Rate: Double; YieldP: Double; Redemption: Double; Frequency: Integer; [Basis: Integer = 0]): Double;
Settlement. The payment day on securities. Must be greater than Issue.
Maturity. The security's maturity date. Must be greater than FirstCouponDate.
LastCouponDate. The date of the last coupon payment on securities. Must be less than Settlement.
Rate. The security's interest rate. Must be positive.
YieldP. The annual income on securities. Must be positive.
Redemption. The security's redemption value per $100 face value. Must be positive.
Frequency. The annual number of coupon payments. The parameter can take the following values:
1. Annual payments.
2. Semi-annual payments.
4. Quarterly payments.
Basis. The day calculation method used. Select a value from 0 to 4:
0. Day calculation method - American/360 days (NSAD method). Default value.
1. Day calculation method - Actual/actual.
2. Day calculation method - Actual/360 days.
3. Day calculation method - Actual/365 days.
4. Day calculation method - European 30/360 days.
Optional parameter.
The Price method returns the price for $100 of securities face value, for which periodic interest is paid.
To get yield of securities, by which regular interest payments are executed, use the IFinance.YieldF method.
Add a link to the MathFin system assembly.
Sub UserProc;
Var
r: Double;
Begin
r := Finance.Price(DateTime.ComposeDay(2007,01,01), DateTime.ComposeDay(2007,10,01), 0.05, 0.35, 1510, 1, 0);
Debug.WriteLine(r);
End Sub UserProc;
After executing the example the console window displays a price for 100$ of securities face value equal to 1198.75.
See also: