cdm.event.common.functions.ResolvePerformanceObservationIdentifiers Maven / Gradle / Ivy
package cdm.event.common.functions;
import cdm.base.datetime.AdjustableOrRelativeDate;
import cdm.base.datetime.BusinessCenterTime;
import cdm.base.datetime.functions.ResolveAdjustableDate;
import cdm.base.staticdata.asset.common.ProductIdentifier;
import cdm.base.staticdata.asset.common.Security;
import cdm.base.staticdata.asset.common.metafields.FieldWithMetaProductIdentifier;
import cdm.base.staticdata.asset.common.metafields.ReferenceWithMetaProductIdentifier;
import cdm.observable.asset.Observable;
import cdm.observable.asset.PerformanceValuationDates;
import cdm.observable.asset.ValuationDates;
import cdm.observable.common.DeterminationMethodEnum;
import cdm.observable.common.TimeTypeEnum;
import cdm.observable.event.ObservationIdentifier;
import cdm.observable.event.ObservationIdentifier.ObservationIdentifierBuilder;
import cdm.product.template.PerformancePayout;
import cdm.product.template.Product;
import com.google.inject.ImplementedBy;
import com.rosetta.model.lib.expression.CardinalityOperator;
import com.rosetta.model.lib.functions.ModelObjectValidator;
import com.rosetta.model.lib.functions.RosettaFunction;
import com.rosetta.model.lib.mapper.Mapper;
import com.rosetta.model.lib.mapper.MapperC;
import com.rosetta.model.lib.mapper.MapperS;
import com.rosetta.model.lib.mapper.MapperUtils;
import com.rosetta.model.lib.records.Date;
import java.util.Optional;
import javax.inject.Inject;
import static com.rosetta.model.lib.expression.ExpressionOperators.*;
@ImplementedBy(ResolvePerformanceObservationIdentifiers.ResolvePerformanceObservationIdentifiersDefault.class)
public abstract class ResolvePerformanceObservationIdentifiers implements RosettaFunction {
@Inject protected ModelObjectValidator objectValidator;
// RosettaFunction dependencies
//
@Inject protected AdjustedValuationDates adjustedValuationDates;
@Inject protected ResolveAdjustableDate resolveAdjustableDate;
@Inject protected ResolvePerformanceValuationTime resolvePerformanceValuationTime;
/**
* @param payout
* @param adjustedDate
* @return identifiers
*/
public ObservationIdentifier evaluate(PerformancePayout payout, Date adjustedDate) {
ObservationIdentifier.ObservationIdentifierBuilder identifiersBuilder = doEvaluate(payout, adjustedDate);
final ObservationIdentifier identifiers;
if (identifiersBuilder == null) {
identifiers = null;
} else {
identifiers = identifiersBuilder.build();
objectValidator.validate(ObservationIdentifier.class, identifiers);
}
return identifiers;
}
protected abstract ObservationIdentifier.ObservationIdentifierBuilder doEvaluate(PerformancePayout payout, Date adjustedDate);
protected abstract Mapper adjustedFinalValuationDate(PerformancePayout payout, Date adjustedDate);
protected abstract Mapper extends PerformanceValuationDates> valuationDates(PerformancePayout payout, Date adjustedDate);
public static class ResolvePerformanceObservationIdentifiersDefault extends ResolvePerformanceObservationIdentifiers {
@Override
protected ObservationIdentifier.ObservationIdentifierBuilder doEvaluate(PerformancePayout payout, Date adjustedDate) {
ObservationIdentifier.ObservationIdentifierBuilder identifiers = ObservationIdentifier.builder();
return assignOutput(identifiers, payout, adjustedDate);
}
protected ObservationIdentifier.ObservationIdentifierBuilder assignOutput(ObservationIdentifier.ObservationIdentifierBuilder identifiers, PerformancePayout payout, Date adjustedDate) {
identifiers
.getOrCreateObservable()
.addProductIdentifierValue(MapperS.of(payout).map("getUnderlier", performancePayout -> performancePayout.getUnderlier()).map("getSecurity", product -> product.getSecurity()).mapC("getProductIdentifier", productBase -> productBase.getProductIdentifier()).map("getValue", _f->_f.getValue()).getMulti());
identifiers
.setObservationDate(MapperC.of(adjustedValuationDates.evaluate(MapperS.of(payout).map("getValuationDates", performancePayout -> performancePayout.getValuationDates()).get()))
.filterItemNullSafe(item -> (Boolean)lessThanEquals(item, MapperS.of(adjustedDate), CardinalityOperator.All).get())
.apply(item -> item
.last()).get());
identifiers
.setObservationTime(MapperS.of(resolvePerformanceValuationTime.evaluate(MapperS.of(valuationDates(payout, adjustedDate).get()).map("getValuationTime", performanceValuationDates -> performanceValuationDates.getValuationTime()).get(), MapperS.of(valuationDates(payout, adjustedDate).get()).map("getValuationTimeType", performanceValuationDates -> performanceValuationDates.getValuationTimeType()).get(), MapperS.of(MapperS.of(identifiers).map("getObservable", observationIdentifier -> observationIdentifier.getObservable()).mapC("getProductIdentifier", observable -> observable.getProductIdentifier()).map("getValue", _f->_f.getValue()).get()).get(), MapperS.of(valuationDates(payout, adjustedDate).get()).map("getDeterminationMethod", performanceValuationDates -> performanceValuationDates.getDeterminationMethod()).get())).get());
identifiers
.getOrCreateDeterminationMethodology()
.setDeterminationMethod(MapperS.of(valuationDates(payout, adjustedDate).get()).map("getDeterminationMethod", performanceValuationDates -> performanceValuationDates.getDeterminationMethod()).get());
return Optional.ofNullable(identifiers)
.map(o -> o.prune())
.orElse(null);
}
@Override
protected Mapper adjustedFinalValuationDate(PerformancePayout payout, Date adjustedDate) {
return MapperS.of(resolveAdjustableDate.evaluate(MapperS.of(payout).map("getValuationDates", performancePayout -> performancePayout.getValuationDates()).map("getValuationDatesFinal", _valuationDates -> _valuationDates.getValuationDatesFinal()).map("getValuationDate", performanceValuationDates -> performanceValuationDates.getValuationDate()).get()));
}
@Override
protected Mapper extends PerformanceValuationDates> valuationDates(PerformancePayout payout, Date adjustedDate) {
return MapperUtils.runSinglePolymorphic(() -> {
if (lessThan(MapperS.of(adjustedDate), MapperS.of(adjustedFinalValuationDate(payout, adjustedDate).get()), CardinalityOperator.All).getOrDefault(false)) {
return MapperS.of(payout).map("getValuationDates", performancePayout -> performancePayout.getValuationDates()).map("getValuationDatesInterim", _valuationDates -> _valuationDates.getValuationDatesInterim());
}
else {
return MapperS.of(payout).map("getValuationDates", performancePayout -> performancePayout.getValuationDates()).map("getValuationDatesFinal", _valuationDates -> _valuationDates.getValuationDatesFinal());
}
});
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy