机器学习之机器如何学习

news2024/11/25 21:31:33

通过Julia的语法、函数、编译器使机器学习技术变得更加简单。

1、机器学习如何工作

通过机器学习,研究人员可以构造算法,使计算机自身能够在大量的数据中找到数学模式,而这是人类不可能做到的。想想看: 如果我问你,你怎么知道一张照片中的动物是猫还是狗,你会怎么说?你可能会看看动物的胡须、脸形和耳朵。但是,你要如何从数学模式上判断这个动物是否有胡须呢?你能写出一个数学公式获取图像的像素值,并将其转换为动物物种的分类器吗?

当然不能,因为人类几乎不可能这样做,我们以前尝试过。事实上,有一个叫作特征工程(feature engineering)的研究领域,但对于稍微复杂的任务,它完成得从来都不理想。

这就是机器学习存在的原因,它可以使计算机为我们找到这些数学公式。

就像人类从经验中学习一样,机器学习算法也是如此。你可以在一个数据集上“训练”一个机器学习算法,它将尝试“建模”该数据集,并理解从输入到输出映射的数据集中的复杂性和模式。但是,训练人类和训练机器有一个关键区别: 人类可以从少数几个样本中学习,但是机器却需要从成百上千,甚至数百万个样本中学习。

如果你要向那些从来没见过吹雪机和割草机的人口头描述它们的区别,他们一定能很好地区分它们。但是,如果你希望计算机将图像分为这两类,那么你至少需要提供数百个视觉样本,才能得到可接受的结果。

此外,训练这些算法需要很强大的计算能力,而Julia恰好比较擅长这件事。

2、使用Flux的样式传递

Julia提供了一个叫作Flux的包,它可以帮助你解决许多问题!Flux包的一部分被称为Metalhead project,它可以使你在计算机上使用预先训练过的机器学习算法,而不必自己训练它们。让我们来看一个例子。

首先,请打开REPL并添加以下软件包:

① Flux
② Metalhead
③ Images
④ PyCall

以下是使用的命令:

using Pkg
Pkg.add("Flux")
Pkg.add("Metalhead")
Pkg.add("Images")
Pkg.add("PyCall")

现在,打开一个新的Julia文件,并输入以下代码:

Code Listing 9.1, ImageClassifier.jl
using Metalhead: VGG19, preprocess, load, labels
using Flux: onecold

model =VGG19()
class_labels =labels(model)

print("Enter the name of your file: ")
user_image =preprocess(load(readline()))
model_prediction =model(user_image)
top_class =onecold(model_prediction)\[1\]
class_name =labels\[top_class\]

println("I think this image contains: $(class_name)")

从数学和机器学习的角度来看,这是比较简单的工作,但因为你对此还比较陌生,所以我不会深入讲解模型本身的工作原理。然而,Julia代码非常简单,你应该可以理解此文件中的大部分代码。这就是Julia和Flux的优雅之处,你不需要编写非常复杂的代码以使用机器学习模型。

现在你可以拍一些照片,可以是你的宠物、电脑、电视或你自己,或者你可以从网上下载一张照片,将它们放在与你刚刚编写的Julia代码文件相同的目录中,然后运行该代码。

当你第一次运行该代码时,它将会从网上下载名为VGG19的机器学习模型(VGG19表示Oxford Visual Geometry Group’s 19-layer model)。根据你的网络环境,这可能需要几分钟的时间。

然而,无论你运行了多少次代码,它都会继续初始化模型。一旦模型加载后,你将看到一个请求图像文件的提示。输入文件的名称和扩展名,然后按Enter键。几秒后,代码应该会输出它在图像中看到的内容。例如,假设有一张如图1所示的称为cat.jpg的图像。

■ 图1 测试图像分类器程序的猫图像

这是我与程序之间的交互:

Enter the name of your file: cat.jpg
I think this image contains: Egyptian cat

结果非常接近,应用程序在图像中看到一只Egyptian cat。这真的很棒,但这并不是什么新鲜事,这种技术已经存在很多年了,如果你使用Apple Photos或Google Photos,你的图像会被自动分类。事实上,这些平台甚至可以自动进行面部识别,使你的生活更便捷。

那么如何用机器学习生成一些艺术作品呢?我们将使用一种称为梯度上升(gradient ascent)的技术生成DeepDream艺术作品。你可能还记得几年前的DeepDream,当时Google的研究人员可视化了“神经网络的激活”。我知道这听起来很复杂,在大多数语言中,即使是实现算法的一个简单版本也需要相当多的代码。

但在Julia中,这几乎是微不足道的。下面让我们实现一个可以获取图像并对其添加“艺术风格”的应用程序。打开一个新文件,输入以下代码:

Code Listing 9.2 DeepDream.jl
using Metalhead: VGG19,preprocess,load
using Flux: @epochs
using Statistics, PyCall, Flux.Tracker
using Images: RGB
np= pyimport("numpy")
Image = pyimport("PIL.Image")
function deprocess and pillow(img)([0.485,0.456,0.406], [0.229,0.224,0.225])队,=rgb = cat(collect(map(x-> (img[:,:,x,1].* [x]) .+ 从[x],1:3))..., dims= 3)rgb = np.uint8(np.interp(np.clip(rgb ./ 255,-1,1),以 (-1,1),(0,255)))
returnImage.fromarray(rgb).transpose(Image.FLIP LEFT RIGHT).Crotate(90)
end
model = VGG19().layers[1:11]
loss(x) = mean(model(x))
dloss(x) = Tracker.gradient(loss,x)[1]function calc gradient(x)g = Tracker.data(dloss(x))
return g * (mean(1.5 ./ abs.(g)) + 1e- 7)
end
print("Enter the name of your file: ")img = preprocess(load(readline()))
epochs 20 global img += calc gradient(img)deprocess and pillow(img).show()

在本例中,我不会深入讲解这段代码的工作原理,关键是让你看到使用Julia能够做些什么。

更多需要了解的内容:
从本质上说,这不是训练一个神经网络的权重,而是通过一个损失函数(loss function)找到对权重的梯度,我们通过使用一个可以使卷积神经网络中某层滤波器的均值最大化的函数找到了相对于输入的梯度。

现在,如果你再次运行该应用程序,它将加载该模型并请求你输入一个文件。这次我输入了一张自己的图像(见图2)。

■ 图2 输入DeepDream.jl的图片

我得到了如图3所示的输出。

■ 图3 DeepDream.jl生成的第一张艺术作品

哇!这是一张很棒的艺术作品。如果你将代码

model =VGG19().layers[1:11]

改为

model =VGG19().layers[1:end-10]

你应该会得到一张令人毛骨悚然的艺术作品(见图4)

■ 图4 DeepDream.jl生成的第二张艺术作品

好吧,这也太奇怪了。让我们将代码更改为

model =VGG19().layers[1:7]

现在,你应该会看到图5中的图像。

■ 图5 DeepDream.jl生成的第三张艺术作品

很好!关于这种艺术作品还有一些需要讲解的地方: 它不是计算机在画布上的基本图像上随机画出来的,事实上,该系统是在世界上最大的图像数据集上进行训练的,它包含超过1000个类别的100多万张图像。所以,如果你仔细观察,你可能会发现动物或其他类似于图像中描绘的物体的一些特征。例如,在生成的第二张图像中,你可能会在我的眼睛和嘴巴周围看到一些类似狗或其他动物的特征,这是因为在生成本艺术作品之前,这个系统的数据集中有很多动物。

你刚刚实现的一切都是由机器学习技术支持的,并且通过Julia的语法、函数和编译器使其变得非常简单。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/566277.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Padstack editor 绘制SMD Pin,Thru Pin和Via

一,椭圆形状的SMD PIN 的创建(例如:0.55/0.23 补偿后 0.95/0.28) 1,在select padstack usage 中选择 SMD Pin ;select pad geometry中选择 Oblong; 2,先将左下角 decimal places中的值设置为2&…

Java内部类(成员内部类、局部内部类、静态内部类、匿名内部类)

目录 ①. 什么是内部类 ②. 内部类的共性 ③. 为什么需要内部类 ④. 成员内部类 ⑤. 局部内部类 ⑥. 静态内部类(嵌套类) ⑦. 匿名内部类 ①. 什么是内部类 内部类是指在一个外部类的内部再定义一个类。内部类作为外部类的一个成员,并…

C++常用的支持中文的GUI库Qt 6之三: 项目的发布

C常用的支持中文的GUI库Qt 6之三: 项目的发布 本文接着上一篇“C常用的支持中文的GUI库Qt 6之二:项目的结构、资源文件的使用” https://blog.csdn.net/cnds123/article/details/130741807介绍,并使用其中的例子。 程序代码能正确编译运行&…

1. Tomcat整体架构及其设计精髓分析

MySQL性能调优 1.Tomcat的整体架构1.1 Tomcat介绍1.1.1 Servlet基础回顾 1.2 目录结构1.3 web应用部署的方式1.4 结合Server.xml理解Tomcat架构1.5 架构图 2. Tomcat核心组件详解2.1 Server 组件2.2 Service组件2.3 连接器Connector组件2.3.1 ProtocolHandler 组件2.3.1.1 EndP…

全志V3S嵌入式驱动开发(移植linux kernel和rootfs)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 除了少部分嵌入式设备使用vxworks和freertos之外,大部分嵌入式都是使用linux来做基础os来使用的。linux使用场景很多,除了大…

智慧城市同城V4小程序V2.24独立开源版 + 全插件+VUE小程序开源前端+最新用户授权接口

智慧城市同城V4小程序V2.22开源独立版本月最新版,与上一版相比修复了一些小细节,功能本身并无大的变化。新版系统包含全插件、包括很多稀缺收费的插件都在里面如括招聘、 家政等,外加小程序的VUE开源前端,整个系统全开源&#xff…

chatgpt赋能python:PythonTic:了解一种强大的测试框架

Python Tic: 了解一种强大的测试框架 当你编写代码时,测试通常是不可或缺的一部分。Python Tic是一个出色的测试框架,它可以帮助您自动化测试和验证您的代码。 简介 Python Tic是一种基于Python的测试框架,它能够测试您的代码的各个方面&a…

