При создании и работе с переменной следует учитывать следующие особенности:
класс объекта «Переменная моделирования» - MetabaseObjectClass.KE_CLASS_MSVARIABLE;
обязательно необходимо указывать родительский контейнер, так как переменная моделирования может располагаться только внутри контейнера;
по умолчанию каждая создаваемая переменная содержит годовую динамику и сценарный справочник «Факт».
Для работы с созданной переменной через язык Fore предназначен интерфейс IMsVariable. Используя его свойства и методы можно осуществить загрузку данных в переменную, добавить в неё дополнительные измерения, изменить календарную динамику и настроить прочие параметры.
Примечание. В примерах, представленных ниже, предполагается наличие объектов, которые указаны в разделе описания переменных.
При использовании переменной в расчётах она должна быть представлена как абстрактный источник данных или как терм.
Для использования переменной как абстрактного источника данных, её нужно привести к интерфейсу IVariableStub:
Sub Main;
Var
VarStub: IVariableStub;
MsVar: IMsVariable;
Begin
VarStub := MsVar As IVariableStub;
End Sub Main;
После данного действия переменную можно добавлять в коллекцию входных или выходных переменных модели, реализуемую интерфейсом IMsFormulaTransformVariables:
Sub Main;
Var
Model: IMsModel;
ModelTransform: IMsFormulaTransform;
OutputsVar: IMsFormulaTransformVariables;
VarStub: IVariableStub;
TransformVariable: IMsFormulaTransformVariable;
Begin
ModelTransform := Model.Transform;
OutputsVar := ModelTransform.Outputs;
TransformVariable := InputsVar.Add(VarStub);
End Sub Main;
Если переменная добавлена в коллекцию входных/выходных переменных, то её можно представить как терм, реализуемый интерфейсом IMsFormulaTermInfo:
Sub Main;
Var
Model: IMsModel;
ModelTransform: IMsFormulaTransform;
VarStub: IVariableStub;
TransformVariable: IMsFormulaTransformVariable;
Slice: IMsFormulaTransformSlice;
TermInfo: IMsFormulaTermInfo;
Begin
ModelTransform := Model.Transform;
TransformVariable := ModelTransform.Outputs.Add(VarStub);
Slice := TransformVariable.Slices.Add(Null);
TermInfo := ModelTransform.CreateTermInfo;
TermInfo.Slice := Slice;
End Sub Main;
Используя свойства и методы интерфейса IMsFormulaTermInfo, можно определить тип передачи терма в расчёт, задать начальное преобразование терма и настроить прочие параметры.
Для создания модели сальдо торгового баланса необходимы:
переменные, содержащие исходные данные: «Экспорт - всего, млрд.долл.США» и «Импорт - всего, млрд.долл.США»;
переменная, в которую будут выгружены итоговые данные: «Сальдо торгового баланса, млрд.долл.США».
Для выполнения модуля по созданию переменной «Экспорт - всего, млрд.долл.США» необходимо добавить ссылки на сборки Ms и Metabase.
Sub Main;
Var
MB: IMetabase;
CrInfo: IMetabaseObjectCreateInfo;
MObj: IMetabaseObject;
Begin
MB := MetabaseClass.Active;
// Задаем параметры создания переменной
CrInfo := MB.CreateCreateInfo;
CrInfo.ClassID := MetabaseObjectClass.KE_CLASS_MSVARIABLE;
// Задаем идентификатор переменной
CrInfo.Id := "EXPORT";
// Задаем наименование переменной
CrInfo.Name := "Экспорт - всего, млрд.долл.США";
// Задаем контейнер моделирования для переменной
CrInfo.Parent := MB.ItemById("MODEL_SPACE");
// Создаем и сохраняем переменную
MObj := MB.CreateObject(CrInfo).Edit;
MObj.Save;
// Вывод информации о переменной в окно консоли
Debug.WriteLine("Создана переменная '" + MObj.Name + "' с идентификатором '" + MObj.Id + "'");
End Sub Main;
После выполнения модуля будет создана переменная «Экспорт - всего, млрд.долл.США» с идентификатором EXPORT, информация об этом будет выведена в окно консоли.
Далее аналогичным образом создайте переменную «Импорт - всего, млрд.долл.США» с идентификатором IMPORT и переменную «Сальдо торгового баланса, млрд.долл.США» с идентификатором BALANCE.
Следующим шагом является наполнение начальными данными переменных «Экспорт - всего, млрд.долл.США» и «Импорт - всего, млрд.долл.США». По умолчанию все созданные переменные имеют годовую динамику. Именно для неё и будут вводиться данные.
Для выполнения модуля по наполнению начальными данными переменной «Экспорт - всего, млрд.долл.США» необходимо добавить ссылки на сборки Ms, Metabase, Cubes, Dimensions, Matrix, MathFin.
Sub Main;
Var
MB: IMetabase;
ModelSp: IMetabaseObjectDescriptor;
MObj: IMetabaseObject;
MsVar: IMsVariable;
Cube: IAutoCube;
CubeInst: ICubeInstance;
Des: ICubeInstanceDestination;
DimSS: IDimSelectionSet;
DimS: IDimSelection;
Elem: IDimElementArray;
Mat: IMatrix;
Coord: IMatrixCoord;
Sto: ICubeInstanceStorage;
i: Integer;
Begin
// Задаем переменную моделирования, которая должна быть наполнена данными
MB := MetabaseClass.Active;
ModelSp := MB.ItemById("MODEL_SPACE");
MObj := MB.ItemByIdNamespace("EXPORT", ModelSp.Key).Edit;
MsVar := MObj As IMsVariable;
// Устанавливаем способ наполнения данными - вручную
MsVar.DataFillType := MsVariableDataFillType.Manual;
// Получаем представление переменной в экспресс-анализе
Cube := MsVar.Cube;
CubeInst := (Cube As IMetabaseObject).Open(Null) As ICubeInstance;
Des := CubeInst.Destinations.DefaultDestination;
DimSS := Des.CreateDimSelectionSet;
// Отмечаем динамику, для которой будут указываться данные: Годы
DimS := DimSS.Item(0);
Elem := DimS.Dimension.Levels.Item(0).Elements;
For Each i In Elem Do
DimS.SelectElement(i, False);
End For;
// Отмечаем сценарный справочник «Факт»
DimSS.Item(1).SelectAll;
// Получаем пустую матрицу данных переменной
Mat := Des.Execute(DimSS);
Mat.ValueFlag := Mat.ValueFlag + 1;
Coord := Mat.CreateCoord;
Coord.Item(1) := 0;
// Заполняем матрицу случайными числами из диапазона [50; 100]
Debug.WriteLine("Данные переменной '" + MObj.Name + "':");
For Each i In Elem Do
Coord.Item(0) := i;
Mat.Item(Coord) := Math.RandBetween(50, 100);
Debug.WriteLine(Mat.Item(Coord));
End For;
// Сохраняем данные переменной
Sto := Des.CreateStorage;
Sto.SaveMatrix(Mat, Mat.ValueFlag);
MObj.Save;
End Sub Main;
После выполнения модуля переменная «Экспорт - всего, млрд.долл.США» будет наполнена данными: случайные числа из диапазона [50; 100]. Эти данные будут выведены в окно консоли.
Аналогичным образом наполните данными переменную «Импорт - всего, млрд.долл.США». Переменная «Сальдо торгового баланса, млрд.долл.США» будет содержать результаты расчёта, поэтому данные в неё загружать не требуется.
Следующим шагом будет создание модели.
См. также: