
com.opengamma.strata.product.common.PayReceive Maven / Gradle / Ivy
Show all versions of strata-product Show documentation
/*
* Copyright (C) 2014 - present by OpenGamma Inc. and the OpenGamma group of companies
*
* Please see distribution for license.
*/
package com.opengamma.strata.product.common;
import org.joda.convert.FromString;
import org.joda.convert.ToString;
import com.opengamma.strata.basics.currency.BigMoney;
import com.opengamma.strata.basics.currency.CurrencyAmount;
import com.opengamma.strata.collect.Decimal;
import com.opengamma.strata.collect.named.EnumNames;
import com.opengamma.strata.collect.named.NamedEnum;
/**
* Flag indicating whether a financial instrument is "pay" or "receive".
*
* Specifies the direction of payments.
* For example, a swap typically has two legs, a pay leg, where payments are made
* to the counterparty, and a receive leg, where payments are received.
*/
public enum PayReceive implements NamedEnum {
/**
* Pay.
*/
PAY,
/**
* Receive.
*/
RECEIVE;
// helper for name conversions
private static final EnumNames NAMES = EnumNames.of(PayReceive.class);
//-------------------------------------------------------------------------
/**
* Obtains an instance from the specified name.
*
* Parsing handles the mixed case form produced by {@link #toString()} and
* the upper and lower case variants of the enum constant name.
*
* @param name the name to parse
* @return the type
* @throws IllegalArgumentException if the name is not known
*/
@FromString
public static PayReceive of(String name) {
return NAMES.parse(name);
}
/**
* Converts a boolean "is pay" flag to the enum value.
*
* @param isPay the pay flag, true for pay, false for receive
* @return the equivalent enum
*/
public static PayReceive ofPay(boolean isPay) {
return isPay ? PAY : RECEIVE;
}
/**
* Converts a signed amount to the enum value.
*
* A negative value will return 'Pay'.
* A positive value will return 'Receive'.
* This effectively parses the result of {@link #normalize(double)}.
*
* @param amount the amount to check
* @return the equivalent enum
*/
public static PayReceive ofSignedAmount(double amount) {
return Double.compare(amount, 0d) < 0 ? PAY : RECEIVE;
}
//-------------------------------------------------------------------------
/**
* Normalizes the specified notional amount using this pay/receive rule.
*
* This returns a negative signed amount if this is 'Pay', and a positive
* signed amount if this is 'Receive'. This effectively normalizes the input
* notional to the pay/receive sign conventions of this library.
* The negative form of zero will never be returned.
*
* @param amount the amount to adjust
* @return the adjusted amount
*/
public double normalize(double amount) {
double normalized = Math.abs(amount);
if (normalized == 0) {
return 0;
}
return isPay() ? -normalized : normalized;
}
/**
* Normalizes the specified notional amount using this pay/receive rule.
*
* This returns a negative signed amount if this is 'Pay', and a positive
* signed amount if this is 'Receive'. This effectively normalizes the input
* notional to the pay/receive sign conventions of this library.
*
* @param amount the amount to adjust
* @return the adjusted amount
*/
public Decimal normalize(Decimal amount) {
Decimal normalized = amount.abs();
return isPay() ? normalized.negated() : normalized;
}
/**
* Normalizes the specified amount using this pay/receive rule.
*
* This returns a negative signed amount if this is 'Pay', and a positive
* signed amount if this is 'Receive'. This effectively normalizes the input
* notional to the pay/receive sign conventions of this library.
* The negative form of zero will never be returned.
*
* @param amount the amount to adjust
* @return the adjusted amount
*/
public CurrencyAmount normalize(CurrencyAmount amount) {
return isPay() ? amount.negative() : amount.positive();
}
/**
* Normalizes the specified {@code BigMoney} amount using this pay/receive rule.
*
* This returns a negative signed amount if this is 'Pay', and a positive
* signed amount if this is 'Receive'. This effectively normalizes the input
* notional to the pay/receive sign conventions of this library.
*
* @param amount the amount to adjust
* @return the adjusted amount
*/
public BigMoney normalize(BigMoney amount) {
return isPay() ? amount.negative() : amount.positive();
}
//-------------------------------------------------------------------------
/**
* Checks if the type is 'Pay'.
*
* @return true if pay, false if receive
*/
public boolean isPay() {
return this == PAY;
}
/**
* Checks if the type is 'Receive'.
*
* @return true if receive, false if pay
*/
public boolean isReceive() {
return this == RECEIVE;
}
//-------------------------------------------------------------------------
/**
* Supplies the opposite of this value.
*
* @return the opposite value
*/
public PayReceive opposite() {
return isPay() ? RECEIVE : PAY;
}
//-------------------------------------------------------------------------
/**
* Returns the formatted name of the type.
*
* @return the formatted string representing the type
*/
@ToString
@Override
public String toString() {
return NAMES.format(this);
}
}