IMsMetaModelVisualController.DFTest

Синтаксис Fore

DFTest: IMsVariableTest;

Синтаксис Fore.NET

DFTest: Prognoz.Platform.Interop.Ms.IMsVariableTest;

Описание

Свойство DFTest возвращает параметры расчёта расширенного теста Дики-Фуллера.

Комментарии

Для настройки параметров расчёта используйте интерфейс IMsDFTestSettings.

Пример Fore

Для выполнения примера в репозитории предполагается наличие контейнера моделирования с идентификатором «MS», содержащего задачу моделирования с идентификатором «MODEL_DFTEST_WEB». Задача должна быть создана из веб-приложения и содержать несколько переменных.

Добавьте ссылки на системные сборки: Dimensions, Metabase, Ms, Stat, Transform.

Sub DFTest;
Var
    mb: IMetabase;
    msKey: Integer;
    Problem: IMsProblem;
    Meta: IMsMetaModel;
    MetaVisual: IMsMetaModelVisualController;
    Test: IMsVariableTest;
    CommonSett: IMsVariableTestSettings;
    InclSrc: IMsVariableTestDataList;
    VarArray: Array;
    i, j: Integer;
    Slice: IMsFormulaTransformSlice;
    TestData: IMsVariableTestData;
    DF: IMsDFTestSettings;
    TestRes: IMsVariableTestResults;
    Res: Array;
