IModelling.Rebase

Синтаксис

Rebase(Input: ITimeSeries;

BaseDate: String;

[BasePeriod: DimCalendarLevel = 1;]

[BaseValue: Integer = 100]): Variant;

Параметры

Input. Переменная.

BaseDate. Дата, относительно которой рассчитывается функция.

BasePeriod. Календарная динамика для функции. Необязательный параметр. Значение по умолчанию: DimCalendarLevel.Year - годовая динамика.

BaseValue. Базовое значение для расчета функции. Необязательный параметр. Значение по умолчанию: «100».

Описание

Метод Rebase осуществляет применение функции «Rebase» к указанной переменной.

Пример Fore

Для выполнения примера предполагается наличие в репозитории контейнера моделирования с идентификатором «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».

Применение: можно использовать в формулах моделей контейнера моделирования.

См. также:

IModelling