【6】TensorFlow光速入门-python模型转换为tfjs模型并使用
本文地址:https://www.cnblogs.com/tujia/p/13862365.html
系列文章:
【1】TensorFlow光速入门-tensorflow开发基本流程
【2】TensorFlow光速入门-数据预处理(得到数据集)
【4】TensorFlow光速入门-保存模型及加载模型并使用
【6】TensorFlow光速入门-python模型转换为tfjs模型并使用
一、模型转换
python模型转换tfjs模型,需要用到先安装 tensorflowjs_converter 工具
pip install tensorflowjs
安装成功后,可以用python脚本或shell命令转换,下面是shell的例子:
tensorflowjs_converter /tf/saved_model/wnw /tf/saved_model_js/wnw
注:记得提前创建好 saved_model_js 目录。转换成功成,会得到 model.json 及 n个 .bin 文件,例如:group1-shard1of2.bin、group1-shard2of2.bin等等
转换命令的详细参数,请看:
tensorflowjs_converter --help
二、在浏览器中使用
先准备好模型文件及dict.txt 文件(注:dict.txt 需要自己创建,内容为图片分类,一行一个分类)

基础html元素
<input type="file" class="custom-file-input" id="file" accept="image/*" capture="camera"> <input class="form-control" id="result" readonly="readonly"> <img src="" id="pic">
引入tfjs
<script src="https://cdn.jsdelivr.net/npm/@tensorflow/tfjs@2.6.0/dist/tf.min.js"></script>
加载模型
const MODEL_URL = '/static/models/wnw/model.json'; let model = null;
tf.loadGraphModel(MODEL_URL).then((value)=>{
model = value;
}, (error)=>{
console.log(error);
});
侦听选择图片及图片预览
let image = document.getElementById('pic');
// 图片预览
document.getElementById('file').addEventListener('change', (ev)=>{
let reader = new FileReader();
reader.addEventListener('load', (e)=>{
image.src = e.target.result;
});
reader.readAsDataURL(ev.target.files[0]);
});
图片数据转换及预测
// 图片分类
const CLASSIFY = ['非表', '表']; // 图片处理及评估
image.addEventListener('load', ()=>{
// 图片转换成灰度张量数据
let image_tensor = tf.browser.fromPixels(image, 1);
// 三维张量转四维张量
image_tensor = tf.expandDims(image_tensor);
image_tensor = tf.cast(image_tensor, 'float32');
// console.log(image_tensor.shape);
// 图片缩放,转换为模型需要的大小
image_tensor = tf.image.resizeBilinear(image_tensor, [100, 100]);
// console.log(image_tensor.shape);
let predictions = model.predict(image_tensor);
let label = tf.argMax(predictions, 1).dataSync()[0];
result.value = CLASSIFY[label];
});
注:像【4】TensorFlow光速入门-保存模型及加载模型并使用 说的那样,加载模型,然后准备一个和训练集一样格式的数据(数据格式转换、缩放),然后预测就可以了
重点:
tf.browser.fromPixels base64格式转tensor3D格式
tf.expandDims tensor3D格式车转tensor4D格式
tf.cast 数值转换,上面例子是int32转float32
tf.image.resizeBilinear 图片缩放
model.predict 模型预测
tf.argMax(predictions, 1).dataSync()[0] 取预测结果的最大值的 key(即分类label)
其他:
官方关于tfjs的使用示例并不完善,甚至是错。各种跳转,又是 MobileNet 又是 ml5 的,其实都不需要,直接用 tf.min.js 就可以了。mobilenet 和 ml5 的用法以后再研究
下面是相当混乱的一些相关文档:
https://tensorflow.google.cn/js/tutorials/conversion/import_keras
https://tensorflow.google.cn/js/tutorials/conversion/import_saved_model
https://github.com/tensorflow/tfjs-converter/blob/master/tfjs-converter/README.md
https://github.com/tensorflow/tfjs-converter/tree/master/tfjs-converter/demo/mobilenet
https://learn.ml5js.org/#/tutorials/hello-ml5?id=demo
本文链接:https://www.cnblogs.com/tujia/p/13862365.html
完。
【6】TensorFlow光速入门-python模型转换为tfjs模型并使用的更多相关文章
- 【4】TensorFlow光速入门-保存模型及加载模型并使用
本文地址:https://www.cnblogs.com/tujia/p/13862360.html 系列文章: [0]TensorFlow光速入门-序 [1]TensorFlow光速入门-tenso ...
- 【0】TensorFlow光速入门-序
本文地址:https://www.cnblogs.com/tujia/p/13863181.html 序言: 对于我这么一个技术渣渣来说,想学习TensorFlow机器学习,实在是太难了: 百度&qu ...
- 【1】TensorFlow光速入门-tensorflow开发基本流程
本文地址:https://www.cnblogs.com/tujia/p/13862339.html 系列文章: [0]TensorFlow光速入门-序 [1]TensorFlow光速入门-tenso ...
- 【2】TensorFlow光速入门-数据预处理(得到数据集)
本文地址:https://www.cnblogs.com/tujia/p/13862351.html 系列文章: [0]TensorFlow光速入门-序 [1]TensorFlow光速入门-tenso ...
- 【3】TensorFlow光速入门-训练及评估
本文地址:https://www.cnblogs.com/tujia/p/13862357.html 系列文章: [0]TensorFlow光速入门-序 [1]TensorFlow光速入门-tenso ...
- 【5】TensorFlow光速入门-图片分类完整代码
本文地址:https://www.cnblogs.com/tujia/p/13862364.html 系列文章: [0]TensorFlow光速入门-序 [1]TensorFlow光速入门-tenso ...
- ER图/模型转换为关系模型
ER图中的主要成分是实体类型和联系类型,转换规则就是如何把实体类型.联系类型转换成关系模式. 1. 二元联系转换 规则1.1(实体类型的转换):将每个实体类型转换成一个关系模式,实体的属性即为关系模式 ...
- Tensorflow object detection API 搭建物体识别模型(二)
二.数据准备 1)下载图片 图片来源于ImageNet中的鲤鱼分类,下载地址:https://pan.baidu.com/s/1Ry0ywIXVInGxeHi3uu608g 提取码: wib3 在桌面 ...
- 千行代码入门Python
这个是从网上找到的一份快速入门python的极简教程,大概一千行左右,个人觉得不错,特此收藏以备后用. # _*_ coding: utf-8 _*_ """类型和运算- ...
随机推荐
- 我把公司 10 年老系统改造 Maven,真香!!
公司有几个老古董项目,应该是 10 年前开发的了,有一个是 JSP + Servlet,有一个还用的 SSH 框架,打包用的 Ant,是有多老啊,我想在座的各位很多都没听过吧. 为了持续集成.持续部署 ...
- dubbo学习(十)spring boot整合dubbo
工程搭建与配置 生产者 1.创建一个生产者的spring boot工程,配置好依赖,并把接口实现类文件夹复制到新的工程里 2.pom.xml配置dubbo的相关依赖 <!-- Dubbo Spr ...
- 《Redis入门指南》笔记
第1章 简介 1.1 历史与发展 2008年 意大利创业公司创始人因对mysql性能不满意,于是他决定开发redis. 2009年 redis初版由他一个人开发完成.redis是"remot ...
- 基础篇:JAVA内部类的使用介绍
目录 1 四种内部类 2 内部类的使用场景和优点 3 成员内部类 4 成员内部类的访问范围详解 5 静态内部类 6 局部内部类 7 匿名内部类 欢迎指正文中错误 关注公众号,一起交流 参考文章 1 四 ...
- git 一个可以提高开发效率的命令:cherry-pick
各位码农朋友们一定有碰到过这样的情况:在develop分支上辛辛苦苦撸了一通代码后开发出功能模块A,B,C,这时老板过来说,年青人,我们现在先上线功能模块A,B.你一定心里一万只草泥马奔腾而过,但为了 ...
- Python-在不在判断 in 和 in判断协议- in __contains__
in 判断元素是否在序列中, 可以查看 in == is 区别 __contians__ 如果是对象则调用对象中的 __contains__方法 class BeiMenChuiXue: def __ ...
- matlab中imfinfo 有关图形文件的信息
来源:https://ww2.mathworks.cn/help/matlab/ref/imfinfo.html?searchHighlight=imfinfo&s_tid=doc_srcht ...
- DM8数据库备份还原的原理及应用
(本文部分内容摘自DM产品技术支持培训文档,如需要更详细的文档,请查询官方操作手册,谢谢) 一.原理 1.DM8备份还原简介 1.1.基本概念 (1)表空间与数据文件 ▷ DM8表空间类型: ▷ SY ...
- docker-命令帮助
1. 命令参考 http://www.runoob.com/docker/docker-command-manual.html2. docker-命令,可以使用docker --help查看或 ...
- 多测师讲解自动化 _邮件发送_高级讲师肖sir
第一步.进入如下网址申请163邮箱. https://mail.163.com/ 第二步.注册完之后登录.点击如下图设置点击POP3/SMTP/IMAP. 第三步.右侧点击客户端授权密码. 第四步. ...