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.