一、机器学习以及scikit-learn

  1. 机器学习基本步骤:

    (1)定义一系列函数  =>   (2)定义函数的优劣  =>  (3)选择最优函数

  2.什么是scikit-learn?

    (1)面向python的免费机器学习库

    (2)包含分类、回归、聚类算法,比如:SVM、随机森林、k-means等

    (3)包含降维、模型选择、预处理等算法

    (4)支持Numpy和Scipy数据结构

    (5)用户

    (6)安装:pip install scikit-learn

        pip install scikit-learn

   3.上手:

    (1)加载数据集

      iris

      digits

    (2)在训练集上训练模型

      svm模型

      .fit()训练模型

    (3)在测试集上测试模型

      .predict()进行预测

    (4)保存模型

      .pickle.dumps()

   4.使用scikit-learn的流程

      准备数据集===》选择模型===》训练模型===》测试数据

      数据处理    根据任务选择  根据经验  预测

      特征工程    模型      设动参数  识别

      训练集、    分类模型    交叉验证

      测试集分割   回归模型    确定最优参数

              聚类模型

   5.准备数据集:

    (1)数据准备:

        数据集格式

        二维数组,形状(n_samples,n_features),行数是样本的个数,列数是特征的个数

        使用np.reshape()转换数据集的形状

    (2)特征工程

        特征提取,如图片的特征提取

        特征归一化(normalization),

    (3)train_test_split()分割训练集、测试集

      分类、回归、聚类

      训练模型

       (4)训练模型

      Estimator对象

      从训练数据学习得到的

      可以是分类算法、回归算法或者是特征提取算法

      fit方法用于训练Estimator

      Estimator的参数可以训练前初始化,或者之后更新

      get_params()返回之前定义的参数

      score()对Estimator进行评分

        回归模型:使用“决定系数”评分(Coefficient of Determination)

        分类模型:使用“准确率”评分(accuracy)训练误差  

    6.调整参数

      (1)依靠经验

      (2)依靠实验、交叉验证cv(cross validation)

      

二、机器学习:问题描述

  1.“学习”问题通常包含n个样本数据(训练样本),然后预测未知数据(测试样本)的属性

  2.每个样本包含多个属性(多维数据)被称作“特征”,特征的归一化,将数据范围缩放,缩放进入同一个范围。

  当两个特征的范围不一样的时候,θ1是房屋大小,θ2是卧室个数,当两个值不一样的时候,学习出来的可能是下面作图所示的椭圆形状,如右图所示做归一化,直接进行缩放操作,在scikit_learn中做归一化的操作是:preprocessing.scale

  

  3.分类:

    (1)监督学习,训练样本包含对应的标签,“如识别问题”

        分类问题,样本标签属于两个或者多各类

        回归问题,样本标签包括一个或者多个连续变量

    (2)无监督学习,训练样本的属性不包含对应的“标签”,如聚类问题

    (3)训练集vs验证集vs测试集

    

    

    在没有生产的阶段,没有新的数据,通常会将原始数据集分为三部分:训练集、测试集和验证集,训练集用来训练模型,验证集用来选择最佳模型,调整参数,测试集用来测试模型

    