鹅厂程序员的9个生存法则

👉腾小云导读 本文作者在腾讯多年,主要从事的是腾讯云CDN、EdgeOne产品的后台研发工作。作者在云计算领域遇到了不少代码设计和程序设计的问题,他对于如何把项目中的代码标准化、提高开发维护的效率,做了总结梳理。本篇为各位分享…

解密Java Class文件不为人知的秘密

Java 诞生多年,因此在网络上,有关 Java Class 文件格式解析的文章有很多,但他们大多数都是在列举《Java 虚拟机》中定义的格式,通读下来,好像所有的东西都讲清楚了,但是我个人好像并没有看懂,不…

舵机云台实现体感姿态跟随功能

1. 功能说明 本文示例将实现R207样机舵机云台根据六轴陀螺仪传感器数据实现姿态跟随的功能。 2. 电子硬件 在这个示例中,我们采用了以下硬件,请大家参考: 主控板 Basra主控板(兼容Arduino Uno)‍ 扩展板 Bigfish2.1扩…

【012】C++循环控制语句 for 和 while 详解

C循环控制语句 for 和 while 详解 引言一、循环控制语句 for1.1、for 循环语句1.2、break和continue1.3、for循环的嵌套 二、循环控制语句while2.1、while循环语句2.2、break和continue2.3、do...while()循环语句 总结 引言 💡 作者简介:专注于C/C高性能…

【JavaSE】Java基础语法(九):封装

文章目录 ☔1. private关键字☔2. private关键字的使用☔3. this关键字☔4. this内存原理☔5. 封装思想 ☔1. private关键字 概述 : private是一个修饰符,可以用来修饰成员(成员变量,成员方法) 特点 : 被private修饰的成员&…

公网远程连接Redis数据库【内网穿透】

文章目录 1. Linux(centos8)安装redis数据库2. 配置redis数据库3. 内网穿透3.1 安装cpolar内网穿透3.2 创建隧道映射本地端口 4. 配置固定TCP端口地址4.1 保留一个固定tcp地址4.2 配置固定TCP地址4.3 使用固定的tcp地址连接 转发自cpolar内网穿透的文章:公网远程连接…

(El-button-group)解决:优化 el-button 实现 button 相连且动态切换的使用案例(涉及:动态绑定 class )

Ⅰ、Element-ui 提供的组件与想要目标情况的对比&#xff1a; 1、Element-ui 提供组件情况&#xff1a; 其一、Element-ui 自提供的代码情况为(示例的代码&#xff0c;例子如下)&#xff1a; // Element-ui 自提供的代码&#xff1a; <template><div><el-but…

深度解析多线程的创建方式和正确启动多线程

一、创建多线程 1. 实现多线程 java 实现多线程的方式准确来说有两种&#xff08;oracle官方文档说的&#xff09;&#xff1a; &#xff08;1&#xff09;实现 Runnable 接口&#xff0c; 重写run()函数&#xff0c;运行start()方法 代码演示&#xff1a; /*** 用Runnable…

移动端浏览器性能优化探索

在移动端的页面开发过程中&#xff0c;我们经常提及页面性能优化、消除页面卡顿的话题&#xff0c;如何确定优化策略&#xff0c;我们首先应当对页面卡顿的行为有所认知。 前言 &#xfeff; 页面的卡顿现象可以比较明确的分为三个类型&#xff0c;分别是 “画面撕裂” 、“丢帧…

让你不再好奇怎么给小说配音

你是否曾经想象过&#xff0c;当你在读小说时&#xff0c;你可以听到人物的声音&#xff0c;感受到情感和气氛的变化&#xff1f;有声书的出现已经让这一切成为可能。然而&#xff0c;如何为小说创造生动的配音效果却是一个需要仔细考虑的问题。如果你还不知道怎么给小说配音的…

酷开会员丨版权时代,酷开科技打造更多优质内容服务消费者

以版权产业为核心的文化产业&#xff0c;需要重视版权、鼓励创新&#xff0c;才能形成文化创新的环境与氛围&#xff0c;这也是版权时代的发展趋势。在版权时代&#xff0c;付费观看是基本意识&#xff0c;比如电视内容供应方提供了大量免费的资源&#xff0c;观众为观看更精良…

数据结构之二叉树的基本实现

在我们之前已经了解的堆这样的完全二叉树的实现&#xff0c;也对树型结构有了一些了解&#xff0c;那么今天我们来看看二叉树的一些性质。 因为二叉树是一种每个节点至多只有两个子树&#xff08;即二叉树的每个节点的度不大于2&#xff09;&#xff0c;并且二叉树的子树有左右…

二、Django REST Framework (DRF)序列化反序列化数据校验

参考&#xff1a; DRF 官方文档&#xff1a; Serializers - Django REST framework中文站点 为什么要学DRF和什么是REST API | 大江狗的博客 上一章&#xff1a; 一、Django REST Framework (DRF)& RESTful 风格api_做测试的喵酱的博客-CSDN博客 下一章&#xff1a;…