R - rozkład normalny

W przypadku losowego zbierania danych z niezależnych źródeł, ogólnie obserwuje się, że rozkład danych jest normalny. Oznacza to, że po wykreśleniu wykresu z wartością zmiennej na osi poziomej i liczbą wartości na osi pionowej otrzymamy krzywą w kształcie dzwonu. Środek krzywej przedstawia średnią zbioru danych. Na wykresie pięćdziesiąt procent wartości znajduje się po lewej stronie średniej, a pozostałe pięćdziesiąt procent po prawej stronie wykresu. Nazywa się to rozkładem normalnym w statystykach.

R ma cztery wbudowane funkcje do generowania rozkładu normalnego. Zostały opisane poniżej.

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

Poniżej znajduje się opis parametrów używanych w powyższych funkcjach -

  • x jest wektorem liczb.

  • p jest wektorem prawdopodobieństw.

  • n to liczba obserwacji (wielkość próby).

  • meanjest średnią wartością przykładowych danych. Jego domyślna wartość to zero.

  • sdto odchylenie standardowe. Jego domyślna wartość to 1.

dnorm ()

Ta funkcja podaje wysokość rozkładu prawdopodobieństwa w każdym punkcie dla danej średniej i odchylenia standardowego.

# 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()

Kiedy wykonujemy powyższy kod, daje on następujący wynik -

pnorm ()

Ta funkcja daje prawdopodobieństwo, że liczba losowa o rozkładzie normalnym będzie mniejsza niż wartość danej liczby. Jest również nazywany „funkcją dystrybucji skumulowanej”.

# 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()

Kiedy wykonujemy powyższy kod, daje on następujący wynik -

qnorm ()

Ta funkcja przyjmuje wartość prawdopodobieństwa i podaje liczbę, której skumulowana wartość odpowiada wartości prawdopodobieństwa.

# 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()

Kiedy wykonujemy powyższy kod, daje on następujący wynik -

rnorm ()

Ta funkcja służy do generowania liczb losowych, których rozkład jest normalny. Przyjmuje rozmiar próbki jako dane wejściowe i generuje tyle liczb losowych. Rysujemy histogram, aby pokazać rozkład wygenerowanych liczb.

# 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()

Kiedy wykonujemy powyższy kod, daje on następujący wynik -