1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<meta name="robots" content="none">
<title>QuantLib: ForwardRateAgreement Class Reference</title>
<link rel="stylesheet" href="quantlib.css" type="text/css">
<link rel="stylesheet" href="print.css" type="text/css" media="print">
<link rel="shortcut icon" href="favicon.ico" type="image/x-icon">
<link rel="icon" href="favicon.ico" type="image/x-icon">
</head>
<body>
<div id="container">
<div id="header">
<img class="titleimage"
src="QL-title.jpg" width="212" height="47" border="0"
alt="QuantLib">
<br>
<h3 class="subtitle">A free/open-source library for quantitative finance</h3>
</div>
<div id="menu">
<h3 class="navbartitle">Version 0.3.14</h3>
<hr>
<h3 class="navbartitle">Getting started</h3>
<ul class="navbarlist">
<li class="navlink"><a href="index.html">Introduction</a></li>
<li class="navlink"><a href="overview.html">Project overview</a></li>
<li class="navlink"><a href="where.html">Where to get QuantLib</a></li>
<li class="navlink"><a href="install.html">Installation</a></li>
<li class="navlink"><a href="config.html">Configuration</a></li>
<li class="navlink"><a href="usage.html">Usage</a></li>
<li class="navlink"><a href="faq.html">Frequently asked questions</a></li>
<li class="navlink"><a href="history.html">Version history</a></li>
<li class="navlink"><a href="resources.html">Additional resources</a></li>
<li class="navlink"><a href="group.html">The QuantLib group</a></li>
<li class="navlink"><a href="license.html">Copyright and license</a></li>
</ul>
<hr>
<h3 class="navbartitle">Reference manual</h3>
<ul class="navbarlist">
<li class="navlink"><a href="modules.html">Modules</a></li>
<li class="navlink"><a href="hierarchy.html">Class Hierarchy</a></li>
<li class="navlink"><a href="annotated.html">Compound List</a></li>
<li class="navlink"><a href="files.html">File List</a></li>
<li class="navlink"><a href="functions.html">Compound Members</a></li>
<li class="navlink"><a href="globals.html">File Members</a></li>
<li class="navlink"><a href="todo.html">Todo List</a></li>
<li class="navlink"><a href="bug.html">Known Bugs</a></li>
<li class="navlink"><a href="caveats.html">Caveats</a></li>
<li class="navlink"><a href="test.html">Test Suite</a></li>
<li class="navlink"><a href="deprecated.html">Deprecated Features</a></li>
<li class="navlink"><a href="examples.html">Examples</a></li>
</ul>
</div>
<div id="content">
<!--Doxygen-generated content-->
<!-- Generated by Doxygen 1.5.1 -->
<div class="nav">
<b>QuantLib</b>::<a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html">ForwardRateAgreement</a></div>
<h1>ForwardRateAgreement Class Reference<br>
<small>
[<a class="el" href="group__instruments.html">Financial instruments</a>]</small>
</h1><!-- doxytag: class="QuantLib::ForwardRateAgreement" --><!-- doxytag: inherits="QuantLib::Forward" --><code>#include <ql/Instruments/forwardrateagreement.hpp></code>
<p>
Inheritance diagram for ForwardRateAgreement:<p><center><img src="class_quant_lib_1_1_forward_rate_agreement__inherit__graph.png" border="0" usemap="#_forward_rate_agreement__inherit__map" alt="Inheritance graph"></center>
<map name="_forward_rate_agreement__inherit__map">
<area href="class_quant_lib_1_1_forward.html" shape="rect" coords="75,231,149,255" alt="">
<area href="class_quant_lib_1_1_instrument.html" shape="rect" coords="64,156,160,180" alt="">
<area href="class_quant_lib_1_1_lazy_object.html" shape="rect" coords="64,81,160,105" alt="">
<area href="class_quant_lib_1_1_observable.html" shape="rect" coords="5,7,104,31" alt="">
<area href="class_quant_lib_1_1_observer.html" shape="rect" coords="128,7,211,31" alt="">
</map>
<center><font size="2">[<a href="graph_legend.html">legend</a>]</font></center><a href="class_quant_lib_1_1_forward_rate_agreement-members.html">List of all members.</a><hr><a name="_details"></a><h2>Detailed Description</h2>
<a class="el" href="class_quant_lib_1_1_forward.html">Forward</a> rate agreement (FRA) class.
<p>
1. Unlike the forward contract conventions on carryable financial assets (stocks, bonds, commodities), the valueDate for an FRA is taken to be the day the forward loan or deposit begins and when full settlement takes place (based on the NPV of the contract on that date). maturityDate is the date the forward loan or deposit ends. In fact, the FRA settles and expires on the valueDate, not on the (later) maturityDate. It follows that (maturityDate - valueDate) is the tenor/term of the underlying loan or deposit<p>
2. Choose position type = Long for an "FRA purchase" (future long loan, short deposit [borrower])<p>
3. Choose position type = <a class="el" href="class_quant_lib_1_1_short.html">Short</a> for an "FRA sale" (future short loan, long deposit [lender])<p>
4. If strike is given in the constructor, can calculate the NPV of the contract via <a class="el" href="class_quant_lib_1_1_instrument.html#4f791921f063f3ea19bd6efa9ceb4892">NPV()</a>.<p>
5. If forward rate is desired/unknown, it can be obtained via <a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html#f83c055c629943801ac2df90d61a6d98">forwardRate()</a>. In this case, the strike variable in the constructor is irrelevant and will be ignored.<p>
<b>Example: </b> <a class="el" href="_f_r_a_8cpp-example.html">valuation of a forward-rate agreement </a><p>
<dl compact><dt><b><a class="el" href="todo.html#_todo000027">Todo:</a></b></dt><dd>Add preconditions and tests</dd></dl>
<dl compact><dt><b><a class="el" href="todo.html#_todo000027">Todo:</a></b></dt><dd>Should put an instance of <a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html">ForwardRateAgreement</a> in the <a class="el" href="class_quant_lib_1_1_fra_rate_helper.html">FraRateHelper</a> to ensure consistency with the piecewise yield curve.</dd></dl>
<dl compact><dt><b><a class="el" href="todo.html#_todo000027">Todo:</a></b></dt><dd>Differentiate between BBA (British)/AFB (French) [assumed here] and ABA (Australian) banker conventions in the calculations.</dd></dl>
<dl compact><dt><b><a class="el" href="caveats.html#_caveats000051">Warning:</a></b></dt><dd>This class still needs to be rigorously tested</dd></dl>
<dl compact><dt><b>Examples: </b></dt><dd>
<p>
<a class="el" href="_f_r_a_8cpp-example.html#_a18">FRA.cpp</a>.</dl>
<p>
<table border="0" cellpadding="0" cellspacing="0">
<tr><td></td></tr>
<tr><td colspan="2"><br><h2>Public Member Functions</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="e7b14bfa8a1a869ccab101068863ede8"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::ForwardRateAgreement" ref="e7b14bfa8a1a869ccab101068863ede8" args="(const Date &valueDate, const Date &maturityDate, Position::Type type, Rate strikeForwardRate, Real notionalAmount, const boost::shared_ptr< Xibor > &index, const Handle< YieldTermStructure > &discountCurve=Handle< YieldTermStructure >())" -->
</td><td class="memItemRight" valign="bottom"><b>ForwardRateAgreement</b> (const <a class="el" href="class_quant_lib_1_1_date.html">Date</a> &valueDate, const <a class="el" href="class_quant_lib_1_1_date.html">Date</a> &maturityDate, Position::Type type, <a class="el" href="group__types.html#gede435af51236692b1107d7639581d39">Rate</a> strikeForwardRate, Real notionalAmount, const boost::shared_ptr< <a class="el" href="class_quant_lib_1_1_xibor.html">Xibor</a> > &index, const <a class="el" href="class_quant_lib_1_1_handle.html">Handle</a>< <a class="el" href="class_quant_lib_1_1_yield_term_structure.html">YieldTermStructure</a> > &discountCurve=<a class="el" href="class_quant_lib_1_1_handle.html">Handle</a>< <a class="el" href="class_quant_lib_1_1_yield_term_structure.html">YieldTermStructure</a> >())</td></tr>
<tr><td colspan="2"><div class="groupHeader">Calculations</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html#72b04552f657bbfa9384c3c6139a7725">isExpired</a> () const</td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="class_quant_lib_1_1_date.html">Date</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html#c64e9810c0bd1cbee8425476db0bb58d">settlementDate</a> () const</td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">Real </td><td class="memItemRight" valign="bottom"><a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html#f17ea9c23961db17b0c901c96854c839">spotIncome</a> (const <a class="el" href="class_quant_lib_1_1_handle.html">Handle</a>< <a class="el" href="class_quant_lib_1_1_yield_term_structure.html">YieldTermStructure</a> > &incomeDiscountCurve) const</td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">Real </td><td class="memItemRight" valign="bottom"><a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html#2bb5d56364044aa5899a663ba84e92a3">spotValue</a> () const</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Spot value (NPV) of the underlying loan. <a href="#2bb5d56364044aa5899a663ba84e92a3"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="f83c055c629943801ac2df90d61a6d98"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::forwardRate" ref="f83c055c629943801ac2df90d61a6d98" args="() const" -->
<a class="el" href="class_quant_lib_1_1_interest_rate.html">InterestRate</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html#f83c055c629943801ac2df90d61a6d98">forwardRate</a> () const</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Returns the relevant forward rate associated with the FRA term. <br></td></tr>
<tr><td colspan="2"><br><h2>Protected Member Functions</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html#33f04fb3ac37abe7c9c6032cff611745">performCalculations</a> () const</td></tr>
<tr><td colspan="2"><br><h2>Protected Attributes</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="37b1d8c236b9c6aa5b638ab7116525c1"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::fraType_" ref="37b1d8c236b9c6aa5b638ab7116525c1" args="" -->
Position::Type </td><td class="memItemRight" valign="bottom"><b>fraType_</b></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="4f2b17fe2dbe0ad6d82e5390ac162403"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::forwardRate_" ref="4f2b17fe2dbe0ad6d82e5390ac162403" args="" -->
<a class="el" href="class_quant_lib_1_1_interest_rate.html">InterestRate</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html#4f2b17fe2dbe0ad6d82e5390ac162403">forwardRate_</a></td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">aka FRA rate (the market forward rate) <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="1d09c6bb42f2e1ad73823bfa1ad6f5b3"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::strikeForwardRate_" ref="1d09c6bb42f2e1ad73823bfa1ad6f5b3" args="" -->
<a class="el" href="class_quant_lib_1_1_interest_rate.html">InterestRate</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="class_quant_lib_1_1_forward_rate_agreement.html#1d09c6bb42f2e1ad73823bfa1ad6f5b3">strikeForwardRate_</a></td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">aka FRA fixing rate, contract rate <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="0791bd889954caaaf829a9e5afc95a19"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::notionalAmount_" ref="0791bd889954caaaf829a9e5afc95a19" args="" -->
Real </td><td class="memItemRight" valign="bottom"><b>notionalAmount_</b></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="046436d9788df2cef672afcbff782298"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::index_" ref="046436d9788df2cef672afcbff782298" args="" -->
boost::shared_ptr< <a class="el" href="class_quant_lib_1_1_xibor.html">Xibor</a> > </td><td class="memItemRight" valign="bottom"><b>index_</b></td></tr>
</table>
<hr><h2>Member Function Documentation</h2>
<a class="anchor" name="72b04552f657bbfa9384c3c6139a7725"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::isExpired" ref="72b04552f657bbfa9384c3c6139a7725" args="() const" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool isExpired </td>
<td>(</td>
<td class="paramname"> </td>
<td> ) </td>
<td width="100%"> const<code> [virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>
A FRA expires/settles on the valueDate
<p>
Reimplemented from <a class="el" href="class_quant_lib_1_1_forward.html#72b04552f657bbfa9384c3c6139a7725">Forward</a>.
</div>
</div><p>
<a class="anchor" name="c64e9810c0bd1cbee8425476db0bb58d"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::settlementDate" ref="c64e9810c0bd1cbee8425476db0bb58d" args="() const" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="class_quant_lib_1_1_date.html">Date</a> settlementDate </td>
<td>(</td>
<td class="paramname"> </td>
<td> ) </td>
<td width="100%"> const<code> [virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>
This returns evaluationDate + settlementDays (not FRA valueDate).
<p>
Reimplemented from <a class="el" href="class_quant_lib_1_1_forward.html">Forward</a>.
</div>
</div><p>
<a class="anchor" name="f17ea9c23961db17b0c901c96854c839"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::spotIncome" ref="f17ea9c23961db17b0c901c96854c839" args="(const Handle< YieldTermStructure > &incomeDiscountCurve) const" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">Real spotIncome </td>
<td>(</td>
<td class="paramtype">const <a class="el" href="class_quant_lib_1_1_handle.html">Handle</a>< <a class="el" href="class_quant_lib_1_1_yield_term_structure.html">YieldTermStructure</a> > & </td>
<td class="paramname"> <em>incomeDiscountCurve</em> </td>
<td> ) </td>
<td width="100%"> const<code> [virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>
Income is zero for a FRA
<p>
Implements <a class="el" href="class_quant_lib_1_1_forward.html#a182c8a294fdc1dc381d8674e581045b">Forward</a>.
</div>
</div><p>
<a class="anchor" name="2bb5d56364044aa5899a663ba84e92a3"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::spotValue" ref="2bb5d56364044aa5899a663ba84e92a3" args="() const" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">Real spotValue </td>
<td>(</td>
<td class="paramname"> </td>
<td> ) </td>
<td width="100%"> const<code> [virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>
Spot value (NPV) of the underlying loan.
<p>
This has always a positive value (asset), even if short the FRA
<p>
Implements <a class="el" href="class_quant_lib_1_1_forward.html#03bf9b7028af075bcaf288e9681aa4ba">Forward</a>.
</div>
</div><p>
<a class="anchor" name="33f04fb3ac37abe7c9c6032cff611745"></a><!-- doxytag: member="QuantLib::ForwardRateAgreement::performCalculations" ref="33f04fb3ac37abe7c9c6032cff611745" args="() const" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void performCalculations </td>
<td>(</td>
<td class="paramname"> </td>
<td> ) </td>
<td width="100%"> const<code> [protected, virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>
In case a pricing engine is <b>not</b> used, this method must be overridden to perform the actual calculations and set any needed results. In case a pricing engine is used, the default implementation can be used.
<p>
Reimplemented from <a class="el" href="class_quant_lib_1_1_forward.html#33f04fb3ac37abe7c9c6032cff611745">Forward</a>.
</div>
</div><p>
</div>
<div class="footer">
<table align="top" width="100%">
<tr>
<td align="middle" width="33%">
<strong>QuantLib.org</strong><br>
<a href="http://quantlib.org/">
<img src="QL-small.jpg" alt="QuantLib" align="middle" border=0>
</a>
</td>
<td align="middle" width="33%">
<strong>Hosted by</strong><br>
<a href="http://sourceforge.net"><img src=
"sfnetlogo.png" width="88" height="31"
border="0" alt="SourceForge.net Logo"></a>
</td>
<td align="middle" width="33%">
<strong>Documentation generated by</strong><br>
<a href="http://www.doxygen.org">
<img src="doxygen.png" alt="doxygen" align="middle" border=0 width=110 height=53>
</a></td>
</tr>
</table>
</div>
</div>
</body>
</html>
|