机器学习笔记(1):什么是机器学习

本文来自之前在Udacity上自学机器学习的系列笔记。这是第1篇,介绍了什么是机器学习,以及机器学习的方法。

1. 简介

这门课程全面地介绍了机器学习知识。目标是学会构建用于描述数据的模型,然后根据一些评估指标来验证模型,或者互相比较不同模型的结果。最后,使用模型来解决问题。课程覆盖监督学习、非监督学习、强化学习和深度学习四种机器学习的方式。这些模型作为解决实际问题的工具箱。我们不仅是要学会如何用这些模型,还需要知道什么时候用,以及如何评估结果。

2. 什么是机器学习

机器学习是编写计算机程序,来解决现实中的问题。与传统编程相比,传统编程的方法是编写算法和规则来处理数据,然后得到结果。而机器学习则根据数据来寻找规则。举个例子,假如我们要判断一张图片中是否包含一个人,使用传统编程方法的话,我们需要写很多的判断,来决定这张图片是否有眼睛、鼻子等。而使用机器学习,我们其实是先写一个程序(Agent),然后输入大量的包含人的图片来训练这个程序,最后在给定的图片下,程序自己给出判断结果。机器学习得益于计算机的快速发展,可以收集并处理大量的数据。

3. 机器学习方法

当我们遇到一个问题,想用机器学习来解决时,我们可以先观察数据,然后从“工具箱”中寻找一个合适的模型。然后将数据输入到模型中进行训练。为了找出合适的模型,我们会将总数据划分为训练集和测试集,其中,在模型训练阶段,只用训练集数据,测试集的数据不能用于模型的训练。训练后的模型将使用测试集的数据进行验证。如果验证通过,说明得到的模型泛化能力很好。

下面使用pandas和sklearn库演示了,划分数据,读取训练集数据,然后选择模型,再将数据输入到模型进行训练,最后验证的过程。

# Import statements
from sklearn.tree import DecisionTreeClassifier
from sklearn.metrics import accuracy_score
import pandas as pd
import numpy as np

# Import the train test split
from sklearn.cross_validation import train_test_split

# Read the data.
data = np.asarray(pd.read_csv('data.csv', header=None))
# Assign the features to the variable X, and the labels to the variable y.
X = data[:,0:2]
y = data[:,2]

# Use train test split to split your data
# Use a test size of 25% and a random state of 42
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.25, random_state=42)

# Create the decision tree model and assign it to the variable model.
model = DecisionTreeClassifier()

# Fit the model to the training data.
model.fit(X_train,y_train)

# Make predictions on the test data
y_pred = model.predict(X_test)

# Calculate the accuracy and assign it to the variable acc. on the test data
acc = accuracy_score(y_test, y_pred)

在上面的程序中,模型是如何“训练”出来,就像是一个黑盒子,里面所涉及到的是具体模型选择、将模型转化为一个可求解的数学模型、最后设计算法求解出参数的过程。

所以,总的来说,机器学习是一个“遇到问题->构建模型->验证模型”的过程,其中构建模型涉及到具体的模型选择、问题转化和算法求解的步骤。

最后编辑于:2020-02-23 23:24


喜欢的朋友记得点赞、收藏、关注哦!!!

  • 9
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

武昌库里写JAVA

您的鼓励将是我前进的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值