ml5.js框架实现AI图片识别

ml5.js

ml5.js 提供了简单的接口来加载和使用机器学习模型,如图像分类、文本生成、姿态估计等,不需要深入理解底层的数学原理或复杂的编程技巧
ml5.js 构建在 TensorFlow.js 之上,提供了一系列预训练模型和简易的 API 接口

图片识别

先进行一个简单的图片识别demo (这里我使用的是汽车图片)

  1. 首先创建一个index.html
  2. 引入必要的库

创建index.html

复制代码
<!DOCTYPE html>
<html lang="en">
	<head>
		<script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.11.1/p5.js"></script>
		<script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.11.1/addons/p5.sound.min.js"></script>
		<script src="https://unpkg.com/ml5@1/dist/ml5.min.js"></script>
		<meta charset="utf-8" />
	</head>
	<style>
		html,
		body {
			margin: 0;
			padding: 0;
		}
		canvas {
			display: block;
		}
	</style>
	<body>
		<main></main>
		<script src="sketch.js"></script>
	</body>
</html>

创建sketch.js

复制代码
// 图像分类器
let classifier
// 图像
let img
// 结果
let result

function setup() {
	// 创建幕布
	createCanvas(400, 400)
	// 图像分类器初始化完成后调用classify函数
	if (classifier) {
		classifier.classify(img, (res, error) => {
			if (error) {
				console.error(error)
				return
			}
			result = res
			console.log(res)
		})
	} else {
		console.error('图像分类器未初始化完成')
	}
}

function draw() {
	// 绘制背景
	background(220)
	if (img) {
		image(img, 0, 0, width, height)
	}
	// 绘制结果
	if (result) {
		fill(255)
		stroke(0)
		textSize(18)
		label = 'Label: ' + result[0].label
		confidence = 'Confidence: ' + nf(result[0].confidence, 0, 2)
		text(label, 10, 360)
		text(confidence, 10, 380)
	}
}
function preload() {
	// 图像分类器初始化
	classifier = ml5.imageClassifier('MobileNet', function () {
		console.log('图像分类器初始化完成')
	})
	img = loadImage('https://picsum.photos/id/133/2742/1828')
}
function gotResult(res, error) {
	if (error) {
		console.error(error)
		return
	}
	result = res
	console.log(results)
}

ml5官网

相关推荐
LeonDL16818 小时前
基于YOLO11深度学习的电动车头盔检测系统【Python源码+Pyqt5界面+数据集+安装使用教程+训练代码】【附下载链接】
人工智能·python·深度学习·pyqt5·yolo数据集·电动车头盔检测系统·yolo11深度学习
carver w18 小时前
彻底理解传统卷积,深度可分离卷积
人工智能·深度学习·计算机视觉
my烂笔头18 小时前
长短期记忆网络(LSTM)入门
人工智能·机器学习·lstm
是苏浙18 小时前
零基础入门C语言之C语言实现数据结构之顺序表经典算法
c语言·开发语言·数据结构·算法
xier_ran18 小时前
深度学习:从零开始手搓一个浅层神经网络(Single Hidden Layer Neural Network)
人工智能·深度学习·神经网络
59678515418 小时前
C# 弹出框DialogForm
开发语言·c#
得帆云18 小时前
COC Asia 2025|得帆云 ETL:顺应 Hive 新特性,重塑数据管道的未来
人工智能·etl
FnTop18 小时前
实用教程:打造支持参数配置的 Git Bash 文件清理脚本
开发语言·git·bash
郭庆汝18 小时前
(二)自然语言处理笔记——Seq2Seq架构、注意力机制
人工智能·笔记·自然语言处理
wxdlfkj18 小时前
精准突破 0.5mm 透明玻璃测量瓶颈 —— 泓川科技激光位移传感器的技术革新与成本优势
人工智能