Python'da Lojistik Regresyon - Hızlı Kılavuz

Lojistik Regresyon, nesnelerin sınıflandırılması için istatistiksel bir yöntemdir. Bu bölüm, bazı örneklerin yardımıyla lojistik regresyona bir giriş verecektir.

Sınıflandırma

Lojistik regresyonu anlamak için sınıflandırmanın ne anlama geldiğini bilmelisiniz. Bunu daha iyi anlamak için aşağıdaki örnekleri ele alalım -

  • Bir doktor, tümörü kötü huylu veya iyi huylu olarak sınıflandırır.
  • Bir banka işlemi sahte veya gerçek olabilir.

Uzun yıllardır insanlar bu tür görevleri yerine getiriyorlar - hataya açık olsalar da. Soru şu ki, makineleri bizim için bu görevleri daha iyi bir doğrulukla yapacak şekilde eğitebilir miyiz?

Sınıflandırmayı yapan makinelere böyle bir örnek, e-postadır Clientmakinenizde gelen her postayı "spam" veya "spam değil" olarak sınıflandırır ve oldukça büyük bir doğrulukla yapar. Lojistik regresyonun istatistiksel tekniği, e-posta istemcisinde başarıyla uygulandı. Bu durumda, makinemizi bir sınıflandırma problemini çözmek için eğittik.

Lojistik Regresyon, bu tür ikili sınıflandırma problemini çözmek için kullanılan makine öğreniminin yalnızca bir parçasıdır. Halihazırda geliştirilmiş ve başka türden problemleri çözmek için uygulamada olan birkaç başka makine öğrenimi tekniği vardır.

Yukarıdaki tüm örneklerde, tahminin sonucunun yalnızca iki değeri olduğunu fark ettiyseniz - Evet veya Hayır. Bunlara sınıflar diyoruz - böylece sınıflandırıcımızın nesneleri iki sınıfta sınıflandırdığını söyleyelim. Teknik terimlerle, sonuç veya hedef değişkenin doğası gereği ikiye bölünmüş olduğunu söyleyebiliriz.

Çıktının ikiden fazla sınıfa sınıflandırılabileceği başka sınıflandırma problemleri vardır. Örneğin, meyve dolu bir sepet verildiğinde, farklı türdeki meyveleri ayırmanız istenir. Şimdi sepet, Portakal, Elma, Mango vb. İçerebilir. Yani meyveleri ayırdığınızda, onları ikiden fazla sınıfa ayırırsınız. Bu çok değişkenli bir sınıflandırma problemidir.

Bir bankanın, kendileriyle Vadeli Mevduat (bazı bankalar tarafından Sabit Mevduat olarak da adlandırılır) açacak potansiyel müşterileri belirlemelerine yardımcı olacak bir makine öğrenimi uygulaması geliştirmeye yaklaştığını düşünün. Banka, potansiyel müşteriler hakkında bilgi toplamak için düzenli olarak telefon görüşmeleri veya web formları aracılığıyla bir anket gerçekleştirmektedir. Anket doğası gereği geneldir ve pek çoğu bu bankanın kendisiyle ilgilenmeyebileceği çok geniş bir hedef kitle üzerinde yürütülmektedir. Geri kalanların dışında, sadece birkaçı Vadeli Mevduat açmakla ilgilenebilir. Diğerleri, bankanın sunduğu diğer imkanlarla ilgilenebilir. Dolayısıyla, tank avcısı açan müşterileri belirlemek için anket yapılması zorunlu değildir. Göreviniz, bankanın sizinle paylaşacağı muazzam anket verilerinden TD açma olasılığı yüksek olan tüm müşterileri tespit etmektir.

Neyse ki, bu tür bir veri, makine öğrenimi modelleri geliştirmek isteyenler için halka açıktır. Bu veriler, UC Irvine'deki bazı öğrenciler tarafından dış finansmanla hazırlandı. Veritabanı bir parçası olarak mevcutturUCI Machine Learning Repositoryve dünyanın her yerindeki öğrenciler, eğitimciler ve araştırmacılar tarafından yaygın olarak kullanılmaktadır. Veri indirilebilir burada .

Sonraki bölümlerde, şimdi aynı verileri kullanarak uygulama geliştirmeyi gerçekleştirelim.

Bu bölümde, Python'da lojistik regresyon gerçekleştirmek için bir proje oluşturma sürecini ayrıntılı olarak anlayacağız.

Jupyter Kurulumu

Makine öğrenimi için en yaygın kullanılan platformlardan biri olan Jupyter'i kullanacağız. Makinenizde Jupyter kurulu değilse buradan indirin . Kurulum için, platformu kurmak için sitelerindeki talimatları takip edebilirsiniz. Sitenin önerdiği gibi, kullanmayı tercih edebilirsinizAnaconda DistributionPython ve bilimsel hesaplama ve veri bilimi için yaygın olarak kullanılan birçok Python paketiyle birlikte gelen. Bu, bu paketleri ayrı ayrı kurma ihtiyacını azaltacaktır.

Jupyter'in başarılı bir şekilde kurulmasından sonra yeni bir proje başlatın, bu aşamadaki ekranınız aşağıdaki gibi kodunuzu kabul etmeye hazır görünecektir.

Şimdi, projenin adını Untitled1 to “Logistic Regression” başlık adını tıklayıp düzenleyerek.

İlk olarak, kodumuzda ihtiyaç duyacağımız birkaç Python paketini içe aktaracağız.

Python Paketlerini İçe Aktarma

Bu amaçla, aşağıdaki kodu kod düzenleyicide yazın veya kesip yapıştırın -

In [1]: # import statements
   import pandas as pd
   import numpy as np
   import matplotlib.pyplot as plt

   from sklearn import preprocessing
   from sklearn.linear_model import LogisticRegression
   from sklearn.model_selection import train_test_split

Sizin Notebook bu aşamada aşağıdaki gibi görünmelidir -

Şuna tıklayarak kodu çalıştırın Runbuton. Hiçbir hata oluşturulmazsa, Jupyter'i başarıyla yüklediniz ve artık geliştirmenin geri kalanı için hazırsınız.

İlk üç import deyimi projemizdeki pandas, numpy ve matplotlib.pyplot paketlerini içe aktarır. Sonraki üç ifade belirtilen modülleri sklearn'dan içe aktarır.

Bir sonraki görevimiz projemiz için gerekli olan verileri indirmek. Bunu sonraki bölümde öğreneceğiz.

Python'da lojistik regresyon gerçekleştirmek için veri elde etmenin adımları bu bölümde ayrıntılı olarak tartışılmıştır.

Veri Kümesini İndirme

Daha önce bahsedilen UCI veri setini henüz indirmediyseniz, şimdi buradan indirin . Veri Klasörüne tıklayın. Aşağıdaki ekranı göreceksiniz -

Verilen bağlantıya tıklayarak bank.zip dosyasını indirin. Zip dosyası aşağıdaki dosyaları içerir -

Model geliştirmemiz için bank.csv dosyasını kullanacağız. Banka-adları.txt dosyası, daha sonra ihtiyaç duyacağınız veritabanının açıklamasını içerir. Bank-full.csv, daha gelişmiş geliştirmeler için kullanabileceğiniz çok daha büyük bir veri kümesi içerir.

Burada bank.csv dosyasını indirilebilir kaynak zip dosyasına ekledik. Bu dosya virgülle ayrılmış alanları içerir. Dosyada da birkaç değişiklik yaptık. Öğrenmek için proje kaynak zipinde bulunan dosyayı kullanmanız önerilir.

Veri yükleniyor

Az önce kopyaladığınız csv dosyasından verileri yüklemek için aşağıdaki ifadeyi yazın ve kodu çalıştırın.

In [2]: df = pd.read_csv('bank.csv', header=0)

Aşağıdaki kod ifadesini çalıştırarak da yüklenen verileri inceleyebileceksiniz -

IN [3]: df.head()

Komut çalıştırıldığında, aşağıdaki çıktıyı göreceksiniz -

Temel olarak, yüklenen verilerin ilk beş satırını yazdırdı. Mevcut 21 sütunu inceleyin. Model geliştirmemiz için bunlardan sadece birkaç sütun kullanacağız.

Sonra, verileri temizlememiz gerekiyor. Veriler, aşağıdaki satırları içerebilir:NaN. Bu tür satırları ortadan kaldırmak için aşağıdaki komutu kullanın -

IN [4]: df = df.dropna()

Neyse ki, bank.csv, NaN içeren herhangi bir satır içermediğinden, bu adım bizim durumumuzda gerçekten gerekli değildir. Ancak, genel olarak bu tür satırları büyük bir veritabanında bulmak zordur. Bu nedenle, verileri temizlemek için yukarıdaki ifadeyi çalıştırmak her zaman daha güvenlidir.

Note - Aşağıdaki ifadeyi kullanarak veri boyutunu istediğiniz zaman kolayca inceleyebilirsiniz -

IN [5]: print (df.shape)
(41188, 21)

Yukarıdaki ikinci satırda gösterildiği gibi çıktıda satır ve sütun sayısı yazdırılacaktır.

Bundan sonra yapılacak şey, her bir sütunun oluşturmaya çalıştığımız model için uygunluğunu incelemektir.

Herhangi bir kuruluş bir anket yaptığında, bu bilginin kuruluş için şu ya da bu şekilde daha sonraki bir noktada yararlı olacağı düşüncesiyle müşteriden olabildiğince fazla bilgi toplamaya çalışırlar. Mevcut sorunu çözmek için, sorunumuzla doğrudan ilgili olan bilgileri almalıyız.

Tüm Alanları Görüntüleme

Şimdi, bizim için yararlı olan veri alanlarını nasıl seçeceğimize bakalım. Kod düzenleyicide aşağıdaki ifadeyi çalıştırın.

In [6]: print(list(df.columns))

Aşağıdaki çıktıyı göreceksiniz -

['age', 'job', 'marital', 'education', 'default', 'housing', 'loan', 
'contact', 'month', 'day_of_week', 'duration', 'campaign', 'pdays', 
'previous', 'poutcome', 'emp_var_rate', 'cons_price_idx', 'cons_conf_idx', 
'euribor3m', 'nr_employed', 'y']

Çıktı, veritabanındaki tüm sütunların adlarını gösterir. Son sütun "y", bu müşterinin bankada vadeli mevduatı olup olmadığını gösteren bir Boole değeridir. Bu alanın değerleri "y" veya "n" dir. Verilerin bir parçası olarak indirilen bankalar-adı.txt dosyasındaki her bir sütunun açıklamasını ve amacını okuyabilirsiniz.

İstenmeyen Alanların Ortadan Kaldırılması

Sütun adlarını inceleyerek, bazı alanların eldeki sorun için hiçbir önemi olmadığını anlayacaksınız. Örneğin, gibi alanlarmonth, day_of_weekkampanya vb. bizim işimize yaramaz. Bu alanları veritabanımızdan kaldıracağız. Bir sütun bırakmak için aşağıda gösterildiği gibi drop komutunu kullanıyoruz -

In [8]: #drop columns which are not needed.
   df.drop(df.columns[[0, 3, 7, 8, 9, 10, 11, 12, 13, 15, 16, 17, 18, 19]], 
   axis = 1, inplace = True)

Komut, sütun numarası 0, 3, 7, 8 vb. Bıraktığını söylüyor. Dizinin doğru seçildiğinden emin olmak için aşağıdaki ifadeyi kullanın -

In [7]: df.columns[9]
Out[7]: 'day_of_week'

Bu, verilen dizin için sütun adını yazdırır.

Gerekli olmayan sütunları bıraktıktan sonra veriyi head ifadesiyle inceleyin. Ekran çıktısı burada gösterilmektedir -

In [9]: df.head()
Out[9]:
      job   marital  default  housing  loan  poutcome    y
0     blue-collar    married  unknown yes no nonexistent 0
1     technician     married  no    no    no nonexistent 0
2     management     single   no    yes   no success     1
3     services       married  no    no    no nonexistent 0
4     retired        married  no    yes   no success     1

Artık sadece veri analizimiz ve tahminimiz için önemli olduğunu düşündüğümüz alanlara sahibiz. ÖnemiData Scientistbu adımda resme geliyor. Veri bilimcisi, model oluşturma için uygun sütunları seçmelidir.

