Rebase(Input: ITimeSeries;
BaseDate: String;
[BasePeriod: DimCalendarLevel = 1;]
[BaseValue: Integer = 100]): Variant;
Input. Переменная.
BaseDate. Дата, относительно которой рассчитывается функция.
BasePeriod. Календарная динамика для функции. Необязательный параметр. Значение по умолчанию: DimCalendarLevel.Year - годовая динамика.
BaseValue. Базовое значение для расчета функции. Необязательный параметр. Значение по умолчанию: «100».
Метод Rebase осуществляет применение функции «Rebase» к указанной переменной.
Для выполнения примера предполагается наличие в репозитории контейнера моделирования с идентификатором «MS». В данном контейнере содержится модель с идентификатором «MODEL_D», рассчитываемая методом детерминированного уравнения и содержащая хотя бы одну входную переменную.
Sub UserProc;
Var
Mb: IMetabase;
ModelSpace, ModelObj: IMetabaseObject;
Transf: IMsFormulaTransform;
Formula: IMsFormula;
Model: IMsModel;
Determ: IMsDeterministicTransform;
TransVar: IMsFormulaTransformVariable;
Slice: IMsFormulaTransformSlice;
TermInfo: IMsFormulaTermInfo;
Expr: IExpression;
Begin
Mb := MetabaseClass.Active;
ModelSpace := Mb.ItemById("MS").Bind;
ModelObj := Mb.ItemByIdNamespace("MODEL_D", ModelSpace.Key).Edit;
Model := ModelObj As IMsModel;
Transf := Model.Transform;
Formula := Transf.FormulaItem(0);
Determ := Formula.Method As IMsDeterministicTransform;
TransVar := Transf.Inputs.Item(0);
Slice := TransVar.Slices.Item(0);
TermInfo := Transf.CreateTermInfo;
TermInfo.Slice := Slice;
TermInfo.Type := MsFormulaTermType.Pointwise;
Expr := Determ.Expression;
Expr.References := "Ms";
Expr.AsString := "Rebase(" + TermInfo.TermInnerText + ", "+""""+"01.01.2006"+""""+")";
If Expr.Valid
Then ModelObj.Save;
Else Debug.WriteLine("Модель не сохранена: ошибка в формуле");
End If;
End Sub UserProc;
После выполнения примера модель будет осуществлять преобразование первой входной переменной с использованием функции «Rebase».
Выражение 1:
Rebase({Brazil|BCA},"2005A")
Результат: к показателю Brazil|BCA будет применена функция «Rebase».
Применение: можно использовать в формулах вычисляемых рядов базы данных временных рядов и в формулах моделей контейнера моделирования, являющегося дочерним по отношению к базе данных временных рядов.
Выражение 2:
Rebase(X1,"2000A")
Результат: к фактору X1 будет применена функция «Rebase».
Применение: можно использовать в формулах моделей контейнера моделирования.
См. также: