series_max function compares two numeric arrays element by element and returns a new array. Each position in the result contains the maximum value between the corresponding elements from the two input arrays.
You use series_max when you want to create an envelope or upper bound from multiple series, combine baseline metrics with actual values, or merge data from different sources by keeping the higher value at each point. For example, you can compare response times across different servers and keep the higher value at each time point, or combine SLA thresholds with actual measurements.
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, element-wise maximum comparisons typically require custom logic with
eval or foreach. In contrast, APL provides the specialized series_max function to directly compare arrays element by element and return the maximum values.ANSI SQL users
ANSI SQL users
In ANSI SQL, you use the
GREATEST() function to compare scalar values. To compare sequences element-wise, you need window functions or complex joins. In APL, series_max simplifies this by applying the maximum operation across arrays in a single step.Usage
Syntax
Parameters
| Parameter | Type | Description |
|---|---|---|
array1 | array | The first array of numeric values. |
array2 | array | The second array of numeric values. Must have the same length as array1. |
Returns
An array of numeric values. Each element is the maximum of the corresponding elements fromarray1 and array2.
Use case examples
- Log analysis
- Security logs
You want to create an upper bound by comparing request durations across two different cities and keeping the higher value at each time point.QueryRun in PlaygroundOutput
This query compares response times between two cities and creates a series containing the higher value at each time point.
| london_avg | paris_avg | max_duration |
|---|---|---|
| [120, 150, 100] | [180, 130, 190] | [180, 150, 190] |
List of related functions
- series_min: Compares two arrays and returns the minimum value at each position.
- series_less: Compares two arrays and returns
truewhere elements in the first array are less than the second. - series_greater: Compares two arrays and returns
truewhere the first array element is greater than the second. - max: Aggregation function that returns the maximum value across grouped records.