Ratiostatistieken en de deltamethode

A/B-testen in Python

Moe Lotfy, PhD

Principal Data Science Manager

A/B-testen met ratiostatistieken

  • Gemiddelde statistieken

Voorbeeld van gemiddelde statistieken: gemiddelde bestelwaarde en gemiddelde tijd op pagina

  • Analyseenheid:

    • De entiteit die je in een A/B-test analyseert
    • Noemer in ratiostatistieken
  • Randomisatie-eenheid:

    • Het subject dat willekeurig aan een variant wordt toegewezen
A/B-testen in Python

A/B-testen met ratiostatistieken

  • Ratiostatistieken per gebruiker

Voorbeeld van ratiostatistieken: doorklikratio en opbrengst per sessie

A/B-testen in Python

Motivatie voor de deltamethode

print(checkout.groupby('checkout_page')[['order_value','purchased']].agg({'sum','count','mean'}))
              order_value                     purchased              
                     mean           sum count      mean     sum count
checkout_page                                                        
A               24.956437  61417.791564  2461  0.820333  2461.0  3000
B               29.876202  75915.430125  2541  0.847000  2541.0  3000
C               34.917589  90890.484142  2603  0.867667  2603.0  3000
checkout.groupby('checkout_page')['order_value'].sum()/
checkout.groupby('checkout_page')['purchased'].count()
checkout_page
A    20.472597
B    25.305143
C    30.296828
dtype: float64
A/B-testen in Python

Variantieschatting met deltamethode

  • Variantieschatting ratiostatistieken met deltamethode:{

Variantievergelijking deltamethode

# Variantie van ratiostatistiek via deltamethode
def var_delta(x,y): 
    x_bar = np.mean(x)
    y_bar = np.mean(y)
    x_var = np.var(x,ddof=1)
    y_var = np.var(y,ddof=1)
    cov_xy = np.cov(x,y,ddof=1)[0][1]
    # Note that we divide by len(x) here because the denominator of the test statistic is standard error (=sqrt(var/n))
    var_ratio = (x_var/y_bar**2 + y_var*(x_bar**2/y_bar**4) - 2*cov_xy*(x_bar/y_bar**3))/len(x)
    return var_ratio
1 Budylin, Roman & Drutsa, Alexey & Katsev, Ilya & Tsoy, Valeriya. (2018). Consistent Transformation of Ratio Metrics for Efficient Online Controlled Experiments. 55-63. 10.1145/3159652.3159699.
A/B-testen in Python

Z-test met deltamethode

# Delta method ztest calculation 
ztest_delta(x_control,y_control,x_treatment,y_treatment, alpha = 0.05)

Invoerargumenten:

  • x_control: tellerkolom op gebruikersniveau voor controlevariant
  • y_control: noemer op gebruikersniveau voor controlevariant
  • x_treatment: tellerkolom op gebruikersniveau voor treatmentvariant
  • y_treatment: noemer op gebruikersniveau voor treatmentvariant
  • alpha: significantieniveau.

Uitvoer:

  • mean_control: gemiddelde ratiostatistiek controle
  • mean_treatment: gemiddelde ratiostatistiek treatment
  • difference: verschil tussen treatment- en controlegemiddelde
  • diff_CI: betrouwbaarheidsinterval van het verschil in gemiddelden
  • p-value: tweezijdige z-test p-waarde
1 https://medium.com/@ahmadnuraziz3/applying-delta-method-for-a-b-tests-analysis-8b1d13411c22
A/B-testen in Python

Python-voorbeeld

# Maak DataFrames met per-gebruiker-statistieken voor varianten A en B
A_per_user = pd.DataFrame({'order_value':checkout[checkout['checkout_page']=='A'].groupby('user_id')['order_value'].sum()
                            ,'page_view':checkout[checkout['checkout_page']=='A'].groupby('user_id')['user_id'].count()})
B_per_user = pd.DataFrame({'order_value':checkout[checkout['checkout_page']=='B'].groupby('user_id')['order_value'].sum()
                           ,'page_view':checkout[checkout['checkout_page']=='B'].groupby('user_id')['user_id'].count()})

# Stel de ratio-kolommen voor control en treatment in
x_control = A_per_user['order_value']
y_control = A_per_user['page_view']
x_treatment = B_per_user['order_value']
y_treatment = B_per_user['page_view']

# Voer een z-test uit voor ratiostatistieken
ztest_delta(x_control,y_control,x_treatment,y_treatment)
{'mean_control': 20.472597188012,
 'mean_treatment': 25.30514337484097,
 'difference': 4.833,
 'diff_CI': '[4.257, 5.408]',
 'p-value': 5.954978880467735e-61}
A/B-testen in Python

Laten we oefenen!

A/B-testen in Python

Preparing Video For Download...