Python机器学习-分类「建议收藏」

Python机器学习-分类「建议收藏」监督学习下的分类模型,主要运用sklearn实践kNN分类器kNN分类器决策树决策树朴素贝叶斯朴素贝叶斯实战一:预测股市涨跌实战一:预测股市涨跌实战二:通过运动传感器采集的数据分析运

大家好,又见面了,我是你们的朋友全栈君。

  • 监督学习下的分类模型,主要运用sklearn实践
  • kNN分类器

Python机器学习-分类「建议收藏」

Python机器学习-分类「建议收藏」

Python机器学习-分类「建议收藏」

 

Python机器学习-分类「建议收藏」

  • 决策树

Python机器学习-分类「建议收藏」

Python机器学习-分类「建议收藏」

Python机器学习-分类「建议收藏」

  • 朴素贝叶斯

Python机器学习-分类「建议收藏」

Python机器学习-分类「建议收藏」

Python机器学习-分类「建议收藏」

Python机器学习-分类「建议收藏」

 Python机器学习-分类「建议收藏」

 

  •  实战一:预测股市涨跌

# -*- coding: utf-8 -*-
"""
Created on Mon Aug 28 15:42:55 2017

@author: Administrator
"""

# unit4 classify

#数据介绍:
#网易财经上获得的上证指数的历史数据,爬取了20年的上证指数数据。
#实验目的:
#根据给出当前时间前150天的历史数据,预测当天上证指数的涨跌。

import pandas as pd
import numpy as np
from sklearn import svm
from sklearn import cross_validation

fpath='F:\RANJIEWEN\MachineLearning\Python机器学习实战_mooc\data\classify\stock\\000777.csv'

data=pd.read_csv(fpath,encoding='gbk',parse_dates=[0],index_col=0)
data.sort_index(0,ascending=True,inplace=True)

dayfeature=150
featurenum=5*dayfeature
x=np.zeros((data.shape[0]-dayfeature,featurenum+1))
y=np.zeros((data.shape[0]-dayfeature))

for i in range(0,data.shape[0]-dayfeature):
    x[i,0:featurenum]=np.array(data[i:i+dayfeature] \
          [[u'收盘价',u'最高价',u'最低价',u'开盘价',u'成交量']]).reshape((1,featurenum))
    x[i,featurenum]=data.ix[i+dayfeature][u'开盘价']
 
for i in range(0,data.shape[0]-dayfeature):
    if data.ix[i+dayfeature][u'收盘价']>=data.ix[i+dayfeature][u'开盘价']:
        y[i]=1
    else:
        y[i]=0          
 
clf=svm.SVC(kernel='rbf')
result = []
for i in range(5):
    x_train, x_test, y_train, y_test = \
                cross_validation.train_test_split(x, y, test_size = 0.2)
    clf.fit(x_train, y_train)
    result.append(np.mean(y_test == clf.predict(x_test)))
print("svm classifier accuacy:")
print(result)
  • 实战二:通过运动传感器采集的数据分析运行状态

# -*- coding: utf-8 -*-
"""
Created on Mon Aug 28 19:41:21 2017

@author: Administrator
"""

'''
现在收集了来自 A,B,C,D,E 5位用户的可穿戴设备上的传感器数据,
每位用户的数据集包含一个特征文件(a.feature)和一个标签文件
(a.label)
特征文件中每一行对应一个时刻的所有传感器数值,标签文件中每行记录了
和特征文件中对应时刻的标记过的用户姿态,两个文件的行数相同,相同行
之间互相对应
标签文件内容如图所示,每一行代表与特征文件中对应行的用户姿态类别。
总共有0-24共25种身体姿态,如,无活动状态,坐态、跑态等。标签文件作为
训练集的标准参考准则,可以进行特征的监督学习。

假设现在出现了一个新用户,但我们只有传感器采集的数据,那么该如何得到
这个新用户的姿态呢?
或者对同一用户如果传感器采集了新的数据,怎么样根据新的数据判断当前
用户处于什么样的姿态呢?
'''

import pandas as pd
import numpy as np

from sklearn.preprocessing import Imputer
from sklearn.cross_validation import train_test_split
from sklearn.metrics import classification_report

from sklearn.neighbors import KNeighborsClassifier
from sklearn.tree import DecisionTreeClassifier
from sklearn.naive_bayes import GaussianNB

def load_datasets(feature_paths,label_paths):
    feature=np.ndarray(shape=(0,41))
    label=np.ndarray(shape=(0,1))
    for file in feature_paths:
        df=pd.read_table(file,delimiter=',',na_values='?',header=None)
        imp=Imputer(missing_values='NaN',strategy='mean',axis=0)
        imp.fit(df)
        df=imp.transform(df)
        feature=np.concatenate((feature,df))
        
    for file in label_paths:
        df=pd.read_table(file,header=None)
        label=np.concatenate((label,df))
    
    label=np.ravel(label)
    return feature,label
        
