Use the range function in APL to create a dynamic array of evenly spaced values. You can generate numeric, datetime, or timespan sequences that increase by a constant step, which defaults to 1 for numbers and 1 hour for time-based types. The function stops once the value exceeds the specified endpoint or the maximum result size. range is useful when you want to produce test values, synthetic sequences, time intervals, or loop-like constructs without relying on input data. It helps you populate arrays that can be expanded or joined with real data for further analysis.

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.

Usage

Syntax

range(start, stop [, step])

Parameters

NameTypeRequiredDescription
startscalar (number, datetime, timespan)✔️First value in the array.
stopscalar (same type as start)✔️Upper bound of the array. The last value is less than or equal to stop.
stepscalar (same type as start)Difference between values. Defaults to 1 (numeric) or 1h (time).

Returns

A dynamic array that includes values starting at start, incremented by step, up to and including stop (if it aligns exactly with a step). The array truncates if it reaches the system limit of 1,048,576 elements.

Use case examples

Generate an array of durations to help classify HTTP request latencies.Query
print r = range(100, 500, 100)
| project r
Run in PlaygroundOutput
[
  100,
  200,
  300,
  400,
  500
]
This creates an array of thresholds that you can use to bucket or filter request durations in ['sample-http-logs'].