0

0

PHP 中的机器学习:使用 Rubix ML 构建新闻分类器

花韻仙語

花韻仙語

发布时间:2024-11-02 11:10:09

|

688人浏览过

|

来源于dev.to

转载

php 中的机器学习:使用 rubix ml 构建新闻分类器

介绍

机器学习无处不在——推荐电影、标记图像,现在甚至对新闻文章进行分类。想象一下如果您可以在 php 中做到这一点!借助 rubix ml,您可以以简单易懂的方式将机器学习的强大功能引入 php。本指南将引导您构建一个简单的新闻分类器,将文章分类为“体育”或“技术”等类别。最后,您将拥有一个工作分类器,可以根据新文章的内容预测其类别。

这个项目非常适合想要使用 php 进行机器学习的初学者,您可以按照 github 上的完整代码进行操作。

目录

  1. 什么是 rubix ml?
  2. 设置项目
  3. 创建新闻分类类
  4. 训练模型
  5. 预测新样本
  6. 最后的想法

rubix 机器学习是什么?

rubix ml 是一个 php 机器学习库,它将 ml 工具和算法引入 php 友好的环境中。无论您从事分类、回归、聚类,甚至自然语言处理,rubix ml 都能满足您的需求。它允许您加载和预处理数据、训练模型并评估性能——所有这些都在 php 中进行。

rubix ml 支持广泛的机器学习任务,例如:

立即学习PHP免费学习笔记(深入)”;

  • 分类:对数据进行分类,例如将电子邮件标记为垃圾邮件或非垃圾邮件。
  • 回归:预测连续值,例如房价。
  • 聚类:对没有标签的数据进行分组,就像寻找客户群一样。
  • 自然语言处理 (nlp):处理文本数据,例如标记并将其转换为 ml 可用的格式。

让我们深入了解如何使用 rubix ml 在 php 中构建简单的新闻分类器!

设置项目

我们将首先使用 rubix ml 设置一个新的 php 项目并配置自动加载。

第1步:初始化项目目录

创建一个新的项目目录并导航到其中:

mkdir newsclassifier
cd newsclassifier

第 2 步:安装 rubix ml 和 composer

确保您已安装 composer,然后通过运行以下命令将 rubix ml 添加到您的项目中:

composer require rubix/ml

步骤3:在composer.json中配置自动加载

要从项目的 src 目录自动加载类,请打开或创建一个composer.json 文件并添加以下配置:

{
    "autoload": {
        "psr-4": {
            "newsclassifier\\": "src/"
        }
    },
    "require": {
        "rubix/ml": "^2.5"
    }
}

这告诉 composer 自动加载 newsclassifier 命名空间下 src 文件夹中的任何类。

第 4 步:运行 composer autoload dump

添加自动加载配置后,运行以下命令重新生成 composer 的自动加载器:

缤纷企业管理系统
缤纷企业管理系统

本程序源码全部公开,仅供学习交使用,请误用于商业用途,网页编辑器采用的是FreeTextBox。主要功能模块如下:常规管理 基本设置 | 友情链接 新闻中心 添加新闻 | 管理新闻 作品展示 分类管理 | 作品管理 | 添加作品 | 设想中... 人才招聘 招聘列表 | 添加招聘 关于我们 关于我们 | 添加新项 其它管理 管理员密码变更 客户留言管理 上传图片

下载
composer dump-autoload

第5步:目录结构

您的项目目录应如下所示:

newsclassifier/
├── src/
│   ├── classification.php
│   └── train.php
├── storage/
├── vendor/
├── composer.json
└── composer.lock
  • src/:包含您的 php 脚本。
  • storage/:训练后的模型的保存位置。
  • vendor/:包含 composer 安装的依赖项。

创建新闻分类类

在 src/ 中,创建一个名为 classification.php 的文件。该文件将包含训练模型和预测新闻类别的方法。

modelpath = $modelpath;
    }

    public function train()
    {
        // sample data and corresponding labels
        $samples = [
            ['the team played an amazing game of soccer'],
            ['the new programming language has been released'],
            ['the match between the two teams was incredible'],
            ['the new tech gadget has been launched'],
        ];

        $labels = [
            'sports',
            'technology',
            'sports',
            'technology',
        ];

        // create a labeled dataset
        $dataset = new labeled($samples, $labels);

        // set up the pipeline with a text transformer and k-nearest neighbors classifier
        $estimator = new pipeline([
            new wordcountvectorizer(10000, 1, 1, new word()),
            new tfidftransformer(),
        ], new knearestneighbors(4));

        // train the model
        $estimator->train($dataset);

        // save the model
        $this->savemodel($estimator);

        echo "training completed and model saved.\n";
    }

    private function savemodel($estimator)
    {
        $persister = new filesystem($this->modelpath);
        $model = new persistentmodel($estimator, $persister);
        $model->save();
    }

    public function predict(array $samples)
    {
        // load the saved model
        $persister = new filesystem($this->modelpath);
        $model = persistentmodel::load($persister);

        // predict categories for new samples
        $dataset = new unlabeled($samples);
        return $model->predict($dataset);
    }
}

此分类类包含以下方法:

  • 训练:创建并训练基于管道的模型。
  • 保存模型:将训练好的模型保存到指定路径
  • 预测:加载保存的模型并预测新样本的类别。

训练模型

在 src/ 中创建一个名为 train.php 的脚本来训练模型。

train();

运行此脚本来训练模型:

php src/train.php

如果成功,您将看到:

training completed and model saved.

预测新样本

在 src/ 中创建另一个脚本,predict.php,根据训练的模型对新文章进行分类。

predict($samples);

// display predictions
foreach ($predictions as $index => $prediction) {
    echo "sample: " . $samples[$index][0] . "\n";
    echo "prediction: " . $prediction . "\n\n";
}

运行预测脚本对样本进行分类:

php src/predict.php

输出应显示每个示例文本及其预测类别。

最后的想法

通过本指南,您已经使用 rubix ml 在 php 中成功构建了一个简单的新闻分类器!这展示了 php 如何比您想象的更加通用,为文本分类、推荐系统等任务引入机器学习功能。该项目的完整代码可在 github 上获取。

尝试不同的算法或数据来扩展分类器。谁知道 php 可以进行机器学习?现在你知道了。
快乐编码!

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2812

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1688

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1548

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1036

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1485

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1256

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1589

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1307

2023.11.13

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

8

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.9万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号