Ratio(Input: ITimeSeries;
[Period: MsInversionLag = 0;]
[PeriodNumber: Integer = 1]): Variant;
Input. Моделируемая переменная.
Period. Период, в отношении к которому рассчитывается коэффициент роста. Необязательный параметр. Значение по умолчанию - MsInversionLag.PrecidingValue (предыдущий период).
PeriodNumber. Лаг для периода. Необязательный параметр. Минимальное значение и значение по умолчанию - единица.
Метод Ratio осуществляет расчет коэффициента роста точек переменной.
Для выполнения примера предполагается наличие в репозитории контейнера моделирования с идентификатором «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;Stat";
Expr.AsString := "Ratio(" + TermInfo.TermInnerText + ",MsInversionLag.PrecidingValue, 1)";
If Expr.Valid
Then ModelObj.Save;
Else Debug.WriteLine("Модель не сохранена: ошибка в формуле");
End If;
End Sub UserProc;
После выполнения примера модель будет осуществлять расчет коэффициента роста точек первой входной переменной к предыдущему периоду.
Выражение 1:
Ratio({Brazil|BCA},MsInversionLag.PrecidingYear)
Результат: для показателя Brazil|BCA будет рассчитан коэффициент роста значений наблюдений к соответствующему периоду предыдущего года.
Применение: можно использовать в формулах вычисляемых рядов базы данных временных рядов и в формулах моделей контейнера моделирования, являющегося дочерним по отношению к базе данных временных рядов.
Выражение 2:
Ratio(X1,MsInversionLag.PrecidingValue,2)
Результат: для фактора X1 будет рассчитан коэффициент роста значений точек к периоду, сдвинутому от текущего на две точки.
Применение: можно использовать в формулах моделей контейнера моделирования.
См. также: