Function to add directly to the plot the outliers used in the pre-adjustment process of the seasonal adjustment.
geom_outlier(
mapping = NULL,
data = NULL,
stat = "outlier",
geom = c("text", "label", "text_repel", "label_repel"),
position = "identity",
...,
method = c("x13", "tramoseats"),
spec = NULL,
frequency = NULL,
message = TRUE,
first_date = NULL,
last_date = NULL,
coefficients = FALSE,
digits = 1,
show.legend = NA,
inherit.aes = TRUE
)Set of aesthetic mappings created by aes() or
aes_(). If specified and inherit.aes = TRUE (the
default), it is combined with the default mapping at the top level of the
plot. You must supply mapping if there is no plot mapping.
A data.frame that contains the data used for the seasonal adjustment.
The statistical transformation to use on the data for this layer, as a string.
character. The geometric to use to display the data:
GeomText (geom = "text", the default, see geom_text());
GeomLabel (geom = "label", see geom_label());
GeomTextRepel (geom = "text_repel", the default, see geom_text_repel());
GeomLabelRepel (geom = "label_repel", the default, see geom_label_repel()).
Position adjustment, either as a string, or the result of a call to a position adjustment function.
Other arguments passed on to layer(). They may be parameters of
geom_text() (if geom = "text"),
geom_label() (if geom = "label"),
geom_text_repel() (if geom = "text_repel")
or geom_label_repel() (if geom = "label_repel").
the method used for the seasonal adjustment. "x13" (by default) for the X-13ARIMA method and "tramoseats" for TRAMO-SEATS.
the specification used for the seasonal adjustment.
See rjd3x13::x13() or rjd3tramoseats::tramoseats().
the frequency of the time series. By default (frequency = NULL),
the frequency is computed automatically.
a boolean indicating if a message is printed with the frequency used.
A numeric specifying the first date from which the outliers are plotted.
By default (first_date = NULL) the outliers are plotted from the
beginning of the time series.
A numeric specifying the first date from which the outliers are plotted.
By default (first_date = NULL) the outliers are plotted until the
end of the time series.
boolean indicating if the estimates coefficients are printed.
By default coefficients = FALSE.
integer indicating the number of decimal places to be used for numeric diagnostics. By default digits = 1.
logical. Should this layer be included in the legends?
NA, the default, includes if any aesthetics are mapped.
FALSE never includes, and TRUE always includes.
It can also be a named logical vector to finely select the aesthetics to
display.
If FALSE, overrides the default aesthetics,
rather than combining with them.
With the parameter geom = "text", the outliers used in the pre-adjustment process of the seasonal adjustment are directly added to the plot. With geom = "label" a rectangle is drawn behind the names of the outliers, making them easier to read. The same with geom = "text_repel" or geom = "label_repel" but text labels are also repeled away from each other and away from the data points (see geom_label_repel()).
p_sa_ipi_fr <- ggplot(data = ipi_c_eu_df, mapping = aes(x = date, y = FR)) +
geom_line() +
labs(title = "Seasonal adjustment of the French industrial production index",
x = "time", y = NULL) +
geom_sa(color = "red", message = FALSE)
# To add the outliers:
p_sa_ipi_fr + geom_outlier(geom = "label",
message = FALSE)
# To have a more readable plot with outliers names that repeled away from each other
# and from the data points:
p_sa_ipi_fr +
geom_outlier(geom = "label_repel",
message = FALSE,
vjust = 4,
ylim = c(NA, 65), force = 10,
arrow = arrow(length = unit(0.03, "npc"),
type = "closed", ends = "last"))
# To only plot the outliers from a specific date (2009):
p_sa_ipi_fr +
geom_outlier(geom = "label_repel",
message = FALSE,
first_date = 2009,
vjust = 4,
ylim = c(NA, 65), force = 10,
arrow = arrow(length = unit(0.03, "npc"),
type = "closed", ends = "last"))