机器学习及scikit-learn的更多相关文章

  1. 机器学习框架Scikit Learn的学习

    一   安装 安装pip 代码如下:# wget "https://pypi.python.org/packages/source/p/pip/pip-1.5.4.tar.gz#md5=83 ...

  2. Scikit Learn: 在python中机器学习

    转自:http://my.oschina.net/u/175377/blog/84420#OSC_h2_23 Scikit Learn: 在python中机器学习 Warning 警告:有些没能理解的 ...

  3. (原创)(三)机器学习笔记之Scikit Learn的线性回归模型初探

    一.Scikit Learn中使用estimator三部曲 1. 构造estimator 2. 训练模型:fit 3. 利用模型进行预测:predict 二.模型评价 模型训练好后,度量模型拟合效果的 ...

  4. (原创)(四)机器学习笔记之Scikit Learn的Logistic回归初探

    目录 5.3 使用LogisticRegressionCV进行正则化的 Logistic Regression 参数调优 一.Scikit Learn中有关logistics回归函数的介绍 1. 交叉 ...

  5. scikit learn 模块 调参 pipeline+girdsearch 数据举例:文档分类 (python代码)

    scikit learn 模块 调参 pipeline+girdsearch 数据举例:文档分类数据集 fetch_20newsgroups #-*- coding: UTF-8 -*- import ...

  6. Scikit Learn

    Scikit Learn Scikit-Learn简称sklearn,基于 Python 语言的,简单高效的数据挖掘和数据分析工具,建立在 NumPy,SciPy 和 matplotlib 上.

  7. 机器学习-scikit learn学习笔记

    scikit-learn官网:http://scikit-learn.org/stable/ 通常情况下,一个学习问题会包含一组学习样本数据,计算机通过对样本数据的学习,尝试对未知数据进行预测. 学习 ...

  8. Query意图分析:记一次完整的机器学习过程(scikit learn library学习笔记)

    所谓学习问题,是指观察由n个样本组成的集合,并根据这些数据来预测未知数据的性质. 学习任务(一个二分类问题): 区分一个普通的互联网检索Query是否具有某个垂直领域的意图.假设现在有一个O2O领域的 ...

  9. Python第三方库(模块)"scikit learn"以及其他库的安装

    scikit-learn是一个用于机器学习的 Python 模块. 其主页:http://scikit-learn.org/stable/. GitHub地址: https://github.com/ ...

  10. Linear Regression with Scikit Learn

    Before you read  This is a demo or practice about how to use Simple-Linear-Regression in scikit-lear ...

随机推荐

  1. DVWA--File Inclusion(不能远程包含的问题解决)

    然后别以为这样就完了 我被这样坑了一下午 找到你对应版本的php 进去Ctrl+f 搜索url_allow——fopen 和include

  2. 数组 Kotlin(5)

    数组 数组在 Kotlin 中使用 Array 类来表示,它定义了 get 和 set 函数(按照运算符重载约定这会转变为 [] ) 和 size 属性,以及一些其他有用的成员函数:基本类型 clas ...

  3. kolla-ansible-----常用命令

    常用命令 kolla-ansible prechecks -i multinode #部署前环境检测 kolla-genpwd #生成/etc/kolla/password.yml密码配置文件 kol ...

  4. 使用django-cors-headers 来解决跨域问题

    在settting里面这样配置 ALLOWED_HOSTS = ["*"] # Application definition INSTALLED_APPS = [ 'django. ...

  5. 托管C++中System::String^ 转换为 char*

    https://docs.microsoft.com/en-us/cpp/dotnet/how-to-convert-system-string-to-standard-string?view=vs- ...

  6. 阶段3 2.Spring_03.Spring的 IOC 和 DI_2 spring中的Ioc前期准备

    适应配置的方式解决我们刚才的编码操作 -dist结尾的就是spring 的开发包 解压好的 这里面是约束 libs是扎包 三个为一组,实际上只有21个 自己在使用需要导入jar包的时候,选择这种没有任 ...

  7. rocketmq的一些内容

    分布式开放消息系统(RocketMQ)的原理与实践 作者 CHEN川 关注 2016.02.25 15:43* 字数 6784 阅读 122302评论 41喜欢 321赞赏 7 一年前为了一次内部分享 ...

  8. 第 10 章 python进程与多进程

    一.背景知识 顾明思义,进程即正在执行的一个过程,进程是对正在云的程序的一个抽象. 进程的概念起源与操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一,操作系统的其他所 ...

  9. logstash 写入数据到elasticsearch 索引相差8小时解决办法

    问题说明 Logstash用的UTC时间, logstash在按每天输出到elasticsearch时,因为时区使用utc,造成每天8:00才创建当天索引,而8:00以前数据则输出到昨天的索引 # 使 ...

  10. 浅谈 MySQL的预编译

    之前的一篇 Mybatis中 #{}和${}的区别 中涉及到通过 SQL预编译和 #{} 传值 的方式防止SQL注入. 由此引发了想了解预编译的想法.那么什么是预编译那? 一.三个阶段: 词法和语义解 ...