AB Experiments (Satori)

Run AB Experiments with Satori, the LiveOps solution from HeroicLabs.

Introduction

AB Experiments are set up on the Satori Dashboard. Ensure your Satori instance is set up and you can access your game dashboard.

This document provides instructions for setting up the Example AB Test use case described below.

Satori’s terminology differs from other tools, such as Firebase. Below you can find how the corresponding pairs of Firebase terms in Satori:

Firebase vs. Satori:
———————————
Remote ConfigFeature Flag
Experiment CohortExperiment Variant

Note: Looker also uses Experiment Cohort to refer to Experiment Variant

Requirements

  1. Make sure that you have set up Remote Configuration as experiments depend on remote configurations following the guide here: Remote Configuration
  2. Design your experiment - what are your hypotheses, goals, and game levers? Please see our Experiment Best Practices.
  3. LionSDK will automatically fire theab_cohort event to LionAnalytics, allowing us to analyze the experiment results.
    1. Every experiment needs a unique name, and we need a special (unique for the experiment) feature flag that tracks which variant the player has been assigned for that experiment. LionSDK will automatically check for a feature flag with the following naming convention and use that to fire the required ab_cohort event for you.
      • exp_[EXPERIMENT NAME]" (replace [EXPERIMENT NAME] with your unique name)
    2. Ensure you have all necessary events firing in your game that you will use for analysis. See our Analytics: 1. Planning guide for more information.
  4. Follow Satori’s conceptual documentation here to understand the concept of experiments and experiment phases. If you need to change the current experiment configurations, stop the current phase, fix and start a new one.
    1. See our example below to understand better how to set up your Experiment correctly.
  5. Analyze Results - Once your experiment is complete, please see the Dashboards & Analysis section here: Dashboard & Analysis

Example Experiment (AB Test) Use Case

  1. The Product team wants to set up an experiment to optimize the level at which interstitials start showing in the game.

  2. For that purpose each experiment variant/cohort will receive a different value for the interstitialMinLevel Feature Flag (”FF”), allowing the experimenter to treat users differently by giving them different interstitialMinLevel values

  3. There will be three experiment variants: “passive”-“aggressive”-“control”.

  4. Users will be split equally into the experiment variants

    VariantAllocationinterstitialMinLevelDescription
    Passive 
    33% of players5Users will receive interstitials after level 5
    Aggressive 
    33% of players0Users will receive interstitials after level 0
    Control 
    33% of players3Users will receive interstitials after level 3
  5. The experiment will be concluded, and existing participants will be grandfathered. This means that they will continue to receive their existing treatments, while no new users will be added to the experiment.


Example Dashboard & Client Setup

  1. Create an Experiment called interstitialStart following the instructions provided here

  2. On the Satori dashboard, create a main feature flag for your experiment named exp_interstitialStart

    • The default value of the exp_interstitialStart FF should becontrol.
    • Ensure that the experiment’s name, which we will set up later in step 3 below replaces [EXPERIMENT NAME] of theexp_[EXPERIMENT NAME]
      • This feature flag is created to pass the experiment and experiment variant name to the Analytics package ab_cohort event. This FF does not need to be implemented in the game.

  3. On the Satori dashboard, now create one or more Feature Flag(s) for the variables you want to test

    1. Example
      1. Create a feature flag named interstitialMinLevel on the Satori dashboard with a default value 3

        • The default value of the exp_interstitialStart FF should becontrol.
    • Feature Flag values accept stringintegerfloat, and boolean.
      • For string, please pass the values in the following format → dummy
      • For integer, please pass the values in the following format → 0
      • For float, please pass the values in the following format → 1.5
      • For boolean, please pass the values in the following format → true |false
      • This second feature flag is created to pass the experiment and experiment variant name to the Analytics ab_cohort event. This FF does not need to be implemented in the game.
  4. Please let your developer team know that they will be using the value of the interstitialMinLevel feature flag in the client following the instructions found in Remote Configuration.

    1. Add FeatureFlags to the experiment.
      1. Users participating in the experiment will receive values from these FFs that are overridden for each experiment variant
      2. Add the FeatureFlags we created in Step 2 & 3:
        1. interstitialMinLevel: FF will be used to treat users differently by defining the different minimum levels at which interstitials will appear

        2. exp_interstitialStart: FF value be used to inform the client about the experiment variant name of the user. The LiveOps package will automatically fire the correct ab_cohort event and parameters to our backend.

  5. Create experiment variants on the Satori dashboard

    1. Go to ExperimentsVariants(aka buckets) (in the upper navigation tab)

    2. Create three variants and set the FF values for each variant as provided in the image

    3. Note that you must update the exp_[Experiment Name] FF value with the name of your Experiment Variant.

  6. Create a new phase to initiate the experiment, see here

    1. Go to ExperimentsPhasesCreate New Phase
    2. Provide configurations for the new phase
      1. The following parameters are at the PM’s discretion:
        1. Phase Name
        2. Description
        3. Start Time
        4. End Time
        5. Define the % splits
          1. Variants
            1. aggressive: 33% Split
            2. passive: 33% Split
            3. control: 34% Split
  7. End the running phase when sufficient time has passed to conclude your experiment so that new users do not join the experiment by Experiments > Phases > Halt Phase

  8. Hit the “Export Variants” button. The button will do the following to ensure that existing participants will receive the same FF variants:

    1. Create custom audiences for each experiment variant, encapsulating the participants of each variant.
    2. Define FF variants tointerstitialMinLevel Feature Flag
    3. Link each FF variant with the custom audience parallel to the treatment during the experiment.