Örneğin, türü jobilk bakışta herkesi veritabanına dahil etmeye ikna etmeyebilir ancak çok faydalı bir alan olacaktır. Tüm müşteri türleri TD'yi açmayacaktır. Düşük gelirli kişiler tank avcılarını açmayabilirken, yüksek gelirli kişiler genellikle fazla paralarını tank avcılarına park edeceklerdir. Dolayısıyla, bu senaryoda iş türü önemli ölçüde alakalı hale gelir. Aynı şekilde, analizinizle alakalı olacağını düşündüğünüz sütunları dikkatlice seçin.

Bir sonraki bölümde, modeli oluşturmak için verilerimizi hazırlayacağız.

Sınıflandırıcıyı oluşturmak için, verileri sınıflandırıcı yapı modülü tarafından istenen bir formatta hazırlamalıyız. Verileri yaparak hazırlıyoruzOne Hot Encoding.

Kodlama Verileri

Verileri kodlayarak ne demek istediğimizi kısaca tartışacağız. Önce kodu çalıştıralım. Kod penceresinde aşağıdaki komutu çalıştırın.

In [10]: # creating one hot encoding of the categorical columns.
data = pd.get_dummies(df, columns =['job', 'marital', 'default', 'housing', 'loan', 'poutcome'])

Yorumun dediği gibi, yukarıdaki ifade, verilerin tek sıcak kodlamasını oluşturacaktır. Bakalım ne yarattı? Adlı oluşturulan verileri inceleyin“data” veri tabanındaki kafa kayıtlarını yazdırarak.

In [11]: data.head()

Aşağıdaki çıktıyı göreceksiniz -

Yukarıdaki verileri anlamak için, sütun adlarını çalıştırarak listeleyeceğiz. data.columns komut aşağıda gösterildiği gibi -

In [12]: data.columns
Out[12]: Index(['y', 'job_admin.', 'job_blue-collar', 'job_entrepreneur',
'job_housemaid', 'job_management', 'job_retired', 'job_self-employed', 
'job_services', 'job_student', 'job_technician', 'job_unemployed',
'job_unknown', 'marital_divorced', 'marital_married', 'marital_single', 
'marital_unknown', 'default_no', 'default_unknown', 'default_yes', 
'housing_no', 'housing_unknown', 'housing_yes', 'loan_no',
'loan_unknown', 'loan_yes', 'poutcome_failure', 'poutcome_nonexistent', 
'poutcome_success'], dtype='object')

Şimdi, sıcak kodlamanın nasıl yapıldığını açıklayacağız. get_dummieskomut. Yeni oluşturulan veritabanındaki ilk sütun, bu müşterinin bir TD'ye abone olup olmadığını gösteren "y" alanıdır. Şimdi kodlanmış sütunlara bakalım. İlk kodlanmış sütun“job”. Veritabanında, "iş" sütununun "yönetici", "mavi yakalı", "girişimci" gibi birçok olası değeri olduğunu göreceksiniz. Olası her değer için, veritabanında sütun adı önek olarak eklenen yeni bir sütun oluşturduk.

Bu nedenle, "job_admin", "job_blue-collar" vb. Adlı sütunlarımız var. Orijinal veritabanımızdaki her kodlanmış alan için, oluşturulan veritabanına eklenen sütunların bir listesini, sütunun orijinal veritabanında aldığı tüm olası değerlerle bulacaksınız. Verilerin yeni bir veritabanına nasıl eşlendiğini anlamak için sütun listesini dikkatlice inceleyin.

Veri Eşlemeyi Anlama

Üretilen verileri anlamak için, data komutunu kullanarak tüm verileri yazdıralım. Komutu çalıştırdıktan sonraki kısmi çıktı aşağıda gösterilmiştir.

In [13]: data

Yukarıdaki ekran ilk on iki satırı gösterir. Daha aşağı kaydırırsanız, tüm satırlar için eşlemenin yapıldığını görürsünüz.

Hızlı başvuru için veri tabanının daha aşağısında kısmi bir ekran çıktısı burada gösterilmektedir.

Haritalanan verileri anlamak için ilk satırı inceleyelim.

Bu müşterinin "y" alanındaki değerle gösterildiği gibi TD'ye abone olmadığını söylüyor. Bu müşterinin “mavi yakalı” bir müşteri olduğunu da gösterir. Yatay olarak aşağı kaydırıldığında, size bir "konut" sahibi olduğunu ve "kredi" almadığını söyleyecektir.

Bu sıcak kodlamadan sonra, modelimizi oluşturmaya başlamadan önce biraz daha fazla veri işlemeye ihtiyacımız var.

