ISmHodrickPrescottFilter.SmoothingParameterMode

Синтаксис Fore

SmoothingParameterMode: HPSmoothingParameterModeType;

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

SmoothingParameterMode: Prognoz.Platform.Interop.Stat.HPSmoothingParameterModeType;

Описание

Свойство SmoothingParameterMode определяет способ задания параметра сглаживания.

Комментарии

Для SmoothingParameterMode возможны следующие значения:

Пример Fore

Добавьте ссылку на системную сборку Stat.

Sub Print(Data: Array Of Double);
Var
    i: Integer;
Begin
    For i := 0 To Data.Length - 1 Do
        If Double.IsNan(Data[i]) Then
            Debug.WriteLine("----empty---");
            Else
                Debug.WriteLine(i.ToString + " " + Data[i].ToString);
        End If;
    End For;
End Sub Print;
    
Sub UserProc;
Var
    HP: SmHodrickPrescottFilter;
    s: Array Of Double;
    res: Integer;
Begin
    s := New Double[15];
    // Задаём значения переменной
    s[00] := 670.2; s[08] := 1033.3;
    s[01] := 576.06; s[09] := 780.8;
    s[02] := 717.64; s[10] := 657.5;
    s[03] := 856.9; s[11] := 654.5;
    s[04] := 885.4; s[12] := 678.23;
    s[05] := 1011; s[13] := 642.41;
    s[06] := 995.44; s[14] := 751.9;
    s[07] := 1064.74;
    HP := New SmHodrickPrescottFilter.Create;
    HP.Serie.Value := s;
    // Задаём период идентификации
    HP.ModelPeriod.FirstPoint := 1;
    HP.ModelPeriod.LastPoint := 15;
    // Задаём метод обработки пропусков
    HP.MissingData.Method := MissingDataMethod.SampleAverage;
    // Задаём  количество периодов в году
    HP.Frequency := 12;
    // Определяем способ задания параметра сглаживания
    HP.SmoothingParameterMode := HPSmoothingParameterModeType.SetByFrequencyRule;
    // Задаём значение степени
    HP.Power := 5;
    // Выполняем расчёт метода и выводим результаты
    res := HP.Execute;
    If res <> 0 Then
        Debug.WriteLine(HP.Errors);
    Else
        Debug.WriteLine("Модельный ряд");
        Print(HP.Fitted);
    End If;
End Sub UserProc;

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

Пример Fore.NET

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

Imports Prognoz.Platform.Interop.Stat;

Public Shared Sub Print(Data: System.Array);
Var
    i: Integer;
Begin
    For i := 0 To Data.Length - 1 Do
        If Double.IsNan(Data.GetValue(i) As Double) Then
            System.Diagnostics.Debug.WriteLine("----empty---");
            Else
                System.Diagnostics.Debug.WriteLine(i.ToString() + " " + Data.GetValue(i).ToString());
        End If;
    End For;
End Sub Print;

Public Shared Sub Main(Params: StartParams);
Var
    HP: SmHodrickPrescottFilter;
    s: Array Of Double;
    res: Integer;
Begin
    s := New Double[15];
    // Задаём значения переменной
    s[00] := 670.2; s[08] := 1033.3;
    s[01] := 576.06; s[09] := 780.8;
    s[02] := 717.64; s[10] := 657.5;
    s[03] := 856.9; s[11] := 654.5;
    s[04] := 885.4; s[12] := 678.23;
    s[05] := 1011; s[13] := 642.41;
    s[06] := 995.44; s[14] := 751.9;
    s[07] := 1064.74;
    HP := New SmHodrickPrescottFilter.Create();
    HP.Serie.Value := s;
    // Задаём период идентификации
    HP.ModelPeriod.FirstPoint := 1;
    HP.ModelPeriod.LastPoint := 15;
    // Задаём метод обработки пропусков
    HP.MissingData.Method := MissingDataMethod.mdmSampleAverage;
    // Задаём  количество периодов в году
    HP.Frequency := 12;
    // Определяем способ задания параметра сглаживания
    HP.SmoothingParameterMode := HPSmoothingParameterModeType.hpspmtSetByFrequencyRule;
    // Задаём значение степени
    HP.Power := 5;
    // Выполняем расчёт метода и выводим результаты
    res := HP.Execute();
    If res <> 0 Then
        System.Diagnostics.Debug.WriteLine(HP.Errors);
    Else
        System.Diagnostics.Debug.WriteLine("Модельный ряд");
        Print(HP.Fitted);
    End If;
End Sub;

См. также:

ISmHodrickPrescottFilter