Thundersvm源码查看学习

Thundersvm源码查看学习

评估器(Estimator)和辅助类(Mixin)

在库引入部分, 看到thundersvmsklearn.base中继承了两个类

image-20230629150025202

一个是BaseEstimator评估器基类, 另一个是Mixin辅助类

在 scikit-learn 中,评估器是实现机器学习算法的对象,用于对数据进行拟合和预测。例如,线性回归模型、决策树分类器等都是评估器。

Mixin是一种用于在类中混合(mix-in)功能的技术, 这里只引入了两种Mixin: RegressionMixinClassfierMixin, 即回归任务和分类任务

这两个 mixin 类提供的主要功能如下:

  1. RegressorMixin 提供了回归任务中常用的方法和属性,例如 fit(拟合模型)、predict(进行预测)、score(计算模型的性能得分)等。
  2. ClassifierMixin 提供了分类任务中常用的方法和属性,例如 fitpredictscore,以及其他一些分类特定的方法,如 predict_proba(返回样本属于每个类别的概率)、**decision_function(返回样本的决策函数值)**等。

在评估器sklearn.base的源码中, 可以看到如下函数

image-20230629150102997

关于BaseEstimator基本上都是一些参数的获取和设置相关的函数, 即BaseEstimator主要实现的就是参数的传入和设置相关功能

image-20230629151232600

关于Mixin有多种类型, 其主要实现的就是模型训练和评估等相关功能

问题

那么在最开始的介绍中说, 评估器用于对数据进行拟合和预测, 但是看到源码其实现的都是一些参数传递设置相关的函数

  • 那么在评估器中拟合和预测是怎么进行的呢?
  • 而Mixin中主要实现了模型的训练和评估等函数, 其和Mixin辅助类之间的关系是什么?
  • 其具体的组合和调用方式是什么?

理解

很明显,评估器会调用辅助类中的函数.

评估器类通常会定义一些通用的方法,如参数传入和返回的函数,但不会直接定义具体的训练和评估函数。相反,评估器类会利用继承的辅助类来实现具体的训练和评估功能。

也就是说sklearn.base函数构建的思想基于以下几点:

  • 参数传入设置等基础函数训练中的函数的定义分隔开, 因为训练任务类型较多, 所以对每一中训练类型进行相关的函数定义, 然后在具体的训练函数调用中进行实现
  • 参数传入设置等基础函数作为评估器的主体部分作为baseEstimator
  • 在具体的Estimator中继承BaseEstimator中的变量和函数定义, 用于实现具体的训练细节
  • 对于不同类别的训练任务,考虑到所需要的功能不统一, 有些任务需要特定的函数, 所以定义不同类别的Mixin基类

在具体的任务中,例如svm, 肯定要构建svm的评估器, 该评估器继承BaseEstimator,然后根据svm训练的任务类型调用相应的Mixin辅助类进行模型的训练和评估

而且thundersvm也正是这样的实现方式

image-20230629153235999

对其进行命名之后在svm模型中继承ThundersvmBase也就是BaseEstimator

image-20230629153414339

image-20230629153424272

然后传入参数和实现相关的函数

OS验证识别

image-20230629154153669

可以看到Thundersvm对于WindowsLinuxMac都是支持的

darwin指的是达尔文即Mac OS,和Windows没有关系

函数实现

image-20230630085928474

其只对SvmModel进行了详细的实现, 对于其他的算法均采用继承SvmModel的方式, 并根据算法和相对应的任务类型添加Mixin辅助类的继承

挖个坑 - 考完研把里面的具体实现研究一下

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Every DAV inci

小辣鸡一枚,不求打赏啦~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值