Tek bir belge ile çok sayıda belgenin (n = 1 milyon) her biri arasındaki belge benzerliğini olabildiğince çabuk tespit etmeye çalışıyorum. Daha spesifik olarak, karşılaştırdığım belgeler e-postalardır; gruplandırılırlar (yani, klasörler veya etiketler vardır) ve hangi grubun yeni bir e-posta için en uygun olduğunu belirlemek isterim. Hızlı performans önemlidir.Çok hızlı belge benzerliği
Önsöz varsayımım, terim vektörleri arasındaki kosinüs benzerliğinin bu uygulama için uygun olmasıdır; Lütfen bunun kullanmanın iyi bir ölçü olup olmadığı hakkında yorum yapın!
Zaten, aşağıdaki olanaklar performansını hızlandırmak için dikkate almış:
- tüm terimi vektörleri
her grup için bir terim vektörü hesaplayın (n + = 10,000) Ön normalize her e-posta yerine (n = = 1,000,000); Bu muhtemelen benim başvurum için kabul edilebilir olurdu, ancak bunu yapmamak için bir neden düşünebilirseniz, bana bildirin! Yeni bir e-posta önce önceki e-postaların birinde hiç görülmemiş yeni bir terim varsa ben yeniden gerek demek,
:
bir kaç sorum var Dönem vektörlerimin tüm hesaplamasını? Bu pahalı görünüyor.
Yalnızca sorgu belgesine yakın olması muhtemel olan vektörleri dikkate almanın akıllıca bir yolu var mı?
Tüm bu vektörler için kullanıyorum bellek miktarı hakkında daha tutumlu olmanın bir yolu var mı?
teşekkürler!
Öneri için teşekkürler. Bayes filtreleme ilginç bir fikir. Birkaç sorum var: 1. Neden BF'nin bu örnek için kosinüs benzerliğinden daha iyi olduğunu düşünüyorsunuz? 2. Bir şey kaçırıyor olabilirim, ama kategorize etme zamanım hala n = kategori sayısı için O (n) değil, kosinüs benzerliği için olduğu gibi mi? İhtiyacım olan kategori adaylarını sıralamak için ihtiyacım olan şey bir O (log n) veya O (1) arama tablosu. – Peyton
Buraya geldiğimde - şu anda problem için Bayes filtrelemeyi deniyorum - iyi bir fikir gibi görünüyor, bu yüzden bu cevabı kabul ediyorum. – Peyton