Markov Zincirleri

Markov modelleri, Markov zinciri adı verilen ve gelecekteki durumun yalnızca mevcut duruma bağlı olduğu bir süreç modellemesi türünü temsil eder. Bu model, geçmiş durumların gelecekteki durumları belirlemede tam olarak yeterli olduğunu varsayar. Bu, bir durumun gelecekteki olasılığını, yalnızca mevcut durumun bilgisine dayanarak tahmin etmek için kullanılır. Markov zincirleri, durumları temsil eden bir durum uzayı ve durumlar arasındaki geçiş olasılıklarını tanımlayan bir geçiş matrisi kullanır. Her bir durum, bir durum uzayının bir noktasını temsil eder ve geçiş matrisi, her bir durumun diğer durumlara geçiş olasılıklarını belirtir. Türleri:

  • Birinci Dereceden Markov Zinciri
  • Yüksek Dereceden Markov Zinciri
  • Gizli Markov Modeli (Hidden Markov Model – HMM)

Birinci Dereceden Markov Zinciri

Gelecekteki durum, yalnızca mevcut duruma bağlıdır. Bir sonraki durum, yalnızca mevcut durumun bilgisine dayanarak tahmin edilir.

Çalışma Adımları

  1. Modelin kullanılacağı durumlar tanımlanır.
  2. Her bir durumun, bir sonraki duruma geçme olasılığı belirlenir.
  3. Modelin başlangıç durumu (başlangıç noktası) seçilir.
  4. Başlangıç durumundan başlayarak, her bir adımda geçiş olasılıklarına dayanarak bir sonraki durum rastgele seçilir.
  5. Zincir belirlenen adımlar boyunca çalıştırılır ve bir sonraki durum tahmin edilir.
import markovify

# Ornek metin
text = """
This is a sample text. This text will be analysed with a first order Markov chain. 
Markov chains are used to predict the next state based on the past state.
"""

# Markov zinciri modelini olusturma
model = markovify.Text(text, state_size=1)

# Rastgele bir dizi olusturma
generated_sequence = model.make_sentence()

print("Generated Sequence:", generated_sequence)
# Generated Sequence: This is a first order Markov chain.   

Yüksek Dereceden Markov Zinciri

Yüksek dereceden Markov zinciri, birinci derecede Markov zincirinden farklı olarak, daha önceki birden fazla durumu dikkate alarak bir sonraki durumu tahmin etmek için kullanılır. Geçmişteki birden fazla durumun etkilerini içeren daha karmaşık ilişkileri modelleyebilir.

import markovify

# Ornek metin
text = """
This is a sample text. This text will be analysed with a first order Markov chain. 
Markov chains are used to predict the next state based on the past state.
"""

# Markov zinciri modelini olusturma
model = markovify.Text(text, state_size=3)

# Rastgele bir dizi olusturma
generated_sequence = model.make_sentence()

print("Generated Sequence:", generated_sequence)

Hidden Markov Model (HMM)

Zamanla değişen gizli durumların gözlemlenebilir durumlar aracılığıyla modellendiği bir olasılıksal modeldir. HMM, bir Markov zincirinin gizli bir durumla eşlenmesiyle oluşturulur ve bu gizli durumlar gözlemlenebilir durumlarla ilişkilendirilir. İki tür durumu içerir:

  • Gizli Durumlar (Hidden States): Gözlemleyiciler tarafından doğrudan gözlemlenemeyen ve model tarafından tahmin edilmeye çalışılan durumlardır.
  • Gözlemlenebilir Durumlar (Observable States): Model tarafından gözlemlenebilen durumlardır. Bu durumlar gizli durumlarla ilişkilendirilir ve belirli bir zaman aralığında gözlenen gerçek verilerdir.

Çalışma Adımları

  1. Modelin kullanacağı gizli ve gözlemlenebilir durumlar tanımlanır.
  2. Gizli durumlar arasındaki geçiş olasılıkları belirlenir.
  3. Her bir gizli durumun gözlemlenebilir durumlarla ilişkilendirilme olasılıkları belirlenir.
  4. Modelin başlangıç durumu belirlenir.
  5. Model genellikle gözlemlenen veriler kullanılarak eğitilir. Bu, Viterbi algoritması veya Baum-Welch algoritması gibi yöntemler kullanılarak gerçekleştirilebilir.
from hmmlearn import hmm
import numpy as np

# Ornek veri
X = np.array([[0], [1], [0], [1], [0], [1], [0], [1]])
lengths = [8]  # Gozlemlenen verinin uzunlugu

# Gizli Markov Modeli olusturma
model = hmm.GaussianHMM(n_components=2, covariance_type="full")

# Modeli egitme
model.fit(X, lengths)

# Gizli durumlari tahmin etme
predicted_states = model.predict(X)

print("Gizli Durumlar:", predicted_states)
# Gizli Durumlar: [0 1 0 1 0 1 0 1]