Performs a forward fill interpolation of missing values in a series.

An expression containing dynamic numerical array is the input. The function replaces all instances of missing_value_placeholder with the nearest value from its left side other than missing_value_placeholder, and returns the resulting array. The leftmost instances of missing_value_placeholder are preserved.


series_fill_forward(x[, missing_value_placeholder])

  • Will return series x with all instances of missing_value_placeholder filled forwards.


  • x: dynamic array scalar expression, which is an array of numeric values.
  • missing_value_placeholder: optional parameter, which specifies a placeholder for a missing value to be replaced. Default value is double(null).


  • Specify null as the default value to apply interpolation functions after make-series:
make-series num=count() default=long(null) on TimeStamp from ago(1d) to ago(1h) step 1h by Os, Browser
  • The missing_value_placeholder can be of any type that will be converted to actual element types. Both double(null) long(null) and int(null) have the same meaning.
  • If missing_value_placeholder is (null) (or omitted - which have the same meaning), then a result may contain null values. To fill these null values, use other interpolation functions. Currently only series_outliers() support null values in input arrays.
  • The functions preserve the original type of array elements.


let data = datatable(arr: dynamic)
| project arr, 
          fill_forward = series_fill_forward(arr)  

arr fill_forward
[null,null,36,41,null,null,16,61,33,null,null] [null,null,36,41,41,41,16,61,33,33,33]

Use series_fill_backward or series-fill-const to complete interpolation of the above array.