聊聊传统算法系统和机器学习系统的一点不同
这里就简单聊聊传统算法系统与机器学习系统的一点不同。
1 传统算法系统
传统算法系统,是已经给定了一个算法处理逻辑,那么你给我的输入,我按照这个算法处理逻辑进行处理,就能得到相应的输出。如下图:
2 机器学习系统
而机器学习系统,是给定我们数据的输入输出(这里先指监督学习),让我们从这些数据中学习出算法,以后,通过这个学习到的算法模型进行给定输入的判断,得到输出。如下图:
3 例子:
在我们传统的算法系统中,我们的要求是,给定一个数n,让我们输出1+2...+n的结果。
我们很容易由等差数列求和公式得到算法程序如下:
# include <stdio.h>
double get_sum(int n)
{
double ans;
ans = n(1+n)/2.0; //等差数列求和公式
return ans;
}
int main(void)
{
double res;
int n;
printf("please input an integer:\n");
scanf("%d",&n);
res = get_sum(n);
printf("%lf\n",res);
}
根据上面算法流程,我们来了一个数n,直接用程序跑一下,就能得到结果!
那我们的机器学习系统是否也能够直接编写判断逻辑算法呢?
用一个机器学习最经典的入门例子来解释,手写数字识别。
比如我们要判断一个手写数字是几。按照我们的思维逻辑,我们需要写10个if else来分别判断是不是0,是不是1,....是不是9
比如我们判断是不是2,就会有下面判断
if(满足是2的条件){
printf(这个手写数字是2);}else{
printf(这个手写数字不是2);}
恩,看起来我们好像完成任务了。
但是,if(满足是2的条件)
这个满足是2的条件怎么写呢?
我们先看看2是什么样子,如下:
我们可以根据这个标准的2和其它数字的特征不同来写嘛,比如2最下面是一行横线,2的中间有个弯弧,等等。
哈哈,看似解决问题了,其它的数字类似,我只要找到和其它数字的不同,就能找到if()中的满足是数字为几的条件。
那么岂不是也就满足要求了,为什么还需要机器学习算法呢?
问题没有这么简单。我们真正碰到的手写数字2,根本就不会有上图2这么标准,各种各样的都有,比如下图:
上图这些数字,我们人眼观察还是能够大部分认识是2,但是它跟我们刚刚说的满足2的特征吗?上面好几个都没有最下面一行是横线,等等,我们无法一一列出现实生活中的各种情况。
那么就需要我们的机器学习算法,自动的学习到里面的特征,从而构建出一个机器学习模型,进而帮助我们判断一个手写数字是否为2.和判断一个手写数字是几。
上面这俩个例子,其实从某种程度上,能反应俩种系统的本质区别。欢迎大家指错交流~
推荐阅读文章:
通俗理解信息熵
带你搞懂朴素贝叶斯分类算法
理解朴素贝叶斯算法中的拉普拉斯平滑
可视图讲解神经元w,b参数的作用
近期文章预告:
《深入浅出讲解支持向量机》
开通了[自然语言处理与机器学习]公众号,里面除了干货还是干货,欢迎按住下面二维码扫描关注!