DataWhale集成学习(上)——Task01

目录

  • 1. 导论
    • 1.1 回归
    • 1.2 分类
    • 1.3 无监督学习

1. 导论

机器学习的一个重要的目标就是利用数学模型来理解数据,发现数据中的规律,用作数据的分析和预测。
根据数据是否有因变量,机器学习的任务可分为:有监督学习无监督学习
根据因变量是否连续,有监督学习又分为回归分类

科学计算相关包
numpy
pandas
matplotlib
seaborn

1.1 回归

基于sklearn内置数据集Boston房价数据集来了解监督学习中的回归【波士顿房价price是一个连续型变量,所以是个回归的例子】

  1. data:特征X的矩阵(ndarray)
  2. target:因变量的向量(ndarray)
  3. feature_names:特征名称(ndarray)
from sklearn import datasets
boston = datasets.load_boston()     # 返回一个类似于字典的类
X = boston.data
y = boston.target
features = boston.feature_names
boston_data = pd.DataFrame(X,columns=features)
boston_data["Price"] = y
boston_data.head()

可视化

sns.scatterplot(boston_data['NOX'],boston_data['Price'],color="r",alpha=0.6)
plt.title("Price~NOX")
plt.show()

DataWhale集成学习(上)——Task01_第1张图片

1.2 分类

基于iris数据集进行分类

from sklearn import datasets
iris = datasets.load_iris()
X = iris.data
y = iris.target
features = iris.feature_names
iris_data = pd.DataFrame(X,columns=features)
iris_data['target'] = y
iris_data.head()
# 可视化特征
marker = ['s','x','o']
for index,c in enumerate(np.unique(y)):
    plt.scatter(x=iris_data.loc[y==c,"sepal length (cm)"],y=iris_data.loc[y==c,"sepal width (cm)"],alpha=0.8,label=c,marker=marker[c])
plt.xlabel("sepal length (cm)")
plt.ylabel("sepal width (cm)")
plt.legend()
plt.show()

DataWhale集成学习(上)——Task01_第2张图片
不同样式代表不同类型的鸢尾花,数据集中共有三种

1.3 无监督学习

生成无因变量的数据集:https://scikit-learn.org/stable/modules/classes.html?highlight=datasets#module-sklearn.datasets

# 生成月牙型非凸集
from sklearn import datasets
x, y = datasets.make_moons(n_samples=2000, shuffle=True,
                  noise=0.05, random_state=None)
for index,c in enumerate(np.unique(y)):
    plt.scatter(x[y==c,0],x[y==c,1],s=7)
plt.show()

DataWhale集成学习(上)——Task01_第3张图片

# 生成符合正态分布的聚类数据
from sklearn import datasets
x, y = datasets.make_blobs(n_samples=5000, n_features=2, centers=3)
for index,c in enumerate(np.unique(y)):
    plt.scatter(x[y==c, 0], x[y==c, 1],s=7)
plt.show()

DataWhale集成学习(上)——Task01_第4张图片

你可能感兴趣的:(Datawhale零基础入门,集成学习入门,机器学习)