IModelling.RandBetween

Синтаксис

RandBetween(Bottom: Variant; Top: Variant): Variant;

Параметры

Bottom. Наименьшее число, которое возвращает метод RandBetween;

Top. Наибольшее число, которое возвращает метод RandBetween.

Описание

Метод RandBetween возвращает случайное вещественное число между двумя заданными числами.

Пример 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;

Inp_1, Inp_2: String;

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;

Inp_1 := TermInfo.TermInnerText;

TransVar := Transf.Inputs.Item(1);

Slice := TransVar.Slices.Item(0);

TermInfo := Transf.CreateTermInfo;

TermInfo.Slice := Slice;

TermInfo.Type := MsFormulaTermType.Pointwise;

Inp_2 := TermInfo.TermInnerText;

Expr := Determ.Expression;

Expr.References := "Ms";

Expr.AsString := "RandBetween(" + Inp_1 + ", " + Inp_2 + ")";

If Expr.Valid

Then ModelObj.Save;

Else Debug.WriteLine("Модель не сохранена: ошибка в формуле");

End If;

End Sub UserProc;

После выполнения примера модель будет возвращать случайные числа, расположенные между соответствующих точек первой и второй входных переменных.

Пример использования в выражениях

Выражение 1:

RandBetween(Min({Brazil|BCA}),Max({Brazil|BCA}))

Результат: случайное число из диапазона: минимальное значение показателя Brazil|BCA - максимальное значение показателя Brazil|BCA.

Применение: можно использовать в формулах вычисляемых рядов базы данных временных рядов и в формулах моделей контейнера моделирования, являющегося дочерним по отношению к базе данных временных рядов.

Выражение 2:

RandBetween(Min(X1),0)

Результат: случайное число, расположенное между минимальным значением фактора X1 и нулем.

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

См. также:

IModelling | База данных временных рядов: Калькулятор, Абсолютное значение | Контейнер моделирования: Редактирование регрессора/формулы