forked from annasmyk/JD_Quarto_Book
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathA-SA-Pre-Treatment.qmd
1042 lines (609 loc) · 44.2 KB
/
A-SA-Pre-Treatment.qmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
# SA: Pre-Treatment {#sa-pre-t .unnumbered}
## In this chapter
The following sections cover pre-treatment with Reg-ARIMA (or Tramo) algorithms. Tramo and the Reg-Arima part of X13-ARIMA rely on very similar [principles](#m-reg-a). Thus Tramo will only be mentioned to highlight differences with the Reg-Arima part of X13-ARIMA.
Reg-Arima modelling part can be the first of a seasonal adjustment process or run on its [own](#a-reg-a). Below we focus on performing reg-arima modelling as pre-treatment in a SA processing.
More in-depth methodological explanations of the algorithms can be found in [this part](#part-M) of the documentation.
## Pre-treatment principles
The goal of this step is to remove deterministic effects (calendar and outliers) in order to improve the decomposition.
$$
Y_t = \sum{\alpha}_i O_{it} + \sum\beta_j C_{jt} + \sum {\gamma}_i Reg_{it} + Y_{lin,t}
$$
- $O_{it}$ are the $i$ final outliers (AO, LS, TC)
- $C_{it}$ are the calendar regressors (automatic or user-defined), details [here](#a-cal)
- $Reg_{it}$ are all the other user-defined regressors details [here](#a-out-reg-ext)
- $Y_{lin,t} \sim ARIMA(p,d,q)(P,D,Q)$
## Reallocation of pre-treatment effects {#sa-pre-t-realloc}
The linearised series ($Y_{lin,t}$) is be decomposed into unobservable components in the decomposition phase
$$Y_{lin} =S_{lin} +T_{lin}+I_{lin}$$
Pre-treatment effects are then reallocated to build the final components
$$S=S_{lin}+cal+out_s+reg_s$$
$$T=T_{lin}+out_t+reg_{t}$$
$$I=I_{lin}+out_i+reg_{i}$$
Where
- $cal$ is the total calendar effect
- $out_j$ is the total effect of outliers on component $j$
- $reg_j$ is the total effect of user-defined regressors on component $j$
## Setting Specifications {#a-pre-t-def-spec}
Default specifications are set for the whole SA procedure, pre-treatment and decomposition. They are slightly different for X13-ARIMA and TRAMO-SEATS and can be modified with user-defined parameters.
#### Starting point for X13-ARIMA {#a-pre-t-def-spec-x13}
| Spec identifier | Log/level detection | Outliers detection | Calendar effects | ARIMA |
|-----------------|---------------------|--------------------|------------------|----------------|
| RSA0 | *NA* | *NA* | *NA* | Airline(+mean) |
| RSA1 | automatic | AO/LS/TC | *NA* | Airline(+mean) |
| RSA2c | automatic | AO/LS/TC | 2 TD vars+Easter | Airline(+mean) |
| RSA3 | automatic | AO/LS/TC | *NA* | automatic |
| RSA4c | automatic | AO/LS/TC | 2 TD vars+Easter | automatic |
| RSA5 | automatic | AO/LS/TC | 7 TD vars+Easter | automatic |
| X-11 | *NA* | *NA* | *NA* | *NA* |
explanations:
- *NA:* non applied, for example in RSA3 there is no calendar effect correction
- automatic: test is performed
outliers detection: AO/LS/TC type of outliers automatically detected under a critical T-Stat value (default value=4)
calendar:
- 2 regressors: weekdays vs week-ends + LY
- 7 regressors: each week day vs Sundays + LY
- always tested
- easter tested (default length = 6 days in Tramo, 8 days in X13-ARIMA)
#### Starting point for Tramo-Seats {#sa-pre-t-ts-specs}
| Spec identifier | Log/level detection | Outliers detection | Calendar effects | ARIMA |
|-----------------|---------------------|--------------------|------------------|----------------|
| RSA0 | *NA* | *NA* | *NA* | Airline(+mean) |
| RSA1 | automatic | AO/LS/TC | *NA* | Airline(+mean) |
| RSA2 | automatic | AO/LS/TC | 2 TD vars+Easter | Airline(+mean) |
| RSA3 | automatic | AO/LS/TC | *NA* | automatic |
| RSA5 | automatic | AO/LS/TC | 6 TD vars+Easter | automatic |
| RSAfull | automatic | AO/LS/TC | automatic | automatic |
### User-defined specifications {#usr-def-spec}
Principle oser setting parameters: can be done from one of the default specifications or any specification in a "Save as" mode very similar in GUI and R, as detailed below.
The user may add new seasonal adjustment specifications to the *Workspace* window. To do it, go to the *Seasonal adjustment* section, right click on the *tramoseats* or *x13* item in the *specifications* node and select *New* from the local menu.
data:image/s3,"s3://crabby-images/5c297/5c297a014a7bfe8008112aa0ca15311a0d5ddf79" alt="**Creating a new specification in the *Seasonal adjustment* section**"
Next, double click on the newly created specification, change the settings accordingly and confirm with the **OK** button.
data:image/s3,"s3://crabby-images/596f8/596f85e80439a7e12243fcc8e7cd3be62708c2cc" alt="**Changing settings of seasonal adjustment specification**"
### Spans {#sa-pre-t-spans}
#### Estimation span
Specifies the span (data interval) of the time series to be used in the seasonal adjustment process. The user can restrict the span
Common settings
| Option | Description (expected format) | |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| All | default | |
| From | first observation included (yyyy-mm-dd) | |
| To | last observation included (yyyy-mm-dd) | |
| Between | interval \[from ; to\] included (yyyy-mm-dd to yyyy-mm-dd) | |
| First | number of obs from the beginning of the series included (dynamic) (integer) | |
| Last | number of obs from the end of the series (dynamic)(integer) | |
| Excluding | excluding N first obs and P last obs from the computation,dynamic) (integer) | |
| Preliminary check | check to exclude highly problematic series e.g. the series with a number of identical observations and/or missing values above pre-specified threshold values. (True/False) | |
**Setting series span in GUI**
Use the specification window for a given series and expand the nodes.
data:image/s3,"s3://crabby-images/3a084/3a0845d63870f7840bd274ae7fd4b2f96fb905bd" alt="**Setting series span in R**"
x13 in version 2
```{r, echo = TRUE, eval = FALSE}
library("RJDemetra")
# estimation interval: option with static dates
user_spec_1 <- x13_spec(
spec = c(
"RSA5c", "RSA0", "RSA1", "RSA2c",
"RSA3", "RSA4c", "X11"
),
preliminary.check = TRUE,
estimate.from = "2012-06-01",
estimate.to = "2019-12-01"
)
# estimation interval: option with dynamic numbers of observations
#
# spec can be applied on different series and therefore exclude different dates
user_spec_2 <- x13_spec(
spec = c("RSA5c", "RSA0", "RSA1", "RSA2c", "RSA3", "RSA4c", "X11"),
estimate.first = 12
)
# eestimation on the last 120 obs
user_spec_3 <- x13_spec(
spec = c("RSA5c", "RSA0", "RSA1", "RSA2c", "RSA3", "RSA4c", "X11"),
estimate.last = 120
)
# excluding first 24 and last 36 observations
user_spec_4 <- x13_spec(
spec = c("RSA5c", "RSA0", "RSA1", "RSA2c", "RSA3", "RSA4c", "X11"),
estimate.exclFirst = 24,
estimate.exclLast = 36
)
# Retrieve settings
```
For comprehensive details about x13_spec function see RJDemetra R help pages.
TRAMO-SEATS in version 2
```{r, echo = TRUE, eval = FALSE}
# excluding first 24 and last 36 observations
user_spec_1 <- tramoseats_spec(
spec = c("RSAfull", "RSA0", "RSA1", "RSA2", "RSA3", "RSA4", "RSA5"),
estimate.exclFirst = 24,
estimate.exclLast = 36
)
```
For comprehensive details about tramoseats_spec function see RJDemetra R help pages.
#### Setting model span
The user can also specify the span (data interval) of the time series to be used for the estimation of the Reg-ARIMA model coefficients. It allows to impede a chosen part of the data from influencing the regression estimates. Setting works the same way as setting series (estimation) span described above.
Additional (vs series span setting) parameters are described below:
+---------------------------+-----------------------------------------------------------------------------------------------------------------------------+
| Tolerance | Convergence tolerance for the non-linear estimation. |
| | |
| | The absolute changes in the log-likelihood are compared to Tolerance to check the convergence of the estimation iterations. |
| | |
| | The default setting is 0.0000001. |
+---------------------------+-----------------------------------------------------------------------------------------------------------------------------+
| Tramo specific parameters | |
+---------------------------+-----------------------------------------------------------------------------------------------------------------------------+
| Exact ML | When this option is marked, an exact maximum likelihood estimation is performed. |
| | |
| | Alternatively, the Unconditional Least Squares method is used. |
| | |
| | However, in the current version of JDemetra+ it is not recommended to change this parameter's value |
+---------------------------+-----------------------------------------------------------------------------------------------------------------------------+
| Unit Root Limit | Limit for the autoregressive roots. If the inverse of a real root of the autoregressive polynomial of the |
| | |
| | ARIMA model is higher than this limit, the root is set equal to 1. The default parameter value is 0.96. |
+---------------------------+-----------------------------------------------------------------------------------------------------------------------------+
**Setting model span in GUI**:
Use the specification window
data:image/s3,"s3://crabby-images/31f1c/31f1cb460b3eeb0d3496028a9bd574189fdd7423" alt="**Setting in R**"
Tramo example in version 2
```{r, echo = TRUE, eval = FALSE}
# excluding first 24 and last 36 observations
user_spec_1 <- tramoseats_spec(
spec = c("RSAfull", "RSA0", "RSA1", "RSA2", "RSA3", "RSA4", "RSA5"),
estimate.tol = 0.0000001,
estimate.eml = FALSE,
estimate.urfinal = 0.98
)
```
### Decomposition Scheme {#sa-pre-t-mode}
#### Parameters
Transformation test: a test is performed to choose between an additive decomposition (no transformation) (link to reg A chap to detail this)
Settings
Function
transform {function=}
Transformation of data. 2 The user can choose between:
None -- no transformation of the data;
Log -- takes logs of the data;
Auto -- the program tests for the log-level specification. This option is recommended for automatic modelling of many series.
The default setting is Auto.
Reg-Arima specific settings
AIC difference
transform {aicdiff=}
Defines the difference in AICC needed to accept no transformation over a log transformation when the automatic transformation
selection option is invoked. The option is disabled when Function is not set to Auto. The default AIC difference value is -2.
Adjust
transform {adjust=}
Options for proportional adjustment for the leap year effect. The option is available when Function is set to Log. Adjust can be set to:
LeapYear -- performs a leap year adjustment of monthly or quarterly data;
LengthofPeriod -- performs a length-of-month adjustment on monthly data or length-of-quarter adjustment on quarterly data;
None -- does not include a correction for the length of the period.
The default setting is None
Tramo specific settings
**Fct**\
*Transformation; fct*
Controls the bias in the log/level pre-test (the function is active when **Function** is set to *Auto*); **Fct** \> 1 favours levels, **Fct** \< 1 favors logs. The default setting is 0.95.
**Set in GUI**
data:image/s3,"s3://crabby-images/fcda7/fcda7fd0cf84a115a8b3712feec67fdf3bc81f2e" alt="Model span setting"
**Set and in R**
X13
```{r, echo = TRUE, eval = FALSE}
# excluding first 24 and last 36 observations
user_spec <- x13_spec(
spec = c("RSA5c", "RSA0", "RSA1", "RSA2c", "RSA3", "RSA4c", "X11"),
transform.function = "Log", # choose from: c(NA, "Auto", "None", "Log"),
transform.adjust = "LeapYear", # c(NA, "None", "LeapYear", "LengthOfPeriod"),
transform.aicdiff = -3
)
# Retrieve settings: to complete*
```
TRAMO-SEATS settings
```{r, echo = TRUE, eval = FALSE}
# transfo
user_spec_1 <- tramoseats_spec(
spec = c("RSAfull", "RSA0", "RSA1", "RSA2", "RSA3", "RSA4", "RSA5"),
transform.function = "Auto", # c(NA, "Auto", "None", "Log"),
transform.fct = 0.5
)
# Retrieve settings: to complete
```
### Calendar correction
Some calendar correction options included in the starting specifications for X13-ARIMA or TRAMO-SEATS, they can be fine-tuned by modifying specifications. The following section lists all the available options, illustrates how to set them in GUI or R and shows have to retrieve used parameters, regressors as well as results.
JDemetra+ offers two default options for calendar correction working days regressors and trading days regressors, with Leap-year effect if needed. Those options don't take into account national calendars (link) and their specific holidays. There are two ways to change this:
- user-defined regressors (link)
- customized calendars (link)
Overview: what you can do
Need 1: correct for working days, trading days (+ easter) not taking national calendars
Need 2: taking national calendar into account Solutions
- add a work of means of allocating regressors to the calendar component
#### Available Options
##### Trading Days
"Trading Days" has two meanings: general calendar correction process (here without easter effect) and one of the options of this correction (see below)
```
- "None": no correction for trading days and working days effects
- "Default": JDemetra + built regressors (xorking days or trading days)
- "Holidays": same as above but taking into accoutn a national calendar, available on ly in GUI, R interface requires direct use of pre-built regressors
- "UserDefined": user-defined trading days regressors (see below)
- (if NONE) indicating the day of the month when inventories and other stock are reported (to denote the last day of the month, set the variable to 31).
```
##### Leap Year effect
**Autoadjust**
If enabled, the program corrects automatically for the leap year effect.. When is the option available Modifications of this variable are taken into account only when transform.function is set to "Auto".
**Leapyear**
to specify whether or not to include the leap-year effect in the model: - "LeapYear": leap year effect; - "LengthOfPeriod": length of period, - "None" = no effect included.
The leap-year effect can be pre-specified in the model only if the input series hasn't been pre-adjusted (transform.adjust set to "None") and if the automatic correction for the leap-year effect isn't selected (tradingdays.autoadjust set to FALSE).
#### Test
**Test**: defines the pre-tests for the significance of the trading day regression variables based on the AICC statistics: "Add" = the trading day variables are not included in the initial regression model but can be added to the Reg-ARIMA model after the test; "Remove" = the trading day variables belong to the initial regression model but can be removed from the RegARIMA model after the test; "None" = the trading day variables are not pre-tested and are included in the model.
##### Easter
Easter.enabled a logical. If TRUE, the program considers the Easter effect in the model.
easter.Julian a logical. If TRUE, the program uses the Julian Easter (expressed in Gregorian calendar).
easter.duration a numeric indicating the duration of the Easter effect (length in days, between 1 and 20).
easter.test defines the pre-tests for the significance of the Easter effect based on the t-statistic (the Easter effect is considered as significant if the t-statistic is greater than 1.96): "Add" = the Easter effect variable is not included in the initial regression model but can be added to the Reg-ARIMA model after the test; "Remove" = the Easter effect variable belongs to the initial regression model but can be removed from the RegARIMA model after the test; "None" = the Easter effect variable is not pre-tested and is included in the model.
A user-defined regressor can also be used, see chapter on [calendar correction](A-calendar-correction.qmd)
(to be added: additional options in Tramo)
#### Setting Calendar correction in GUI
##### Using default options (without national calendars)
**In GUI** Use the specification window
Calendar effects
data:image/s3,"s3://crabby-images/aad8c/aad8c2c257670d12970e3f6f99130cf1aae5b245" alt="**STEP 1: Selection from JDemetra+ Default...or User_defined**"
data:image/s3,"s3://crabby-images/2bce7/2bce72d1735bd2c5416e479246a0dc0d05a51ec9" alt="**STEP2: Calendar effects minus Easter are labeled *trading days* **"
##### Holidays option
using a customized calendar just show how to fetch it building process in calendar chapter
data:image/s3,"s3://crabby-images/64617/64617198759b4cfc4dd0ec7f6eb51c1a41cb10cc" alt="**The list of calendars displayed under *Holidays* option corresponds to the calendars defined in the *Workspace* window**"
Missing: stock td option, length-of-period
User-defined regressors: adding see below
Link to Import data Once data imported: here explain how to link variables
##### Easter
data:image/s3,"s3://crabby-images/892a6/892a64662856545fe7aa495fff77a7a92fc87929" alt="**easter Options**"
#### Setting Calendar correction in R
In version 2
```{r, echo = TRUE, eval = FALSE}
# Parameter choice NA=...
tradingdays.option <- c(NA_character_, "TradingDays", "WorkingDays", "UserDefined", "None")
tradingdays.autoadjust <- NA
tradingdays.leapyear <- c(NA_character_, "LeapYear", "LengthOfPeriod", "None")
tradingdays.stocktd <- NA_integer_
tradingdays.test <- c(NA_character_, "Remove", "Add", "None")
easter.enabled <- NA
easter.julian <- NA
easter.duration <- NA_integer_
easter.test <- c(NA_character_, "Add", "Remove", "None")
# example
```
In version 3 (Under construction)
#### User defined regressors
If **User Defined** options is used for trading days, regressors have to be provided by the user.
Building Regressors The underlying methodology and implementation in JDemetra+ to build these regression variables are provided [here](A-calendar-correction.qmd)
##### Adding Regressors in GUI
Step 1: import data set containing the regressors, general procedure explained here
Step 2: Link the regressors to the workspace, procedure detailed here
Step 3: Modify specifications Modifications are done the same way in a global specification (whole SAP) or series by series.
- select trading days **User-defined option** and select variables
In the specification window, click right from "userVariables" on "Unused" to open the variable selection window
data:image/s3,"s3://crabby-images/dd56f/dd56f3d18c7ef68b91f2bf95a81222f8eb253b65" alt=""
Move right the chosen regressors
data:image/s3,"s3://crabby-images/c504e/c504e709a27481ecb9bcef90033dcd3fe1a2907d" alt=""
- set TEST option (expl)
data:image/s3,"s3://crabby-images/d6129/d61295d43ec2b2db58a760ba3f4b3f2fb6ccf51a" alt=""
##### Adding Regressors in R
"UserDefined" = user-defined trading days regressors (regressors must be defined by the usrdef.var argument with usrdef.varType set to "Calendar" and usrdef.varEnabled = TRUE).
```{r, echo = TRUE, eval = FALSE}
# example
spec_4 <- x13_spec(
spec = spec_1,
tradingdays.option = "UserDefined",
tradingdays.test = "None",
usrdef.varEnabled = TRUE,
usrdef.varType = "Calendar",
usrdef.var = reg3
) # set of regressors in TS format
```
#### Retrieving Results
The following section details how to retrieve results (parameters, regressors, regression coefficients and tests) when using GUI or R interface.
##### Parameters
Parameters are regressors used in fine. If non test options, parameters are known If test options are selected by the algorithm.
**In GUI**
Automatically chosen or user-defined calendar options (as well as other pre-adjustment options) are displayed at the top of the MAIN Results NODE displayed by clicking on a given series name in the SAProcessing panel.
data:image/s3,"s3://crabby-images/dc219/dc219425341613f6dd0b80b5cfb949f951ba72b7" alt=""
**In R**
(to be added)
version 2: RJDemetra
version 3: rjd3x13 or rjd3tramoseats
##### Regressors
**In GUI** All regressors in the pre-adjustment phase (calendar, outliers, external) are displayed in the pre-processing-regressors node.
data:image/s3,"s3://crabby-images/ff59b/ff59b1e52b9aa32d8cf4068e1fb19579e957f9c8" alt=""
**In R**
(to be added)
Version 2
version 3
##### Regression results
Regressions results
**In GUI**
The results of the whole Reg-Arima regression (link to last section) including calendar effects (below) are displayed in the pre-processing panel.
data:image/s3,"s3://crabby-images/ac415/ac4158becce2add637ea76ccc36719126521c870" alt=""
**In R**
##### Test for residual trading-days effects
Residual calendar effects are tested with A F-Test 7 regressors and no national calendar, on sa final series and on irregular component (link to calendar chapter for test details)
**In GUI**
F-Test results are displayed at the bottom of **Main Results** NODE in the SAProcessing panel
data:image/s3,"s3://crabby-images/064c2/064c23fc56d867a83a5dfb9a5882e369f7447210" alt="**F-Test results in GUI**"
**In R**
#### Customizing Calendars
The following describes how to take a national calendar into account.
Solution 1: if working with GUI build a new calendar in GUI ([here](A-calendar-correction.qmd##Generating%20Regressors%20for%20calendar%20correction)
(to be added: GUI: how to use it or customize HTML file structure explanation)
set this option in GUI
(to be added: image: spec window calendar / holidays / choice of calendars)
set this option in R (to be added) version 2:
version 3:
solution 2: import external regressors, which can be built with rjd3toolkit (link) which can then be used in via are or imported via GUI
set this option in GUI how to import variables into JD+ / set utility (in interface chapter) classical user defined
set this option in R version 2:
version 3
Once the calendar regressors are set, the Reg-ARIMA (tramo) model will be estimated globally with all the other regression variables and taking into account Arima model specificities as well. That is why diagnostics are all jointly displayed at the end of the process. (link)
(to be added: worked example: french calendar in R)
### Outliers
The sections below focus on
- outlier detection parameters (type and critical value)
- pre-specifying outliers in a seasonal adjustement (reg-arima modelling) process
Additional information can be found in [this chapter](A-outlier-detection.qmd).
#### Options for automatic detection
- **Is enabled**
*outliers; iatip*
Enables/disables the automatic detection of outliers in the span determined by the **Detection span** option. By default, the checkbox is marked, which implies that the automatic identification of outliers is enabled.
- **Use default critical value**
*outliers; va*
The critical value is automatically determined by the number of observations in the interval specified by the **Detection span** option. When **Use default critical value** is disabled, the procedure uses the critical value inputted in the **Critical value** item (see below). Otherwise, the default value is used (the first case corresponds to "*critical* = *xxx*"; the second corresponds to a specification without the critical argument). It should be noted that it is not possible to define a separate critical value for each outlier type. By default, the checkbox is marked, which implies that the automatic determination of the critical value is enabled.
- **Critical value**
*outliers; va*
The critical value used in the outlier detection procedure. The option is active once **Use default critical value** is disabled. By default, it is set to 3.5.
- **Detection span** $\rightarrow $ **type**
*outliers; int1, int2\**
A span of the time series to be searched for outliers. The possible values of the parameter are:
- *All* -- full time series span is considered in the modelling;
- *From* -- date of the first time series observation included in the pre-processing model;
- *To* -- date of the last time series observation included in the pre-processing model;
- *Between* -- date of the first and the last time series observations included in the pre-processing model;
- *Last* -- number of observations from the end of the time series included in the pre-processing model;
- *First* -- number of observations from the beginning of the time series included in the pre-processing model;
- *Excluding* -- number of observations excluded from the beginning (specified in the *first* field) and/or end of the time series (specified in the *last* field) of the pre-processing model.
With the options *Last*, *First*, *Excluding* the span can be computed dynamically on the series. The default setting is *All*.
- **Additive**
*outliers; aio\**
Automatic identification of additive outliers. By default, this option is enabled.\
- **Level shift**
*outliers; aio\**
Automatic identification of level shifts. By default, this option is enabled.
- **Transitory change**
*outliers; aio\**
Automatic identification of transitory changes. By default, this option is enabled.
- **Seasonal outlier**
*outliers; aio\**
Automatic identification of seasonal outliers. By default, this option is disabled. Tramo specific
- **EML estimation**
*outliers; imvx*
The estimation method used in the automatic model identification procedure. By default, the fast method of Hannan-Rissanen is used for parameter estimation in the intermediate steps of the automatic detection and correction of outliers. When the checkbox is marked the exact maximum likelihood estimation method is used.
- **TC rate**
*outliers; deltatc*
The rate of decay for the transitory change outlier. It takes values between 0 and 1. The default value is 0.7.
#### Options for pre-specified outliers
User-defined outliers are used when prior knowledge suggests that certain effects exist at known time points\[\^14\]. Four pre-defined outlier types, which are simple forms of intervention variables, are implemented: \* Additive Outlier (AO); \* Level shift (LS); \* Temporary change\[\^15\] (TC); \* Seasonal outliers (SO).
#### Setting in GUI
data:image/s3,"s3://crabby-images/b06a7/b06a7580dd32498ff78f236496406277b82506e1" alt="**Automatic detection of outliers in GUI**"
data:image/s3,"s3://crabby-images/31643/31643d975eb8a112865409181ce0d6c47c4174d7" alt="**Outliers types in GUI**"
Pre-specified :
- Click on **...**
- Click on **+**
- Fill the outlier's information
- Click on **Ok**
data:image/s3,"s3://crabby-images/6807a/6807a9c6dd1dbce5f8af06ed6376d9390cf0f9a5" alt="**Pre-specified outliers in GUI**"
To change the view to set the outliers, got to Tools --\> Options
data:image/s3,"s3://crabby-images/9c00c/9c00cd1982b89284974823d93379a6906453bf36" alt="Options in GUI"
Then to **Demetra** --\> **Pre-specified Outliers** --\> **Calendar-like Grid** --\> **Ok**
data:image/s3,"s3://crabby-images/7f5d7/7f5d72c2b358c26ebb907b269b71183b22d15254" alt="**Change view to calendar**"
Then you have the calendar view (when selecting the pre-specified outliers) :
data:image/s3,"s3://crabby-images/4a747/4a747913399bdb94f6549f4c8bcddc3d51166ccc" alt="**Calendar view in GUI"
#### Setting in R
(to be added)
#### Retrieving results
##### Parameters
**In GUI**
In main results NODE (same info at top of pre-processing NODE)
data:image/s3,"s3://crabby-images/8ca25/8ca25faf836feeb0b6b6710442a26080d98741f7" alt="**Main results in GUI**"
##### Regressors
**In GUI**
data:image/s3,"s3://crabby-images/78b55/78b55493bcdb3e0f150412d5fae8d881226e5107" alt="**Regressors in GUI**"
**In R**
(to be added)
##### Regression details
**In GUI**
data:image/s3,"s3://crabby-images/293ea/293ea321f197387cbb9f50afccf50cab138f9093" alt="**Regression details in GUI**"
**In R**
(to be added)
### User-defined regressors
(to be added)
- rationale
- parameters: assign to a component
Pre-treatment regression with additional outliers
$$
Y_t = \sum \hat{\alpha}_i O_{it} + \sum\hat\beta_j C_{jt} + \sum\hat\gamma_k Reg_{kt} + y_{lin_t}
$$
##### Allocation to components
$reg= reg_{i}+reg_{t}+reg_{s}+...$ The user-defined regression variable associated to a specific component should not contain effects that have to be associated with another component. Therefore, the following rules should be observed: \* The variable assigned to the trend or to the seasonally adjusted series should not contain a seasonal pattern; \* The variable assigned to the seasonal should not contain a trend (or level); \* The variable assigned to the irregular should contain neither a seasonal pattern nor a trend (or level). - no external regressors can be assigned to calendar component. It has to be be done via user defined calendar regressors specific part (link)
Ramps and intervention variables are Specific cases of external regressors
#### Setting in GUI
User-defined variables
Step 1: import data set containing the regressors, general procedure explained here
Step 2: Link the regressors to the workspace, procedure detailed here
Step 3: Modify specifications via window
Modifications are done the same way in a global specification (whole SAP) or series by series.
data:image/s3,"s3://crabby-images/59cf8/59cf8c434b591c0f1d3991ea469716948a63e913" alt="**Creation of user-defined variables in GUI**"
#### Setting in R
(to be added)
#### Special case 1: Ramp effects
A ramp effect means a linear increase or decrease in the level of the series over a specified time interval $t_{0}$ to $\ t_{1}$. All dates of the ramps must occur within the time series span. (tested: not true). Ramps can overlap other ramps, additive outliers and level shifts.
###### Creation in GUI
data:image/s3,"s3://crabby-images/62e8d/62e8d54bedd9ed9b4ebb71d53ba0941930831cc2" alt="**Creation of ramp variable in GUI**"
###### Allocation to components
allocation when intervention or ramps ? in test allocated to trend ? (reg)
impossible (?) to create several intervention variables
#### Special case 2: Intervention variables
Intervention variables are modeled as any possible sequence of ones and zeros, on which some operators may be applied. They are built as combinations of the following basic structures:
* Dummy variables \[\^17\];
* Any possible sequence of ones and zeros;
* $\frac{1}{(1 - \delta B)}$,
* $(0 < \delta \leq 1)$
* $\frac{1}{(1 - \delta_{s}B^{s })}$,
* $(0 < \delta_{s} \leq 1)$;
* $\frac{1}{(1 - B)(1 - B^{s})}$;
where $B$ is backshift operator (i.e. $B^{k}X_{t} = X_{t - k}$) and $s$ is frequency of the time series ($s = 12$ for a monthly time series, $s = 4$ for a quarterly time series).
These basic structures enable the generation of not only AO, LS, TC, SO and RP outliers but also sophisticated intervention variables that are well-adjusted to the particular case.
###### Creation in GUI
data:image/s3,"s3://crabby-images/07676/0767631a2a470d6008dac94178dde501391cd5e4" alt="**Step 1**"
data:image/s3,"s3://crabby-images/3136a/3136a854f60102844d3996a1b6a60d111ed95c1e" alt="**Step 2**"
data:image/s3,"s3://crabby-images/1ffcc/1ffccdee932f682737f3ca184a060a255245bfc5" alt="**Step 3**"
###### Creation in R
(to be added)
###### Allocation to components
allocation (to be added)
fixed coefficient options
- **Fixed regression coefficients**
*regression variables; --*
For the pre-specified regression variables this option specifies the parameter estimates that will be held fixed at the values provided by the user. To fix a coefficient the user should undertake the following actions:
- Choose the transformation (log or none).
- Define some regression variables in the *Regressors* specification.
- Push on the fixed regression coefficients editor button in the **User-defined variables** row.
- Select the regression variable from the list for which the coefficient will be fixed.
- Save the new setting with the **Done** button.
<!-- Overview: differences GUI set up vs R set up -->
#### Retrieving Results
For all types of external regressors: user-defined, ramps or intervention variables.
##### Regressors
**In GUI**
To retrieve regressors that were actually used, expand pre-processing NODE and click on Regressors pane.
data:image/s3,"s3://crabby-images/a03c2/a03c236c2eda15081b478324ddfdec59c3fa1d38" alt="**Regressors in GUI**"
**In R**
(to be added )
##### Regression details
**In GUI**
Regression details are in the pre-processing pane.
data:image/s3,"s3://crabby-images/3927d/3927dac51c2505f3551727680b7990e750d2d7df" alt="**Regression details**"
**IN R**
### Arima Model
Key specifications on Arima modelling are embedded in default specifications: airline (default model) or full automatic research.(links)
Two kinds of interventions are available to the user
- modify automatic detection parameters
- set a user defined Arima model
In both cases forecast horizon can also be set (link)
#### Options for modifying automatic detection
*automdl.enabled* If TRUE, the automatic modelling of the ARIMA model is enabled. (If FALSE, the parameters of the ARIMA model can be specified, see below)
Control variables for the automatic modelling of the ARIMA model (when automdl.enabled is set to TRUE):
*automdl.acceptdefault* a logical. If TRUE, the default model (ARIMA(0,1,1)(0,1,1)) may be chosen in the first step of the automatic model identification. If the Ljung-Box Q statistics for the residuals is acceptable, the default model is accepted and no further attempt will be made to identify another model.
*automdl.cancel* the cancellation limit (numeric). If the difference in moduli of an AR and an MA roots (when estimating ARIMA(1,0,1)(1,0,1) models in the second step of the automatic identification of the differencing orders) is smaller than the cancellation limit, the two roots are assumed equal and cancel out.
*automdl.ub1* the first unit root limit (numeric). It is the threshold value for the initial unit root test in the automatic differencing procedure. When one of the roots in the estimation of the ARIMA(2,0,0)(1,0,0) plus mean model, performed in the first step of the automatic model identification procedure, is larger than the first unit root limit in modulus, it is set equal to unity.
*automdl.ub2* the second unit root limit (numeric). When one of the roots in the estimation of the ARIMA(1,0,1)(1,0,1) plus mean model, which is performed in the second step of the automatic model identification procedure, is larger than second unit root limit in modulus, it is checked if there is a common factor in the corresponding AR and MA polynomials of the ARMA model that can be cancelled (see automdl.cancel). If there is no cancellation, the AR root is set equal to unity (i.e. the differencing order changes).
*automdl.mixed* a logical. This variable controls whether ARIMA models with non-seasonal AR and MA terms or seasonal AR and MA terms will be considered in the automatic model identification procedure. If FALSE, a model with AR and MA terms in both the seasonal and non-seasonal parts of the model can be acceptable, provided there are no AR or MA terms in either the seasonal or non-seasonal terms.
*automdl.balanced* a logical. If TRUE, the automatic model identification procedure will have a preference for balanced models (i.e. models for which the order of the combined AR and differencing operator is equal to the order of the combined MA operator).
*automdl.armalimit* the ARMA limit (numeric). It is the threshold value for t-statistics of ARMA coefficients and constant term used for the final test of model parsimony. If the highest order ARMA coefficient has a t-value smaller than this value in magnitude, the order of the model is reduced. If the constant term t-value is smaller than the ARMA limit in magnitude, it is removed from the set of regressors.
*automdl.reducecv* numeric, ReduceCV. The percentage by which the outlier's critical value will be reduced when an identified model is found to have a Ljung-Box statistic with an unacceptable confidence coefficient. The parameter should be between 0 and 1, and will only be active when automatic outlier identification is enabled. The reduced critical value will be set to (1-ReduceCV)\*CV, where CV is the original critical value.
*automdl.ljungboxlimit* the Ljung Box limit (numeric). Acceptance criterion for the confidence intervals of the Ljung-Box Q statistic. If the LjungBox Q statistics for the residuals of a final model is greater than the Ljung Box limit, then the model is rejected, the outlier critical value is reduced and model and outlier identification (if specified) is redone with a reduced value.
*automdl.ubfinal* numeric, final unit root limit. The threshold value for the final unit root test. If the magnitude of an AR root for the final model is smaller than the final unit root limit, then a unit root is assumed, the order of the AR polynomial is reduced by one and the appropriate order of the differencing (non-seasonal, seasonal) is increased. The parameter value should be greater than one.
(for both options) *fcst.horizon* the forecasting horizon (numeric). The forecast length generated by the Reg-Arima model in periods (positive values) or years (negative values). By default, the program generates a two-year forecast (fcst.horizon set to -2). Defaults different in GUI and R.
::: {.panel-tabset .content-visible when-format="html"}
#### v2
data:image/s3,"s3://crabby-images/4a4f7/4a4f7b5977fd81a3ceb80c79f77e9e8418d32d31" alt="**Setting in GUI in v2**"
#### v3
data:image/s3,"s3://crabby-images/303cc/303cccf351793800ea3f8a5cdac0dbb262cb9f85" alt="**Setting in GUI in v3**"
:::
::: {.content-visible when-format="pdf"}
data:image/s3,"s3://crabby-images/4a4f7/4a4f7b5977fd81a3ceb80c79f77e9e8418d32d31" alt="**Setting in GUI in v2**"
data:image/s3,"s3://crabby-images/303cc/303cccf351793800ea3f8a5cdac0dbb262cb9f85" alt="**Setting in GUI in v3**"
:::
Forecast horizon when using TRAMO-SEATS Is set in the decomposition part of the specification in GUI.
data:image/s3,"s3://crabby-images/66797/6679784c081a822f14247a582173804ae6886d5b" alt="**Forecast horizon when using TRAMO-SEATS**"
data:image/s3,"s3://crabby-images/b2f0c/b2f0c29dc4d59e4bd77779513ba0cb13f1cadca4" alt="**Forecast horizon when using X13-ARIMA**"
**Setting in R** (first template, then worked example) X13-ARIMA template in version 2
```{r, echo = TRUE, eval = FALSE}
spec_2 <- x13_spec(
spec = spec_1,
automdl.enabled = NA,
automdl.acceptdefault = NA,
automdl.cancel = NA_integer_,
automdl.ub1 = NA_integer_,
automdl.ub2 = NA_integer_,
automdl.mixed = NA,
automdl.balanced = NA,
automdl.armalimit = NA_integer_,
automdl.reducecv = NA_integer_,
automdl.ljungboxlimit = NA_integer_,
automdl.ubfinal = NA_integer_
)
```
add worked example in version 2
in version 3
add worked example in version 3
#### Options for setting a user-defined Arima model
Control variables for the non-automatic modelling of the ARIMA model (when *automdl.enabled* is set to FALSE):
*arima.mu* logical. If TRUE, the mean is considered as part of the ARIMA model.
*arima.p* numeric. The order of the non-seasonal autoregressive (AR) polynomial.
*arima.d* numeric. The regular differencing order.
*arima.q* numeric. The order of the non-seasonal moving average (MA) polynomial.
*arima.bp* numeric. The order of the seasonal autoregressive (AR) polynomial.
*arima.bd* numeric. The seasonal differencing order.
*arima.bq* numeric. The order of the seasonal moving average (MA) polynomial.
Control variables for the user-defined ARMA coefficients. Coefficients can be defined for the regular and seasonal autoregressive (AR) polynomials and moving average (MA) polynomials. The model considers the coefficients only if the procedure for their estimation (arima.coefType) is provided, and the number of provided coefficients matches the sum of (regular and seasonal) AR and MA orders (p,q,bp,bq).
*arima.coefEnabled* logical. If TRUE, the program uses the user-defined ARMA coefficients.
*arima.coef* a vector providing the coefficients for the regular and seasonal AR and MA polynomials. The vector length must be equal to the sum of the regular and seasonal AR and MA orders. The coefficients shall be provided in the following order: regular AR (Phi; p elements), regular MA (Theta; q elements), seasonal AR (BPhi; bp elements) and seasonal MA (BTheta; bq elements). E.g.: arima.coef=c(0.6,0.7) with arima.p=1, arima.q=0,arima.bp=1 and arima.bq=0.
*arima.coefType* a vector defining the ARMA coefficients estimation procedure. Possible procedures are: "Undefined" = no use of any user-defined input (i.e. coefficients are estimated), "Fixed" = the coefficients are fixed at the value provided by the user, "Initial" = the value defined by the user is used as the initial condition. For orders for which the coefficients shall not be defined, the arima.coef can be set to NA or 0, or the arima.coefType can be set to "Undefined". E.g.: arima.coef = c(-0.8,-0.6,NA), arima.coefType = c("Fixed","Fixed","Undefined").
**Setting in GUI**
data:image/s3,"s3://crabby-images/f25d6/f25d601cc5553fdd1c47c9a2f270fa93e7fad280" alt="**Manual ARIMA modelling**"
data:image/s3,"s3://crabby-images/6deb0/6deb0516ce4fcb45e3f23c65b1bd1f72fe20a222" alt="**Fixing coefficients**"
**Setting in R**
X13-ARIMA template in version 2
```{r, echo = TRUE, eval = FALSE}
spec_2 <- x13_spec(
spec = spec_1,
automdl.enabled = FALSE,
arima.mu = NA,
arima.p = NA_integer_,
arima.d = NA_integer_,
arima.q = NA_integer_,
arima.bp = NA_integer_,
arima.bd = NA_integer_,
arima.bq = NA_integer_,
arima.coefEnabled = NA,
arima.coef = NA,
arima.coefType = NA,
fcst.horizon = NA_integer_
)
```
in version 3
### Reg-Arima model Results and Diagnostics
Type of results (including Tramo addenda)
- all regressors used (shown above)
- regression details: explanatory variables (above)
- Arima model specific results
- additional diagnostics on residuals
- likelihood
- seasonality tests on residuals
#### Display in GUI
Reg-Arima model detail with other regression results in pre-processing pane. with number of observations.. parameters