使用预训练模型进行图片分类

 

前言

TensorFlow.js中加载预训练模型进行图片分类预测。

项目结构:

data:

|----mobileNet:       

|----|----web_model:

|----|----|----group1-shard1of1.bin

|----|----|----model.json

mobileNet:

|----imagenet_classes.js

|----index.html

|----script.js

|--- untils.js

一、加载MobileNet模型

创建index.html程序入口文件,编写script标签跳转到script.js。

<script src="script.js"></script>

 在script.js中编写程序主要代码。

加载预训练模型可以翻墙直接加载国外该模型的地址,如果没办法翻墙可以先把模型下载保存在本地,在Vscode中启动一个静态服务器,从静态服务器中加载。

启动静态服务器。我们的模型在data文件夹下面,所以在data中启动一个静态服务器,默认端口8080。

 http-server data --cors
Available on:
  http://192.168.4.167:8080
  http://127.0.0.1:8080
Hit CTRL-C to stop the server

 接着在script.js文件中加载mobilenet模型。

import * as tf from "@tensorflow/tfjs"


// 定义mobilenet模型地址
const MOBILENET_MODEL_PATH = "http://127.0.0.1:8080/mobilenet/web_model/model.json"

window.onload = async() => {
    // 加载预训练模型
    const model = tf.loadLayersModel(MOBILENET_MODEL_PATH);
    
};

二、编写前端界面输入带预测结果

在index.html中编写上传文件的功能。

<input type="file" onchange="predict(this.files[0])">

当上传文件就会触发predict方法进行预测。 

新建一个文件utils.js,编写将file转成img的方法。

export function file2img(f){
    return new Promise(resolve => {
        const reader = new FileReader();
        reader.readAsDataURL(f);
        reader.onload = (e) =>{
            const img = document.createElement('img');
            img.src = e.target.result;
            img.width = 224;
            img.height = 224;
            img.onload = () => resolve(img);
        };
    });
    
}

在script.js中将该方法引入。

import {file2img} from "./utils";

 获取上传的图片,转换成img格式之后再转成tensor,并对其进行归一化操作。

    window.predict = async(file) => {
        // 将加载的图片文件转换成img格式
        const img = await file2img(file);
        const pred = tf.tidy(() => {
            const input = tf.browser.fromPixels(img)
                .toFloat()
                .sub(255 / 2)
                .div(255 / 2)
                .reshape([1, 224, 224, 3]);
            return model.predict(input);
        });

三、使用训练好的模型进行预测

        // 预测
        const index = pred.argMax(1).dataSync()[0];
        setTimeout(() => {
            alert(`预测结果:${IMAGENET_CLASSES[index]}`);
        }, 0);

四、完整代码

index.html

<script src="script.js"></script>

<input type="file" onchange="predict(this.files[0])">

script.js

import * as tf from "@tensorflow/tfjs"
import { IMAGENET_CLASSES } from './imagenet_classes';
import {file2img} from "./utils";

// 定义mobilenet模型地址
const MOBILENET_MODEL_PATH = "http://127.0.0.1:8080/mobilenet/web_model/model.json"

window.onload = async() => {
    // 加载预训练模型
    const model = await tf.loadLayersModel(MOBILENET_MODEL_PATH);
    window.predict = async(file) => {
        // 将加载的图片文件转换成img格式
        const img = await file2img(file);
        document.body.appendChild(img)
        const pred = tf.tidy(() => {
            const input = tf.browser.fromPixels(img)
                .toFloat()
                .sub(255 / 2)
                .div(255 / 2)
                .reshape([1, 224, 224, 3]);
            return model.predict(input);
        });

        // 预测
        const index = pred.argMax(1).dataSync()[0];
        setTimeout(() => {
            alert(`预测结果:${IMAGENET_CLASSES[index]}`);
            document.body.removeChild(img)
        }, 0);

    }

};

utils.js

export function file2img(f){
    return new Promise(resolve => {
        const reader = new FileReader();
        reader.readAsDataURL(f);
        reader.onload = (e) =>{
            const img = document.createElement('img');
            img.src = e.target.result;
            img.width = 224;
            img.height = 224;
            img.onload = () => resolve(img);
        };
    });
    
}

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

.Thinking.

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值