relative_period
Holistics has also supported Period Comparison on UI via Dashboard-level Period Comparison and widget-level Period Comparison which use exact_period()
and relative_period()
behind the scenes.
Definition
Calculates a metric in the active time-range shifted by a specified interval. The active time-range can be the time range specified in a filter (if no time dimension is active) or the time period in each row of a time dimension.
Syntax
relative_period(metric, time_dimension, time_interval)
relative_period(orders.total_orders, orders.created_at, interval(-1 month))
// with pipe
orders.total_orders | relative_period(orders.created_at, interval(-1 month))
Input
metric
: A metric that you want to calculate within a relative intervaltime_dimension
: A pre-defined datetime/date dimension that is used for shiftingtime_interval
: A relative interval for shifting from the time condition. E.g.interval(-1 month)
Output
The same metric calculated in the active time-range shifted by the specified interval.
Combine with dimension
Categorical dimension
When combining with categorical dimension with no filtering on the time dimension, relative_period()
will have no effect on the metric.
data:image/s3,"s3://crabby-images/5fd56/5fd5666a973098213a96ecfdd37e7e60ff34c868" alt=""
Categorical dimension with filtering on time dimension
When combining with categorical dimension with filtering on the time dimension, relative_period()
will shift the time condition by the specified interval in time_interval
argument.
data:image/s3,"s3://crabby-images/5dfd8/5dfd83ec36bac0987c6a09f1cb10f9a3bab3f765" alt=""
Time dimension
Similar to Dashboard previous period comparison, when combining with another time dimension, relative_period()
, will shift the time period in each row of the time dimension by the specified interval in time_interval
argument.
data:image/s3,"s3://crabby-images/048ea/048ea940bdaac0e1dda8b03c349c9562f8c3e978" alt=""
Sample Usages
We’ll implement a quick Period Comparison analysis on the total_orders
metric which is defined as below
Dataset ecommerce {
(...)
metric total_orders {
label: "Total Orders"
type: "number"
definition: @aql count(orders.id) ;;
}
}
And then define total_orders_last_month
as this expression:
count(orders.id) | relative_period(orders.created_at, interval(-1 month))
Examples
For all the examples below, the filter on reporting is set as orders.created_at last 1 month
data:image/s3,"s3://crabby-images/8ae7f/8ae7ff45924fa8a8b016ca40f2e0cc6b3c6f8c28" alt=""
Compare total_orders
from with the preceding month
data:image/s3,"s3://crabby-images/37d65/37d650dec7ab0d6847d51414447d616ff906caa9" alt=""
Compare total_orders
week-by-week with the previous month
data:image/s3,"s3://crabby-images/048ea/048ea940bdaac0e1dda8b03c349c9562f8c3e978" alt=""
Compare total_orders
with the previous month for each continent
data:image/s3,"s3://crabby-images/52675/52675eb1c0c087a581dfbfad4dc99b53c14e9f29" alt=""