"Bilinmeyeni" düşürmek

Haritalanan veritabanındaki sütunları incelersek, "bilinmeyen" ile biten birkaç sütunun varlığını göreceksiniz. Örneğin, ekran görüntüsünde gösterilen aşağıdaki komutla 12. dizindeki sütunu inceleyin -

In [14]: data.columns[12]
Out[14]: 'job_unknown'

Bu, belirtilen müşteri için işin bilinmediğini gösterir. Açıkçası, bu tür sütunları analizimize ve model oluşturmamıza dahil etmenin bir anlamı yok. Bu nedenle, "bilinmeyen" değere sahip tüm sütunlar kaldırılmalıdır. Bu, aşağıdaki komutla yapılır -

In [15]: data.drop(data.columns[[12, 16, 18, 21, 24]], axis=1, inplace=True)

Doğru sütun numaralarını belirttiğinizden emin olun. Şüphe durumunda, sütun adını daha önce açıklandığı gibi sütunlar komutunda indeksini belirterek istediğiniz zaman inceleyebilirsiniz.

İstenmeyen sütunları bıraktıktan sonra, aşağıdaki çıktıda gösterildiği gibi son sütun listesini inceleyebilirsiniz -

In [16]: data.columns
Out[16]: Index(['y', 'job_admin.', 'job_blue-collar', 'job_entrepreneur', 
'job_housemaid', 'job_management', 'job_retired', 'job_self-employed', 
'job_services', 'job_student', 'job_technician', 'job_unemployed',
'marital_divorced', 'marital_married', 'marital_single', 'default_no', 
'default_yes', 'housing_no', 'housing_yes', 'loan_no', 'loan_yes',
'poutcome_failure', 'poutcome_nonexistent', 'poutcome_success'], 
dtype='object')

Bu noktada verilerimiz model oluşturmaya hazırdır.

Yaklaşık kırk bin tuhaf kaydımız var. Tüm verileri model oluşturmak için kullanırsak, test için herhangi bir veri bırakılmayacaktır. Genel olarak, tüm veri kümesini iki kısma, örneğin yüzde 70/30 olarak ayırırız. Verilerin% 70'ini model oluşturmak için, geri kalanını ise oluşturduğumuz modelin tahminindeki doğruluğunu test etmek için kullanıyoruz. İhtiyacınıza göre farklı bir bölme oranı kullanabilirsiniz.

Özellikler Dizisi Oluşturma

Verileri bölmeden önce, verileri X ve Y olmak üzere iki diziye ayırırız. X dizisi, analiz etmek istediğimiz tüm özellikleri (veri sütunları) içerir ve Y dizisi, tek boyutlu bir boole değerleri dizisidir. Tahmini. Bunu anlamak için biraz kod çalıştıralım.

İlk olarak, X dizisini oluşturmak için aşağıdaki Python ifadesini yürütün -

In [17]: X = data.iloc[:,1:]

İçeriğini incelemek için X kullanım headbirkaç ilk kaydı yazdırmak için. Aşağıdaki ekran X dizisinin içeriğini gösterir.

In [18]: X.head ()

Dizinin birkaç satırı ve 23 sütunu vardır.

Sonra, "y”Değerleri.

Çıktı Dizisi Oluşturma

Öngörülen değer sütunu için bir dizi oluşturmak için aşağıdaki Python ifadesini kullanın -

In [19]: Y = data.iloc[:,0]

İçeriğini arayarak inceleyin head. Aşağıdaki ekran çıktısı sonucu gösterir -

In [20]: Y.head()
Out[20]: 0   0
1    0
2    1
3    0
4    1
Name: y, dtype: int64

Şimdi, aşağıdaki komutu kullanarak verileri bölün -

In [21]: X_train, X_test, Y_train, Y_test = train_test_split(X, Y, random_state=0)

Bu, adı verilen dört diziyi oluşturacaktır. X_train, Y_train, X_test, and Y_test. Daha önce olduğu gibi bu dizilerin içeriklerini head komutunu kullanarak inceleyebilirsiniz. Modelimizi eğitmek için X_train ve Y_train dizilerini ve test etmek ve doğrulamak için X_test ve Y_test dizilerini kullanacağız.

