R - Hutan Acak

Dalam pendekatan hutan acak, sejumlah besar pohon keputusan dibuat. Setiap pengamatan dimasukkan ke dalam setiap pohon keputusan. Hasil paling umum untuk setiap pengamatan digunakan sebagai keluaran akhir. Pengamatan baru dimasukkan ke semua pohon dan mengambil suara mayoritas untuk setiap model klasifikasi.

Perkiraan kesalahan dibuat untuk kasus-kasus yang tidak digunakan saat membangun pohon. Itu disebutOOB (Out-of-bag) perkiraan kesalahan yang disebutkan sebagai persentase.

Paket R. "randomForest" digunakan untuk membuat hutan acak.

Instal Paket R.

Gunakan perintah di bawah ini di konsol R untuk menginstal paket. Anda juga harus menginstal paket dependen jika ada.

install.packages("randomForest)

Paket "randomForest" memiliki fungsi randomForest() yang digunakan untuk membuat dan menganalisis hutan acak.

Sintaksis

Sintaks dasar untuk membuat hutan acak di R adalah -

randomForest(formula, data)

Berikut ini adalah deskripsi parameter yang digunakan -

  • formula adalah rumus yang menjelaskan variabel prediktor dan respons.

  • data adalah nama kumpulan data yang digunakan.

Memasukan data

Kami akan menggunakan set data built-in R bernama readingSkills untuk membuat pohon keputusan. Ini menggambarkan skor keterampilan membaca seseorang jika kita mengetahui variabel "usia", "sepatu", "skor" dan apakah orang tersebut adalah penutur asli.

Berikut adalah contoh datanya.

# Load the party package. It will automatically load other
# required packages.
library(party)

# Print some records from data set readingSkills.
print(head(readingSkills))

Ketika kami mengeksekusi kode di atas, ini menghasilkan hasil dan grafik berikut -

nativeSpeaker   age   shoeSize      score
1           yes     5   24.83189   32.29385
2           yes     6   25.95238   36.63105
3            no    11   30.42170   49.60593
4           yes     7   28.66450   40.28456
5           yes    11   31.88207   55.46085
6           yes    10   30.07843   52.83124
Loading required package: methods
Loading required package: grid
...............................
...............................

Contoh

Kami akan menggunakan randomForest() berfungsi untuk membuat pohon keputusan dan melihat grafiknya.

# Load the party package. It will automatically load other
# required packages.
library(party)
library(randomForest)

# Create the forest.
output.forest <- randomForest(nativeSpeaker ~ age + shoeSize + score, 
           data = readingSkills)

# View the forest results.
print(output.forest) 

# Importance of each predictor.
print(importance(fit,type = 2))

Ketika kita menjalankan kode di atas, hasilnya adalah sebagai berikut -

Call:
 randomForest(formula = nativeSpeaker ~ age + shoeSize + score,     
                 data = readingSkills)
               Type of random forest: classification
                     Number of trees: 500
No. of variables tried at each split: 1

        OOB estimate of  error rate: 1%
Confusion matrix:
    no yes class.error
no  99   1        0.01
yes  1  99        0.01
         MeanDecreaseGini
age              13.95406
shoeSize         18.91006
score            56.73051

Kesimpulan

Dari random forest yang ditunjukkan di atas kita dapat menyimpulkan bahwa shoesize dan score adalah faktor penting yang menentukan apakah seseorang adalah native speaker atau bukan. Juga model hanya memiliki kesalahan 1% yang berarti kita dapat memprediksi dengan akurasi 99%.