Tests d'hypothèses en Python
James Chapman
Curriculum Manager, DataCamp

Contrôle :

Traitement :

import pandas as pd
print(stack_overflow)
respondent age_1st_code ... age hobbyist
0 36.0 30.0 ... 34.0 Yes
1 47.0 10.0 ... 53.0 Yes
2 69.0 12.0 ... 25.0 Yes
3 125.0 30.0 ... 41.0 Yes
4 147.0 15.0 ... 28.0 No
... ... ... ... ... ...
2259 62867.0 13.0 ... 33.0 Yes
2260 62882.0 13.0 ... 28.0 Yes
[2261 rows x 8 columns]
Une hypothèse :
La rémunération annuelle moyenne des data scientists dans la population est de 110 000 $
L’estimateur ponctuel (statistique d’échantillon) :
mean_comp_samp = stack_overflow['converted_comp'].mean()
119574.71738168952
import numpy as np# Étape 3. Répéter les étapes 1 et 2 plusieurs fois et ajouter à une liste so_boot_distn = [] for i in range(5000): so_boot_distn.append(# Étape 2. Calculer l’estimateur ponctuel np.mean(# Étape 1. Rééchantillonner stack_overflow.sample(frac=1, replace=True)['converted_comp']))
import matplotlib.pyplot as plt
plt.hist(so_boot_distn, bins=50)
plt.show()

std_error = np.std(so_boot_distn, ddof=1)
5607.997577378606
$\text{valeur standardisée} = \dfrac{\text{valeur} - \text{moyenne}}{\text{écart-type}}$
$z = \dfrac{\text{stat. d’échantillon} - \text{valeur param. hypoth.}}{\text{erreur standard}}$
$z = \dfrac{\text{stat. d’échantillon} - \text{valeur param. hypoth.}}{\text{erreur standard}}$
stack_overflow['converted_comp'].mean()
119574.71738168952
mean_comp_hyp = 110000
std_error
5607.997577378606
z_score = (mean_comp_samp - mean_comp_hyp) / std_error
1.7073326529796957
Déterminer si les statistiques d’échantillon sont proches ou éloignées des valeurs attendues (ou « hypothétiques »)
Distribution normale standard : normale avec moyenne = 0 et écart-type = 1

Tests d'hypothèses en Python