Options
All
  • Public
  • Public/Protected
  • All
Menu

Plain-vanilla swap: fix vs floating leg

If no payment convention is passed, the convention of the floating-rate schedule is used.

warning

if Settings.includeReferenceDateCashFlows() is set to true, payments occurring at the settlement date of the swap might be included in the NPV and therefore affect the fair-rate and fair-spread calculation. This might not be what you want.

test
  • the correctness of the returned value is tested by checking that the price of a swap paying the fair fixed rate is null.
  • the correctness of the returned value is tested by checking that the price of a swap receiving the fair floating-rate spread is null.
  • the correctness of the returned value is tested by checking that the price of a swap decreases with the paid fixed rate.
  • the correctness of the returned value is tested by checking that the price of a swap increases with the received floating-rate spread.
  • the correctness of the returned value is tested by checking it against a known good value.

Hierarchy

Implements

Index

Constructors

constructor

Properties

Protected _NPV

_NPV: Real

Protected _additionalResults

_additionalResults: Map<string, any> = new Map<string, any>()

_alwaysForward

_alwaysForward: boolean = false

_calculated

_calculated: boolean = false

Protected _endDiscounts

_endDiscounts: DiscountFactor[]

_engine

_engine: PricingEngine

Protected _errorEstimate

_errorEstimate: Real

Private _fairRate

_fairRate: Rate

Private _fairSpread

_fairSpread: Spread

Private _fixedDayCount

_fixedDayCount: DayCounter

Private _fixedRate

_fixedRate: Rate

Private _fixedSchedule

_fixedSchedule: Schedule

Private _floatingDayCount

_floatingDayCount: DayCounter

Private _floatingSchedule

_floatingSchedule: Schedule

_frozen

_frozen: boolean = false

Private _iborIndex

_iborIndex: IborIndex

_isDisposed

_isDisposed: boolean = false

Protected _legBPS

_legBPS: Real[]

Protected _legNPV

_legNPV: Real[]

Protected _legs

_legs: Leg[]

Private _nominal

_nominal: Real

Protected _npvDateDiscount

_npvDateDiscount: DiscountFactor

_observables

_observables: Set<Observable> = new Set()

_observers

_observers: Set<Observer> = new Set()

Protected _payer

_payer: Real[]

Private _paymentConvention

_paymentConvention: BusinessDayConvention

Private _spread

_spread: Spread

Protected _startDiscounts

_startDiscounts: DiscountFactor[]

Private _type

_type: Type

Protected _valuationDate

_valuationDate: Date

dispose

dispose: () => void

Type declaration

    • (): void
    • Returns void

isDisposed

isDisposed: boolean

notifyObservers

notifyObservers: () => void

Type declaration

    • (): void
    • Returns void

registerObserver

registerObserver: (o: Observer) => void

Type declaration

registerWith

registerWith: (h: Observable) => void

Type declaration

registerWithObservables

registerWithObservables: (o: Observer) => void

Type declaration

unregisterObserver

unregisterObserver: (o: Observer) => void

Type declaration

unregisterWith

unregisterWith: (h: Observable) => Size

Type declaration

unregisterWithAll

unregisterWithAll: () => void

Type declaration

    • (): void
    • Returns void

Methods

NPV

  • returns the net present value of the instrument.

    Returns Real

additionalResults

  • additionalResults(): Map<string, any>
  • returns all additional result returned by the pricing engine.

    Returns Map<string, any>

alwaysForwardNotifications

  • alwaysForwardNotifications(): void
  • This method causes the object to forward all notifications, even when not calculated. The default behavior is to forward the first notification received, and discard the others until recalculated; the rationale is that observers were already notified, and don't need further notification until they recalculate, at which point this object would be recalculated too. After recalculation, this object would again forward the first notification received.

    warning Forwarding all notifications will cause a performance hit, and should be used only when discarding notifications cause an incorrect behavior.

    Returns void

calculate

  • calculate(): void

deepUpdate

  • deepUpdate(): void

endDiscounts

errorEstimate

  • errorEstimate(): Real
  • returns the error estimate on the NPV when available.

    Returns Real

fairRate

  • Returns Rate

fairSpread

  • Returns Spread

fetchResults

fixedDayCount

  • Returns DayCounter

fixedLeg

  • fixedLeg(): Leg
  • Returns Leg

fixedLegBPS

  • fixedLegBPS(): Real
  • Returns Real

fixedLegNPV

  • fixedLegNPV(): Real
  • Returns Real

fixedRate

  • Returns Rate

fixedSchedule

  • Returns Schedule

floatingDayCount

  • Returns DayCounter

floatingLeg

  • floatingLeg(): Leg
  • Returns Leg

floatingLegBPS

  • floatingLegBPS(): Real
  • Returns Real

floatingLegNPV

  • floatingLegNPV(): Real
  • Returns Real

floatingSchedule

  • Returns Schedule

freeze

  • freeze(): void
  • This method constrains the object to return the presently cached results on successive invocations, even if arguments upon which they depend should change.

    Returns void

iborIndex

  • Returns IborIndex

init

init1

  • Parameters

    • firstLeg: Leg
    • secondLeg: Leg

    Returns Swap

init2

  • init2(legs: Leg[], payer: boolean[]): Swap
  • Parameters

    • legs: Leg[]
    • payer: boolean[]

    Returns Swap

init3

  • Parameters

    Returns Swap

isExpired

  • isExpired(): boolean

leg

  • Parameters

    Returns Leg

legBPS

  • Parameters

    Returns Real

legNPV

  • Parameters

    Returns Real

maturityDate

  • maturityDate(): Date
  • Returns Date

nominal

  • Returns Real

npvDateDiscount

paymentConvention

performCalculations

  • performCalculations(): void

recalculate

  • recalculate(): void
  • This method force the recalculation of any results which would otherwise be cached. It is not declared as const since it needs to call the non-const notifyObservers method.

    note Explicit invocation of this method is not necessary if the object registered itself as observer with the structures on which such results depend. It is strongly advised to follow this policy when possible.

    Returns void

result

  • result(tag: string): any
  • returns any additional result returned by the pricing engine.

    Parameters

    • tag: string

    Returns any

setPricingEngine

  • set the pricing engine to be used.

    warning calling this method will have no effects in case the performCalculation method was overridden in a derived class.

    Parameters

    Returns void

setupArguments

setupExpired

  • setupExpired(): void
  • Returns void

spread

  • Returns Spread

startDate

  • startDate(): Date
  • Returns Date

startDiscounts

type

  • Returns Type

unfreeze

  • unfreeze(): void
  • This method reverts the effect of the freeze method, thus re-enabling recalculations.

    Returns void

update

  • update(): void

valuationDate

  • valuationDate(): Date
  • returns the date the net present value refers to.

    Returns Date