series_fill_backward function fills missing values (nulls) in a numeric dynamic array (series) by propagating the last known value backward through the array. This function is useful for handling gaps in time series data where you want to use the most recent available value to fill earlier missing data points.
You can use series_fill_backward when you have time series data with missing values and want to fill gaps using the last observed value. This is particularly useful for forward-looking analysis, forecasting scenarios, or when the most recent data point is the best estimate for missing earlier values. Typical applications include financial data analysis, sensor data processing, and performance monitoring where recent values are more relevant.
For users of other query languages
If you come from other query languages, this section explains how to adjust your existing queries to achieve the same results in APL.Splunk SPL users
Splunk SPL users
In Splunk SPL, filling missing values typically requires complex
eval expressions with fillnull or custom logic using streamstats and filldown. The backward filling approach is less common and usually requires manual implementation. In APL, series_fill_backward provides a direct, efficient way to perform backward filling on dynamic arrays.ANSI SQL users
ANSI SQL users
In SQL, filling missing values backward requires complex window functions with
LAG() or custom logic using LAST_VALUE() with specific window specifications. Most SQL implementations focus on forward filling rather than backward filling. In APL, series_fill_backward simplifies this operation by directly handling backward propagation of values in arrays.Usage
Syntax
Parameters
| Parameter | Type | Description |
|---|---|---|
array | dynamic | A dynamic array of numeric values that may contain null values. |
Returns
A dynamic array where null values are replaced by the last non-null value encountered when traversing the array backward.Use case examples
- Log analysis
- OpenTelemetry traces
- Security logs
In log analysis, you can use Run in PlaygroundOutput
This query fills missing request durations with the most recent available values, useful for maintaining continuity in performance analysis.
series_fill_backward to fill missing request duration data using the most recent available values, which is useful for analyzing performance trends.Query| id | durations | filled_durations |
|---|---|---|
| u123 | [null, 150, null, 200] | [150, 150, 150, 200] |
| u456 | [100, null, null, 300] | [100, 300, 300, 300] |
List of related functions
- series_fill_forward: Fills missing values by propagating the first known value forward. Use when you want to use the earliest available value to fill gaps.
- series_fill_const: Fills missing values with a constant value. Use when you want to replace nulls with a specific default value.
- series_fill_linear: Fills missing values using linear interpolation. Use when you want smooth transitions between known values.
- series_equals: Compares each element to a specified value. Use for identifying specific values after filling operations.
- series_greater: Returns elements greater than a specified value. Use for threshold analysis after filling missing data.