Gensim - Vektor & Model

Di sini, kita akan belajar tentang konsep inti Gensim, dengan fokus utama pada vektor dan model.

Apa itu Vector?

Bagaimana jika kita ingin menyimpulkan struktur laten dalam korpus kita? Untuk ini, kita perlu merepresentasikan dokumen sedemikian rupa sehingga kita dapat memanipulasinya secara matematis. Salah satu jenis representasi yang populer adalah merepresentasikan setiap dokumen korpus sebagai vektor fitur. Itulah mengapa kita dapat mengatakan bahwa vektor adalah representasi praktis matematis dari sebuah dokumen.

Untuk memberi Anda contoh, mari kita wakili satu fitur, dari korpus bekas kami di atas, sebagai pasangan QA -

Q - Berapa kali kata itu Hello muncul di dokumen?

A - Nol (0).

Q - Ada berapa paragraf di dokumen?

A - Dua (2)

Pertanyaan tersebut umumnya diwakili oleh bilangan bulat idnya, maka representasi dari dokumen ini adalah serangkaian pasangan seperti (1, 0.0), (2, 2.0). Representasi vektor tersebut dikenal sebagai adensevektor. Mengapadense, karena ini terdiri dari jawaban eksplisit untuk semua pertanyaan yang ditulis di atas.

Representasinya bisa sederhana seperti (0, 2), jika kita mengetahui semua pertanyaan sebelumnya. Urutan jawaban seperti itu (tentu saja jika pertanyaannya diketahui sebelumnya) adalahvector untuk dokumen kami.

Jenis representasi populer lainnya adalah bag-of-word (BoW)model. Dalam pendekatan ini, setiap dokumen pada dasarnya diwakili oleh vektor yang berisi jumlah frekuensi setiap kata dalam kamus.

Sebagai contoh, misalkan kita memiliki kamus yang berisi kata-kata ['Hello', 'How', 'are', 'you']. Sebuah dokumen yang terdiri dari string “Bagaimana kabarmu” kemudian akan diwakili oleh vektor [0, 2, 1, 1]. Di sini, entri vektor diurutkan dari kemunculan "Halo", "Bagaimana", "adalah", dan "Anda".

Vektor versus Dokumen

Dari penjelasan vektor di atas, hampir dapat dipahami perbedaan antara dokumen dan vektor. Tapi, untuk membuatnya lebih jelas,document adalah teks dan vectoradalah representasi teks yang sesuai secara matematis. Sayangnya, terkadang banyak orang menggunakan istilah ini secara bergantian.

Sebagai contoh, misalkan kita memiliki beberapa sembarang dokumen A maka alih-alih mengatakan, "vektor yang sesuai dengan dokumen A", mereka biasa mengatakan, "vektor A" atau "dokumen A". Ini mengarah pada ambiguitas yang besar. Satu hal penting yang perlu diperhatikan di sini adalah, dua dokumen berbeda mungkin memiliki representasi vektor yang sama.

Mengubah korpus menjadi daftar vektor

Sebelum mengambil contoh implementasi untuk mengonversi korpus ke dalam daftar vektor, kita perlu mengaitkan setiap kata dalam korpus dengan ID integer unik. Untuk ini, kami akan memperluas contoh yang diambil pada bab di atas.

Contoh

from gensim import corpora
dictionary = corpora.Dictionary(processed_corpus)
print(dictionary)

Keluaran

Dictionary(25 unique tokens: ['computer', 'opinion', 'response', 'survey', 'system']...)

Ini menunjukkan bahwa dalam korpus kami ada 25 token berbeda dalam hal ini gensim.corpora.Dictionary.

Contoh Implementasi

Kita dapat menggunakan kamus untuk mengubah dokumen tokenis menjadi vektor 5-dimensi sebagai berikut -

pprint.pprint(dictionary.token2id)

Keluaran

{
   'binary': 11,
   'computer': 0,
   'error': 7,
   'generation': 12,
   'graph': 16,
   'intersection': 17,
   'iv': 19,
   'measurement': 8,
   'minors': 20,
   'opinion': 1,
   'ordering': 21,
   'paths': 18,
   'perceived': 9,
   'quasi': 22,
   'random': 13,
   'relation': 10,
   'response': 2,
   'survey': 3,
   'system': 4,
   'time': 5,
   'trees': 14,
   'unordered': 15,
   'user': 6,
   'well': 23,
   'widths': 24
}

Dan serupa, kita dapat membuat representasi bag-of-word untuk dokumen sebagai berikut -

BoW_corpus = [dictionary.doc2bow(text) for text in processed_corpus]
pprint.pprint(BoW_corpus)

Keluaran

[
   [(0, 1), (1, 1), (2, 1), (3, 1), (4, 1), (5, 1), (6, 1)],
   [(2, 1), (5, 1), (6, 1), (7, 1), (8, 1), (9, 1), (10, 1)],
   [(11, 1), (12, 1), (13, 1), (14, 1), (15, 1)],
   [(14, 1), (16, 1), (17, 1), (18, 1)],
   [(14, 1), (16, 1), (19, 1), (20, 1), (21, 1), (22, 1), (23, 1), (24, 1)]
]

Apa Model?

Setelah kita memvektorisasi korpus, selanjutnya apa? Sekarang, kita bisa mengubahnya menggunakan model. Model dapat mengacu pada algoritma yang digunakan untuk mengubah satu representasi dokumen ke yang lain.

Seperti yang telah kita diskusikan, dokumen, dalam Gensim, direpresentasikan sebagai vektor, oleh karena itu, kita dapat, meskipun memodelkan sebagai transformasi antara dua ruang vektor. Selalu ada fase pelatihan di mana model mempelajari detail transformasi semacam itu. Model membaca korpus pelatihan selama fase pelatihan.

Menginisialisasi Model

Mari kita mulai tf-idfmodel. Model ini mengubah vektor dari representasi BoW (Bag of Words) ke ruang vektor lain di mana jumlah frekuensi diberi bobot sesuai dengan kelangkaan relatif setiap kata dalam korpus.

Contoh Implementasi

Dalam contoh berikut, kita akan menginisialisasi file tf-idfmodel. Kami akan melatihnya di korpus kami dan kemudian mengubah string "grafik pohon".

Contoh

from gensim import models
tfidf = models.TfidfModel(BoW_corpus)
words = "trees graph".lower().split()
print(tfidf[dictionary.doc2bow(words)])

Keluaran

[(3, 0.4869354917707381), (4, 0.8734379353188121)]

Sekarang, setelah kami membuat model, kami dapat mengubah seluruh korpus melalui tfidf dan mengindeksnya, dan menanyakan kesamaan dokumen kueri kami (kami memberikan dokumen kueri 'sistem pohon') terhadap setiap dokumen dalam korpus -

Contoh

from gensim import similarities
index = similarities.SparseMatrixSimilarity(tfidf[BoW_corpus],num_features=5)
query_document = 'trees system'.split()
query_bow = dictionary.doc2bow(query_document)
simils = index[tfidf[query_bow]]
print(list(enumerate(simils)))

Keluaran

[(0, 0.0), (1, 0.0), (2, 1.0), (3, 0.4869355), (4, 0.4869355)]

Dari keluaran di atas, dokumen 4 dan dokumen 5 memiliki nilai kesamaan sekitar 49%.

Selain itu, kami juga dapat mengurutkan keluaran ini agar lebih mudah dibaca sebagai berikut -

Contoh

for doc_number, score in sorted(enumerate(sims), key=lambda x: x[1], reverse=True):
   print(doc_number, score)

Keluaran

2 1.0
3 0.4869355
4 0.4869355
0 0.0
1 0.0