Artık sınıflandırıcımızı oluşturmaya hazırız. Bir sonraki bölümde buna bakacağız.

Sınıflandırıcıyı sıfırdan oluşturmanız gerekmez. Sınıflandırıcılar oluşturmak karmaşıktır ve İstatistikler, olasılık teorileri, optimizasyon teknikleri vb. Gibi birkaç alan hakkında bilgi gerektirir. Piyasada bu sınıflandırıcıların tam olarak test edilmiş ve çok verimli bir şekilde uygulanmasına sahip önceden oluşturulmuş birkaç kitaplık bulunmaktadır. Böyle bir önceden oluşturulmuş modeli kullanacağız.sklearn.

Sklearn Sınıflandırıcı

Sklearn araç setinden Logistic Regression sınıflandırıcı oluşturmak önemsizdir ve burada gösterildiği gibi tek bir program deyiminde yapılır -

In [22]: classifier = LogisticRegression(solver='lbfgs',random_state=0)

Sınıflandırıcı oluşturulduktan sonra, eğitim verilerinizi sınıflandırıcıya beslersiniz, böylece sınıflandırma kendi dahili parametrelerini ayarlayabilir ve gelecekteki verileriniz için tahminler için hazır olabilir. Sınıflandırıcıyı ayarlamak için aşağıdaki ifadeyi çalıştırıyoruz -

In [23]: classifier.fit(X_train, Y_train)

Sınıflandırıcı artık test edilmeye hazırdır. Aşağıdaki kod, yukarıdaki iki ifadenin yürütülmesinin çıktısıdır -

Out[23]: LogisticRegression(C = 1.0, class_weight = None, dual = False, 
   fit_intercept=True, intercept_scaling=1, max_iter=100, 
   multi_class='warn', n_jobs=None, penalty='l2', random_state=0, 
   solver='lbfgs', tol=0.0001, verbose=0, warm_start=False))

Şimdi, oluşturulan sınıflandırıcıyı test etmeye hazırız. Bunu bir sonraki bölümde ele alacağız.

Üretimde kullanıma sokmadan önce yukarıda oluşturulan sınıflandırıcıyı test etmemiz gerekir. Test, modelin istenen doğruluğu karşılamadığını ortaya çıkarsa, yukarıdaki sürece geri dönmemiz, başka bir özellik kümesi (veri alanları) seçmemiz, modeli yeniden oluşturmamız ve test etmemiz gerekir. Bu, sınıflandırıcı istenen doğruluk gereksiniminizi karşılayana kadar yinelemeli bir adım olacaktır. Öyleyse sınıflandırıcımızı test edelim.

Test Verilerini Tahmin Etme

Sınıflandırıcıyı test etmek için, önceki aşamada oluşturulan test verilerini kullanırız. Biz arıyoruzpredict yöntemi oluşturulan nesnede ve X aşağıdaki komutta gösterildiği gibi test verilerinin dizisi -

In [24]: predicted_y = classifier.predict(X_test)

Bu, tüm eğitim veri seti için X dizisindeki her satır için tahmin veren tek boyutlu bir dizi oluşturur. Aşağıdaki komutu kullanarak bu diziyi inceleyebilirsiniz -

In [25]: predicted_y

Aşağıdakiler, yukarıdaki iki komutun yürütülmesi üzerine çıktıdır -

Out[25]: array([0, 0, 0, ..., 0, 0, 0])

Çıktı, ilk ve son üç müşterinin potansiyel adaylar olmadığını göstermektedir. Term Deposit. Potansiyel müşterileri sıralamak için tüm diziyi inceleyebilirsiniz. Bunu yapmak için aşağıdaki Python kod parçacığını kullanın -

In [26]: for x in range(len(predicted_y)):
   if (predicted_y[x] == 1):
      print(x, end="\t")

Yukarıdaki kodu çalıştırmanın çıktısı aşağıda gösterilmiştir -

Çıktı, TD'ye abone olmak için muhtemel aday olan tüm satırların indekslerini gösterir. Artık bu çıktıyı, seçilen satırdaki her bir müşteri için iletişim bilgilerini alacak ve işlerine devam edecek olan bankanın pazarlama ekibine verebilirsiniz.

Bu modeli üretime sokmadan önce tahminin doğruluğunu kontrol etmemiz gerekiyor.

