-
Added new
bpv
non-negative forecast reconciliation algorithm (experimental) based on the cross-sectional framework presented in Wickramasuriya et al. (2020) and, now, extended for the temporal and cross-temporal framework.- Wickramasuriya, S. L., Turlach, B. A., and Hyndman, R. J. (2020), "Optimal non-negative forecast reconciliation", Statistics and Computing, 30(5), 1167–1182. doi:10.1007/s11222-020-09930-0.
-
New
oasd
cross-sectional covariance matrix (experimental), implementing an oracle shrunk covariance estimation (Ando and Xiao, 2023).- Ando, S., and Xiao, M. (2023), "High-dimensional covariance matrix estimation: shrinkage toward a diagonal target", IMF Working Papers, 2023(257), A001. doi:10.5089/9798400260780.001.A001.
-
Redesigned
bounds
parameter to enable bounded forecast reconciliation forcsrec()
,terec()
, andctrec()
functions. -
Introduced new
set_bounds()
function to define custom bounds for reconciliation.
- Fixed bug when only a subset of
agg_order
factors was selected initerec()
,tcsrec()
, andcstrec()
functions.
Note – The latest release of FoReco introduces significant changes to its function notation and adds several new features. This major update, FoReco 1.0, is not compatible with previous versions due to the substantial changes made to the package's core structure. The previous version is available on Github (docs).
Due to the significant changes in FoReco 1.0, users are advised to carefully review the updated documentation and examples before using the new version. The latest documentation and release notes are available on danigiro.github.io/FoReco/
-
Updated Function Notation: All functions related to cross-sectional, temporal, and cross-temporal frameworks now use the prefixes cs, te, and ct, respectively. For example, the optimal combination reconciliation functions are now
csrec()
,terec()
, andctrec()
. -
Simplified Function Outputs: Reconciliation functions now return only matrices. Additional information can be accessed using
attr(., "FoReco")
or therecoinfo()
function. -
New Datasets: Two new datasets,
itagdp
(Italian Quarterly National Accounts) andvndata
(Australian Tourism Demand), are included along with their respective aggregation or constraint matrices. -
Classic Approach: The middle-out approach (
csmo()
,temo()
, andctmo()
) has been implemented alongside the classic bottom-up (csbu()
,tebu()
, andctbu()
) and top-down (cstd()
,tetd()
, andcttd()
) methods. -
Level Conditional Coherent Reconciliation: Level conditional coherent reconciliation is now available for all constraints:
cslcc()
(cross-sectional),telcc()
(temporal), andctlcc()
(cross-temporal). -
Immutable reconciliation: The
immutable()
parameter has been added to the reconciliation functions (csrec()
,terec()
, andctrec()
) to prevent the base forecasts from being modified with both the structural (approach='strc'
) and the zero-constrained (approach='proj'
) approach. -
Balanced and unbalanced hierarchy: added
balance_hierarchy()
andunbalance_hierarchy()
for dealing with balanced and unbalanced hierarchies. -
Projection Matrix Functions: Functions
csprojmat()
,teprojmat()
, andctprojmat()
have been added to obtain projection matrices. -
Covariance Matrix Functions: Functions
cscov()
,tecov()
, andctcov()
have been added to obtain covariance matrices. -
Function Renaming: Several functions have been renamed to improve consistency and clarity
Cmatrix()
->df2aggmat()
hts_tools()
->cstools()
thf_tools()
->tetools()
ctf_tools()
->cttools()
agg_ts()
->aggts()
residuals_matrix()
->res2matrix()
boot_cs()
->csboot()
boot_te()
->teboot()
boot_ct()
->ctboot()
htsrec()
->csrec()
thfrec()
->terec()
octrec()
->ctrec()
lccrec()
->cslcc()
- Added
boot_cs()
,boot_te()
andboot_ct()
to draw samples from, respectively, cross-sectional, temporal and cross-temporal joint (block) bootstrap.
- Fixed deprecation warnings in Matrix (v. 1.5-0);
- Improved docs and bug fixes;
- Fixed
ctbu()
inputs; - Added
FoReco2matrix()
to transform FoReco forecasts input and output in a list of matrix/vector class; - Added
agg_ts()
: non-overlapping temporal aggregation of a time series according to a specific aggregation order. - Added
arrange_hres()
andresiduals_matrix()
functions to arrange residuals for the covariance matrix under Gaussianity;
- Fixed the not negative reconciliation "sntz" for
octrec()
; - Fixed documentation.
- Added
lcmat()
function.
- Fixed BU approach when the number of columns of basef is equal to the number of bottom time series
htsrec()
; - Fixed
score_index()
; - Fixed the
bounds
param whentype = "S"
inhtsrec()
,thfrec()
andoctrec()
; - Add the possibility to fix base forecasts through the
v
param inhtsrec()
,thfrec()
andoctrec()
- experimental; - Add two new type of optimal cross-temporal reconciliation (cs_struc and t_struc);
- Improved docs and bug fixes.
- Fixed documentation;
- Removed
ut2c()
andsrref()
.
- Fixed a bug in the output of
lccrec()
(now the function returns the Level Conditional Coherent or the Combined Conditional Coherent forecasts); - Fixed the not negative reconciliation "KAnn" when
keep = "list"
.
- It's possible to use a subset of factors of m (max. order of temporal aggregation);
- Added the possibility for
htsrec()
,thfrec()
andoctrec()
to introduce a list of h covariance matrices in the parametersW
andOmega
, where h stands for the forecast horizon (note that forthfrec()
andoctrec()
this is the forecast horizon of the entire cycle); - Param
Sstruc
is no more avaible inoctrec()
andctf_tools()
. FoReco uses a fast algorithm to compute Scheck, so no external input is needed; - Modified output of
ctf_tools()
(addedCcheck
,Htcheck
,Scheck
, removedCstruc
,Sstruc
),hts_tools()
(addedC
) andthf_tools()
(addedm
); - Added two new not negative reconciliation techniques ("KAnn" and "sntz") with a new parameter (
nn_type
) inhtsrec()
,thfrec()
andoctrec()
; - Added the top-down reconciliation function
tdrec()
; - Added the level conditional forecast reconciliation (with and without not-negative constraints) for genuine hierarchical/grouped time series
levrec()
(cross-sectional, temporal and cross-temporal).
- Now in
octrec()
it is also possible to introduce the Ω covariance matrix variant through theOmega
parameter and not only the W variant with theW
parameter; - Updated
tcsrec()
,cstrec()
anditerec()
. In theiterec()
function themaxit
parameter has been replaced byitmax
, however for the momentmaxit
is still supported; - Now FoReco removes null rows from the cross-sectional aggregation matrix C and it warns the user if the balanced version of an unbalanced hierarchy is considering duplicated variables;
- Redesigned the console output and added a new convergence norm as default for
iterec()
(norm
parameter).
- Add the possibility to introduce constraints through the
bounds
param inhtsrec()
,thfrec()
andoctrec()
; - Add a function
oct_bounds()
to organize the bounds on a specific dimension (i.e. only cross-sectional or only temporal) in a cross-temporal framework; - Added
ut2c()
andsrref()
to develop a cross-sectional structural representation starting from a zero constraints kernel matrix; - Added in
score_index()
the calculation of multiple forecast horizons index (like 1:6) and multiple cross-sectional levels for a forecasting experiment.
Minore release, fixing some bugs and the documentation
- Fixed a bug in
iterec()
when calculating the incoherence - Fixed documentation
- Changed the contact mail (now it's [email protected])
- Corrected the second section of the vignette "
Average relative accuracy indices
"
- Release on github