R - Distribution normale

Dans une collecte aléatoire de données provenant de sources indépendantes, on observe généralement que la distribution des données est normale. Ce qui signifie que, en traçant un graphique avec la valeur de la variable sur l'axe horizontal et le décompte des valeurs sur l'axe vertical, nous obtenons une courbe en forme de cloche. Le centre de la courbe représente la moyenne de l'ensemble de données. Dans le graphique, cinquante pour cent des valeurs se trouvent à gauche de la moyenne et les cinquante pour cent restants se trouvent à droite du graphique. C'est ce qu'on appelle la distribution normale dans les statistiques.

R a quatre fonctions intégrées pour générer une distribution normale. Ils sont décrits ci-dessous.

dnorm(x, mean, sd)
pnorm(x, mean, sd)
qnorm(p, mean, sd)
rnorm(n, mean, sd)

Voici la description des paramètres utilisés dans les fonctions ci-dessus -

  • x est un vecteur de nombres.

  • p est un vecteur de probabilités.

  • n est le nombre d'observations (taille de l'échantillon).

  • meanest la valeur moyenne des données d'échantillon. Sa valeur par défaut est zéro.

  • sdest l'écart type. Sa valeur par défaut est 1.

dnorm ()

Cette fonction donne la hauteur de la distribution de probabilité en chaque point pour une moyenne et un écart type donnés.

# Create a sequence of numbers between -10 and 10 incrementing by 0.1.
x <- seq(-10, 10, by = .1)

# Choose the mean as 2.5 and standard deviation as 0.5.
y <- dnorm(x, mean = 2.5, sd = 0.5)

# Give the chart file a name.
png(file = "dnorm.png")

plot(x,y)

# Save the file.
dev.off()

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

pnorm ()

Cette fonction donne la probabilité qu'un nombre aléatoire normalement distribué soit inférieur à la valeur d'un nombre donné. Elle est également appelée "Fonction de distribution cumulative".

# Create a sequence of numbers between -10 and 10 incrementing by 0.2.
x <- seq(-10,10,by = .2)
 
# Choose the mean as 2.5 and standard deviation as 2. 
y <- pnorm(x, mean = 2.5, sd = 2)

# Give the chart file a name.
png(file = "pnorm.png")

# Plot the graph.
plot(x,y)

# Save the file.
dev.off()

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

qnorm ()

Cette fonction prend la valeur de probabilité et donne un nombre dont la valeur cumulée correspond à la valeur de probabilité.

# Create a sequence of probability values incrementing by 0.02.
x <- seq(0, 1, by = 0.02)

# Choose the mean as 2 and standard deviation as 3.
y <- qnorm(x, mean = 2, sd = 1)

# Give the chart file a name.
png(file = "qnorm.png")

# Plot the graph.
plot(x,y)

# Save the file.
dev.off()

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

rnorm ()

Cette fonction permet de générer des nombres aléatoires dont la distribution est normale. Il prend la taille de l'échantillon comme entrée et génère autant de nombres aléatoires. Nous dessinons un histogramme pour montrer la distribution des nombres générés.

# Create a sample of 50 numbers which are normally distributed.
y <- rnorm(50)

# Give the chart file a name.
png(file = "rnorm.png")

# Plot the histogram for this sample.
hist(y, main = "Normal DIstribution")

# Save the file.
dev.off()

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