zoukankan      html  css  js  c++  java
  • 机器学习 ---- Accord.Net之HelloWorld

    开发环境配置

    1.本系列博文主要以VS2017版本介绍,具体安装方法请参照官方说明;

    2.模块的引用请参照上一小结;

    创建新项目

    本章节将从启动Visual Studio开始,逐步介绍开发如何使用Accord.Net开发一个简单的事例,以决策树分类为例。

    Visual启动后,选择【文件】->【新建项目】

    在弹出的新建对话框中,以Visual C#分类下选择【控制台应用程序】。在本章节中虽然创建的事例是C#语言,但Accord.Net同样支持所有.Net兼容的语言,如VB.Net或C++/CLI。

     给新建的项目添加引用。具体操作可参考上一节介绍的两种方法,在这里通过命令的方式添加了Accord.MachineLearning模块。

    PM>Install-Package Accord.MachineLearning

    编码

    现在准备开发应用程序。下面将演示如何创建和训练一个决策树模型识别一个西瓜是否为好瓜,关于决策树的相关介绍大家可以看看周志华的《机器学习》一书,在这里就不在累赘相关的原理。问题关键在学习下面的训练集:

    西瓜数据集

    编号(No)

    Color(色泽)Root(根蒂)Sound(敲声)Result(好瓜)

    1

    青绿 蜷缩 浊响

    2

    乌黑 蜷缩 浊响

    3

    青绿 硬挺 清脆

    4

    乌黑 稍蜷 沉闷

    输入数据集inputs由Color、Root、Sound、Good三列组成,对应的输出数据集output由Result组成,在这里主要采用C45方法进行训练,关键代码如下:

    1.  
      //1.创建数据集
    2.  
      DataTable data = new DataTable("Watermelon Example");
    3.  
       
    4.  
      data.Columns.Add("No", typeof(string));
    5.  
      data.Columns.Add("Color", typeof(string));
    6.  
      data.Columns.Add("Root", typeof(string));
    7.  
      data.Columns.Add("Sound", typeof(string));
    8.  
      data.Columns.Add("Result", typeof(string));
    9.  
       
    10.  
      data.Rows.Add("1", "青绿", "蜷缩", "浊响", "是");
    11.  
      data.Rows.Add("2", "乌黑", "蜷缩", "浊响", "是");
    12.  
      data.Rows.Add("3", "青绿", "硬挺", "清脆", "否");
    13.  
      data.Rows.Add("4", "乌黑", "稍蜷", "沉闷", "否");
    14.  
       
    15.  
      data.Rows.Add("5", "青绿", "蜷缩", "浊响", "是");//用于预测
    16.  
       
    17.  
      //2.创建Codification用于把字符串转化为整型
    18.  
      Codification codebook = new Codification(data);
    19.  
      DecisionVariable[] attributes =
    20.  
      {
    21.  
      new DecisionVariable("Color",codebook["Color"].NumberOfClasses),
    22.  
      new DecisionVariable("Root",codebook["Root"].NumberOfClasses),
    23.  
      new DecisionVariable("Sound",codebook["Outlook"].NumberOfClasses)
    24.  
      };
    25.  
       
    26.  
      int classCount = codebook["Result"].NumberOfClasses;
    27.  
       
    28.  
      //3.创建C45决策树
    29.  
      tree = new DecisionTree(attributes, classCount);
    30.  
      C45Learning c45 = new C45Learning(tree);
    31.  
       
    32.  
      DataTable symbols = codebook.Apply(data);
    33.  
      inputs = symbols.ToJagged("Color", "Root", "Sound");
    34.  
      outputs = symbols.ToArray<int>("Result");
    35.  
       
    36.  
      c45.Learn(inputs, outputs);

      测试代码:

    1.  
      static void Main(string[] args)
    2.  
      {
    3.  
      DecisionTree tree;
    4.  
      double[][] inputs;
    5.  
      int[] outputs;
    6.  
       
    7.  
      CreateDecisionTreeExample(out tree, out inputs, out outputs);
    8.  
       
    9.  
      int result = tree.Decide(inputs[4]);
    10.  
       
    11.  
      Console.WriteLine("该瓜是否是好瓜:" + (result == 0 ? "是" : "否"));
    12.  
      Console.ReadKey();
    13.  
      }

    运行结果如图所示

    出处:https://blog.csdn.net/lynchee/article/details/82718330

  • 相关阅读:
    Go 1.16新特性embed包及其使用
    PHP汉字转拼音的方法
    git diff ^M的消除
    转 C/C++中extern关键字详解
    idea安装步骤_IntelliJ IDEA 2019.3安装激活教程
    intellij idea 的全局搜索快捷键方法
    多边形面积计算及顶点顺逆时针方向判断
    凸多边形碰撞检测的分离轴算法(SAT)
    使用PCA方法创建OBB(oriented boundingbox)包围盒
    2021/12/08今日旧闻
  • 原文地址:https://www.cnblogs.com/mq0036/p/12737213.html
Copyright © 2011-2022 走看看