Mahout - Panduan Cepat
Kita hidup di zaman di mana informasi tersedia berlimpah. Kelebihan informasi telah meningkat sedemikian rupa sehingga terkadang menjadi sulit untuk mengelola kotak surat kecil kita! Bayangkan volume data dan catatan yang harus dikumpulkan dan dikelola oleh beberapa situs web populer (seperti Facebook, Twitter, dan Youtube) setiap hari. Tidak jarang bahkan situs web yang kurang dikenal menerima informasi dalam jumlah besar secara massal.
Biasanya kami menggunakan algoritma data mining untuk menganalisis data massal untuk mengidentifikasi tren dan menarik kesimpulan. Namun, tidak ada algoritme penambangan data yang cukup efisien untuk memproses kumpulan data yang sangat besar dan memberikan hasil dalam waktu cepat, kecuali jika tugas komputasi dijalankan pada beberapa mesin yang didistribusikan melalui cloud.
Kami sekarang memiliki kerangka kerja baru yang memungkinkan kami memecah tugas komputasi menjadi beberapa segmen dan menjalankan setiap segmen pada mesin yang berbeda. Mahout adalah kerangka kerja data mining yang biasanya berjalan bersama dengan infrastruktur Hadoop di latar belakangnya untuk mengelola data dalam jumlah besar.
Apa itu Apache Mahout?
Seorang mahout adalah orang yang mengendarai gajah sebagai tuannya. Nama tersebut berasal dari keterkaitannya yang erat dengan Apache Hadoop yang menggunakan gajah sebagai logonya.
Hadoop adalah kerangka kerja sumber terbuka dari Apache yang memungkinkan untuk menyimpan dan memproses data besar dalam lingkungan terdistribusi di seluruh kelompok komputer menggunakan model pemrograman sederhana.
Apache Mahoutadalah proyek sumber terbuka yang utamanya digunakan untuk membuat algoritme pembelajaran mesin yang dapat diskalakan. Ini mengimplementasikan teknik pembelajaran mesin populer seperti:
- Recommendation
- Classification
- Clustering
Apache Mahout dimulai sebagai sub-proyek dari Apache's Lucene pada tahun 2008. Pada tahun 2010, Mahout menjadi proyek tingkat atas Apache.
Fitur Mahout
Fitur primitif Apache Mahout tercantum di bawah ini.
Algoritma Mahout ditulis di atas Hadoop, sehingga berfungsi dengan baik di lingkungan terdistribusi. Mahout menggunakan pustaka Apache Hadoop untuk menskalakan secara efektif di awan.
Mahout menawarkan kepada pembuat kode kerangka kerja yang siap digunakan untuk melakukan tugas penambangan data pada volume data yang besar.
Mahout memungkinkan aplikasi menganalisis kumpulan data besar secara efektif dan dalam waktu cepat.
Termasuk beberapa implementasi pengelompokan berkemampuan MapReduce seperti k-means, fuzzy k-means, Canopy, Dirichlet, dan Mean-Shift.
Mendukung implementasi klasifikasi Distributed Naive Bayes dan Complementary Naive Bayes.
Dilengkapi dengan kemampuan fungsi kebugaran terdistribusi untuk pemrograman evolusioner.
Termasuk perpustakaan matriks dan vektor.
Aplikasi Mahout
Perusahaan seperti Adobe, Facebook, LinkedIn, Foursquare, Twitter, dan Yahoo menggunakan Mahout secara internal.
Foursquare membantu Anda mengetahui tempat, makanan, dan hiburan yang tersedia di area tertentu. Ini menggunakan mesin pemberi rekomendasi Mahout.
Twitter menggunakan Mahout untuk pemodelan minat pengguna.
Yahoo! menggunakan Mahout untuk penambangan pola.
Apache Mahout adalah pustaka pembelajaran mesin yang sangat skalabel yang memungkinkan pengembang menggunakan algoritme yang dioptimalkan. Mahout menerapkan teknik pembelajaran mesin yang populer seperti rekomendasi, klasifikasi, dan pengelompokan. Oleh karena itu, sebaiknya Anda memiliki bagian singkat tentang pembelajaran mesin sebelum melangkah lebih jauh.
Apa itu Pembelajaran Mesin?
Pembelajaran mesin adalah cabang ilmu yang berhubungan dengan pemrograman sistem sedemikian rupa sehingga mereka secara otomatis belajar dan meningkat dengan pengalaman. Di sini, belajar berarti mengenali dan memahami data yang diinput dan mengambil keputusan yang bijak berdasarkan data yang disediakan.
Sangat sulit untuk memenuhi semua keputusan berdasarkan semua masukan yang mungkin. Untuk mengatasi masalah ini, algoritma dikembangkan. Algoritma ini membangun pengetahuan dari data spesifik dan pengalaman masa lalu dengan prinsip statistik, teori probabilitas, logika, optimasi kombinatorial, pencarian, pembelajaran penguatan, dan teori kontrol.
Algoritma yang dikembangkan menjadi dasar dari berbagai aplikasi seperti:
- Pemrosesan visi
- Pemrosesan bahasa
- Peramalan (mis., Tren pasar saham)
- Pengenalan pola
- Games
- Penambangan data
- Sistem pakar
- Robotics
Pembelajaran mesin adalah area yang luas dan cukup di luar cakupan tutorial ini untuk mencakup semua fiturnya. Ada beberapa cara untuk menerapkan teknik pembelajaran mesin, namun yang paling umum digunakan adalahsupervised dan unsupervised learning.
Pembelajaran yang Diawasi
Pembelajaran yang diawasi berkaitan dengan mempelajari suatu fungsi dari data pelatihan yang tersedia. Algoritme pembelajaran yang diawasi menganalisis data pelatihan dan menghasilkan fungsi yang disimpulkan, yang dapat digunakan untuk memetakan contoh baru. Contoh umum dari supervised learning meliputi:
- mengklasifikasikan email sebagai spam,
- memberi label laman web berdasarkan kontennya, dan
- pengenalan suara.
Ada banyak algoritme pembelajaran yang diawasi seperti jaringan saraf, Support Vector Machines (SVM), dan pengklasifikasi Naive Bayes. Mahout mengimplementasikan pengklasifikasi Naive Bayes.
Pembelajaran Tanpa Pengawasan
Pembelajaran tanpa pengawasan memahami data yang tidak berlabel tanpa memiliki set data yang telah ditentukan sebelumnya untuk pelatihannya. Pembelajaran tanpa pengawasan adalah alat yang sangat ampuh untuk menganalisis data yang tersedia dan mencari pola dan tren. Ini paling sering digunakan untuk mengelompokkan input serupa ke dalam grup logis. Pendekatan umum untuk pembelajaran tanpa pengawasan meliputi:
- k-means
- peta swakelola, dan
- pengelompokan hierarki
Rekomendasi
Rekomendasi adalah teknik populer yang memberikan rekomendasi dekat berdasarkan informasi pengguna seperti pembelian, klik, dan peringkat sebelumnya.
Amazon menggunakan teknik ini untuk menampilkan daftar item yang direkomendasikan yang mungkin Anda minati, mengambil informasi dari tindakan Anda sebelumnya. Ada mesin pemberi rekomendasi yang bekerja di belakang Amazon untuk menangkap perilaku pengguna dan merekomendasikan item yang dipilih berdasarkan tindakan Anda sebelumnya.
Facebook menggunakan teknik pemberi rekomendasi untuk mengidentifikasi dan merekomendasikan "daftar orang yang mungkin Anda kenal".
Klasifikasi
Klasifikasi, juga dikenal sebagai categorization, adalah teknik pembelajaran mesin yang menggunakan data yang diketahui untuk menentukan bagaimana data baru harus diklasifikasikan ke dalam sekumpulan kategori yang ada. Klasifikasi adalah bentuk pembelajaran yang diawasi.
Penyedia layanan surat seperti Yahoo! dan Gmail menggunakan teknik ini untuk memutuskan apakah email baru harus diklasifikasikan sebagai spam. Algoritme kategorisasi melatih dirinya sendiri dengan menganalisis kebiasaan pengguna dalam menandai email tertentu sebagai spam. Berdasarkan itu, pengklasifikasi memutuskan apakah email di masa mendatang harus disimpan di kotak masuk Anda atau di folder spam.
Aplikasi iTunes menggunakan klasifikasi untuk menyiapkan playlist.
Kekelompokan
Clustering digunakan untuk membentuk kelompok atau cluster dari data yang serupa berdasarkan karakteristik yang sama. Clustering adalah salah satu bentuk pembelajaran tanpa pengawasan.
Mesin pencari seperti Google dan Yahoo! menggunakan teknik clustering untuk mengelompokkan data dengan karakteristik yang serupa.
Newsgroup menggunakan teknik pengelompokan untuk mengelompokkan berbagai artikel berdasarkan topik terkait.
Mesin pengelompokan melewati data masukan secara lengkap dan berdasarkan karakteristik data, ia akan memutuskan di kluster mana ia harus dikelompokkan. Lihat contoh berikut.
Perpustakaan tutorial kami berisi topik tentang berbagai subjek. Saat kami menerima tutorial baru di TutorialsPoint, itu diproses oleh mesin pengelompokan yang memutuskan, berdasarkan kontennya, di mana ia harus dikelompokkan.
Bab ini mengajarkan Anda cara mengatur mahout. Java dan Hadoop adalah prasyarat mahout. Di bawah ini diberikan langkah-langkah untuk mengunduh dan menginstal Java, Hadoop, dan Mahout.
Pengaturan Pra-Instalasi
Sebelum menginstal Hadoop ke lingkungan Linux, kita perlu mengatur Linux menggunakan ssh(Secure Shell). Ikuti langkah-langkah yang disebutkan di bawah ini untuk menyiapkan lingkungan Linux.
Membuat Pengguna
Direkomendasikan untuk membuat pengguna terpisah untuk Hadoop guna mengisolasi sistem file Hadoop dari sistem file Unix. Ikuti langkah-langkah yang diberikan di bawah ini untuk membuat pengguna:
Buka root menggunakan perintah "su".
- Buat pengguna dari akun root menggunakan perintah “useradd username”.
Sekarang Anda dapat membuka akun pengguna yang ada menggunakan perintah “su username”.
Buka terminal Linux dan ketik perintah berikut untuk membuat pengguna.
$ su
password:
# useradd hadoop
# passwd hadoop
New passwd:
Retype new passwd
Penyiapan SSH dan Pembuatan Kunci
Penyiapan SSH diperlukan untuk melakukan operasi yang berbeda pada cluster seperti memulai, menghentikan, dan mendistribusikan operasi shell daemon. Untuk mengautentikasi pengguna Hadoop yang berbeda, diperlukan pasangan kunci publik / pribadi untuk pengguna Hadoop dan membagikannya dengan pengguna yang berbeda.
Perintah berikut digunakan untuk membuat pasangan nilai kunci menggunakan SSH, salin formulir kunci publik id_rsa.pub ke authorized_keys, dan berikan izin pemilik, baca dan tulis ke file authorized_keys.
$ ssh-keygen -t rsa
$ cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
$ chmod 0600 ~/.ssh/authorized_keys
Memverifikasi ssh
ssh localhost
Menginstal Java
Jawa adalah prasyarat utama Hadoop dan HBase. Pertama-tama, Anda harus memverifikasi keberadaan Java di sistem Anda menggunakan "java -version". Sintaks perintah versi Java diberikan di bawah ini.
$ java -version
Ini harus menghasilkan keluaran sebagai berikut.
java version "1.7.0_71"
Java(TM) SE Runtime Environment (build 1.7.0_71-b13)
Java HotSpot(TM) Client VM (build 25.0-b02, mixed mode)
Jika Anda belum menginstal Java di sistem Anda, ikuti langkah-langkah yang diberikan di bawah ini untuk menginstal Java.
Step 1
Unduh java (JDK <latest version> - X64.tar.gz) dengan mengunjungi tautan berikut: Oracle
Kemudian jdk-7u71-linux-x64.tar.gz is downloaded ke sistem Anda.
Step 2
Umumnya, Anda menemukan file Java yang diunduh di folder Unduhan. Verifikasi dan ekstrak filejdk-7u71-linux-x64.gz file menggunakan perintah berikut.
$ cd Downloads/
$ ls
jdk-7u71-linux-x64.gz
$ tar zxf jdk-7u71-linux-x64.gz
$ ls
jdk1.7.0_71 jdk-7u71-linux-x64.gz
Step 3
Agar Java tersedia untuk semua pengguna, Anda perlu memindahkannya ke lokasi "/ usr / local /". Buka root, dan ketik perintah berikut.
$ su
password:
# mv jdk1.7.0_71 /usr/local/
# exit
Step 4
Untuk menyiapkan PATH dan JAVA_HOME variabel, tambahkan perintah berikut ke ~/.bashrc file.
export JAVA_HOME=/usr/local/jdk1.7.0_71
export PATH= $PATH:$JAVA_HOME/bin
Sekarang, verifikasi java -version perintah dari terminal seperti dijelaskan di atas.
Mendownload Hadoop
Setelah menginstal Java, Anda perlu menginstal Hadoop terlebih dahulu. Verifikasi keberadaan Hadoop menggunakan perintah “Versi Hadoop” seperti yang ditunjukkan di bawah ini.
hadoop version
Ini harus menghasilkan keluaran berikut:
Hadoop 2.6.0
Compiled by jenkins on 2014-11-13T21:10Z
Compiled with protoc 2.5.0
From source with checksum 18e43357c8f927c0695f1e9522859d6a
This command was run using /home/hadoop/hadoop/share/hadoop/common/hadoopcommon-2.6.0.jar
Jika sistem Anda tidak dapat menemukan Hadoop, unduh Hadoop dan instal di sistem Anda. Ikuti perintah yang diberikan di bawah ini untuk melakukannya.
Unduh dan ekstrak hadoop-2.6.0 dari fondasi perangkat lunak apache menggunakan perintah berikut.
$ su
password:
# cd /usr/local
# wget http://mirrors.advancedhosters.com/apache/hadoop/common/hadoop-
2.6.0/hadoop-2.6.0-src.tar.gz
# tar xzf hadoop-2.6.0-src.tar.gz
# mv hadoop-2.6.0/* hadoop/
# exit
Memasang Hadoop
Instal Hadoop di salah satu mode yang diperlukan. Di sini, kami mendemonstrasikan fungsionalitas HBase dalam mode pseudo-didistribusikan, oleh karena itu instal Hadoop dalam mode pseudo-didistribusikan.
Ikuti langkah-langkah yang diberikan di bawah ini untuk menginstal Hadoop 2.4.1 di sistem Anda.
Langkah 1: Menyiapkan Hadoop
Anda dapat menyetel variabel lingkungan Hadoop dengan menambahkan perintah berikut ke ~/.bashrc mengajukan.
export HADOOP_HOME=/usr/local/hadoop
export HADOOP_MAPRED_HOME=$HADOOP_HOME
export HADOOP_COMMON_HOME=$HADOOP_HOME
export HADOOP_HDFS_HOME=$HADOOP_HOME
export YARN_HOME=$HADOOP_HOME
export HADOOP_COMMON_LIB_NATIVE_DIR=$HADOOP_HOME/lib/native
export PATH=$PATH:$HADOOP_HOME/sbin:$HADOOP_HOME/bin
export HADOOP_INSTALL=$HADOOP_HOME
Sekarang, terapkan semua perubahan ke dalam sistem yang sedang berjalan.
$ source ~/.bashrc
Langkah 2: Konfigurasi Hadoop
Anda dapat menemukan semua file konfigurasi Hadoop di lokasi "$ HADOOP_HOME / etc / hadoop". Diperlukan untuk membuat perubahan pada file konfigurasi tersebut sesuai dengan infrastruktur Hadoop Anda.
$ cd $HADOOP_HOME/etc/hadoop
Untuk mengembangkan program Hadoop di Java, Anda perlu mengatur ulang variabel lingkungan Java di hadoop-env.sh mengajukan dengan mengganti JAVA_HOME nilai dengan lokasi Java di sistem Anda.
export JAVA_HOME=/usr/local/jdk1.7.0_71
Diberikan di bawah ini adalah daftar file yang harus Anda edit untuk mengkonfigurasi Hadoop.
core-site.xml
Itu core-site.xml file berisi informasi seperti nomor port yang digunakan untuk instance Hadoop, memori yang dialokasikan untuk sistem file, batas memori untuk menyimpan data, dan ukuran buffer Baca / Tulis.
Buka core-site.xml dan tambahkan properti berikut di antara tag <configuration>, </configuration>:
<configuration>
<property>
<name>fs.default.name</name>
<value>hdfs://localhost:9000</value>
</property>
</configuration>
hdfs-site.xm
Itu hdfs-site.xmlfile berisi informasi seperti nilai data replikasi, jalur kode nama, dan jalur datanode sistem file lokal Anda. Artinya tempat di mana Anda ingin menyimpan infrastruktur Hadoop.
Mari kita asumsikan data berikut:
dfs.replication (data replication value) = 1
(In the below given path /hadoop/ is the user name.
hadoopinfra/hdfs/namenode is the directory created by hdfs file system.)
namenode path = //home/hadoop/hadoopinfra/hdfs/namenode
(hadoopinfra/hdfs/datanode is the directory created by hdfs file system.)
datanode path = //home/hadoop/hadoopinfra/hdfs/datanode
Buka file ini dan tambahkan properti berikut di antara tag <configuration>, </configuration> di file ini.
<configuration>
<property>
<name>dfs.replication</name>
<value>1</value>
</property>
<property>
<name>dfs.name.dir</name>
<value>file:///home/hadoop/hadoopinfra/hdfs/namenode</value>
</property>
<property>
<name>dfs.data.dir</name>
<value>file:///home/hadoop/hadoopinfra/hdfs/datanode</value>
</property>
</configuration>
Note:Dalam file di atas, semua nilai properti ditentukan oleh pengguna. Anda dapat membuat perubahan sesuai dengan infrastruktur Hadoop Anda.
mapred-site.xml
File ini digunakan untuk mengkonfigurasi benang menjadi Hadoop. Buka file mapred-site.xml dan tambahkan properti berikut di antara tag <configuration>, </configuration> di file ini.
<configuration>
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle</value>
</property>
</configuration>
mapred-site.xml
File ini digunakan untuk menentukan kerangka MapReduce mana yang kita gunakan. Secara default, Hadoop berisi template mapred-site.xml. Pertama-tama, Anda harus menyalin file darimapred-site.xml.template untuk mapred-site.xml file menggunakan perintah berikut.
$ cp mapred-site.xml.template mapred-site.xml
Buka mapred-site.xml file dan tambahkan properti berikut di antara tag <configuration>, </configuration> di file ini.
<configuration>
<property>
<name>mapreduce.framework.name</name>
<value>yarn</value>
</property>
</configuration>
Memverifikasi Instalasi Hadoop
Langkah-langkah berikut digunakan untuk memverifikasi penginstalan Hadoop.
Langkah 1: Penyiapan Node Nama
Siapkan namenode menggunakan perintah “hdfs namenode -format” sebagai berikut:
$ cd ~
$ hdfs namenode -format
Hasil yang diharapkan adalah sebagai berikut:
10/24/14 21:30:55 INFO namenode.NameNode: STARTUP_MSG:
/************************************************************
STARTUP_MSG: Starting NameNode
STARTUP_MSG: host = localhost/192.168.1.11
STARTUP_MSG: args = [-format]
STARTUP_MSG: version = 2.4.1
...
...
10/24/14 21:30:56 INFO common.Storage: Storage directory
/home/hadoop/hadoopinfra/hdfs/namenode has been successfully formatted.
10/24/14 21:30:56 INFO namenode.NNStorageRetentionManager: Going to retain
1 images with txid >= 0
10/24/14 21:30:56 INFO util.ExitUtil: Exiting with status 0
10/24/14 21:30:56 INFO namenode.NameNode: SHUTDOWN_MSG:
/************************************************************
SHUTDOWN_MSG: Shutting down NameNode at localhost/192.168.1.11
************************************************************/
Langkah 2: Memverifikasi Hadoop dfs
Perintah berikut digunakan untuk memulai dfs. Perintah ini memulai sistem file Hadoop Anda.
$ start-dfs.sh
Output yang diharapkan adalah sebagai berikut:
10/24/14 21:37:56
Starting namenodes on [localhost]
localhost: starting namenode, logging to /home/hadoop/hadoop-
2.4.1/logs/hadoop-hadoop-namenode-localhost.out
localhost: starting datanode, logging to /home/hadoop/hadoop-
2.4.1/logs/hadoop-hadoop-datanode-localhost.out
Starting secondary namenodes [0.0.0.0]
Langkah 3: Memverifikasi Skrip Benang
Perintah berikut digunakan untuk memulai skrip benang. Melaksanakan perintah ini akan memulai setan benang Anda.
$ start-yarn.sh
Output yang diharapkan adalah sebagai berikut:
starting yarn daemons
starting resource manager, logging to /home/hadoop/hadoop-2.4.1/logs/yarn-
hadoop-resourcemanager-localhost.out
localhost: starting node manager, logging to /home/hadoop/hadoop-
2.4.1/logs/yarn-hadoop-nodemanager-localhost.out
Langkah 4: Mengakses Hadoop di Browser
Nomor port default untuk mengakses hadoop adalah 50070. Gunakan URL berikut untuk mendapatkan layanan Hadoop di browser Anda.
http://localhost:50070/
Langkah 5: Verifikasi Semua Aplikasi untuk Cluster
Nomor port default untuk mengakses semua aplikasi cluster adalah 8088. Gunakan URL berikut untuk mengunjungi layanan ini.
http://localhost:8088/
Mengunduh Mahout
Mahout tersedia di situs web Mahout . Unduh Mahout dari tautan yang disediakan di situs web. Berikut adalah tangkapan layar dari situs web tersebut.
Langkah 1
Unduh Apache mahout dari tautan http://mirror.nexcess.net/apache/mahout/ menggunakan perintah berikut.
[Hadoop@localhost ~]$ wget
http://mirror.nexcess.net/apache/mahout/0.9/mahout-distribution-0.9.tar.gz
Kemudian mahout-distribution-0.9.tar.gz akan diunduh ke sistem Anda.
Langkah 2
Jelajahi folder tempat mahout-distribution-0.9.tar.gz disimpan dan ekstrak file jar yang diunduh seperti yang ditunjukkan di bawah ini.
[Hadoop@localhost ~]$ tar zxvf mahout-distribution-0.9.tar.gz
Repositori Maven
Diberikan di bawah ini adalah pom.xml untuk membangun Apache Mahout menggunakan Eclipse.
<dependency>
<groupId>org.apache.mahout</groupId>
<artifactId>mahout-core</artifactId>
<version>0.9</version>
</dependency>
<dependency>
<groupId>org.apache.mahout</groupId>
<artifactId>mahout-math</artifactId>
<version>${mahout.version}</version>
</dependency>
<dependency>
<groupId>org.apache.mahout</groupId>
<artifactId>mahout-integration</artifactId>
<version>${mahout.version}</version>
</dependency>
Bab ini membahas teknik pembelajaran mesin populer yang disebut recommendation, mekanismenya, dan cara menulis aplikasi yang mengimplementasikan rekomendasi Mahout.
Rekomendasi
Pernah bertanya-tanya bagaimana Amazon membuat daftar item yang direkomendasikan untuk menarik perhatian Anda ke produk tertentu yang mungkin Anda minati!
Misalkan Anda ingin membeli buku "Mahout in Action" dari Amazon:
Bersamaan dengan produk yang dipilih, Amazon juga menampilkan daftar item yang direkomendasikan terkait, seperti yang ditunjukkan di bawah ini.
Daftar rekomendasi semacam itu dibuat dengan bantuan recommender engines. Mahout menyediakan beberapa jenis mesin rekomender seperti:
- pemberi rekomendasi berbasis pengguna,
- rekomendasi berbasis item, dan
- beberapa algoritma lainnya.
Mesin Rekomendasi Mahout
Mahout memiliki mesin pemberi rekomendasi yang tidak terdistribusi dan tidak berbasis Hadoop. Anda harus memberikan dokumen teks yang memiliki preferensi pengguna untuk item. Dan output dari mesin ini adalah perkiraan preferensi pengguna tertentu untuk item lain.
Contoh
Pertimbangkan situs web yang menjual barang-barang konsumen seperti ponsel, gadget, dan aksesorinya. Jika kita ingin mengimplementasikan fitur Mahout di situs seperti itu, maka kita bisa membangun mesin rekomender. Mesin ini menganalisis data pembelian sebelumnya dari pengguna dan merekomendasikan produk baru berdasarkan itu.
Komponen-komponen yang disediakan Mahout untuk membangun mesin rekomender adalah sebagai berikut:
- DataModel
- UserSimilarity
- ItemSimilarity
- UserNeighborhood
- Recommender
Dari penyimpanan data, model data disiapkan dan diteruskan sebagai masukan ke mesin pemberi rekomendasi. Mesin Recommender menghasilkan rekomendasi untuk pengguna tertentu. Diberikan di bawah ini adalah arsitektur mesin pemberi rekomendasi.
Arsitektur Mesin Rekomendasi
Membangun Recommender menggunakan Mahout
Berikut langkah-langkah untuk mengembangkan pemberi rekomendasi sederhana:
Langkah 1: Buat Objek DataModel
Konstruktor PearsonCorrelationSimilarityclass memerlukan objek model data, yang menyimpan file yang berisi detail Pengguna, Item, dan Preferensi dari suatu produk. Berikut ini contoh file model data:
1,00,1.0
1,01,2.0
1,02,5.0
1,03,5.0
1,04,5.0
2,00,1.0
2,01,2.0
2,05,5.0
2,06,4.5
2,02,5.0
3,01,2.5
3,02,5.0
3,03,4.0
3,04,3.0
4,00,5.0
4,01,5.0
4,02,5.0
4,03,0.0
Itu DataModelobjek membutuhkan objek file, yang berisi jalur dari file input. BuatDataModel objek seperti yang ditunjukkan di bawah ini.
DataModel datamodel = new FileDataModel(new File("input file"));
Langkah2: Buat Objek UserSimilarity
Membuat UserSimilarity objek menggunakan PearsonCorrelationSimilarity kelas seperti yang ditunjukkan di bawah ini:
UserSimilarity similarity = new PearsonCorrelationSimilarity(datamodel);
Langkah3: Buat objek UserNe Neighbor
Objek ini menghitung "lingkungan" pengguna seperti pengguna tertentu. Ada dua jenis lingkungan:
NearestNUserNeighborhood- Kelas ini menghitung lingkungan yang terdiri dari n pengguna terdekat ke pengguna tertentu. "Terdekat" ditentukan oleh UserSimilarity yang diberikan.
ThresholdUserNeighborhood- Kelas ini menghitung lingkungan yang terdiri dari semua pengguna yang kesamaannya dengan pengguna tertentu memenuhi atau melebihi ambang batas tertentu. Kesamaan ditentukan oleh UserSimilarity yang diberikan.
Di sini kami menggunakan ThresholdUserNeighborhood dan setel batas preferensi ke 3.0.
UserNeighborhood neighborhood = new ThresholdUserNeighborhood(3.0, similarity, model);
Step4: Buat Objek Pemberi Rekomendasi
Membuat UserbasedRecomenderobyek. Meneruskan semua objek yang dibuat di atas ke konstruktornya seperti yang ditunjukkan di bawah ini.
UserBasedRecommender recommender = new GenericUserBasedRecommender(model, neighborhood, similarity);
Step5: Merekomendasikan Item ke Pengguna
Merekomendasikan produk kepada pengguna menggunakan metode recommend () dari Recommenderantarmuka. Metode ini membutuhkan dua parameter. Yang pertama mewakili id pengguna dari pengguna yang perlu kami kirimi rekomendasi, dan yang kedua mewakili jumlah rekomendasi yang akan dikirim. Berikut adalah penggunaanrecommender() metode:
List<RecommendedItem> recommendations = recommender.recommend(2, 3);
for (RecommendedItem recommendation : recommendations) {
System.out.println(recommendation);
}
Example Program
Diberikan di bawah ini adalah contoh program untuk mengatur rekomendasi. Siapkan rekomendasi untuk pengguna dengan id pengguna 2.
import java.io.File;
import java.util.List;
import org.apache.mahout.cf.taste.impl.model.file.FileDataModel;
import org.apache.mahout.cf.taste.impl.neighborhood.ThresholdUserNeighborhood;
import org.apache.mahout.cf.taste.impl.recommender.GenericUserBasedRecommender;
import org.apache.mahout.cf.taste.impl.similarity.PearsonCorrelationSimilarity;
import org.apache.mahout.cf.taste.model.DataModel;
import org.apache.mahout.cf.taste.neighborhood.UserNeighborhood;
import org.apache.mahout.cf.taste.recommender.RecommendedItem;
import org.apache.mahout.cf.taste.recommender.UserBasedRecommender;
import org.apache.mahout.cf.taste.similarity.UserSimilarity;
public class Recommender {
public static void main(String args[]){
try{
//Creating data model
DataModel datamodel = new FileDataModel(new File("data")); //data
//Creating UserSimilarity object.
UserSimilarity usersimilarity = new PearsonCorrelationSimilarity(datamodel);
//Creating UserNeighbourHHood object.
UserNeighborhood userneighborhood = new ThresholdUserNeighborhood(3.0, usersimilarity, datamodel);
//Create UserRecomender
UserBasedRecommender recommender = new GenericUserBasedRecommender(datamodel, userneighborhood, usersimilarity);
List<RecommendedItem> recommendations = recommender.recommend(2, 3);
for (RecommendedItem recommendation : recommendations) {
System.out.println(recommendation);
}
}catch(Exception e){}
}
}
Kompilasi program menggunakan perintah berikut:
javac Recommender.java
java Recommender
Ini harus menghasilkan keluaran berikut:
RecommendedItem [item:3, value:4.5]
RecommendedItem [item:4, value:4.0]
Clustering adalah prosedur untuk mengatur elemen atau item dari suatu koleksi ke dalam kelompok berdasarkan kesamaan antar item. Misalnya, aplikasi yang terkait dengan penerbitan berita online mengelompokkan artikel beritanya menggunakan clustering.
Aplikasi Clustering
Clustering secara luas digunakan di banyak aplikasi seperti riset pasar, pengenalan pola, analisis data, dan pemrosesan gambar.
Pengelompokan dapat membantu pemasar menemukan grup yang berbeda dalam basis pelanggan mereka. Dan mereka dapat mengkarakterisasi kelompok pelanggan mereka berdasarkan pola pembelian.
Di bidang biologi, ini dapat digunakan untuk memperoleh taksonomi tumbuhan dan hewan, mengkategorikan gen dengan fungsi serupa dan mendapatkan wawasan tentang struktur yang melekat dalam populasi.
Pengelompokan membantu dalam mengidentifikasi area penggunaan lahan serupa dalam database observasi bumi.
Pengelompokan juga membantu dalam mengklasifikasikan dokumen di web untuk penemuan informasi.
Clustering digunakan dalam aplikasi deteksi outlier seperti deteksi penipuan kartu kredit.
Sebagai fungsi data mining, Cluster Analysis berfungsi sebagai alat untuk mendapatkan wawasan tentang distribusi data untuk mengamati karakteristik setiap cluster.
Menggunakan Mahout, kita dapat mengelompokkan sekumpulan data tertentu. Langkah-langkah yang diperlukan adalah sebagai berikut:
Algorithm Anda perlu memilih algoritme pengelompokan yang sesuai untuk mengelompokkan elemen kluster.
Similarity and Dissimilarity Anda perlu memiliki aturan untuk memverifikasi kesamaan antara elemen yang baru ditemukan dan elemen dalam grup.
Stopping Condition Kondisi penghentian diperlukan untuk menentukan titik di mana tidak diperlukan pengelompokan.
Prosedur Pengelompokan
Untuk mengelompokkan data yang diberikan, Anda perlu -
Mulai server Hadoop. Buat direktori yang diperlukan untuk menyimpan file di Sistem File Hadoop. (Buat direktori untuk file input, file urutan, dan output berkerumun jika ada kanopi).
Salin file input ke sistem File Hadoop dari sistem file Unix.
Siapkan file sequence dari input data.
Jalankan salah satu algoritme pengelompokan yang tersedia.
Dapatkan data berkerumun.
Memulai Hadoop
Mahout bekerja dengan Hadoop, oleh karena itu pastikan server Hadoop aktif dan berjalan.
$ cd HADOOP_HOME/bin
$ start-all.sh
Mempersiapkan Direktori File Input
Buat direktori di sistem file Hadoop untuk menyimpan file input, file urutan, dan data berkerumun menggunakan perintah berikut:
$ hadoop fs -p mkdir /mahout_data
$ hadoop fs -p mkdir /clustered_data
$ hadoop fs -p mkdir /mahout_seq
Anda dapat memverifikasi apakah direktori dibuat menggunakan antarmuka web hadoop di URL berikut - http://localhost:50070/
Ini memberi Anda output seperti yang ditunjukkan di bawah ini:
Menyalin File Input ke HDFS
Sekarang, salin file data masukan dari sistem file Linux ke direktori mahout_data di Sistem File Hadoop seperti yang ditunjukkan di bawah ini. Asumsikan file input Anda adalah mydata.txt dan itu ada di direktori / home / Hadoop / data /.
$ hadoop fs -put /home/Hadoop/data/mydata.txt /mahout_data/
Mempersiapkan File Urutan
Mahout memberi Anda utilitas untuk mengubah file input yang diberikan menjadi format file urutan. Utilitas ini membutuhkan dua parameter.
- Direktori file masukan tempat data asli berada.
- Direktori file keluaran tempat penyimpanan data berkerumun.
Diberikan di bawah ini adalah prompt bantuan mahout seqdirectory utilitas.
Step 1:Jelajahi direktori utama Mahout. Anda bisa mendapatkan bantuan utilitas seperti yang ditunjukkan di bawah ini:
[Hadoop@localhost bin]$ ./mahout seqdirectory --help
Job-Specific Options:
--input (-i) input Path to job input directory.
--output (-o) output The directory pathname for output.
--overwrite (-ow) If present, overwrite the output directory
Buat file urutan menggunakan utilitas menggunakan sintaks berikut:
mahout seqdirectory -i <input file path> -o <output directory>
Example
mahout seqdirectory
-i hdfs://localhost:9000/mahout_seq/
-o hdfs://localhost:9000/clustered_data/
Algoritma Pengelompokan
Mahout mendukung dua algoritma utama untuk pengelompokan yaitu:
- Pengelompokan kanopi
- Pengelompokan K-means
Pengelompokan Kanopi
Pengelompokan kanopi adalah teknik sederhana dan cepat yang digunakan oleh Mahout untuk tujuan pengelompokan. Objek akan diperlakukan sebagai titik di ruang biasa. Teknik ini sering digunakan sebagai langkah awal pada teknik clustering lain seperti k-means clustering. Anda dapat menjalankan pekerjaan Canopy menggunakan sintaks berikut:
mahout canopy -i <input vectors directory>
-o <output directory>
-t1 <threshold value 1>
-t2 <threshold value 2>
Pekerjaan kanopi membutuhkan direktori file masukan dengan file urutan dan direktori keluaran tempat penyimpanan data berkerumun.
Example
mahout canopy -i hdfs://localhost:9000/mahout_seq/mydata.seq
-o hdfs://localhost:9000/clustered_data
-t1 20
-t2 30
Anda akan mendapatkan data berkerumun yang dihasilkan di direktori keluaran yang diberikan.
Pengelompokan K-means
Pengelompokan K-means adalah algoritme pengelompokan yang penting. K dalam algoritme pengelompokan k-means mewakili jumlah kluster tempat data akan dibagi. Misalnya, nilai k yang ditentukan untuk algoritme ini dipilih sebagai 3, algoritme akan membagi data menjadi 3 cluster.
Setiap objek akan direpresentasikan sebagai vektor di ruang angkasa. Awalnya k poin akan dipilih oleh algoritma secara acak dan diperlakukan sebagai pusat, setiap objek yang paling dekat dengan setiap pusat dikelompokkan. Ada beberapa algoritma untuk pengukuran jarak dan pengguna harus memilih salah satu yang diperlukan.
Creating Vector Files
Berbeda dengan algoritma Canopy, algoritma k-means membutuhkan file vektor sebagai input, oleh karena itu Anda harus membuat file vektor.
Untuk menghasilkan file vektor dari format file sequence, Mahout menyediakan seq2parse utilitas.
Diberikan di bawah ini adalah beberapa opsi seq2parseutilitas. Buat file vektor menggunakan opsi ini.
$MAHOUT_HOME/bin/mahout seq2sparse
--analyzerName (-a) analyzerName The class name of the analyzer
--chunkSize (-chunk) chunkSize The chunkSize in MegaBytes.
--output (-o) output The directory pathname for o/p
--input (-i) input Path to job input directory.
Setelah membuat vektor, lanjutkan dengan algoritma k-means. Sintaks untuk menjalankan pekerjaan k-means adalah sebagai berikut:
mahout kmeans -i <input vectors directory>
-c <input clusters directory>
-o <output working directory>
-dm <Distance Measure technique>
-x <maximum number of iterations>
-k <number of initial clusters>
Pekerjaan clustering K-means membutuhkan direktori vektor input, direktori cluster output, pengukuran jarak, jumlah iterasi maksimum yang akan dilakukan, dan nilai integer yang mewakili jumlah cluster tempat data input akan dibagi.
Apa itu Klasifikasi?
Klasifikasi adalah teknik pembelajaran mesin yang menggunakan data yang diketahui untuk menentukan bagaimana data baru harus diklasifikasikan ke dalam sekumpulan kategori yang ada. Sebagai contoh,
Aplikasi iTunes menggunakan klasifikasi untuk menyiapkan playlist.
Penyedia layanan surat seperti Yahoo! dan Gmail menggunakan teknik ini untuk memutuskan apakah email baru harus diklasifikasikan sebagai spam. Algoritme kategorisasi melatih dirinya sendiri dengan menganalisis kebiasaan pengguna dalam menandai email tertentu sebagai spam. Berdasarkan itu, pengklasifikasi memutuskan apakah email di masa mendatang harus disimpan di kotak masuk Anda atau di folder spam.
Bagaimana Klasifikasi Bekerja
Saat mengklasifikasikan kumpulan data tertentu, sistem pengklasifikasi melakukan tindakan berikut:
- Awalnya model data baru disiapkan menggunakan salah satu algoritma pembelajaran.
- Kemudian model data yang telah disiapkan diuji.
- Selanjutnya model data ini digunakan untuk mengevaluasi data baru dan menentukan kelasnya.
Aplikasi Klasifikasi
Credit card fraud detection- Mekanisme Klasifikasi digunakan untuk memprediksi penipuan kartu kredit. Dengan menggunakan informasi historis dari penipuan sebelumnya, pengklasifikasi dapat memprediksi transaksi masa depan mana yang dapat berubah menjadi penipuan.
Spam e-mails - Bergantung pada karakteristik email spam sebelumnya, pengklasifikasi menentukan apakah email yang baru ditemui harus dikirim ke folder spam.
Penggolong Naive Bayes
Mahout menggunakan algoritma pengklasifikasi Naive Bayes. Ini menggunakan dua implementasi:
- Klasifikasi Naive Bayes terdistribusi
- Klasifikasi pelengkap Naive Bayes
Naive Bayes adalah teknik sederhana untuk membangun pengklasifikasi. Ini bukan algoritme tunggal untuk melatih pengklasifikasi semacam itu, tetapi sekumpulan algoritme. Pengklasifikasi Bayes membangun model untuk mengklasifikasikan instance masalah. Klasifikasi ini dibuat dengan menggunakan data yang tersedia.
Keuntungan dari naive Bayes adalah hanya membutuhkan sedikit data pelatihan untuk memperkirakan parameter yang diperlukan untuk klasifikasi.
Untuk beberapa jenis model probabilitas, pengklasifikasi naive Bayes dapat dilatih dengan sangat efisien dalam pengaturan pembelajaran yang diawasi.
Terlepas dari asumsinya yang terlalu disederhanakan, pengklasifikasi Bayes yang naif telah bekerja cukup baik dalam banyak situasi dunia nyata yang kompleks.
Prosedur Klasifikasi
Langkah-langkah berikut harus diikuti untuk mengimplementasikan Klasifikasi:
- Hasilkan data contoh
- Buat file urutan dari data
- Ubah file urutan menjadi vektor
- Latih vektor
- Uji vektornya
Langkah 1: Buat Data Contoh
Hasilkan atau unduh data untuk diklasifikasikan. Misalnya, Anda bisa mendapatkan file 20 newsgroups contoh data dari tautan berikut: http://people.csail.mit.edu/jrennie/20Newsgroups/20news-bydate.tar.gz
Buat direktori untuk menyimpan data masukan. Unduh contoh seperti yang ditunjukkan di bawah ini.
$ mkdir classification_example
$ cd classification_example
$tar xzvf 20news-bydate.tar.gz
wget http://people.csail.mit.edu/jrennie/20Newsgroups/20news-bydate.tar.gz
Langkah 2: Buat File Urutan
Buat file urutan dari contoh menggunakan seqdirectoryutilitas. Sintaks untuk menghasilkan urutan diberikan di bawah ini:
mahout seqdirectory -i <input file path> -o <output directory>
Langkah 3: Konversi File Urutan ke Vektor
Buat file vektor dari file urutan menggunakan seq2parseutilitas. Opsi dari seq2parse utilitas diberikan di bawah ini:
$MAHOUT_HOME/bin/mahout seq2sparse
--analyzerName (-a) analyzerName The class name of the analyzer
--chunkSize (-chunk) chunkSize The chunkSize in MegaBytes.
--output (-o) output The directory pathname for o/p
--input (-i) input Path to job input directory.
Langkah 4: Latih Vektor
Latih vektor yang dihasilkan menggunakan trainnbutilitas. Opsi untuk digunakantrainnb utilitas diberikan di bawah ini:
mahout trainnb
-i ${PATH_TO_TFIDF_VECTORS}
-el
-o ${PATH_TO_MODEL}/model
-li ${PATH_TO_MODEL}/labelindex
-ow
-c
Langkah 5: Uji Vektor
Uji vektor menggunakan testnbutilitas. Opsi untuk digunakantestnb utilitas diberikan di bawah ini:
mahout testnb
-i ${PATH_TO_TFIDF_TEST_VECTORS}
-m ${PATH_TO_MODEL}/model
-l ${PATH_TO_MODEL}/labelindex
-ow
-o ${PATH_TO_OUTPUT}
-c
-seq