Gensim - Dokumen & Corpus
Di sini kita akan belajar tentang konsep inti Gensim, dengan fokus utama pada dokumen dan korpus.
Konsep Inti Gensim
Berikut adalah konsep inti dan istilah yang diperlukan untuk memahami dan menggunakan Gensim -
Document - ZItu mengacu pada beberapa teks.
Corpus - Mengacu pada kumpulan dokumen.
Vector - Representasi matematis dari suatu dokumen disebut vektor.
Model - Ini mengacu pada algoritma yang digunakan untuk mengubah vektor dari satu representasi ke representasi lainnya.
Apa itu Dokumen?
Seperti yang telah dibahas, ini mengacu pada beberapa teks. Jika kita membahas beberapa detail, itu adalah objek dari tipe urutan teks yang dikenal sebagai‘str’ dengan Python 3. Misalnya, di Gensim, dokumen bisa berupa apa saja seperti -
- Tweet pendek 140 karakter
- Paragraf tunggal, yaitu abstrak artikel atau makalah penelitian
- Artikel berita
- Book
- Novel
- Theses
Urutan Teks
Jenis urutan teks umumnya dikenal sebagai ‘str’ dengan Python 3. Seperti yang kita ketahui bahwa dalam Python, data tekstual ditangani dengan string atau lebih spesifik ‘str’benda. String pada dasarnya adalah urutan poin kode Unicode yang tidak dapat diubah dan dapat ditulis dengan cara berikut -
Single quotes - Misalnya, ‘Hi! How are you?’. Ini memungkinkan kami untuk menyematkan tanda kutip ganda juga. Sebagai contoh,‘Hi! “How” are you?’
Double quotes - Misalnya, "Hi! How are you?". Ini memungkinkan kami untuk menyematkan juga tanda kutip tunggal. Sebagai contoh,"Hi! 'How' are you?"
Triple quotes - Dapat memiliki tiga tanda kutip tunggal seperti, '''Hi! How are you?'''. atau tiga tanda kutip ganda seperti,"""Hi! 'How' are you?"""
Semua spasi akan dimasukkan dalam string literal.
Contoh
Berikut adalah contoh Dokumen di Gensim -
Document = “Tutorialspoint.com is the biggest online tutorials library and it’s all free also”
Apa itu Corpus?
Korpus dapat didefinisikan sebagai kumpulan teks besar dan terstruktur yang dapat dibaca mesin yang diproduksi dalam pengaturan komunikatif alami. Dalam Gensim, kumpulan objek dokumen disebut corpus. Bentuk jamak dari corpus adalahcorpora.
Peran Corpus di Gensim
Korpus di Gensim memiliki dua peran berikut -
Berfungsi sebagai Masukan untuk Pelatihan Model
Peran pertama dan penting yang dimainkan korpus di Gensim, adalah sebagai masukan untuk pelatihan model. Untuk menginisialisasi parameter internal model, selama pelatihan, model mencari beberapa tema dan topik umum dari korpus pelatihan. Seperti dibahas di atas, Gensim berfokus pada model tanpa pengawasan, sehingga tidak memerlukan campur tangan manusia apa pun.
Berfungsi sebagai Ekstraktor Topik
Setelah model dilatih, model tersebut dapat digunakan untuk mengekstrak topik dari dokumen baru. Di sini, dokumen baru adalah dokumen yang tidak digunakan dalam fase pelatihan.
Contoh
Korpus dapat mencakup semua tweet oleh orang tertentu, daftar semua artikel di surat kabar atau semua makalah penelitian tentang topik tertentu, dll.
Mengumpulkan Corpus
Berikut adalah contoh korpus kecil yang berisi 5 dokumen. Di sini, setiap dokumen adalah string yang terdiri dari satu kalimat.
t_corpus = [
"A survey of user opinion of computer system response time",
"Relation of user perceived response time to error measurement",
"The generation of random binary unordered trees",
"The intersection graph of paths in trees",
"Graph minors IV Widths of trees and well quasi ordering",
]
Preprocessing Collecting Corpus
Setelah kami mengumpulkan korpus, beberapa langkah praproses harus dilakukan agar korpus tetap sederhana. Kami hanya dapat menghapus beberapa kata bahasa Inggris yang umum digunakan seperti 'the'. Kami juga dapat menghapus kata-kata yang hanya muncul sekali dalam korpus.
Misalnya, skrip Python berikut digunakan untuk mengecilkan setiap dokumen, membaginya dengan spasi dan memfilter kata-kata berhenti -
Contoh
import pprint
t_corpus = [
"A survey of user opinion of computer system response time",
"Relation of user perceived response time to error measurement",
"The generation of random binary unordered trees",
"The intersection graph of paths in trees",
"Graph minors IV Widths of trees and well quasi ordering",
]
stoplist = set('for a of the and to in'.split(' '))
processed_corpus = [[word for word in document.lower().split() if word not in stoplist]
for document in t_corpus]
pprint.pprint(processed_corpus)
]
Keluaran
[['survey', 'user', 'opinion', 'computer', 'system', 'response', 'time'],
['relation', 'user', 'perceived', 'response', 'time', 'error', 'measurement'],
['generation', 'random', 'binary', 'unordered', 'trees'],
['intersection', 'graph', 'paths', 'trees'],
['graph', 'minors', 'iv', 'widths', 'trees', 'well', 'quasi', 'ordering']]
Pemrosesan Awal yang Efektif
Gensim juga berfungsi untuk preprocessing korpus yang lebih efektif. Dalam preprocessing seperti itu, kita dapat mengubah dokumen menjadi daftar token huruf kecil. Kami juga dapat mengabaikan token yang terlalu pendek atau terlalu panjang. Fungsi tersebut adalahgensim.utils.simple_preprocess(doc, deacc=False, min_len=2, max_len=15).
gensim.utils.simple_preprocess() fucntion
Gensim menyediakan fungsi ini untuk mengubah dokumen menjadi daftar token huruf kecil dan juga untuk mengabaikan token yang terlalu pendek atau terlalu panjang. Ini memiliki parameter berikut -
doc (str)
Ini mengacu pada dokumen masukan di mana preprocessing harus diterapkan.
deacc (bool, opsional)
Parameter ini digunakan untuk menghilangkan tanda aksen dari token. Itu menggunakandeaccent() untuk melakukan ini.
min_len (int, opsional)
Dengan bantuan parameter ini, kita dapat mengatur panjang minimum sebuah token. Token yang lebih pendek dari panjang yang ditentukan akan dibuang.
max_len (int, opsional)
Dengan bantuan parameter ini kita dapat mengatur panjang maksimum sebuah token. Token yang lebih panjang dari panjang yang ditentukan akan dibuang.
Keluaran dari fungsi ini adalah token yang diekstrak dari dokumen masukan.