All Downloads are FREE. Search and download functionalities are using the official Maven repository.

cdm.margin.schedule.functions.FXFarLeg Maven / Gradle / Ivy

There is a newer version: 6.0.0-dev.89
Show newest version
package cdm.margin.schedule.functions;

import cdm.base.datetime.AdjustableOrAdjustedOrRelativeDate;
import cdm.product.common.settlement.SettlementDate;
import cdm.product.common.settlement.SettlementTerms;
import cdm.product.qualification.functions.Qualify_ForeignExchange_NDS;
import cdm.product.qualification.functions.Qualify_ForeignExchange_Swap;
import cdm.product.template.EconomicTerms;
import cdm.product.template.NonTransferableProduct;
import cdm.product.template.Payout;
import cdm.product.template.SettlementPayout;
import cdm.product.template.SettlementPayout.SettlementPayoutBuilder;
import com.google.inject.ImplementedBy;
import com.rosetta.model.lib.expression.ComparisonResult;
import com.rosetta.model.lib.functions.ModelObjectValidator;
import com.rosetta.model.lib.functions.RosettaFunction;
import com.rosetta.model.lib.mapper.MapperC;
import com.rosetta.model.lib.mapper.MapperS;
import com.rosetta.model.lib.records.Date;
import java.util.Optional;
import javax.inject.Inject;

import static com.rosetta.model.lib.expression.ExpressionOperators.*;

@ImplementedBy(FXFarLeg.FXFarLegDefault.class)
public abstract class FXFarLeg implements RosettaFunction {
	
	@Inject protected ModelObjectValidator objectValidator;
	
	// RosettaFunction dependencies
	//
	@Inject protected AdjustableOrAdjustedOrRelativeDateResolution adjustableOrAdjustedOrRelativeDateResolution;
	@Inject protected Qualify_ForeignExchange_NDS qualify_ForeignExchange_NDS;
	@Inject protected Qualify_ForeignExchange_Swap qualify_ForeignExchange_Swap;

	/**
	* @param product 
	* @return farLegPayout 
	*/
	public SettlementPayout evaluate(NonTransferableProduct product) {
		SettlementPayout.SettlementPayoutBuilder farLegPayoutBuilder = doEvaluate(product);
		
		final SettlementPayout farLegPayout;
		if (farLegPayoutBuilder == null) {
			farLegPayout = null;
		} else {
			farLegPayout = farLegPayoutBuilder.build();
			objectValidator.validate(SettlementPayout.class, farLegPayout);
		}
		
		return farLegPayout;
	}

	protected abstract SettlementPayout.SettlementPayoutBuilder doEvaluate(NonTransferableProduct product);

	protected abstract MapperC settlementPayout(NonTransferableProduct product);

	public static class FXFarLegDefault extends FXFarLeg {
		@Override
		protected SettlementPayout.SettlementPayoutBuilder doEvaluate(NonTransferableProduct product) {
			SettlementPayout.SettlementPayoutBuilder farLegPayout = SettlementPayout.builder();
			return assignOutput(farLegPayout, product);
		}
		
		protected SettlementPayout.SettlementPayoutBuilder assignOutput(SettlementPayout.SettlementPayoutBuilder farLegPayout, NonTransferableProduct product) {
			if (ComparisonResult.of(MapperS.of(qualify_ForeignExchange_Swap.evaluate(MapperS.of(product).map("getEconomicTerms", nonTransferableProduct -> nonTransferableProduct.getEconomicTerms()).get()))).or(ComparisonResult.of(MapperS.of(qualify_ForeignExchange_NDS.evaluate(MapperS.of(product).map("getEconomicTerms", nonTransferableProduct -> nonTransferableProduct.getEconomicTerms()).get())))).and(exists(settlementPayout(product).map("getSettlementTerms", _settlementPayout -> _settlementPayout.getSettlementTerms()).map("getSettlementDate", settlementTerms -> settlementTerms.getSettlementDate()).map("getValueDate", settlementDate -> settlementDate.getValueDate()))).getOrDefault(false)) {
				farLegPayout = toBuilder(settlementPayout(product)
					.max(item -> item.map("getSettlementTerms", _settlementPayout -> _settlementPayout.getSettlementTerms()).map("getSettlementDate", settlementTerms -> settlementTerms.getSettlementDate()).map("getValueDate", settlementDate -> settlementDate.getValueDate())).get());
			} else if (ComparisonResult.of(MapperS.of(qualify_ForeignExchange_Swap.evaluate(MapperS.of(product).map("getEconomicTerms", nonTransferableProduct -> nonTransferableProduct.getEconomicTerms()).get()))).or(ComparisonResult.of(MapperS.of(qualify_ForeignExchange_NDS.evaluate(MapperS.of(product).map("getEconomicTerms", nonTransferableProduct -> nonTransferableProduct.getEconomicTerms()).get())))).and(exists(settlementPayout(product).map("getSettlementTerms", _settlementPayout -> _settlementPayout.getSettlementTerms()).map("getSettlementDate", settlementTerms -> settlementTerms.getSettlementDate()).map("getAdjustableOrRelativeDate", settlementDate -> settlementDate.getAdjustableOrRelativeDate()))).getOrDefault(false)) {
				farLegPayout = toBuilder(settlementPayout(product)
					.max(item -> MapperS.of(adjustableOrAdjustedOrRelativeDateResolution.evaluate(item.map("getSettlementTerms", _settlementPayout -> _settlementPayout.getSettlementTerms()).map("getSettlementDate", settlementTerms -> settlementTerms.getSettlementDate()).map("getAdjustableOrRelativeDate", settlementDate -> settlementDate.getAdjustableOrRelativeDate()).get()))).get());
			} else {
				farLegPayout = null;
			}
			
			return Optional.ofNullable(farLegPayout)
				.map(o -> o.prune())
				.orElse(null);
		}
		
		@Override
		protected MapperC settlementPayout(NonTransferableProduct product) {
			return MapperS.of(product).map("getEconomicTerms", nonTransferableProduct -> nonTransferableProduct.getEconomicTerms()).mapC("getPayout", economicTerms -> economicTerms.getPayout()).map("getSettlementPayout", payout -> payout.getSettlementPayout());
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy