算法基础与开发流程

Posted ywjfx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法基础与开发流程相关的知识,希望对你有一定的参考价值。

# coding = utf-8
from sklearn import datasets
from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
‘‘‘
算法是核心,数据和计算是基础
定位:
    1、分析数据
    2、分析业务
    3、应用常见算法进行对比校验
    4、特征工程、调参、优化

数据类型
    离散型数据:由记录不同类别个体的数目所得到的数据,又称计数数据,所以数据全是整数
    连续型数据:变量可以在某一范围内任取一数,即变量的取值是可以连续的,通常是小数
    注意:离散型是区间内不可分,连续型区间内可分

算法分类:
    监督学习:特征值和目标值
        分类(目标值是离散型):K近邻,贝叶斯、决策树、随机森林、逻辑回归、神经网络
        回归(目标值是连续型):线性回归、岭回归
    非监督学习:特征值
        聚类:K均值(K-means)

算法开发流程:
    1、准备数据
        公司本身数据
        kaggle
        购买数据
    2、明确问题(分类还是回归)
        建立算法数据:根据数据类型划分应用种类
    3、数据基本处理
        pd去处理数据(缺失值,合并表....)
    4、特征工程
        特征进行处理(训练集,测试集、验证集)
    5、找寻合适的算法进行分析
        1、估计器选择
        2、调用fit(x_train,y_train)
        3、调用    a)预测:y_predict=predict(x_test)     b)预测的准确率:score(x_test,y_test)
    6、模型的评估  ---->评估不合格,则考虑:1、换算法 2、调参数 3、特征工程再进一步处理
    7、模型实现预测,以API形式提供


数据集划分
    训练集:70%     75%(建议)     80%
    测试集:30%     25%(建议)     20%
    验证集
    API: Sklearn.model_selection.train_test_split(*arrays, **options)
        x           数据集的特征值
        y        数据集的标签值
        test_size      测试集的大小,一般为float
        random_state        随机数种子,不同的种子会造成不同的随机
        采样结果。相同的种子采样结果相同。
        return  训练集特征值,测试集特征值,训练标签,测试标签
        (默认随机取)    
    
Sklearn数据集Api
    datasets.load_*() #获取小规模数据集
    datasets.fetch_*(data_home=None) #获取大的数据集  
    
    小数据集:
        load*和fetch*返回的数据类型datasets.base.Bunch(字典格式)
            data:特征数据数组,是 [n_samples * n_features] 的二维 
                  numpy.ndarray 数组
            target:标签数组,是 n_samples 的一维 numpy.ndarray 数组
            DESCR:数据描述
            feature_names:特征名,新闻数据,手写数字、回归数据集没有
            target_names:标签名,回归数据集没有
    大数据集:
        sklearn.datasets.fetch_20newsgroups(data_home=None,subset=‘train’)
            subset: ‘train‘或者‘test‘,‘all‘,可选,选择要加载的数据集.
            训练集的“训练”,测试集的“测试”,两者的“全部”
    
    清除数据:
        datasets.clear_data_home(data_home=None)
            清除目录下的数据

转换器:
    fit_transform():输入数据直接转换   
    
    fit():输入数据,不做转换,但会计算一些平均值,方差等
    transform():进行数据的转换
    注意:fit_transform = fit + transform

估计器:是一类实现了算法的API
    1、用于分类的估计器:
        sklearn.neighbors    k-近邻算法
        sklearn.naive_bayes      贝叶斯
        sklearn.linear_model.LogisticRegression     逻辑回归
    2、用于回归的估计器:
        sklearn.linear_model.LinearRegression     线性回归
        sklearn.linear_model.Ridge      岭回归 
    
    

    
‘‘‘


def iris():
    """
    数据切分
    :return:
    """
    li = load_iris()

    x_train,x_test,y_train,y_test = train_test_split(li.data,li.target,test_size=0.25)
    print("训练集数据特征值",x_train)
    print("训练集数据目标值", y_train)


if __name__ == "__main__":
    iris()

 

以上是关于算法基础与开发流程的主要内容,如果未能解决你的问题,请参考以下文章

编程思想与算法

常用编程思想与算法

知识图谱基础概念开发流程以及落地策略

基于能量均衡LEACH改进算法matlab代码

基于能量均衡LEACH改进算法matlab代码

基于能量均衡LEACH改进算法matlab代码