Hands-On Machine Learning with Scikit-Learn and TensorFlow



Download 26,57 Mb.
Pdf ko'rish
bet213/225
Sana16.03.2022
Hajmi26,57 Mb.
#497859
1   ...   209   210   211   212   213   214   215   216   ...   225
Bog'liq
Hands on Machine Learning with Scikit Learn Keras and TensorFlow

Σ
(1)
to Σ
(
k
)
. Scikit-Learn’s 
GaussianMixture
class makes this trivial:
from
sklearn.mixture
import
GaussianMixture
gm
=
GaussianMixture
(
n_components
=
3

n_init
=
10
)
gm
.
fit
(
X
)
Let’s look at the parameters that the algorithm estimated:
>>> 
gm
.
weights_
array([0.20965228, 0.4000662 , 0.39028152])
>>> 
gm
.
means_
array([[ 3.39909717, 1.05933727],
[-1.40763984, 1.42710194],
[ 0.05135313, 0.07524095]])
>>> 
gm
.
covariances_
array([[[ 1.14807234, -0.03270354],
[-0.03270354, 0.95496237]],
[[ 0.63478101, 0.72969804],
[ 0.72969804, 1.1609872 ]],
264 | Chapter 9: Unsupervised Learning Techniques


[[ 0.68809572, 0.79608475],
[ 0.79608475, 1.21234145]]])
Great, it worked fine! Indeed, the weights that were used to generate the data were
0.2, 0.4 and 0.4, and similarly, the means and covariance matrices were very close to
those found by the algorithm. But how? This class relies on the 
Expectation-
Maximization
(EM) algorithm, which has many similarities with the K-Means algo‐
rithm: it also initializes the cluster parameters randomly, then it repeats two steps
until convergence, first assigning instances to clusters (this is called the 
expectation
step
) then updating the clusters (this is called the 
maximization step
). Sounds famil‐
iar? Indeed, in the context of clustering you can think of EM as a generalization of K-
Means which not only finds the cluster centers (μ
(1)
to μ
(
k
)
), but also their size, shape
and orientation (Σ
(1)
to Σ
(
k
)
), as well as their relative weights (
ϕ
(1)
to 
ϕ
(
k
)
). Unlike K-
Means, EM uses soft cluster assignments rather than hard assignments: for each
instance during the expectation step, the algorithm estimates the probability that it
belongs to each cluster (based on the current cluster parameters). Then, during the
maximization step, each cluster is updated using 
all
the instances in the dataset, with
each instance weighted by the estimated probability that it belongs to that cluster.
These probabilities are called the 
responsibilities
of the clusters for the instances. Dur‐
ing the maximization step, each cluster’s update will mostly be impacted by the
instances it is most responsible for.
Unfortunately, just like K-Means, EM can end up converging to
poor solutions, so it needs to be run several times, keeping only the
best solution. This is why we set 
n_init
to 10. Be careful: by default
n_init
is only set to 1.
You can check whether or not the algorithm converged and how many iterations it
took:

Download 26,57 Mb.

Do'stlaringiz bilan baham:
1   ...   209   210   211   212   213   214   215   216   ...   225




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish