Sudden Changes

The third and last basic "Average" verse we will define is "AverageSuddenChange". This verse configures Mona to find timeseries-based anomalies in the data where the average of a metric has changed significantly in the last day, compared to a defined time period prior to it.

In our case, we want to check if the average of the following metrics: "credit_score", "offered_amount", "approved_amount", "credit_label_delta" and "offered_approved_delta_normalized", has significantlly changed in the last day, in one of the values of our segmentations: "occupation", "purpose", "stage", "model_version" and "city".

Add new AverageSuddenChange verse

On the configurations page, under the "Stanzas" tab, go to the "general" stanza and click on the edit button on the right.
Go to the "Verses" tab and click on "Add new verse"
Again, on the left, you will see a list of all possible verse types. Let's choose AverageSuddenChange.

The verse window is divided into different categories, for different possible params that can be defined in the verse. The first category is "Basic", and it holds all the basic params needed to configure the verse.

📘

All verse params have a default value which will be defined if no other value is given to override

Define "Basic" verse params

In the following params, click on "override" and add the following:

metrics - "credit_score", "offered_amount", "approved_amount", "credit_label_delta", "offered_approved_delta_normalized".
min_anomaly_level - 2
min_culprit_size - 10
min_segment_size_fraction - 0.05
segment_by - "occupation", "purpose", "stage", "model_version", "city"
time_series_points - 30

All verses added or edited in the GUI will reflect in the configuration JSON file, which can be downloaded on the configurations page.
Here is how this verse will be defined in our JSON config file:

{
  "stanzas": {
    "name_of_stanza": {
      "verses": [
        {
          "type": "AverageSuddenChange",
          "metrics": [
            "credit_score",
            "offered_amount",
            "approved_amount",
            "credit_label_delta",
            "offered_approved_delta_normalized"
          ],
          "segment_by": [
            "occupation",
            "purpose",
            "stage",
            "model_version",
            "city"
          ],
          "min_anomaly_level": 2,
          "min_culprit_size": 10,
          "min_segment_size_fraction": 0.05,
          "time_series_points": 30
        }
      ]
    }
  }
}

With this verse configuration, we are overriding the default values of AverageSuddenChange (defined under "type"), and we are looking for segments from the segmentation fields (defined in "segment_by") (or any intersection of values) where the average of a metric has changed significantly in the last day, compared to the 29 days prior to it. (You can set the duration of the time series with the "time_series_points" param)

We are using "min_anomaly_level" to define that a segment is a sudden change when the difference in averages between the last day and the time series prior to it is at least the difference from the median in the benchmark period to a defined percentile, multiplied by "min_anomaly_level".

The "min_culprit_size" param will filter out segments that in the last day have less than 10 records.
Lastly, the "min_segment_size_fraction" param will filter out segments that are smaller than 5% of the data.

📘

Low thresholds

Note that we are using low thresholds such as min_anomaly_level and min_segment_size_fraction in order to get insights. After getting insights, users can raise the thresholds to get only relevant and significant insights.

Save new verse and stanza

Once all params have been defined, click on "Add verse", and then "Add stanza".

Once this is defined and saved in the config, Mona will start searching for anomalies that match these parameters. When done, new insights will be generated on the insights page.
You can configure Mona to send notifications on new insights via Email, Slack, PagerDuty, and more. We will go over this in the next chapters.

Check new insights

AverageSuddenChange insights that match these params will look like this:

This insight shows a sudden drop in the average of "credit_score" in the last day, when looking at the segment "purpose": "Home construction". The drop is from an average of 0.7 to 0.24. The anomaly level is 10.13.

When clicking on the insight card, you will open the single insight page which will show you additional information regarding this anomaly.

More information on how to read an insight can be found here


Did this page help you?