Model Drift Detection with Model Insights
Model Drift Detection with Assays
Wallaroo provides the ability to monitor the input and outputs of models to detect model drift by using model insights. Changes in the inputs or model predictions that fall outside of expected norms, known as data drift, can occur due to errors in the data processing pipeline or due to changes in the environment such as user preference or behavior.
Monitoring tasks called assays provides model insights by comparing a model’s predictions or the input data coming into the model against an established baseline. Changes in the distribution of this data can be an indication of model drift, or of a change in the environment that the model trained for. This can provide tips on whether a model needs to be retrained or the environment data analyzed for accuracy or other needs.
Model Insights provides interactive assays to explore data from a pipeline and learn how the data is behaving. With this information and the knowledge of your particular business use case you can then choose appropriate settings to launch an assay to run on a given frequency as more data is collected.
Assay versions
Wallaroo defaults to Assay V2 for new installations of Wallaroo 2024.4 and above. Assays V2 provides additional performance enhancements and multi-threaded processing of assay runs for realtime drift detection scenarios and offline drift detection scenarios. Except where noted, the Wallaroo SDK and Wallaroo MLOps API calls and returns are the same.
Configuring Assay Version
The assay version is set through platform operations, either during installation or via update. For Wallaroo 2024.4, Assays V2 is the default for a fresh install of Wallaroo; users who upgrade will be on Assays V1 unless they manually change the version via platform operations.
When changing from one assay version to the other, the following effects will follow:
- The Wallaroo Dashboard Pipeline Insights page only displays assays created in the configured assay version.
- For example, if the assay was created in Assays V1, then the Wallaroo instance is configured to Assays V2, only assays created under Assays V2 are displayed in the Wallaroo Dashboard.
- The Wallaroo SDK Assay methods must be set to same configured Wallaroo Assay version.
- The Wallaroo MLOps API endpoints only support the Assay V1. For V2, use the Wallaroo SDK.
Organizations should inform ML engineers and other developers on what Wallaroo Assay version is used so they can use the correct SDK settings.
It is highly recommended to set the Wallaroo Assay version at installation time, or before any assays are created. When moving from one Wallaroo Assay version to another, all existing assays should be migrated by recreating them with the same original settings.
Model Drift Detection with Model Insights via the Wallaroo Dashboard
Model Drift Detection with Model Insights via the Wallaroo Dashboard allows organizations to create assays that monitor inference requests and results against an established baseline.
Access the Model Insights Page
Assays created through the Wallaroo Dashboard are accessed through the Pipeline Dashboard through the following process.
- Log into the Wallaroo Dashboard.
- Select the workspace containing the pipeline with the models being monitored from the Change Current Workspace and Workspace Management drop down.
- Select View Pipelines.
- Select the pipeline containing the models being monitored.
- Select Insights.
The Wallaroo Assay Dashboard contains the following elements. For more details of each configuration type, see the Model Insights and Assays Introduction.
IMPORTANT NOTE
Assays are only displayed in the version they were created in. For new installations of Wallaroo 2024.4, Wallaroo Assays default to V2. If Wallaroo is configured for Assays V1, then only assays created under Assay V1 will be displayed. If Wallaroo is configured for Assays V2, only assays created for Assays V2 are displayed.Pipeline Name and Identifier (A): The pipeline’s assigned name and unique identifier in UUID format.
Filter Edges (B): By default, all locations are displayed. Filter Edges provides a list of available edge deployments are displayed. Selecting one or more filters from the list limits the available metrics and logs displayed to only the selected locations.
Status (C): The status of the pipeline. The status only applies to the pipeline’s status in the Wallaroo Ops instance.. Options are:
- Active: The pipeline is deployed.
- Inactive: The pipeline is not deployed.
Tags (D): Any tags applied to the pipeline.
Inference Urls (E): The internal and external inference URLs for the deployed pipeline in the Wallaroo Ops instance.
+ Create Assay (F): Create a new assay.
Deploy/Undeploy the Pipeline (G): Deploy an inactive pipeline, or deploy an active pipeline in the Wallaroo Ops instance.
Filter Assays (H): Filter the assays by Name or Status, and Sort.
- Status filters are:
- All Status: All statuses.
- Active: Active assays.
- Paused: Assays that are paused.
- Drift Detected: Assays where model drift is detected.
- Sort filters are:
- Creation Date
- Last Assay Run
- Status filters are:
Assay Details View (I): A chart of the assay analyses. This is filtered by the selected dates and time ranges.
Activity (J): Comments left by users.
Assay Details View
The following details are visible by selecting the Assay View Details icon:
- (A) Assay Name: The name of the assay displayed.
- (B) Input / Output: The input or output and the index of the element being monitored.
- (C) Baseline: The time period used to generate the baseline. For baselines generated from a file, the baseline displayed
Uploaded File
. - (D) Last Run: The date and time the assay was last run.
- (E) Next Run: The future date and time the assay will be run again. NOTE: If the assay is paused, then it will not run at the scheduled time. When unpaused, the date will be updated to the next date and time that the assay will be run.
- (F) Aggregation Type: The aggregation type used with the assay.
- (G) Threshold: The threshold value used for the assay.
- (H) Metric: The metric type used for the assay.
- (I) Number of Bins: The number of bins used for the assay.
- (J) Bin Weight: The weight applied to each bin.
- (K) Bin Mode: The type of bin node applied to each bin.
View Assay Alert Details
To view details on an assay alert:
- Select the data with available alert data.
- Mouse hover of a specific Assay Event Alert to view the data and time of the event and the alert value.
- Select the Assay Event Alert to view the Baseline and Window details of the alert including the left_outlier and right_outlier.
Hover over a bar chart graph to view additional details.
- Select the ⊗ symbol to exit the Assay Event Alert details and return to the Assay View.
Build an Assay Through the Pipeline Dashboard
To create a new assay through the Wallaroo Pipeline Dashboard:
- Log into the Wallaroo Dashboard.
- Select the workspace containing the pipeline with the models being monitored from the Change Current Workspace and Workspace Management drop down.
- Select View Pipelines.
- Select the pipeline containing the models being monitored.
- Select Insights.
- Select +Create Assay.
- On the Create Assay module, enter the following:
On the Assay Name section, enter the following:
Assay Name (A): The name of the new assay.
Monitor output data or Monitor input data (B): Select whether to monitor input or output data.
Select an output/input to monitor (C): Select the input or output to monitor.
- Named Field: The name of the field to monitor.
- Index: The index of the monitored field.
On the Specify Baseline section, select one of the following options:
- (D) Select the data to use for the baseline. This can either be set with a preset recent time period (last 30 seconds, last 60 seconds, etc) or with a custom date range.
(E) Upload an assay baseline file as either a CSV or TXT file. These assay baselines must be a list of numpy (aka float) values that are comma and newline separated, terminating at the last record with no additional commas or returns.
For example:
684577.200, 921561.500, 705013.440, 725875.900, 684577.200, 379398.300, 266405.600, 256630.310
Once selected, a preview graph of the baseline values will be displayed (C). Note that this may take a few seconds to generate.
Select Next to continue.
- On the Settings Module:
Set the date and time range to view values generated by the assay. This can either be set with a preset recent time period (last 30 seconds, last 60 seconds, etc) or with a custom date range.
New assays are configured to run a new analysis for every 24 hours starting at the end of the baseline period. For information on how to adjust the scheduling period and other settings for the assay scheduling window, see the SDK section on how to Schedule Assay.
Set the following Advanced Settings.
- (A) Preview Date Range: The date and times to for the preview chart.
- (B) Preview: A preview of the assay results will be displayed based on the settings below.
- (C) Scheduling: Set the Frequency (Daily, Every Minute, Hourly, Weekly, Default: Daily) and the Time (increments of one hour Default: 1:00 AM).
- (D) Group Results: How the results are grouped: Daily (Default), Every Minute, Weekly, or Monthly.
- (E) Aggregation Type: Density or Cumulative.
- (F) Threshold:
- Default: 0.1
- (G) Metric:
- Default: Population Stability Index
- Maximum Difference of Bins
- Sum of the Difference of Bins
- (H) Number of Bins: From 5 to 14. Default: 5
- (F) Bin Mode:
- Equally Spaced
- Default: Quantile
- (I) Bin Weights: The bin weights:
- Equally Weighted (Default)
- Custom: Users can assign their own bin weights as required.
Review the preview chart to verify the settings are correct.
Select Build to complete the process and build the new assay.
Once created, it may take a few minutes for the assay to complete compiling data. If needed, reload the Pipeline Dashboard to view changes.
Model Insights via the Wallaroo Dashboard SDK
Assays generated through the Wallaroo SDK can be previewed, configured, and uploaded to the Wallaroo Ops instance. The following is a condensed version of this process. For full details see the Wallaroo SDK Essentials Guide: Assays Management guide.
Model drift detection with assays using the Wallaroo SDK follows this general process.
- Define the Baseline: From either historical inference data for a specific model in a pipeline, or from a pre-determine array of data, a baseline is formed.
- Assay Preview: Once the baseline is formed, we preview the assay and configure the different options until we have the the best method of detecting environment or model drift.
- Create Assay: With the previews and configuration complete, we upload the assay. The assay will perform an analysis on a regular scheduled based on the configuration.
- Get Assay Results: Retrieve the analyses and use them to detect model drift and possible sources.
- Pause/Resume Assay: Pause or restart an assay as needed.
Set the Assay Version
The assay version is set through platform operations, either during installation or via update. Wallaroo platform engineers should inform users which assay version is being used. For Wallaroo 2024.4, Assays V2 is the default.
The Wallaroo SDK is configured to use Assays V2 by setting the following environmental variable:
ASSAYS_V2_ENABLED=True|False
If True
(Default), the Wallaroo SDK uses Wallaroo Assay V2. If False
, the Wallaroo SDK uses Wallaroo Assays V1. This must match the same Assay setting set for through platform operations. For the Wallaroo 2024.4 SDK, the SDK defaults to Assays V2; no environmental variable is required if using Assays V2.
Define the Baseline
Assay baselines are defined with the wallaroo.client.build_assay
method. Through this process we define the baseline from either a range of dates or pre-generated values.
wallaroo.client.build_assay
take the following parameters:
Parameter | Type | Description |
---|---|---|
assay_name | String (Required) - required | The name of the assay. Assay names must be unique across the Wallaroo instance. |
pipeline | wallaroo.pipeline.Pipeline (Required) | The pipeline the assay is monitoring. |
model_name | String (Optional) / None | The name of the model to monitor. This field should only be used to track the inputs/outputs for a specific model step in a pipeline. If no model_name is to be included, then the parameters must be passed a named parameters not positional ones. |
iopath | String (Required) | The input/output data for the model being tracked in the format input/output field index . Only one value is tracked for any assay. For example, to track the output of the model’s field house_value at index 0 , the iopath is 'output house_value 0 . |
baseline_start | datetime.datetime (Optional) | The start time for the inferences to use as the baseline. Must be included with baseline_end . Cannot be included with baseline_data . |
baseline_end | datetime.datetime (Optional) | The end time of the baseline window. the baseline. Windows start immediately after the baseline window and are run at regular intervals continuously until the assay is deactivated or deleted. Must be included with baseline_start . Cannot be included with baseline_data .. |
baseline_data | numpy.array (Optional) | The baseline data in numpy array format. Cannot be included with either baseline_start or baseline_data . |
Note that model_name
is an optional parameters when parameters are named. For example:
assay_builder_from_dates = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
or:
assay_builder_from_dates = wl.build_assay("assays from date baseline",
mainpipeline,
None, ## since we are using positional parameters, `None` must be included for the model parameter
"output variable 0",
assay_baseline_start,
assay_baseline_end)
Baselines are created in one of two mutually exclusive methods:
- Date Range: The
baseline_start
andbaseline_end
retrieves the inference requests and results for the pipeline from the start and end period. This data is summarized and used to create the baseline. For our examples, we’re using the variablesassay_baseline_start
andassay_baseline_end
to represent a range of dates, withassay_baseline_start
being set beforeassay_baseline_end
. - Numpy Values: The
baseline_data
sets the baseline from a provided numpy array. This allows assay baselines to be created without first performing inferences in Wallaroo.
Define the Baseline Example
This example shows two methods of defining the baseline for an assay:
"assays from date baseline"
: This assay uses historical inference requests to define the baseline. This assay is saved to the variableassay_builder_from_dates
."assays from numpy"
: This assay uses a pre-generated numpy array to define the baseline. This assay is saved to the variableassay_builder_from_numpy
.
In both cases, the following parameters are used:
Parameter | Value |
---|---|
assay_name | "assays from date baseline" and "assays from numpy" |
pipeline | mainpipeline : A pipeline with a ML model that predicts house prices. The output field for this model is variable . |
iopath | These assays monitor the model’s output field variable at index 0 for the pipeline. From this, the iopath setting is "output variable 0" . |
The difference between the two assays’ parameters determines how the baseline is generated.
"assays from date baseline"
: Uses thebaseline_start
andbaseline_end
to set the time period of inference requests and results to gather data from."assays from numpy"
: Uses a pre-generated numpy array as for the baseline data.
First we generate an assay baseline from a range of historical inferences performed through the specified pipeline deployment.
# Build the assay, based on the start and end of our baseline time,
# and tracking the output variable index 0
display(assay_baseline_start)
display(assay_baseline_end)
assay_baseline_from_dates = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# create the baseline from the dates
assay_baseline_run_from_dates = assay_baseline_from_dates.build().interactive_baseline_run()
datetime.datetime(2024, 12, 19, 16, 24, 26, 96082)
datetime.datetime(2024, 12, 19, 16, 25, 26, 198091)
# storing the workspace id for later requests
workspace_id = workspace.id()
workspace_id
9
In this code sample, we generate the assay baseline from a preset numpy array called small_results_baseline
.
# build the baseline from the numpy array
display(small_results_baseline[0:5])
# assay builder by baseline
assay_baseline_from_numpy = wl.build_assay(assay_name = assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_data = small_results_baseline)
# create the baseline from the numpy array
assay_baseline_run_from_numpy = assay_baseline_from_numpy.build().interactive_baseline_run()
array([424966.6 , 303002.25, 544392.06, 937359.6 , 634865.7 ])
Baseline Chart
The baseline chart is displayed with wallaroo.assay.AssayAnalysis.chart()
, which returns a chart with:
- baseline mean: The mean value of the baseline values.
- baseline median: The median value of the baseline values.
- bin_mode: The binning mode. See Binning Mode
- aggregation: The aggregation type. See Aggregation Options
- metric: The assay’s metric type. See Score Metric
- weighted: Whether the binning mode is weighted. See Binning Mode
The first chart is from an assay baseline generated from a set of inferences across a range of dates.
assay_baseline_run_from_dates.chart()
baseline mean = 527349.06153125
baseline median = 448627.8125
bin_mode = Quantile
aggregation = Density
metric = PSI
weighted = False
This chart is from an assay baseline generated from a set of numpy values.
assay_baseline_run_from_numpy.chart()
baseline mean = 527349.0638399998
baseline median = 448627.8
bin_mode = Quantile
aggregation = Density
metric = PSI
weighted = False
Baseline DataFrame
The method wallaroo.assay_config.AssayBuilder.baseline_dataframe
returns a DataFrame of the assay baseline generated from the provided parameters. This includes:
metadata
: The inference metadata with the model information, inference time, and other related factors.in
data: Each input field assigned with the labelin.{input field name}
.out
data: Each output field assigned with the labelout.{output field name}
Note that for assays generated from numpy values, there is only the out
data based on the supplied baseline data.
In the following example, the baseline DataFrame is retrieved.
This baseline DataFrame is from an assay baseline generated from a set of inferences across a range of dates.
display(assay_baseline_from_dates.baseline_dataframe())
time | metadata | input_tensor_0 | input_tensor_1 | input_tensor_2 | input_tensor_3 | input_tensor_4 | input_tensor_5 | input_tensor_6 | input_tensor_7 | input_tensor_8 | input_tensor_9 | input_tensor_10 | input_tensor_11 | input_tensor_12 | input_tensor_13 | input_tensor_14 | input_tensor_15 | input_tensor_16 | input_tensor_17 | output_variable_0 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 3.0 | 3.00 | 1520.0 | 1884.0 | 3.0 | 0.0 | 0.0 | 3.0 | 8.0 | 1520.0 | 0.0 | 47.717602 | -122.283997 | 1360.0 | 1939.0 | 5.0 | 0.0 | 0.0 | 424966.59375 |
1 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 4.0 | 1.00 | 1750.0 | 68841.0 | 1.0 | 0.0 | 0.0 | 3.0 | 7.0 | 1750.0 | 0.0 | 47.444199 | -122.081001 | 1550.0 | 32799.0 | 72.0 | 0.0 | 0.0 | 303002.25000 |
2 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 3.0 | 2.50 | 1660.0 | 2890.0 | 2.0 | 0.0 | 0.0 | 3.0 | 7.0 | 1660.0 | 0.0 | 47.543400 | -122.292999 | 1540.0 | 2890.0 | 14.0 | 0.0 | 0.0 | 544392.06250 |
3 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 3.0 | 2.50 | 2830.0 | 3750.0 | 3.0 | 0.0 | 0.0 | 3.0 | 10.0 | 2830.0 | 0.0 | 47.679901 | -122.385002 | 1780.0 | 5000.0 | 0.0 | 0.0 | 0.0 | 937359.62500 |
4 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 3.0 | 2.25 | 3280.0 | 79279.0 | 1.0 | 0.0 | 0.0 | 3.0 | 10.0 | 3280.0 | 0.0 | 47.320702 | -122.292999 | 1860.0 | 24008.0 | 13.0 | 0.0 | 0.0 | 634865.68750 |
... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... |
495 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 3.0 | 2.50 | 2370.0 | 4200.0 | 2.0 | 0.0 | 0.0 | 3.0 | 8.0 | 2370.0 | 0.0 | 47.369900 | -122.018997 | 2370.0 | 4370.0 | 1.0 | 0.0 | 0.0 | 349102.75000 |
496 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 2.0 | 1.75 | 2080.0 | 8112.0 | 1.0 | 1.0 | 4.0 | 4.0 | 8.0 | 1040.0 | 1040.0 | 47.713402 | -122.277000 | 2030.0 | 8408.0 | 75.0 | 1.0 | 45.0 | 987157.25000 |
497 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 4.0 | 2.50 | 2630.0 | 5701.0 | 2.0 | 0.0 | 0.0 | 3.0 | 7.0 | 2630.0 | 0.0 | 47.375000 | -122.160004 | 2770.0 | 5939.0 | 4.0 | 0.0 | 0.0 | 368504.31250 |
498 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 3.0 | 3.75 | 3710.0 | 34412.0 | 2.0 | 0.0 | 0.0 | 3.0 | 10.0 | 2910.0 | 800.0 | 47.588799 | -122.040001 | 2390.0 | 34412.0 | 36.0 | 0.0 | 0.0 | 924823.81250 |
499 | 1734625526186 | {'last_model': '{"model_name":"house-price-estimator","model_sha":"e22a0831aafd9917f3cc87a15ed267797f80e2afa12ad7d8810ca58f173b8cc6"}', 'pipeline_version': '891c2825-2a2a-41d5-9cc0-d163eba07225', 'elapsed': [2146223, 3334204], 'dropped': [], 'partition': 'engine-79dbc8986-5fbxf'} | 3.0 | 1.50 | 1590.0 | 8911.0 | 1.0 | 0.0 | 0.0 | 3.0 | 7.0 | 1590.0 | 0.0 | 47.739399 | -122.251999 | 1590.0 | 9625.0 | 58.0 | 0.0 | 0.0 | 437177.96875 |
500 rows × 21 columns
This baseline DataFrame is from an assay baseline generated from an array of numpy values.
display(assay_baseline_from_numpy.baseline_dataframe())
output_variable_0 | |
---|---|
0 | 424966.60 |
1 | 303002.25 |
2 | 544392.06 |
3 | 937359.60 |
4 | 634865.70 |
... | ... |
495 | 349102.75 |
496 | 987157.25 |
497 | 368504.30 |
498 | 924823.80 |
499 | 437177.97 |
500 rows × 1 columns
Baseline Stats
The method wallaroo.assay.AssayAnalysis.baseline_stats()
returns a pandas.core.frame.DataFrame
of the baseline stats.
The baseline stats for each assay are displayed in the examples below.
This baseline states DataFrame is from an assay baseline generated from a set of inferences across a range of dates.
assay_baseline_run_from_dates.baseline_stats()
Baseline | |
---|---|
count | 500 |
min | 236238.671875 |
max | 1489624.25 |
mean | 527349.061531 |
median | 448627.8125 |
std | 242810.711651 |
start | 2024-12-19T16:24:26.096082+00:00 |
end | 2024-12-19T16:25:26.198082+00:00 |
This baseline states DataFrame is from an assay baseline generated from an array of numpy values.
assay_baseline_run_from_numpy.baseline_stats()
Baseline | |
---|---|
count | 500 |
min | 236238.67 |
max | 1489624.3 |
mean | 527349.06384 |
median | 448627.8 |
std | 242810.71533 |
start | None |
end | None |
Baseline Bins
The method wallaroo.assay.AssayAnalysis.baseline_bins
a simple dataframe to with the edge/bin data for a baseline.
These baseline bins DataFrame is from an assay baseline generated from a set of inferences across a range of dates.
assay_baseline_run_from_dates.baseline_bins()
b_edges | b_edge_names | b_aggregated_values | b_aggregation | |
---|---|---|---|---|
0 | 2.362387e+05 | left_outlier | 0.000 | Aggregation.DENSITY |
1 | 3.238563e+05 | q_20 | 0.200 | Aggregation.DENSITY |
2 | 4.371780e+05 | q_40 | 0.230 | Aggregation.DENSITY |
3 | 5.363712e+05 | q_60 | 0.174 | Aggregation.DENSITY |
4 | 7.032827e+05 | q_80 | 0.198 | Aggregation.DENSITY |
5 | 1.489624e+06 | q_100 | 0.198 | Aggregation.DENSITY |
6 | inf | right_outlier | 0.000 | Aggregation.DENSITY |
These baseline bins DataFrame is from an assay baseline generated from an array of numpy values.
assay_baseline_run_from_numpy.baseline_bins()
b_edges | b_edge_names | b_aggregated_values | b_aggregation | |
---|---|---|---|---|
0 | 236238.67 | left_outlier | 0.000 | Aggregation.DENSITY |
1 | 323856.28 | q_20 | 0.200 | Aggregation.DENSITY |
2 | 437177.97 | q_40 | 0.230 | Aggregation.DENSITY |
3 | 536371.20 | q_60 | 0.174 | Aggregation.DENSITY |
4 | 703282.70 | q_80 | 0.198 | Aggregation.DENSITY |
5 | 1489624.30 | q_100 | 0.198 | Aggregation.DENSITY |
6 | inf | right_outlier | 0.000 | Aggregation.DENSITY |
Baseline Histogram Chart
The method wallaroo.assay_config.AssayBuilder.baseline_histogram
returns a histogram chart of the assay baseline generated from the provided parameters.
These chart is from an assay baseline generated from a set of inferences across a range of dates.
assay_baseline_from_dates.baseline_histogram()
Baseline KDE Chart
The method wallaroo.assay_config.AssayBuilder.baseline_kde
returns a Kernel Density Estimation (KDE) chart of the assay baseline generated from the provided parameters.
These chart is from an assay baseline generated from a set of inferences across a range of dates.
assay_baseline_from_dates.baseline_kde()
Baseline ECDF Chart
The method wallaroo.assay_config.AssayBuilder.baseline_ecdf
returns a Empirical Cumulative Distribution Function (CDF) chart of the assay baseline generated from the provided parameters.
These chart is from an assay baseline generated from a set of inferences across a range of dates.
assay_baseline_from_dates.baseline_ecdf()
Assay Preview
Now that the baseline is defined, we look at different configuration options and view how the assay baseline and results changes. Once we determine what gives us the best method of determining model drift, we can create the assay.
Analysis List Chart Scores
Analysis List scores show the assay scores for each assay result interval in one chart. Values that are outside of the alert threshold are colored red, while scores within the alert threshold are green.
Assay chart scores are displayed with the method wallaroo.assay.AssayAnalysisList.chart_scores
, with ability to display an optional title with the chart. This takes the following parameters:
Parameter | Type | Description |
---|---|---|
title | String (Optional) | The title to assign the chart. |
nth_x_tick | Integer (Optional) (Default: 4) | The density of the x ticks. |
start | DateTime (Optional) | The start time of the chart. If start is set, the parameter end must be set. |
end | DateTime (Optional) | The end time of the chart. If end is set, the parameter start must be set. |
The following example shows retrieving the assay results and displaying the chart scores. From our example, we have two windows - the first should be green, and the second is red showing that values were outside the alert threshold.
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show the analyses chart
assay_results.chart_scores()
The following chart uses the nth_x_tick
setting to space out the x-axis labels further.
# set different nth_x_tick
assay_results.chart_scores(nth_x_tick=10)
Analysis Chart
The method wallaroo.assay.AssayAnalysis.chart()
displays a comparison between the baseline and an interval of inference data.
This is compared to the Chart Scores, which is a list of all of the inference data split into intervals, while the Analysis Chart shows the breakdown of one set of inference data against the baseline.
Score from the Analysis List Chart Scores and each element from the Analysis List DataFrame generates
The following fields are included.
Field | Type | Description |
---|---|---|
baseline mean | Float | The mean of the baseline values. |
window mean | Float | The mean of the window values. |
baseline median | Float | The median of the baseline values. |
window median | Float | The median of the window values. |
bin_mode | String | The binning mode used for the assay. |
aggregation | String | The aggregation mode used for the assay. |
metric | String | The metric mode used for the assay. |
weighted | Bool | Whether the bins were manually weighted. |
score | Float | The score from the assay window. |
scores | List(Float) | The score from each assay window bin. |
index | Integer/None | The window index. Interactive assay runs are None . |
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name="assays from date baseline sample",
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# display one of the analysis from the total results
assay_results[0].chart()
Analysis List DataFrame
wallaroo.assay.AssayAnalysisList.to_dataframe()
returns a DataFrame showing the assay results for each window aka individual analysis. This DataFrame contains the following fields:
Field | Type | Description |
---|---|---|
assay_id | String/None | The assay id in UUID format. Only provided from uploaded and executed assays. |
name | String/None | The name of the assay. Only provided from uploaded and executed assays. |
iopath | String/None | The iopath of the assay. Only provided from uploaded and executed assays. |
score | Float | The assay score. |
start | DateTime | The DateTime start of the assay window. |
min | Float | The minimum value in the assay window. |
max | Float | The maximum value in the assay window. |
mean | Float | The mean value in the assay window. |
median | Float | The median value in the assay window. |
std | Float | The standard deviation value in the assay window. |
warning_threshold | Float/None | The warning threshold of the assay window. |
alert_threshold | Float/None | The alert threshold of the assay window. |
status | String | The assay window status. Values are:
|
For this example, the assay analysis list DataFrame is listed.
From this tutorial, we should have 2 windows of dta to look at, each one minute apart. The first window should show status: OK
, with the second window with the very large house prices will show status: alert
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# display the dataframe from the analyses
assay_results.to_dataframe()
id | assay_id | assay_name | iopath | pipeline_id | pipeline_name | workspace_id | workspace_name | score | start | min | max | mean | median | std | warning_threshold | alert_threshold | status | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.006029 | 2024-12-19 16:26:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.174628e+05 | 4.486278e+05 | 228315.343750 | None | 0.25 | Ok |
1 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.004165 | 2024-12-19 16:27:26.210451+00:00 | 2.362387e+05 | 1364149.875 | 5.176297e+05 | 4.489289e+05 | 223850.687500 | None | 0.25 | Ok |
2 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.008836 | 2024-12-19 16:28:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.202844e+05 | 4.486278e+05 | 237580.015625 | None | 0.25 | Ok |
3 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.001920 | 2024-12-19 16:29:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.255399e+05 | 4.486278e+05 | 243668.000000 | None | 0.25 | Ok |
4 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.003151 | 2024-12-19 16:30:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.106707e+05 | 4.486278e+05 | 221293.593750 | None | 0.25 | Ok |
5 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.001399 | 2024-12-19 16:31:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.164491e+05 | 4.486278e+05 | 229535.453125 | None | 0.25 | Ok |
6 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.001459 | 2024-12-19 16:32:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.242250e+05 | 4.508677e+05 | 233475.187500 | None | 0.25 | Ok |
7 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.007347 | 2024-12-19 16:33:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.174510e+05 | 4.486278e+05 | 227477.843750 | None | 0.25 | Ok |
8 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.008707 | 2024-12-19 16:34:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.073022e+05 | 4.486278e+05 | 230616.375000 | None | 0.25 | Ok |
9 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.007234 | 2024-12-19 16:35:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.087417e+05 | 4.486278e+05 | 230061.750000 | None | 0.25 | Ok |
10 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:38:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.886837e+06 | 1.946438e+06 | 157108.031250 | None | 0.25 | Alert |
11 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:39:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.880314e+06 | 1.946438e+06 | 164319.796875 | None | 0.25 | Alert |
12 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:40:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.885621e+06 | 1.946438e+06 | 153896.281250 | None | 0.25 | Alert |
13 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:41:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.887078e+06 | 1.946438e+06 | 156764.187500 | None | 0.25 | Alert |
14 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:42:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.878626e+06 | 1.946438e+06 | 162892.812500 | None | 0.25 | Alert |
15 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:43:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.868448e+06 | 1.946438e+06 | 167927.687500 | None | 0.25 | Alert |
16 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:44:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.877964e+06 | 1.946438e+06 | 164031.328125 | None | 0.25 | Alert |
17 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:45:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.890221e+06 | 1.946438e+06 | 152987.593750 | None | 0.25 | Alert |
18 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:46:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.887773e+06 | 1.946438e+06 | 155437.328125 | None | 0.25 | Alert |
19 | 0 | cb6e894c-40cc-4f2e-8e9e-4f0ba188d2f2 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:47:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.877611e+06 | 1.946438e+06 | 163545.187500 | None | 0.25 | Alert |
Analysis List Full DataFrame
wallaroo.assay.AssayAnalysisList.to_full_dataframe()
returns a DataFrame showing all values, including the inputs and outputs from the assay results for each window aka individual analysis. This DataFrame contains the following fields:
pipeline_id warning_threshold bin_index created_at
Field | Type | Description |
---|---|---|
window_start | DateTime | The date and time when the window period began. |
analyzed_at | DateTime | The date and time when the assay analysis was performed. |
elapsed_millis | Integer | How long the analysis took to perform in milliseconds. |
baseline_summary_count | Integer | The number of data elements from the baseline. |
baseline_summary_min | Float | The minimum value from the baseline summary. |
baseline_summary_max | Float | The maximum value from the baseline summary. |
baseline_summary_mean | Float | The mean value of the baseline summary. |
baseline_summary_median | Float | The median value of the baseline summary. |
baseline_summary_std | Float | The standard deviation value of the baseline summary. |
baseline_summary_edges_{0…n} | Float | The baseline summary edges for each baseline edge from 0 to number of edges. |
summarizer_type | String | The type of summarizer used for the baseline. See wallaroo.assay_config for other summarizer types. |
summarizer_bin_weights | List / None | If baseline bin weights were provided, the list of those weights. Otherwise, None . |
summarizer_provided_edges | List / None | If baseline bin edges were provided, the list of those edges. Otherwise, None . |
status | String | The assay window status. Values are:
|
id | Integer/None | The id for the window aka analysis. Only provided from uploaded and executed assays. |
assay_id | String/None | The assay id in UUID format. Only provided from uploaded and executed assays. |
pipeline_id | Integer/None | The pipeline id. Only provided from uploaded and executed assays. |
warning_threshold | Float | The warning threshold set for the assay. |
warning_threshold | Float | The warning threshold set for the assay. |
bin_index | Integer/None | The bin index for the window aka analysis. |
created_at | Datetime/None | The date and time the window aka analysis was generated. Only provided from uploaded and executed assays. |
For this example, full DataFrame from an assay preview is generated.
From this tutorial, we should have 2 windows of dta to look at, each one minute apart. The first window should show status: OK
, with the second window with the very large house prices will show status: alert
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# display the full dataframe from the analyses
assay_results.to_full_dataframe()
id | assay_id | window_start | analyzed_at | elapsed_millis | pipeline_id | workspace_id | workspace_name | baseline_summary_aggregated_values_0 | baseline_summary_aggregated_values_1 | baseline_summary_aggregated_values_2 | baseline_summary_aggregated_values_3 | baseline_summary_aggregated_values_4 | baseline_summary_aggregated_values_5 | baseline_summary_aggregated_values_6 | baseline_summary_aggregation | baseline_summary_bins_edges_0 | baseline_summary_bins_edges_1 | baseline_summary_bins_edges_2 | baseline_summary_bins_edges_3 | baseline_summary_bins_edges_4 | baseline_summary_bins_edges_5 | baseline_summary_bins_edges_6 | baseline_summary_bins_labels_0 | baseline_summary_bins_labels_1 | baseline_summary_bins_labels_2 | baseline_summary_bins_labels_3 | baseline_summary_bins_labels_4 | baseline_summary_bins_labels_5 | baseline_summary_bins_labels_6 | baseline_summary_bins_mode_Quantile | baseline_summary_name | baseline_summary_statistics_count | baseline_summary_statistics_max | baseline_summary_statistics_mean | baseline_summary_statistics_median | baseline_summary_statistics_min | baseline_summary_statistics_std | baseline_summary_end | baseline_summary_start | window_summary_aggregated_values_0 | window_summary_aggregated_values_1 | window_summary_aggregated_values_2 | window_summary_aggregated_values_3 | window_summary_aggregated_values_4 | window_summary_aggregated_values_5 | window_summary_aggregated_values_6 | window_summary_bins_edges_0 | window_summary_bins_edges_1 | window_summary_bins_edges_2 | window_summary_bins_edges_3 | window_summary_bins_edges_4 | window_summary_bins_edges_5 | window_summary_bins_edges_6 | window_summary_bins_labels_0 | window_summary_bins_labels_1 | window_summary_bins_labels_2 | window_summary_bins_labels_3 | window_summary_bins_labels_4 | window_summary_bins_labels_5 | window_summary_bins_labels_6 | window_summary_bins_mode_Quantile | window_summary_statistics_count | window_summary_statistics_max | window_summary_statistics_mean | window_summary_statistics_median | window_summary_statistics_min | window_summary_statistics_std | window_summary_end | window_summary_start | warning_threshold | alert_threshold | bin_index | summarizer_UnivariateContinuous_aggregation | summarizer_UnivariateContinuous_bin_mode_Quantile | summarizer_UnivariateContinuous_metric | summarizer_UnivariateContinuous_bin_weights | status | created_at | score | scores_0 | scores_1 | scores_2 | scores_3 | scores_4 | scores_5 | scores_6 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:26:26.210451+00:00 | 2024-12-19 17:00:16.511113+00:00 | 88 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.186 | 0.259 | 0.180 | 0.192 | 0.183 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1489624.250 | 5.174628e+05 | 4.486278e+05 | 2.362387e+05 | 228315.343750 | 2024-12-19T16:27:26.210451+00:00 | 2024-12-19T16:26:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.006029 | 0.0 | 0.001016 | 0.003444 | 0.000203 | 0.000185 | 0.001182 | 0.000000 |
1 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:27:26.210451+00:00 | 2024-12-19 17:00:16.429451+00:00 | 82 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.212 | 0.212 | 0.187 | 0.185 | 0.204 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1364149.875 | 5.176297e+05 | 4.489289e+05 | 2.362387e+05 | 223850.687500 | 2024-12-19T16:28:26.210451+00:00 | 2024-12-19T16:27:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.004165 | 0.0 | 0.000699 | 0.001467 | 0.000937 | 0.000883 | 0.000179 | 0.000000 |
2 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:28:26.210451+00:00 | 2024-12-19 17:00:13.192341+00:00 | 76 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.221 | 0.207 | 0.190 | 0.176 | 0.206 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1489624.250 | 5.202844e+05 | 4.486278e+05 | 2.362387e+05 | 237580.015625 | 2024-12-19T16:29:26.210451+00:00 | 2024-12-19T16:28:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.008836 | 0.0 | 0.002097 | 0.002423 | 0.001408 | 0.002591 | 0.000317 | 0.000000 |
3 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:29:26.210451+00:00 | 2024-12-19 17:00:12.882017+00:00 | 94 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.205 | 0.234 | 0.176 | 0.181 | 0.204 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1489624.250 | 5.255399e+05 | 4.486278e+05 | 2.362387e+05 | 243668.000000 | 2024-12-19T16:30:26.210451+00:00 | 2024-12-19T16:29:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.001920 | 0.0 | 0.000123 | 0.000069 | 0.000023 | 0.001526 | 0.000179 | 0.000000 |
4 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:30:26.210451+00:00 | 2024-12-19 17:00:12.878454+00:00 | 94 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.214 | 0.228 | 0.185 | 0.190 | 0.183 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1489624.250 | 5.106707e+05 | 4.486278e+05 | 2.362387e+05 | 221293.593750 | 2024-12-19T16:31:26.210451+00:00 | 2024-12-19T16:30:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.003151 | 0.0 | 0.000947 | 0.000017 | 0.000674 | 0.000330 | 0.001182 | 0.000000 |
5 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:31:26.210451+00:00 | 2024-12-19 17:00:12.870522+00:00 | 85 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.208 | 0.222 | 0.180 | 0.202 | 0.188 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1489624.250 | 5.164491e+05 | 4.486278e+05 | 2.362387e+05 | 229535.453125 | 2024-12-19T16:32:26.210451+00:00 | 2024-12-19T16:31:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.001399 | 0.0 | 0.000314 | 0.000283 | 0.000203 | 0.000080 | 0.000518 | 0.000000 |
6 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:32:26.210451+00:00 | 2024-12-19 17:00:12.866794+00:00 | 92 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.187 | 0.241 | 0.175 | 0.196 | 0.201 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1489624.250 | 5.242250e+05 | 4.508677e+05 | 2.362387e+05 | 233475.187500 | 2024-12-19T16:33:26.210451+00:00 | 2024-12-19T16:32:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.001459 | 0.0 | 0.000874 | 0.000514 | 0.000006 | 0.000020 | 0.000045 | 0.000000 |
7 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:33:26.210451+00:00 | 2024-12-19 17:00:12.888289+00:00 | 89 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.203 | 0.223 | 0.204 | 0.178 | 0.192 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1489624.250 | 5.174510e+05 | 4.486278e+05 | 2.362387e+05 | 227477.843750 | 2024-12-19T16:34:26.210451+00:00 | 2024-12-19T16:33:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.007347 | 0.0 | 0.000045 | 0.000216 | 0.004772 | 0.002130 | 0.000185 | 0.000000 |
8 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:34:26.210451+00:00 | 2024-12-19 17:00:12.869400+00:00 | 95 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.234 | 0.232 | 0.170 | 0.175 | 0.189 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1489624.250 | 5.073022e+05 | 4.486278e+05 | 2.362387e+05 | 230616.375000 | 2024-12-19T16:35:26.210451+00:00 | 2024-12-19T16:34:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.008707 | 0.0 | 0.005338 | 0.000017 | 0.000093 | 0.002840 | 0.000419 | 0.000000 |
9 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:35:26.210451+00:00 | 2024-12-19 17:00:12.659150+00:00 | 94 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.232 | 0.218 | 0.179 | 0.183 | 0.188 | 0.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 1489624.250 | 5.087417e+05 | 4.486278e+05 | 2.362387e+05 | 230061.750000 | 2024-12-19T16:36:26.210451+00:00 | 2024-12-19T16:35:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Ok | None | 0.007234 | 0.0 | 0.004749 | 0.000643 | 0.000142 | 0.001182 | 0.000518 | 0.000000 |
10 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:38:26.210451+00:00 | 2024-12-19 17:00:09.953373+00:00 | 76 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.886837e+06 | 1.946438e+06 | 1.514079e+06 | 157108.031250 | 2024-12-19T16:39:26.210451+00:00 | 2024-12-19T16:38:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
11 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:39:26.210451+00:00 | 2024-12-19 17:00:08.344041+00:00 | 98 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.880314e+06 | 1.946438e+06 | 1.514079e+06 | 164319.796875 | 2024-12-19T16:40:26.210451+00:00 | 2024-12-19T16:39:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
12 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:40:26.210451+00:00 | 2024-12-19 17:00:08.304966+00:00 | 88 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.885621e+06 | 1.946438e+06 | 1.514079e+06 | 153896.281250 | 2024-12-19T16:41:26.210451+00:00 | 2024-12-19T16:40:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
13 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:41:26.210451+00:00 | 2024-12-19 17:00:08.228943+00:00 | 88 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.887078e+06 | 1.946438e+06 | 1.514079e+06 | 156764.187500 | 2024-12-19T16:42:26.210451+00:00 | 2024-12-19T16:41:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
14 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:42:26.210451+00:00 | 2024-12-19 17:00:08.217113+00:00 | 94 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.878626e+06 | 1.946438e+06 | 1.514079e+06 | 162892.812500 | 2024-12-19T16:43:26.210451+00:00 | 2024-12-19T16:42:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
15 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:43:26.210451+00:00 | 2024-12-19 17:00:08.207688+00:00 | 105 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.868448e+06 | 1.946438e+06 | 1.514079e+06 | 167927.687500 | 2024-12-19T16:44:26.210451+00:00 | 2024-12-19T16:43:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
16 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:44:26.210451+00:00 | 2024-12-19 17:00:08.078135+00:00 | 95 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.877964e+06 | 1.946438e+06 | 1.514079e+06 | 164031.328125 | 2024-12-19T16:45:26.210451+00:00 | 2024-12-19T16:44:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
17 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:45:26.210451+00:00 | 2024-12-19 17:00:08.027560+00:00 | 97 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.890221e+06 | 1.946438e+06 | 1.514079e+06 | 152987.593750 | 2024-12-19T16:46:26.210451+00:00 | 2024-12-19T16:45:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
18 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:46:26.210451+00:00 | 2024-12-19 17:00:08.085330+00:00 | 84 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.887773e+06 | 1.946438e+06 | 1.514079e+06 | 155437.328125 | 2024-12-19T16:47:26.210451+00:00 | 2024-12-19T16:46:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
19 | 0 | 7a216b5c-93b5-4958-a9ea-b7a0ef39a0c9 | 2024-12-19T16:47:26.210451+00:00 | 2024-12-19 17:00:08.349585+00:00 | 96 | 1 | 9 | assay-demonstration-tutorial-2 | 0.0 | 0.2 | 0.23 | 0.174 | 0.198 | 0.198 | 0.0 | Density | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | out.variable.0 | 500 | 1489624.25 | 527349.061531 | 448627.8125 | 236238.671875 | 242810.711651 | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:24:26.096082+00:00 | 0.0 | 0.000 | 0.000 | 0.000 | 0.000 | 0.000 | 1.0 | 236238.671875 | 323856.28125 | 437177.96875 | 536371.1875 | 703282.6875 | 1489624.25 | INFINITY | left_outlier | q_20 | q_40 | q_60 | q_80 | q_100 | right_outlier | 5 | 1000 | 2016006.125 | 1.877611e+06 | 1.946438e+06 | 1.514079e+06 | 163545.187500 | 2024-12-19T16:48:26.210451+00:00 | 2024-12-19T16:47:26.210451+00:00 | None | 0.25 | None | Density | 5 | PSI | None | Alert | None | 8.872515 | 0.0 | 0.719331 | 0.861444 | 0.599885 | 0.710014 | 0.710014 | 5.271826 |
Analysis Compare Basic Stats
The method wallaroo.assay.AssayAnalysis.compare_basic_stats
returns a DataFrame comparing one set of inference data against the baseline.
This is compared to the Analysis List DataFrame, which is a list of all of the inference data split into intervals, while the Analysis Compare Basic Stats shows the breakdown of one set of inference data against the baseline.
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# display one analysis against the baseline
assay_results[0].compare_basic_stats()
Baseline | Window | diff | pct_diff | |
---|---|---|---|---|
count | 500.0 | 1000.0 | 500.0 | 100.0 |
max | 1489624.25 | 1489624.25 | 0.0 | 0.0 |
mean | 527349.061531 | 517462.795984 | -9886.265547 | -1.87471 |
median | 448627.8125 | 448627.8125 | 0.0 | 0.0 |
min | 236238.671875 | 236238.671875 | 0.0 | 0.0 |
std | 242810.711651 | 228315.34375 | -14495.367901 | -5.969822 |
start | 2024-12-19T16:24:26.096082+00:00 | 2024-12-19T16:26:26.210451+00:00 | NaN | NaN |
end | 2024-12-19T16:25:26.198082+00:00 | 2024-12-19T16:27:26.210451+00:00 | NaN | NaN |
Configure Assays
Before creating the assay, configure the assay and continue to preview it until the best method for detecting drift is set. The following options are available.
Inference Interval and Inference Width
The inference interval aka window interval sets how often to run the assay analysis. This is set from the wallaroo.assay_config.AssayBuilder.window_builder.add_interval
method to collect data expressed in time units: “hours=24”, “minutes=1”, etc.
For example, with an interval of 1 minute, the assay collects data every minute. Within an hour, 60 intervals of data is collected.
We can adjust the interval and see how the assays change based on how frequently they are run.
The width sets the time period from the wallaroo.assay_config.AssayBuilder.window_builder.add_width
method to collect data expressed in time units: “hours=24”, “minutes=1”, etc.
For example, an interval of 1 minute and a width of 1 minute collects 1 minutes worth of data every minute. An interval of 1 minute with a width of 5 minutes collects 5 minute of inference data every minute.
By default, the interval and width is 24 hours.
For this example, we’ll adjust the width and interval from 1 minute to 5 minutes and see how the number of analyses and their score changes.
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show the analyses chart
assay_results.chart_scores()
wl.get_current_workspace()
{'name': 'assay-demonstration-tutorial-2', 'id': 9, 'archived': False, 'created_by': '0c74dc8a-39cb-4b1e-8ba8-4013193b859b', 'created_at': '2024-12-19T16:23:09.211681+00:00', 'models': [{'name': 'house-price-estimator', 'versions': 1, 'owner_id': '""', 'last_update_time': datetime.datetime(2024, 12, 19, 16, 23, 9, 888676, tzinfo=tzutc()), 'created_at': datetime.datetime(2024, 12, 19, 16, 23, 9, 888676, tzinfo=tzutc())}], 'pipelines': [{'name': 'assay-demonstration-tutorial', 'create_time': datetime.datetime(2024, 12, 19, 16, 23, 10, 22182, tzinfo=tzutc()), 'definition': '[]'}]}
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to five minutes each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show the analyses chart
assay_results.chart_scores()
Add Run Until and Add Inference Start
For previewing assays, setting wallaroo.assay_config.AssayBuilder.add_run_until
sets the end date and time for collecting inference data. When an assay is uploaded, this setting is no longer valid - assays run at the Inference Interval until the assay is paused.
Setting the wallaroo.assay_config.WindowBuilder.add_start
sets the start date and time to collect inference data. When an assay is uploaded, this setting is included, and assay results will be displayed starting from that start date at the Inference Interval until the assay is paused. By default, add_start
begins 24 hours after the assay is uploaded unless set in the assay configuration manually.
For the following example, the add_run_until
setting is set to datetime.datetime.now()
to collect all inference data from assay_window_start
up until now, and the second example limits that example to only two minutes of data.
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results, minus 2 minutes for the period to start gathering analyses
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start+datetime.timedelta(seconds=-120))
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show the analyses chart
assay_results.chart_scores()
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now()+datetime.timedelta(seconds=120))
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show the analyses chart
assay_results.chart_scores()
Score Metric
The score
is a distance between the baseline and the analysis window. The larger the score, the greater the difference between the baseline and the analysis window. The following methods are provided determining the score:
PSI
(Default) - Population Stability Index (PSI).MAXDIFF
: Maximum difference between corresponding bins.SUMDIFF
: Mum of differences between corresponding bins.
The metric type used is updated with the wallaroo.assay_config.AssayBuilder.add_metric(metric: wallaroo.assay_config.Metric)
method.
The following three charts use each of the metrics. Note how the scores change based on the score type used.
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# set metric PSI mode
assay_baseline.summarizer_builder.add_metric(wallaroo.assay_config.Metric.PSI)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# display one analysis from the results
assay_results[0].chart()
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# set metric MAXDIFF mode
assay_baseline.summarizer_builder.add_metric(wallaroo.assay_config.Metric.MAXDIFF)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# display one analysis from the results
assay_results[0].chart()
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# set metric SUMDIFF mode
assay_baseline.summarizer_builder.add_metric(wallaroo.assay_config.Metric.SUMDIFF)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# display one analysis from the results
assay_results[0].chart()
Alert Threshold
Assay alert thresholds are modified with the wallaroo.assay_config.AssayBuilder.add_alert_threshold(alert_threshold: float)
method. By default alert thresholds are 0.1
.
The following example updates the alert threshold to 0.5
.
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# set the alert threshold
assay_baseline.add_alert_threshold(0.5)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show the analyses with the alert threshold
assay_results.to_dataframe()
id | assay_id | assay_name | iopath | pipeline_id | pipeline_name | workspace_id | workspace_name | score | start | min | max | mean | median | std | warning_threshold | alert_threshold | status | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.006029 | 2024-12-19 16:26:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.174628e+05 | 4.486278e+05 | 228315.343750 | None | 0.5 | Ok |
1 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.004165 | 2024-12-19 16:27:26.210451+00:00 | 2.362387e+05 | 1364149.875 | 5.176297e+05 | 4.489289e+05 | 223850.687500 | None | 0.5 | Ok |
2 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.008836 | 2024-12-19 16:28:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.202844e+05 | 4.486278e+05 | 237580.015625 | None | 0.5 | Ok |
3 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.001920 | 2024-12-19 16:29:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.255399e+05 | 4.486278e+05 | 243668.000000 | None | 0.5 | Ok |
4 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.003151 | 2024-12-19 16:30:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.106707e+05 | 4.486278e+05 | 221293.593750 | None | 0.5 | Ok |
5 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.001399 | 2024-12-19 16:31:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.164491e+05 | 4.486278e+05 | 229535.453125 | None | 0.5 | Ok |
6 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.001459 | 2024-12-19 16:32:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.242250e+05 | 4.508677e+05 | 233475.187500 | None | 0.5 | Ok |
7 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.007347 | 2024-12-19 16:33:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.174510e+05 | 4.486278e+05 | 227477.843750 | None | 0.5 | Ok |
8 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.008707 | 2024-12-19 16:34:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.073022e+05 | 4.486278e+05 | 230616.375000 | None | 0.5 | Ok |
9 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 0.007234 | 2024-12-19 16:35:26.210451+00:00 | 2.362387e+05 | 1489624.250 | 5.087417e+05 | 4.486278e+05 | 230061.750000 | None | 0.5 | Ok |
10 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:38:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.886837e+06 | 1.946438e+06 | 157108.031250 | None | 0.5 | Alert |
11 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:39:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.880314e+06 | 1.946438e+06 | 164319.796875 | None | 0.5 | Alert |
12 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:40:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.885621e+06 | 1.946438e+06 | 153896.281250 | None | 0.5 | Alert |
13 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:41:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.887078e+06 | 1.946438e+06 | 156764.187500 | None | 0.5 | Alert |
14 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:42:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.878626e+06 | 1.946438e+06 | 162892.812500 | None | 0.5 | Alert |
15 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:43:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.868448e+06 | 1.946438e+06 | 167927.687500 | None | 0.5 | Alert |
16 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:44:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.877964e+06 | 1.946438e+06 | 164031.328125 | None | 0.5 | Alert |
17 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:45:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.890221e+06 | 1.946438e+06 | 152987.593750 | None | 0.5 | Alert |
18 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:46:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.887773e+06 | 1.946438e+06 | 155437.328125 | None | 0.5 | Alert |
19 | 0 | 882a80b7-5bd9-4349-a899-1d954df4d611 | assay-demonstration-tutorial assay | out.variable.0 | 1 | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | 8.872515 | 2024-12-19 16:47:26.210451+00:00 | 1.514079e+06 | 2016006.125 | 1.877611e+06 | 1.946438e+06 | 163545.187500 | None | 0.5 | Alert |
Number of Bins
Number of bins sets how the baseline data is partitioned. The total number of bins includes the set number plus the left_outlier and the right_outlier, so the total number of bins will be the total set + 2.
The number of bins is set with the wallaroo.assay_config.UnivariateContinousSummarizerBuilder.add_num_bins(num_bins: int)
method.
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# update number of bins here
assay_baseline.summarizer_builder.add_num_bins(10)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show one analysis with the updated bins
assay_results[0].chart()
Binning Mode
Binning Mode defines how the bins are separated. Binning modes are modified through the wallaroo.assay_config.UnivariateContinousSummarizerBuilder.add_bin_mode(bin_mode: bin_mode: wallaroo.assay_config.BinMode, edges: Optional[List[float]] = None)
.
Available bin_mode
values from wallaroo.assay_config.Binmode
are the following:
QUANTILE
(Default): Based on percentages. Ifnum_bins
is 5 then quintiles so bins are created at the 20%, 40%, 60%, 80% and 100% points.EQUAL
: Evenly spaced bins where each bin is set with the formulamin - max / num_bins
PROVIDED
: The user provides the edge points for the bins.
If PROVIDED
is supplied, then a List of float values must be provided for the edges
parameter that matches the number of bins.
The following examples are used to show how each of the binning modes effects the bins.
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# update binning mode here
assay_baseline.summarizer_builder.add_bin_mode(wallaroo.assay_config.BinMode.QUANTILE)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show one analysis with the updated bins
assay_results[0].chart()
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# update binning mode here
assay_baseline.summarizer_builder.add_bin_mode(wallaroo.assay_config.BinMode.EQUAL)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show one analysis with the updated bins
assay_results[0].chart()
The following example manually sets the bin values.
The values in this dataset run from 200000 to 1500000. We can specify the bins with the BinMode.PROVIDED
and specifying a list of floats with the right hand / upper edge of each bin and optionally the lower edge of the smallest bin. If the lowest edge is not specified the threshold for left outliers is taken from the smallest value in the baseline dataset.
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
edges = [200000.0, 400000.0, 600000.0, 800000.0, 1500000.0, 2000000.0]
# update binning mode here
assay_baseline.summarizer_builder.add_bin_mode(wallaroo.assay_config.BinMode.PROVIDED, edges)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show one analysis with the updated bins
assay_results[0].chart()
Aggregation Options
Assay aggregation options are modified with the wallaroo.assay_config.AssayBuilder.add_aggregation(aggregation: wallaroo.assay_config.Aggregation)
method. The following options are provided:
Aggregation.DENSITY
(Default): Count the number/percentage of values that fall in each bin.Aggregation.CUMULATIVE
: Empirical Cumulative Density Function style, which keeps a cumulative count of the values/percentages that fall in each bin.
The following example demonstrate the different results between the two.
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
#Aggregation.DENSITY - the default
assay_baseline.summarizer_builder.add_aggregation(wallaroo.assay_config.Aggregation.DENSITY)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show one analysis with the updated bins
assay_results[0].chart()
# Create the assay baseline
assay_baseline = wl.build_assay(assay_name=assay_name,
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# Set the assay parameters
# The end date to gather inference results
assay_baseline.add_run_until(datetime.datetime.now())
# Set the interval and window to one minute each, set the start date for gathering inference results
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
#Aggregation.CUMULATIVE
assay_baseline.summarizer_builder.add_aggregation(wallaroo.assay_config.Aggregation.CUMULATIVE)
# build the assay configuration
assay_config = assay_baseline.build()
# perform an interactive run and collect inference data
assay_results = assay_config.interactive_run()
# show one analysis with the updated bins
assay_results[0].chart()
Create Assay
With the assay previewed and configuration options determined, we officially create it by uploading it to the Wallaroo instance.
Once it is uploaded, the assay runs an analysis based on the window width, interval, and the other settings configured.
Assays are uploaded with the wallaroo.assay_config.upload()
method. This uploads the assay into the Wallaroo database with the configurations applied and returns the assay id. Note that assay names must be unique across the Wallaroo instance; attempting to upload an assay with the same name as an existing one will return an error.
wallaroo.assay_config.upload()
returns the assay id for the assay.
Typically we would just call wallaroo.assay_config.upload()
after configuring the assay. For the example below, we will perform the complete configuration in one window to show all of the configuration steps at once before creating the assay.
# Build the assay, based on the start and end of our baseline time,
# and tracking the output variable index 0
assay_baseline = wl.build_assay(assay_name="assays from date baseline tutorial samples",
pipeline=mainpipeline,
iopath="output variable 0",
baseline_start=assay_baseline_start,
baseline_end=assay_baseline_end)
# set the width, interval, and assay start date and time
assay_baseline.window_builder().add_width(minutes=1).add_interval(minutes=1).add_start(assay_window_start)
# add other options
assay_baseline.summarizer_builder.add_aggregation(wallaroo.assay_config.Aggregation.CUMULATIVE)
assay_baseline.summarizer_builder.add_metric(wallaroo.assay_config.Metric.MAXDIFF)
assay_baseline.add_alert_threshold(0.5)
assay_id = assay_baseline.upload()
# wait 65 seconds for the first analysis run performed
time.sleep(65)
The assay is now visible through the Wallaroo UI by selecting the workspace, then the pipeline, then Insights.
Get Assay Info
Assay information is retrieved with the wallaroo.client.get_assay_info()
which takes the following parameters.
Parameter | Type | Description |
---|---|---|
assay_id | String (Required) | The numerical id of the assay in UUID format. |
workspace_id | (Int) (Optional) | The numerical identifier of the workspace to filter by. |
workspace_name | (String) (Optional) | The name of the workspace to filter by. |
This returns the following:
Parameter | Type | Description |
---|---|---|
id | String | The id of the assay in UUID format. |
name | String | The name of the assay. |
active | Boolean | True : The assay is active and generates analyses based on its configuration. False : The assay is disabled and will not generate new analyses. |
pipeline_name | String | The name of the pipeline the assay references. |
last_run | DateTime | The date and time the assay last ran. |
next_run | DateTime | THe date and time the assay analysis will next run. |
alert_threshold | Float | The alert threshold setting for the assay. |
baseline | Dict | The baseline and settings as set from the assay configuration. |
iopath | String | The iopath setting for the assay. |
metric | String | The metric setting for the assay. |
num_bins | Integer | The number of bins for the assay. |
bin_weights | List/None | The bin weights used if any. |
bin_mode | String | The binning mode used. |
workspace_id | (Int) | The numerical identifier of the workspace the assay is associated with. |
workspace_name | (String) | The name of the workspace the assay is associated with. |
display(wl.get_assay_info(assay_id))
Field | Value |
---|---|
ID | a2a81e83-ce01-40f5-9323-c710dba454c8 |
Name | assays from date baseline tutorial samples |
Active | True |
Pipeline | assay-demonstration-tutorial |
Workspace ID | 9 |
Workspace Name | assay-demonstration-tutorial-2 |
Monitoring | ['out.variable.0'] |
Window Width | 60 seconds |
First Run | 2024-19-Dec 16:26:26 |
Run Frequency | 1 Minute |
Bin Mode | 5 Quantile bins |
Aggregation | Cumulative |
Metric | MaxDiff |
Last Run | 2024-19-Dec 17:16:26 |
Next Run | 2024-19-Dec 17:17:26 |
Created At | 2024-19-Dec 17:15:50 |
Updated At | 2024-19-Dec 17:15:50 |
Get Assay Results
Once an assay is created the assay runs an analysis based on the window width, interval, and the other settings configured.
Assay results are retrieved with the wallaroo.client.get_assay_results
method which takes the following parameters:
Parameter | Type | Description |
---|---|---|
assay_id | String (Required) | The id of the assay in UUID format. |
start | Datetime.Datetime (Required) | The start date and time of historical data from the pipeline to start analyses from. |
end | Datetime.Datetime (Required) | The end date and time of historical data from the pipeline to limit analyses to. |
workspace_id | (Int) (Optional) | The numerical identifier of the workspace to filter by. |
workspace_name | (String) (Optional) | The name of the workspace to filter by. |
- IMPORTANT NOTE: This process requires that additional historical data is generated from the time the assay is created to when the results are available. To add additional inference data, use the Assay Test Data section above.
assay_results = wl.get_assay_results(assay_id=assay_id,
start=(datetime.datetime.now()-datetime.timedelta(days=2)),
end=datetime.datetime.now())
# Preview the assay analyses
assay_results.chart_scores()
assay_results[0].chart()
List Assays
A list of assays is retrieved with the wallaroo.client.list_assays()
method and takes the following parameters:
Parameter | Type | Description |
---|---|---|
workspace_id | (Int) (Optional) | The numerical identifier of the workspace to filter by. |
workspace_name | (String) (Optional) | The name of the workspace to filter by. |
This returns a list of assays as filtered in reverse chronological order.
Parameter | Type | Description |
---|---|---|
Assay Id | String | The id of the assay in UUID format. |
Assay Name | String | The name of the assay. |
Active | Boolean | True : The assay is active and generates analyses based on its configuration. False : The assay is disabled and will not generate new analyses. |
Status | Dict | The status of the assay including the |
Warning Threshold | Float/None | The warning threshold if set. |
Alert Threshold | Float | The alert threshold for the assay. |
workspace_id | (Int) | The numerical identifier of the workspace the assay is associated with. |
workspace_name | (String) | The name of the workspace the assay is associated with. |
The errors for this method include:
- If the parameter
workspace_id
is not an integer. - If the parameter
workspace_name
is not a String.
wl.list_assays()
id | name | active | pipeline | workspace id | workspace name | monitored fields | last_run | next_run | created_at | updated_at |
---|---|---|---|---|---|---|---|---|---|---|
a2a81e83-ce01-40f5-9323-c710dba454c8 | assays from date baseline tutorial samples | True | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | ['out.variable.0'] | 2024-19-Dec 17:16:26 | 2024-19-Dec 17:17:26 | 2024-19-Dec 17:15:50 | 2024-19-Dec 17:15:50 |
Set Assay Active Status
Assays active status is either:
- True: The assay generates analyses based on the assay configuration.
- False: The assay will not generate new analyses.
Assays are set to active or not active with the wallaroo.client.set_assay_active
which takes the following parameters.
Parameter | Type | Description |
---|---|---|
assay_id | String | The id of the assay in UUID format. |
active | Boolean | True : The assay status is set to Active . False : The assay status is Not Active . |
First we will show the current active status.
In the following, set the assay status to False
, then set the assay active status back to True
.
display(wl.get_assay_info(assay_id))
Field | Value |
---|---|
ID | a2a81e83-ce01-40f5-9323-c710dba454c8 |
Name | assays from date baseline tutorial samples |
Active | True |
Pipeline | assay-demonstration-tutorial |
Workspace ID | 9 |
Workspace Name | assay-demonstration-tutorial-2 |
Monitoring | ['out.variable.0'] |
Window Width | 60 seconds |
First Run | 2024-19-Dec 16:26:26 |
Run Frequency | 1 Minute |
Bin Mode | 5 Quantile bins |
Aggregation | Cumulative |
Metric | MaxDiff |
Last Run | 2024-19-Dec 17:18:26 |
Next Run | 2024-19-Dec 17:19:26 |
Created At | 2024-19-Dec 17:15:50 |
Updated At | 2024-19-Dec 17:15:50 |
Now we set the active status to False
, and show the assay list to verify it is no longer active.
wl.set_assay_active(assay_id, False)
display(wl.get_assay_info(assay_id))
Field | Value |
---|---|
ID | a2a81e83-ce01-40f5-9323-c710dba454c8 |
Name | assays from date baseline tutorial samples |
Active | False |
Pipeline | assay-demonstration-tutorial |
Workspace ID | 9 |
Workspace Name | assay-demonstration-tutorial-2 |
Monitoring | ['out.variable.0'] |
Window Width | 60 seconds |
First Run | 2024-19-Dec 16:26:26 |
Run Frequency | 1 Minute |
Bin Mode | 5 Quantile bins |
Aggregation | Cumulative |
Metric | MaxDiff |
Last Run | 2024-19-Dec 17:18:26 |
Next Run | None |
Created At | 2024-19-Dec 17:15:50 |
Updated At | 2024-19-Dec 17:18:50 |
We resume the assay by setting it’s active status to True
.
wl.set_assay_active(assay_id, True)
display(wl.get_assay_info(assay_id))
Field | Value |
---|---|
ID | a2a81e83-ce01-40f5-9323-c710dba454c8 |
Name | assays from date baseline tutorial samples |
Active | True |
Pipeline | assay-demonstration-tutorial |
Workspace ID | 9 |
Workspace Name | assay-demonstration-tutorial-2 |
Monitoring | ['out.variable.0'] |
Window Width | 60 seconds |
First Run | 2024-19-Dec 16:26:26 |
Run Frequency | 1 Minute |
Bin Mode | 5 Quantile bins |
Aggregation | Cumulative |
Metric | MaxDiff |
Last Run | 2024-19-Dec 17:18:26 |
Next Run | 2024-19-Dec 17:19:26 |
Created At | 2024-19-Dec 17:15:50 |
Updated At | 2024-19-Dec 17:18:54 |
View Assay Filters
The following examples demonstrate various ways of listing assays and retrieving assay details, with filtering options.
List Assays with Filters
List all assays for workspaces the user is a member of.
wl.list_assays()
id | name | active | pipeline | workspace id | workspace name | monitored fields | last_run | next_run | created_at | updated_at |
---|---|---|---|---|---|---|---|---|---|---|
a2a81e83-ce01-40f5-9323-c710dba454c8 | assays from date baseline tutorial samples | True | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | ['out.variable.0'] | 2024-19-Dec 17:19:26 | 2024-19-Dec 17:20:26 | 2024-19-Dec 17:15:50 | 2024-19-Dec 17:18:54 |
List all assays filtered by workspace id.
wl.list_assays(workspace_id=workspace_id)
id | name | active | pipeline | workspace id | workspace name | monitored fields | last_run | next_run | created_at | updated_at |
---|---|---|---|---|---|---|---|---|---|---|
a2a81e83-ce01-40f5-9323-c710dba454c8 | assays from date baseline tutorial samples | True | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | ['out.variable.0'] | 2024-19-Dec 17:19:26 | 2024-19-Dec 17:20:26 | 2024-19-Dec 17:15:50 | 2024-19-Dec 17:18:54 |
List assays filtered by workspace name.
wl.list_assays(workspace_name=workspace_name)
id | name | active | pipeline | workspace id | workspace name | monitored fields | last_run | next_run | created_at | updated_at |
---|---|---|---|---|---|---|---|---|---|---|
a2a81e83-ce01-40f5-9323-c710dba454c8 | assays from date baseline tutorial samples | True | assay-demonstration-tutorial | 9 | assay-demonstration-tutorial-2 | ['out.variable.0'] | 2024-19-Dec 17:19:26 | 2024-19-Dec 17:20:26 | 2024-19-Dec 17:15:50 | 2024-19-Dec 17:18:54 |
Get Assay Results with Filters
Get assay results.
assay_results = wl.get_assay_results(assay_id=assay_id,
start=assay_window_start,
end=datetime.datetime.now())
assay_results.chart_scores()
Get assay results filtered by workspace id.
assay_results = wl.get_assay_results(assay_id=assay_id,
workspace_id=workspace_id,
start=assay_window_start,
end=datetime.datetime.now())
assay_results.chart_scores()
Get assay results filtered by workspace name.
assay_results = wl.get_assay_results(assay_id=assay_id,
workspace_name=workspace_name,
start=assay_window_start,
end=datetime.datetime.now())
assay_results.chart_scores()
Get Assay Info with Filter
Get assay info.
wl.get_assay_info(assay_id=assay_id)
Field | Value |
---|---|
ID | a2a81e83-ce01-40f5-9323-c710dba454c8 |
Name | assays from date baseline tutorial samples |
Active | True |
Pipeline | assay-demonstration-tutorial |
Workspace ID | 9 |
Workspace Name | assay-demonstration-tutorial-2 |
Monitoring | ['out.variable.0'] |
Window Width | 60 seconds |
First Run | 2024-19-Dec 16:26:26 |
Run Frequency | 1 Minute |
Bin Mode | 5 Quantile bins |
Aggregation | Cumulative |
Metric | MaxDiff |
Last Run | 2024-19-Dec 17:19:26 |
Next Run | 2024-19-Dec 17:20:26 |
Created At | 2024-19-Dec 17:15:50 |
Updated At | 2024-19-Dec 17:18:54 |
Get assay info filtered by workspace id.
wl.get_assay_info(assay_id=assay_id,
workspace_id=workspace_id)
Field | Value |
---|---|
ID | a2a81e83-ce01-40f5-9323-c710dba454c8 |
Name | assays from date baseline tutorial samples |
Active | True |
Pipeline | assay-demonstration-tutorial |
Workspace ID | 9 |
Workspace Name | assay-demonstration-tutorial-2 |
Monitoring | ['out.variable.0'] |
Window Width | 60 seconds |
First Run | 2024-19-Dec 16:26:26 |
Run Frequency | 1 Minute |
Bin Mode | 5 Quantile bins |
Aggregation | Cumulative |
Metric | MaxDiff |
Last Run | 2024-19-Dec 17:19:26 |
Next Run | 2024-19-Dec 17:20:26 |
Created At | 2024-19-Dec 17:15:50 |
Updated At | 2024-19-Dec 17:18:54 |
Get assay info filtered by workspace name.
wl.get_assay_info(assay_id=assay_id,
workspace_name=workspace_name)
Field | Value |
---|---|
ID | a2a81e83-ce01-40f5-9323-c710dba454c8 |
Name | assays from date baseline tutorial samples |
Active | True |
Pipeline | assay-demonstration-tutorial |
Workspace ID | 9 |
Workspace Name | assay-demonstration-tutorial-2 |
Monitoring | ['out.variable.0'] |
Window Width | 60 seconds |
First Run | 2024-19-Dec 16:26:26 |
Run Frequency | 1 Minute |
Bin Mode | 5 Quantile bins |
Aggregation | Cumulative |
Metric | MaxDiff |
Last Run | 2024-19-Dec 17:19:26 |
Next Run | 2024-19-Dec 17:20:26 |
Created At | 2024-19-Dec 17:15:50 |
Updated At | 2024-19-Dec 17:18:54 |