Begin
    mb := MetabaseClass.Active;
    // Получаем ключ контейнера моделирования
    msKey := mb.GetObjectKeyById("MS");
    // Получаем задачу моделирования
    Problem := mb.ItemByIdNamespace("MODEL_DFTEST_WEB", msKey).Edit As IMsProblem;
    // Получаем метамодель
    Meta := Problem.MetaModel;
    MetaVisual := Meta.VisualController;
    // Задаем общие параметры расчёта описательных статистик
    Test := MetaVisual.DFTest;
    CommonSett := Test.Settings;
    // Период расчёта
    CommonSett.StartDate := DateTime.Parse("01.01.1990");
    CommonSett.EndDate := DateTime.Parse("01.01.2015");
    // Метод обработки пропусков
    CommonSett.MissingData.Method := MissingDataMethod.LinTrend;
    // Задаем переменные для расчёта
    VarArray := MetaVisual.GetVariables;
    InclSrc := CommonSett.IncludedSources;
    InclSrc.Clear;
    Debug.WriteLine("Тестируемые переменные");
    Debug.WriteLine("");
    For i := 0 To VarArray.Length - 1 Do
        // Добавляем только переменные с годовой динамикой
        Slice := VarArray[i] As IMsFormulaTransformSlice;
        If Slice.Level = DimCalendarLevel.Year Then
            TestData := InclSrc.Add(Slice);
            // Задаем лаг и преобразование 1-й переменной
            If i = 0 Then
                TestData.Lag := "1";
                TestData.InversionInfo.Inversion := TsInversion.Log;
            End If;
            // Выводим информацию о переменной в окно консоли
            Debug.WriteLine("Исходное наименование переменной: " + TestData.Slice.Name);
            Debug.WriteLine("Наименование переменной с учетом преобразований и лага: " + TestData.Name);
            Debug.WriteLine("Ключ переменной: " + TestData.EntryKey.ToString);
            Debug.WriteLine("");
        End If;
    End For;
    // Задаем параметры расчёта теста Дики-Фуллера
    DF := CommonSett As IMsDFTestSettings;
    // Задаем порядок авторегрессии
    DF.AutoRegressionOrder := 1;
    // Задаем параметры дифференцирования ряда
    DF.TestedSeries := ADFTestedSeriesType.FirstDifference;
    // Задаем тип модели
    DF.EquationType := ADFEquationType.ConstantTrend;
    // Проверяем, доступен ли расчет теста с помощью пакета R
    If DF.SupportsR
        Then
            DF.UseR := True;
            Debug.WriteLine("При расчете теста будет использоваться подключение R");
        Else
            Debug.WriteLine("Тест не поддерживает расчет с помощью R");
    End If;
    Debug.WriteLine("");
    // Выполняем расчёт теста
    TestRes := Test.Execute;
    // Выводим результаты
    If TestRes.Error <> "" Then
        Debug.WriteLine(TestRes.Error);
    Else
        Res := TestRes.ResValueMatrix;
        Debug.WriteLine("Расширенный тест Дики-Фуллера");
        Debug.WriteLine("");
        For i := 0 To Res.GetUpperBound(1Do
            Select Case i
                Case 0: Debug.Write("Переменные:     ");
                Case 1: Debug.Write("ADF-статистика: ");
                Case 2: Debug.Write("1% значимости:  ");
                Case 3: Debug.Write("5% значимости:  ");
                Case 4: Debug.Write("10% значимости: ");
                Case 5: Debug.Write("Стационарность: ");
                Case 6: Debug.Write("Ошибка:         ");
            End Select;
            For j := 0 To Res.GetUpperBound(2Do
                Debug.Write(Res[i, j]); Debug.Write(";    ");
            End For;
            Debug.WriteLine("");
        End For;
    End If;
End Sub DFTest;

Результат выполнения примера: для всех переменных годовой динамики, которые содержатся модели, рассчитан расширенный тест Дики-Фуллера с помощью пакета R. Результаты выведены в окно консоли.

Пример Fore.NET

Необходимые требования и результат выполнения примера Fore.NET совпадают с примером Fore.

Imports Prognoz.Platform.Interop.Dimensions;
Imports Prognoz.Platform.Interop.Ms;
Imports Prognoz.Platform.Interop.Stat;
Imports Prognoz.Platform.Interop.Transform;

Public Shared Sub Main(Params: StartParams);
Var
    mb: IMetabase;
    msKey: uinteger;
    Problem: IMsProblem;
    Meta: IMsMetaModel;
    MetaVisual: IMsMetaModelVisualController;
    Test: IMsVariableTest;
    CommonSett: IMsVariableTestSettings;
    InclSrc: IMsVariableTestDataList;
    VarArray: Array;
    i, j: Integer;
    Slice: IMsFormulaTransformSlice;
    TestData: IMsVariableTestData;
    DF: IMsDFTestSettings;
    TestRes: IMsVariableTestResults;
    Res: Array;
Begin
    mb := Params.Metabase;
    // Получаем ключ контейнера моделирования
    msKey := mb.GetObjectKeyById("MS");
    // Получаем задачу моделирования
    Problem := mb.ItemByIdNamespace["MODEL_DFTEST_WEB", msKey].Edit() As IMsProblem;
    // Получаем метамодель
    Meta := Problem.MetaModel;
    MetaVisual := Meta.VisualController;
    // Задаем общие параметры расчёта описательных статистик
    Test := MetaVisual.DFTest;
    CommonSett := Test.Settings;
    // Период расчёта
    CommonSett.StartDate := DateTime.Parse("01.01.1990");
    CommonSett.EndDate := DateTime.Parse("01.01.2015");
    // Метод обработки пропусков
    CommonSett.MissingData.Method := MissingDataMethod.mdmLinTrend;
    // Задаем переменные для расчёта
    VarArray := MetaVisual.GetVariables();
    InclSrc := CommonSett.IncludedSources;
    InclSrc.Clear();
    System.Diagnostics.Debug.WriteLine("Тестируемые переменные");
    System.Diagnostics.Debug.WriteLine("");
    For i := 0 To VarArray.Length - 1 Do
        // Добавляем только переменные с годовой динамикой
        Slice := VarArray[i] As IMsFormulaTransformSlice;
        If Slice.Level = DimCalendarLevel.dclYear Then
            TestData := InclSrc.Add(Slice, 0);
            // Задаем лаг и преобразование 1-й переменной
            If i = 0 Then
                TestData.Lag := "1";
                TestData.InversionInfo.Inversion := TsInversion.tsiLog;
            End If;
            // Выводим информацию о переменной в окно консоли
            System.Diagnostics.Debug.WriteLine("Исходное наименование переменной: " + TestData.Slice.Name);
            System.Diagnostics.Debug.WriteLine("Наименование переменной с учетом преобразований и лага: " + TestData.Name);
            System.Diagnostics.Debug.WriteLine("");
        End If;
    End For;
    // Задаем параметры расчёта теста Дики-Фуллера
    DF := CommonSett As IMsDFTestSettings;
    // Задаем порядок авторегрессии
    DF.AutoRegressionOrder := 1;
    // Задаем параметры дифференцирования ряда
    DF.TestedSeries := ADFTestedSeriesType.adftstLevel;
    // Задаем тип модели
    DF.EquationType := ADFEquationType.adfetConstantTrend;
    // Проверяем, доступен ли расчет теста с помощью пакета R
    If DF.SupportsR
        Then
            DF.UseR := True;
            System.Diagnostics.Debug.WriteLine("При расчете теста будет использоваться подключение R");
        Else
            System.Diagnostics.Debug.WriteLine("Тест не поддерживает расчет с помощью R");
    End If;
    System.Diagnostics.Debug.WriteLine("");
    // Выполняем расчёт теста
    TestRes := Test.Execute();
    // Выводим результаты
    If TestRes.Error <> "" Then
        System.Diagnostics.Debug.WriteLine(TestRes.Error);
    Else
        Res := TestRes.ResValueMatrix;
        System.Diagnostics.Debug.WriteLine("Расширенный тест Дики-Фуллера");
        System.Diagnostics.Debug.WriteLine("");
        For i := 0 To Res.GetUpperBound(1Do
            Select Case i
                Case 0: System.Diagnostics.Debug.Write("Переменные:     ");
                Case 1: System.Diagnostics.Debug.Write("ADF-статистика: ");
                Case 2: System.Diagnostics.Debug.Write("1% значимости:  ");
                Case 3: System.Diagnostics.Debug.Write("5% значимости:  ");
                Case 4: System.Diagnostics.Debug.Write("10% значимости: ");
                Case 5: System.Diagnostics.Debug.Write("Стационарность: ");
                Case 6: System.Diagnostics.Debug.Write("Ошибка:         ");
            End Select;
            For j := 0 To Res.GetUpperBound(0Do
                System.Diagnostics.Debug.Write(Res[j, i]); System.Diagnostics.Debug.Write(";    ");
            End For;
            System.Diagnostics.Debug.WriteLine("");
        End For;
    End If;
End Sub;

См. также:

IMsMetaModelVisualController