cfdates
Cash flow dates for fixed-income security
Syntax
Description
generates a matrix of actual cash flow payment dates for
CFlowDates
= cfdates(Settle
,Maturity
)NUMBONDS
fixed income securities. All cash flow
dates are determined regardless of whether the first and last coupon periods
are normal, long or short.
specifies options using one or more optional arguments in addition to the
input arguments in the previous syntax. CFlowDates
= cfdates(___,Period
,Basis
,EndMonthRule
,IssueDate
,FirstCouponDate
,LastCouponDate
)
Examples
Obtain Cash Flow Dates for Fixed-Income Security
Compute the cash flow dates given the Settle
and Maturity
dates.
CFlowDates = cfdates('14 Mar 1997', '30 Nov 1998', 2, 0, 1)
CFlowDates = 1×4
729541 729724 729906 730089
datestr(CFlowDates)
ans = 4x11 char array
'31-May-1997'
'30-Nov-1997'
'31-May-1998'
'30-Nov-1998'
If any of the inputs for Settle
, Maturity
, IssueDate
, FirstCouponDate
, or LastCouponDate
are datetime arrays, then CFlowDates
is returned as a datetime array. For example:
CFlowDates = cfdates('14-Mar-1997', datetime('30-Nov-1998','Locale','en_US'), 2, 0, 1)
CFlowDates = 1x4 datetime
31-May-1997 30-Nov-1997 31-May-1998 30-Nov-1998
Given three securities with different maturity dates and the same default arguments:
Maturity = ['30-Sep-1997'; '31-Oct-1998'; '30-Nov-1998']; CFlowDates = cfdates('14-Mar-1997', Maturity)
CFlowDates = 3×4
729480 729663 NaN NaN
729510 729694 729875 730059
729541 729724 729906 730089
To look at the cash-flow dates for the last security:
datestr(CFlowDates(3,:))
ans = 4x11 char array
'31-May-1997'
'30-Nov-1997'
'31-May-1998'
'30-Nov-1998'
Input Arguments
Settle
— Settlement date
datetime array | string array | date character vector
Settlement date, specified as an
NINST
-by-1
vector
using a datetime array, string array, or date character vectors.
Settle
must be earlier than
Maturity
.
To support existing code, cfdates
also
accepts serial date numbers as inputs, but they are not recommended.
Data Types: char
| string
| datetime
Maturity
— Maturity date
datetime array | string array | date character vector
Maturity date, specified as an
NINST
-by-1
vector
using a datetime array, string array, or date character vectors.
To support existing code, cfdates
also
accepts serial date numbers as inputs, but they are not recommended.
Data Types: char
| string
| datetime
Period
— Coupons per year of the bond
2
(semiannual) (default) | vector of positive integers from the set [1,2,3,4,6,12]
(Optional) Coupons per year of the bond, specified as a vector
of positive integers from the set
[1,2,3,4,6,12]
.
Data Types: double
Basis
— Day-count basis
0
(actual/actual) (default) | positive integers of the set [1...13]
| vector of positive integers of the set [1...13]
(Optional) Day-count basis, specified as positive integers using
a NINST
-by-1
vector.
0 = actual/actual
1 = 30/360 (SIA)
2 = actual/360
3 = actual/365
4 = 30/360 (PSA)
5 = 30/360 (ISDA)
6 = 30/360 (European)
7 = actual/365 (Japanese)
8 = actual/actual (ICMA)
9 = actual/360 (ICMA)
10 = actual/365 (ICMA)
11 = 30/360E (ICMA)
12 = actual/365 (ISDA)
13 = BUS/252
For more information, see Basis.
Data Types: double
EndMonthRule
— End-of-month rule flag
1
(in effect) (default) | nonnegative integer 0
or 1
(Optional) End-of-month rule flag, specified as a scalar or a
NUMBONDS
-by-1
or
1
-by-NUMBONDS
vector. This rule applies only when
Maturity
is an end-of-month date for
a month having 30 or fewer days.
0
= Ignore rule, meaning that a bond coupon payment date is always the same numerical day of the month.1
= Set rule on, meaning that a bond coupon payment date is always the last actual day of the month.
Data Types: logical
IssueDate
— Bond issue date
cash flow payment dates are determined from other inputs (default) | datetime array | string array | date character vector
(Optional) Bond Issue date, specified as a scalar or a
NUMBONDS
-by-1
or
1
-by-NUMBONDS
vector
using a datetime array, string array, or date character vectors.
If you do not specify an IssueDate
, the cash
flow payment dates are determined from other inputs.
To support existing code, cfdates
also
accepts serial date numbers as inputs, but they are not recommended.
Data Types: char
| string
| datetime
FirstCouponDate
— Irregular or normal first coupon date
cash flow payment dates are determined from other inputs (default) | datetime array | string array | date character vector
Irregular or normal first coupon date, specified as a scalar or
a NUMBONDS
-by-1
or
1
-by-NUMBONDS
vector
using a datetime array, string array, or date character
vectors.
If you do not specify a FirstCouponDate
, the
cash flow payment dates are determined from other inputs.
To support existing code, cfdates
also
accepts serial date numbers as inputs, but they are not recommended.
Data Types: char
| string
| datetime
LastCouponDate
— Irregular or normal last coupon date
cash flow payment dates are determined from other inputs (default) | datetime array | string array | date character vector
Irregular or normal last coupon date, specified as a scalar or a
NUMBONDS
-by-1
or
1
-by-NUMBONDS
vector
using a datetime array, string array, or date character
vectors.
If you do not specify a LastCouponDate
, the
cash flow payment dates are determined from other inputs.
To support existing code, cfdates
also
accepts serial date numbers as inputs, but they are not recommended.
Data Types: char
| string
| datetime
Output Arguments
CFlowDates
— Actual cash flow payment dates
matrix
Actual cash flow payment dates, returned as a
N
-row matrix of dates in datetime
format (if inputs are in datetime format).
CFlowDates
has
NUMBONDS
rows and the number of columns
is determined by the maximum number of cash flow payment dates
required to hold the bond portfolio. NaN
s are
padded for bonds which have less than the maximum number of cash
flow payment dates.
If all of the inputs for Settle
,
Maturity
,
IssueDate
,
FirstCouponDate
, or
LastCouponDate
are either strings or
date character vectors, then CFlowDates
is
returned as a serial date number. Use the function datetime
to
convert serial date numbers to formatted datetime arrays.
If any of the inputs for Settle
,
Maturity
,
IssueDate
,
FirstCouponDate
, or
LastCouponDate
are datetime arrays,
then CFlowDates
is returned as a datetime
array.
Note
The cash flow flags for a portfolio of bonds were formerly
available as the cfdates
second output
argument, CFlowFlags
. You can now use
cfamounts
to get these flags. If you
specify a CFlowFlags
argument,
cfdates
displays a message
directing you to use cfamounts
.
Version History
Introduced before R2006aR2022b: Serial date numbers not recommended
Although cfdates
supports serial date numbers,
datetime
values are recommended instead. The
datetime
data type provides flexible date and time
formats, storage out to nanosecond precision, and properties to account for time
zones and daylight saving time.
To convert serial date numbers or text to datetime
values, use the datetime
function. For example:
t = datetime(738427.656845093,"ConvertFrom","datenum"); y = year(t)
y = 2021
There are no plans to remove support for serial date number inputs.
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: United States.
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
Asia Pacific
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)