if __name__ == '__main__':
    ''' 数据路径 '''
    fpath='F:/RANJIEWEN/MachineLearning/Python机器学习实战_mooc/data/classify/dataset/'
    featurePaths = [fpath+'A/A.feature',fpath+'B/B.feature',fpath+'C/C.feature',fpath+'D/D.feature',fpath+'E/E.feature']
    labelPaths = [fpath+'A/A.label',fpath+'B/B.label',fpath+'C/C.label',fpath+'D/D.label',fpath+'E/E.label']
    ''' 读入数据  '''
    x_train,y_train = load_datasets(featurePaths[:4],labelPaths[:4])
    x_test,y_test = load_datasets(featurePaths[4:],labelPaths[4:])
    x_train, x_, y_train, y_ = train_test_split(x_train, y_train, test_size = 0.0)
     
    print('Start training knn')
    knn = KNeighborsClassifier().fit(x_train, y_train)
    print('Training done')
    answer_knn = knn.predict(x_test)
    print('Prediction done')
     
    print('Start training DT')
    dt = DecisionTreeClassifier().fit(x_train, y_train)
    print('Training done')
    answer_dt = dt.predict(x_test)
    print('Prediction done')
     
    print('Start training Bayes')
    gnb = GaussianNB().fit(x_train, y_train)
    print('Training done')
    answer_gnb = gnb.predict(x_test)
    print('Prediction done')
     
    print('\n\nThe classification report for knn:')
    print(classification_report(y_test, answer_knn))
    print('\n\nThe classification report for DT:')
    print(classification_report(y_test, answer_dt))
    print('\n\nThe classification report for Bayes:')
    print(classification_report(y_test, answer_gnb))
  • result

Python机器学习-分类「建议收藏」

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/156059.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月5日 下午10:36
下一篇 2022年7月5日 下午10:46


相关推荐

  • SpringCloud SpringCloud与Dubbo的区别

    SpringCloud SpringCloud与Dubbo的区别(1)SpringCloud与Dubbo的服务治理框架全局性对比(2)最大的区别:SpringCloud抛弃了Dubbo的RPC通信,采用了基于HTTP的REST方式。严格来说,这两种方式各有优劣,虽然从一定程度上来说,后者牺牲了服务调用的性能,但是也避免了RPC带来的问题,并且REST相比RPC更为灵活,服务提供方和调用方的依赖只依靠一纸协议,不存在代码的强依赖性,这在强调快速演化稍…

    2022年5月29日
    37
  • 动态sql模糊查询和分页「建议收藏」

    动态sql模糊查询和分页「建议收藏」文章目录动态sql模糊查询查询返回结果集的处理分页动态sqlBookMapperxmlbookservice测试:MapperSql.test运行:模糊查询BookMapperBookMapper.xmlBookserviceStringUtiles测试:一共介绍了三种模糊查询的方法,对比第三种更加实用。运行:查询返回结果集的处理BookM…

    2022年5月9日
    39
  • Java 处理json经常使用代码

    Java 处理json经常使用代码

    2022年1月28日
    127
  • Mac部署OpenClaw 从安装到造出诸葛亮、小乔、张良三个AI助手

    Mac部署OpenClaw 从安装到造出诸葛亮、小乔、张良三个AI助手

    2026年3月13日
    5
  • python电脑攻击_python实现MAC洪水攻击

    python电脑攻击_python实现MAC洪水攻击前言 一般交换机在数据转发过程中 依靠对 CAM 表的查询来确定正确的转发接口 如果在 CAM 表中查询不到 则将该数据帧作为广播帧处理 CAM 表存储数量有限 当数据到达上限之后将不会存储 根据此原理 可以通过在刷新时间内对其发送足够多的不同 MAC 地址的伪造数据包来占用 CAM 表 这种情况下 所有经过交换机的数据帧都会被作为广播帧处理 然后就可以获取到所有经过交换机的正常数据帧 并且交换机模式会降为 Hub 模

    2026年3月18日
    2
  • 架构之美读书笔记之三

    架构之美读书笔记之三架构之美第三章问题 品质需求 1 系统的伸缩性需求 如大型在线游戏 需要满足大量用户 在线用户数量短时间内可能有很大的变化 这其中隐含的需求是 多用户并行分布式系统 系统运行在多台机器上高可扩展性 用于加入新的故事情节 意味着新的代码 高稳定性 可靠性 一个用户崩溃 不影响其他用户 数据一致性 多个用户看到同一个东西的状态应该是一样的 2

    2026年3月16日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号