Doğruluğu Doğrulamak

Modelin doğruluğunu test etmek için, aşağıda gösterildiği gibi sınıflandırıcıdaki puan yöntemini kullanın -

In [27]: print('Accuracy: {:.2f}'.format(classifier.score(X_test, Y_test)))

Bu komutu çalıştırmanın ekran çıktısı aşağıda gösterilmiştir -

Accuracy: 0.90

Çoğu uygulamada çok iyi kabul edilen modelimizin doğruluğunun% 90 olduğunu göstermektedir. Bu nedenle, daha fazla ayar yapmaya gerek yoktur. Artık müşterimiz bir sonraki kampanyayı yürütmeye, potansiyel müşterilerin listesini almaya ve olası bir yüksek başarı oranıyla TD'yi açmak için onları kovalamaya hazır.

Yukarıdaki örnekten de gördüğünüz gibi, makine öğrenimi için lojistik regresyon uygulamak zor bir iş değildir. Ancak, kendi sınırlamaları ile birlikte gelir. Lojistik regresyon, çok sayıda kategorik özelliği işleyemeyecektir. Şimdiye kadar tartıştığımız örnekte, özelliklerin sayısını çok büyük ölçüde azalttık.

Bununla birlikte, bu özellikler tahminimizde önemli olsaydı, onları dahil etmek zorunda kalırdık, ancak o zaman lojistik regresyon bize iyi bir doğruluk veremezdi. Lojistik regresyon, aşırı uyuma karşı da savunmasızdır. Doğrusal olmayan bir probleme uygulanamaz. Hedefle ilişkili olmayan ve birbiriyle ilişkili olan bağımsız değişkenlerle kötü performans gösterecektir. Bu nedenle, lojistik regresyonun çözmeye çalıştığınız probleme uygunluğunu dikkatlice değerlendirmeniz gerekecektir.

Diğer tekniklerin tasarlandığı birçok makine öğrenimi alanı vardır. Birkaçını saymak gerekirse, k-en yakın komşular (kNN), Doğrusal Regresyon, Destek Vektör Makineleri (SVM), Karar Ağaçları, Naif Bayes ve benzeri algoritmalarımız var. Belirli bir modeli tamamlamadan önce, bu çeşitli tekniklerin çözmeye çalıştığımız probleme uygulanabilirliğini değerlendirmeniz gerekecektir.

Lojistik Regresyon, ikili sınıflandırmanın istatistiksel bir tekniğidir. Bu eğitimde, makineyi lojistik regresyonu kullanacak şekilde nasıl eğiteceğinizi öğrendiniz. Makine öğrenimi modelleri oluştururken, en önemli gereksinim verilerin kullanılabilirliğidir. Yeterli ve ilgili veriler olmadan, makinenin öğrenmesini sağlayamazsınız.

Verilere sahip olduğunuzda, bir sonraki ana göreviniz verileri temizlemek, istenmeyen satırları, alanları ortadan kaldırmak ve model geliştirmeniz için uygun alanları seçmektir. Bu yapıldıktan sonra, verileri sınıflandırıcı tarafından eğitimi için gerekli olan bir formatta eşlemeniz gerekir. Bu nedenle, veri hazırlama, herhangi bir makine öğrenimi uygulamasında önemli bir görevdir. Verilere hazır olduğunuzda, belirli bir sınıflandırıcı türü seçebilirsiniz.

Bu eğitimde, şu bölümde verilen lojistik regresyon sınıflandırıcısının nasıl kullanılacağını öğrendiniz. sklearnkütüphane. Sınıflandırıcıyı eğitmek için, modeli eğitmek için verilerin yaklaşık% 70'ini kullanırız. Geri kalan verileri test etmek için kullanırız. Modelin doğruluğunu test ediyoruz. Bu kabul edilebilir sınırlar dahilinde değilse, yeni özellik kümesini seçmeye geri dönüyoruz.

Doğruluğundan memnun kalana kadar bir kez daha, tüm veri hazırlama sürecini takip edin, modeli eğitin ve test edin. Herhangi bir makine öğrenimi projesine başlamadan önce, şimdiye kadar geliştirilmiş ve sektörde başarıyla uygulanmış çok çeşitli teknikleri öğrenmeli ve bunlara maruz kalmalısınız.