You may pad the result with the value of your choice

padding is a keyword argument

  • if you assign e.g. padding = missing, the result will be padded
  • you may pad using any defined value and all types except Nothing
  • example pads(missing, 0, nothing, NaN, 'โˆ…', AbstractString)
using RollingFunctions

๐ท๐‘Ž๐‘ก๐‘Ž = [1, 2, 3, 4, 5]
๐น๐‘ข๐‘›๐‘ = sum
๐‘†๐‘๐‘Ž๐‘› = 3

result = rolling(๐น๐‘ข๐‘›๐‘, ๐ท๐‘Ž๐‘ก๐‘Ž, ๐‘†๐‘๐‘Ž๐‘›; padding = missing);
#=
julia> result
5-element Vector{Union{Missing, Int64}}:
   missing
   missing
  6
  9
 12
=#
 
result = rolling(๐น๐‘ข๐‘›๐‘, ๐ท๐‘Ž๐‘ก๐‘Ž, ๐‘†๐‘๐‘Ž๐‘›; padding = zero(eltype(๐ท๐‘Ž๐‘ก๐‘Ž));
#=
julia> result
5-element Vector{Int64}:
  0
  0
  6
  9
 12
=#

Give me the real values first, pad to the end.

result = rolling(๐น๐‘ข๐‘›๐‘, ๐ท๐‘Ž๐‘ก๐‘Ž, ๐‘†๐‘๐‘Ž๐‘›; padding = missing, padlast=true);
#=
julia> result
5-element Vector{Union{Missing,Int64}}:
  6
  9
 12
  missing
  missing
=#

technical aside: this is not the same as reverse(rolling(๐น๐‘ข๐‘›๐‘,๐ท๐‘Ž๐‘ก๐‘Ž, ๐‘†๐‘๐‘Ž๐‘›; padding = zero(eltype(๐ท๐‘Ž๐‘ก๐‘Ž)).