public final class FraCurveNode extends Object implements CurveNode, org.joda.beans.ImmutableBean, Serializable
The trade produced by the node will be a fixed rate receiver (SELL) for a positive quantity and a payer (BUY) for a negative quantity. This convention is line with other nodes where a positive quantity is similar to long a bond or deposit.
| Modifier and Type | Class and Description |
|---|---|
static class |
FraCurveNode.Builder
The bean-builder for
FraCurveNode. |
static class |
FraCurveNode.Meta
The meta-bean for
FraCurveNode. |
| Modifier and Type | Method and Description |
|---|---|
static FraCurveNode.Builder |
builder()
Returns a builder used to create an instance of the bean.
|
LocalDate |
date(LocalDate valuationDate,
ReferenceData refData)
Calculates the date associated with the node.
|
boolean |
equals(Object obj) |
double |
getAdditionalSpread()
Gets the additional spread added to the rate.
|
CurveNodeDate |
getDate()
Gets the method by which the date of the node is calculated, defaulted to 'End'.
|
CurveNodeDateOrder |
getDateOrder()
Gets the date order rules, used to ensure that the dates in the curve are in order.
|
String |
getLabel()
Gets the label to use for the node, defaulted.
|
ObservableId |
getRateId()
Gets the identifier of the market data value that provides the rate.
|
FraTemplate |
getTemplate()
Gets the template for the FRA associated with this node.
|
int |
hashCode() |
double |
initialGuess(MarketData marketData,
ValueType valueType)
Gets the initial guess used for calibrating the node.
|
static FraCurveNode.Meta |
meta()
The meta-bean for
FraCurveNode. |
FraCurveNode.Meta |
metaBean() |
DatedParameterMetadata |
metadata(LocalDate valuationDate,
ReferenceData refData)
Returns metadata for the node.
|
static FraCurveNode |
of(FraTemplate template,
ObservableId rateId)
Returns a curve node for a FRA using the specified instrument template and rate key.
|
static FraCurveNode |
of(FraTemplate template,
ObservableId rateId,
double additionalSpread)
Returns a curve node for a FRA using the specified instrument template, rate key and spread.
|
static FraCurveNode |
of(FraTemplate template,
ObservableId rateId,
double additionalSpread,
String label)
Returns a curve node for a FRA using the specified instrument template, rate key, spread and label.
|
Set<ObservableId> |
requirements()
Determines the market data that is required by the node.
|
ResolvedFraTrade |
resolvedTrade(double quantity,
MarketData marketData,
ReferenceData refData)
Creates a resolved trade representing the instrument at the node.
|
ResolvedFraTrade |
sampleResolvedTrade(LocalDate valuationDate,
FxRateProvider fxProvider,
ReferenceData refData)
Creates a resolved trade representing the instrument at the node.
|
FraCurveNode.Builder |
toBuilder()
Returns a builder that allows this bean to be mutated.
|
String |
toString() |
FraTrade |
trade(double quantity,
MarketData marketData,
ReferenceData refData)
Creates a trade representing the instrument at the node.
|
FraCurveNode |
withDate(CurveNodeDate date)
Returns a copy of this node with the specified date.
|
public static FraCurveNode of(FraTemplate template, ObservableId rateId)
A suitable default label will be created.
template - the template used for building the instrument for the noderateId - the identifier of the market rate used when building the instrument for the nodepublic static FraCurveNode of(FraTemplate template, ObservableId rateId, double additionalSpread)
A suitable default label will be created.
template - the template defining the node instrumentrateId - the identifier of the market data providing the rate for the node instrumentadditionalSpread - the additional spread amount added to the ratepublic static FraCurveNode of(FraTemplate template, ObservableId rateId, double additionalSpread, String label)
template - the template defining the node instrumentrateId - the identifier of the market data providing the rate for the node instrumentadditionalSpread - the additional spread amount added to the ratelabel - the label to use for the nodepublic Set<ObservableId> requirements()
CurveNodeThis returns the market data needed to build the trade that the node represents.
requirements in interface CurveNodepublic LocalDate date(LocalDate valuationDate, ReferenceData refData)
CurveNodeEach curve node has an associated date which defines the x-value in the curve. This date is visible in the parameter metadata.
public DatedParameterMetadata metadata(LocalDate valuationDate, ReferenceData refData)
CurveNodeThis provides curve metadata for the node at the specified valuation date.
public FraTrade trade(double quantity, MarketData marketData, ReferenceData refData)
CurveNodeThis uses the observed market data to build the trade that the node represents. The reference data is typically used to find the start date of the trade from the valuation date. The resulting trade is not resolved. The notional of the trade is taken from the 'quantity' variable. The quantity is signed and will affect whether the trade is Buy or Sell. The valuation date is defined by the market data.
trade in interface CurveNodequantity - the quantity or notional of the trademarketData - the market data required to build a trade for the instrument, including the valuation daterefData - the reference data, used to resolve the trade datespublic ResolvedFraTrade resolvedTrade(double quantity, MarketData marketData, ReferenceData refData)
CurveNodeThis uses the observed market data to build the trade that the node represents. The trade is then resolved using the specified reference data if necessary. The valuation date is defined by the market data.
Resolved objects may be bound to data that changes over time, such as holiday calendars. If the data changes, such as the addition of a new holiday, the resolved form will not be updated. Care must be taken when placing the resolved form in a cache or persistence layer.
resolvedTrade in interface CurveNodequantity - the quantity or notional of the trademarketData - the market data required to build a trade for the instrument, including the valuation daterefData - the reference data, used to resolve the tradepublic ResolvedFraTrade sampleResolvedTrade(LocalDate valuationDate, FxRateProvider fxProvider, ReferenceData refData)
CurveNode
This uses an arbitrary quantity, typically 1, and an arbitrary market data quote, typically 0, to create a trade.
This is useful when the trade is to be used to calculate the current par value.
The FX provider is typically only used for cross-currency trades.
In many cases, FxRateProvider.minimal() can be passed in.
Resolved objects may be bound to data that changes over time, such as holiday calendars. If the data changes, such as the addition of a new holiday, the resolved form will not be updated. Care must be taken when placing the resolved form in a cache or persistence layer.
sampleResolvedTrade in interface CurveNodevaluationDate - the valuation datefxProvider - the FX rate providerrefData - the reference data, used to resolve the tradepublic double initialGuess(MarketData marketData, ValueType valueType)
CurveNodeThis uses the observed market data to select a suitable initial guess. For example, a Fixed-Ibor swap would return the market quote, which is the fixed rate, providing that the value type is 'ZeroRate'. The valuation date is defined by the market data.
This is primarily used as a performance hint. Since the guess is refined by calibration, in most cases any suitable number can be returned, such as zero.
initialGuess in interface CurveNodemarketData - the market data required to build a trade for the instrument, including the valuation datevalueType - the type of y-value that the curve will containpublic FraCurveNode withDate(CurveNodeDate date)
date - the date to usepublic static FraCurveNode.Meta meta()
FraCurveNode.public static FraCurveNode.Builder builder()
public FraCurveNode.Meta metaBean()
metaBean in interface org.joda.beans.Beanpublic FraTemplate getTemplate()
public ObservableId getRateId()
public double getAdditionalSpread()
public String getLabel()
When building, this will default based on the period to end if not specified.
public CurveNodeDate getDate()
public CurveNodeDateOrder getDateOrder()
CurveNodeDateOrder.DEFAULT.getDateOrder in interface CurveNodepublic FraCurveNode.Builder toBuilder()
Copyright 2009-Present by OpenGamma Inc. and individual contributors
Apache v2 licensed
Additional documentation can be found at strata.opengamma.io.