R - Test du chi carré

Chi-Square testest une méthode statistique pour déterminer si deux variables catégorielles ont une corrélation significative entre elles. Ces deux variables doivent provenir de la même population et doivent être catégoriques comme - Oui / Non, Homme / Femme, Rouge / Vert, etc.

Par exemple, nous pouvons construire un ensemble de données avec des observations sur les habitudes d'achat de crème glacée des gens et essayer de corréler le sexe d'une personne avec la saveur de la glace qu'elle préfère. Si une corrélation est trouvée, nous pouvons planifier un stock approprié de saveurs en connaissant le nombre de sexe des visiteurs.

Syntaxe

La fonction utilisée pour effectuer le test du chi carré est chisq.test().

La syntaxe de base pour créer un test du chi carré dans R est -

chisq.test(data)

Voici la description des paramètres utilisés -

  • data sont les données sous forme de tableau contenant la valeur de comptage des variables de l'observation.

Exemple

Nous prendrons les données de Cars93 dans la bibliothèque "MASS" qui représente les ventes de différents modèles de voitures en 1993.

library("MASS")
print(str(Cars93))

Lorsque nous exécutons le code ci-dessus, cela produit le résultat suivant -

'data.frame':   93 obs. of  27 variables: 
 $ Manufacturer      : Factor w/ 32 levels "Acura","Audi",..: 1 1 2 2 3 4 4 4 4 5 ... 
 $ Model             : Factor w/ 93 levels "100","190E","240",..: 49 56 9 1 6 24 54 74 73 35 ... 
 $ Type              : Factor w/ 6 levels "Compact","Large",..: 4 3 1 3 3 3 2 2 3 2 ... 
 $ Min.Price         : num  12.9 29.2 25.9 30.8 23.7 14.2 19.9 22.6 26.3 33 ... 
 $ Price             : num  15.9 33.9 29.1 37.7 30 15.7 20.8 23.7 26.3 34.7 ... 
 $ Max.Price         : num  18.8 38.7 32.3 44.6 36.2 17.3 21.7 24.9 26.3 36.3 ... 
 $ MPG.city          : int  25 18 20 19 22 22 19 16 19 16 ... 
 $ MPG.highway       : int  31 25 26 26 30 31 28 25 27 25 ... 
 $ AirBags           : Factor w/ 3 levels "Driver & Passenger",..: 3 1 2 1 2 2 2 2 2 2 ... 
 $ DriveTrain        : Factor w/ 3 levels "4WD","Front",..: 2 2 2 2 3 2 2 3 2 2 ... 
 $ Cylinders         : Factor w/ 6 levels "3","4","5","6",..: 2 4 4 4 2 2 4 4 4 5 ... 
 $ EngineSize        : num  1.8 3.2 2.8 2.8 3.5 2.2 3.8 5.7 3.8 4.9 ... 
 $ Horsepower        : int  140 200 172 172 208 110 170 180 170 200 ... 
 $ RPM               : int  6300 5500 5500 5500 5700 5200 4800 4000 4800 4100 ... 
 $ Rev.per.mile      : int  2890 2335 2280 2535 2545 2565 1570 1320 1690 1510 ... 
 $ Man.trans.avail   : Factor w/ 2 levels "No","Yes": 2 2 2 2 2 1 1 1 1 1 ... 
 $ Fuel.tank.capacity: num  13.2 18 16.9 21.1 21.1 16.4 18 23 18.8 18 ... 
 $ Passengers        : int  5 5 5 6 4 6 6 6 5 6 ... 
 $ Length            : int  177 195 180 193 186 189 200 216 198 206 ... 
 $ Wheelbase         : int  102 115 102 106 109 105 111 116 108 114 ... 
 $ Width             : int  68 71 67 70 69 69 74 78 73 73 ... 
 $ Turn.circle       : int  37 38 37 37 39 41 42 45 41 43 ... 
 $ Rear.seat.room    : num  26.5 30 28 31 27 28 30.5 30.5 26.5 35 ... 
 $ Luggage.room      : int  11 15 14 17 13 16 17 21 14 18 ... 
 $ Weight            : int  2705 3560 3375 3405 3640 2880 3470 4105 3495 3620 ... 
 $ Origin            : Factor w/ 2 levels "USA","non-USA": 2 2 2 2 2 1 1 1 1 1 ... 
 $ Make              : Factor w/ 93 levels "Acura Integra",..: 1 2 4 3 5 6 7 9 8 10 ...

Le résultat ci-dessus montre que l'ensemble de données contient de nombreuses variables Factor qui peuvent être considérées comme des variables catégorielles. Pour notre modèle, nous considérerons les variables "AirBags" et "Type". Ici, nous visons à découvrir toute corrélation significative entre les types de voitures vendues et le type de sacs gonflables dont elle dispose. Si une corrélation est observée, nous pouvons estimer quels types de voitures peuvent mieux se vendre avec quels types de sacs gonflables.

# Load the library.
library("MASS")

# Create a data frame from the main data set.
car.data <- data.frame(Cars93$AirBags, Cars93$Type)

# Create a table with the needed variables.
car.data = table(Cars93$AirBags, Cars93$Type) 
print(car.data)

# Perform the Chi-Square test.
print(chisq.test(car.data))

Lorsque nous exécutons le code ci-dessus, cela produit le résultat suivant -

Compact Large Midsize Small Sporty Van
  Driver & Passenger       2     4       7     0      3   0
  Driver only              9     7      11     5      8   3
  None                     5     0       4    16      3   6

         Pearson's Chi-squared test

data:  car.data
X-squared = 33.001, df = 10, p-value = 0.0002723

Warning message:
In chisq.test(car.data) : Chi-squared approximation may be incorrect

Conclusion

Le résultat montre la valeur p inférieure à 0,05 qui indique une corrélation de chaîne.