📚 The CoCalc Library - books, templates and other resources
License: OTHER
import matplotlib.pyplot as plt1import numpy as np2from sklearn.datasets import make_blobs3from sklearn.preprocessing import (StandardScaler, MinMaxScaler, Normalizer,4RobustScaler)5from .plot_helpers import cm2678def plot_scaling():9X, y = make_blobs(n_samples=50, centers=2, random_state=4, cluster_std=1)10X += 31112plt.figure(figsize=(15, 8))13main_ax = plt.subplot2grid((2, 4), (0, 0), rowspan=2, colspan=2)1415main_ax.scatter(X[:, 0], X[:, 1], c=y, cmap=cm2, s=60)16maxx = np.abs(X[:, 0]).max()17maxy = np.abs(X[:, 1]).max()1819main_ax.set_xlim(-maxx + 1, maxx + 1)20main_ax.set_ylim(-maxy + 1, maxy + 1)21main_ax.set_title("Original Data")22other_axes = [plt.subplot2grid((2, 4), (i, j))23for j in range(2, 4) for i in range(2)]2425for ax, scaler in zip(other_axes, [StandardScaler(), RobustScaler(),26MinMaxScaler(), Normalizer(norm='l2')]):27X_ = scaler.fit_transform(X)28ax.scatter(X_[:, 0], X_[:, 1], c=y, cmap=cm2, s=60)29ax.set_xlim(-2, 2)30ax.set_ylim(-2, 2)31ax.set_title(type(scaler).__name__)3233other_axes.append(main_ax)3435for ax in other_axes:36ax.spines['left'].set_position('center')37ax.spines['right'].set_color('none')38ax.spines['bottom'].set_position('center')39ax.spines['top'].set_color('none')40ax.xaxis.set_ticks_position('bottom')41ax.yaxis.set_ticks_position('left')424344