TensorFlow.js 微信小程序插件开始支持模型缓存的方法


Posted in Javascript onFebruary 21, 2020

通常情况下,微信小程序追求的是短小精悍,即开即用,用完即走,适用于一些简单的应用场景。然而,随着微信小程序开放能力的提高,人们发现用微信小程序可以实现越来越多的功能,小程序也越来越复杂,越来越庞大起来。这个可以从小程序的大小限制的变化看出,最开始小程序的大小限制为1M,后来限制为2M,最新微信又给小程序提供了分包加载机制,开发者将小程序划分成不同的子包,用户在使用时按需进行加载,所有分包大小限制提高到8M。

虽然小程序的大小限制已经大大提升,但对于小程序开发者而言,仍然捉襟见肘。随便几个图片资源、js库就可能导致小程序超重,尤其对于人工智能小程序而言,更是如此。现在的深度学习模型,动辄几十M,多则一两百M。这个时候开发人员就需要进行取舍,选择那些模型规模小,但精度不那么高的模型。比如图片分类,我们就不要选择Inception V3或ResNet之类的超大规模模型,而是选择针对移动设备优化的MobileNet,也能取得不错的效果。

不过即使是MobileNet,其模型大小也有好几M,对于精简小程序大小仍是一个很大的负担。一种解决方案是从网络加载模型,不增加小程序的体积,但这并不是一个完美的解决方案,毕竟每次推导都需要从网络下载模型,会有一定的网络延迟。在前端开发中,为了保持系统的流畅,通常会采用一些缓存技巧来避免每次从网络加载图片、JS等文件。那能否将模型也作为资源缓存起来呢?

Google团队显然也意识到了这种需求,先是在TensorFlow.js中增加了对tfjs模型缓存的支持。最近,TensorFlow.js 微信小程序插件也得到了更新,支持微信小程序模型缓存。

模型缓存利用了微信小程序的storage接口,需要注意微信小程序对storage的限制:同一个微信用户,同一个小程序 storage 上限为 10MB。storage 以用户维度隔离,同一台设备上,A 用户无法读取到 B 用户的数据;不同小程序之间也无法互相读写数据。所以我们只能选用小于10M的模型。

启用模型缓存也非常简单,步骤如下:

修改app.json文件,将tfjsPlugin的版本修改为0.0.8.

"plugins": {
 "tfjsPlugin": {
  "version": "0.0.8",
  "provider": "wx6afed118d9e81df9"
 }
}

在app.js中提供localStorageHandler函数.

var fetchWechat = require('fetch-wechat');
var tf = require('@tensorflow/tfjs-core');
var plugin = requirePlugin('tfjsPlugin');
//app.js
App({
 // expose localStorage handler
 globalData: {localStorageIO: plugin.localStorageIO},
 ...
});

在模型加载时加入localStorageHandler逻辑。

const LOCAL_STORAGE_KEY = 'mobilenet_model';
export class MobileNet {
 private model: tfc.GraphModel;
 constructor() { }
 
 
 async load() {
 
 
  const localStorageHandler = getApp().globalData.localStorageIO(LOCAL_STORAGE_KEY);
  try {
   this.model = await tfc.loadGraphModel(localStorageHandler);
  } catch (e) {
   this.model =
    await tfc.loadGraphModel(MODEL_URL);
   this.model.save(localStorageHandler);
  }
 }

和浏览器缓存机制有点不同的是,只有在代码包被清理的时候本地缓存才会被清理。如果需要处理缓存,可以通过 wx.setStorage/wx.setStorageSync、wx.getStorage/wx.getStorageSync、wx.clearStorage/wx.clearStorageSync,wx.removeStorage/wx.removeStorageSync 对本地缓存进行读写和清理。

另外需要注意的是,当前tfjs模型托管在tfhub上,需要翻墙访问。项目中的说明文件也提及了这个问题,给出了解决方案,但那是针对以前托管在谷歌云上的模型,建立了中国国内用户可以访问到的镜像。耐心等待吧,相信Google的开发人员会解决tfhub的镜像问题的。

以上就是TensorFlow.js 微信小程序插件开始支持模型缓存的方法的详细内容,更多关于TensorFlow小程序支持模型缓存请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
获取div编辑框,textarea,input text的光标位置 兼容IE,FF和Chrome的方法介绍
Nov 08 Javascript
Javascript/Jquery——简单定时器的多种实现方法
Jul 03 Javascript
通过JS来动态的修改url,实现对url的增删查改
Sep 01 Javascript
基于jquery实现的自动补全功能
Mar 12 Javascript
uploadify多文件上传参数设置技巧
Nov 16 Javascript
微信JS-SDK坐标位置如何转换为百度地图坐标
Jul 04 Javascript
js判断请求的url是否可访问,支持跨域判断的实现方法
Sep 17 Javascript
微信小程序实现YDUI的ScrollNav组件
Feb 02 Javascript
详解在React.js中使用PureComponent的重要性和使用方式
Jul 10 Javascript
解析JS在获取当前月的最后一天遇到的坑
Aug 30 Javascript
在vue中created、mounted等方法使用小结
Jul 21 Javascript
解决VUE项目使用Element-ui 下拉组件的验证失效问题
Nov 07 Javascript
微信小程序使用 vant Dialog组件的正确方式
Feb 21 #Javascript
JS实现判断移动端PC端功能
Feb 21 #Javascript
JS获取表格视图所选行号的ids过程解析
Feb 21 #Javascript
微信小程序vant弹窗组件的实现方式
Feb 21 #Javascript
纯js实现无缝滚动功能代码实例
Feb 21 #Javascript
vue中实现动态生成二维码的方法
Feb 21 #Javascript
JS如何把字符串转换成json
Feb 21 #Javascript
You might like
php的zip解压缩类pclzip使用示例
2014/03/14 PHP
javascript 装载iframe子页面,自适应高度
2009/03/20 Javascript
firefox火狐浏览器与与ie兼容的2个问题总结
2010/07/20 Javascript
把jquery 的dialog和ztree结合实现步骤
2013/08/02 Javascript
javascript文件中引用依赖的js文件的方法
2014/03/17 Javascript
nodeJS代码实现计算交社保是否合适
2015/03/09 NodeJs
使用Chrome浏览器调试AngularJS应用的方法
2015/06/18 Javascript
jQuery实现文本框邮箱输入自动补全效果
2015/11/17 Javascript
全面解析DOM操作和jQuery实现选项移动操作代码分享
2016/06/07 Javascript
jQuery获取剪贴板内容的方法
2016/06/16 Javascript
使用ionic在首页新闻中应用到的跑马灯效果的实现方法
2017/02/13 Javascript
vue js秒转天数小时分钟秒的实例代码
2018/08/08 Javascript
JS面向对象之单选框实现
2020/01/17 Javascript
JavaScript中reduce()的5个基本用法示例
2020/07/19 Javascript
python动态监控日志内容的示例
2014/02/16 Python
浅析PHP与Python进行数据交互
2018/05/15 Python
Python常用爬虫代码总结方便查询
2019/02/25 Python
python tools实现视频的每一帧提取并保存
2020/03/20 Python
pytorch查看torch.Tensor和model是否在CUDA上的实例
2020/01/03 Python
python3 字符串知识点学习笔记
2020/02/08 Python
Python restful框架接口开发实现
2020/04/13 Python
Eclipse配置python默认头过程图解
2020/04/26 Python
Python爬虫爬取博客实现可视化过程解析
2020/06/29 Python
CSS3实现翘边的阴影效果的代码示例
2016/06/13 HTML / CSS
HTML5表单验证特性(知识点小结)
2020/03/10 HTML / CSS
AmazeUI中模态框的实现
2020/08/19 HTML / CSS
在线购买澳大利亚设计师手拿包和奢华晚装手袋:Olga Berg
2019/03/20 全球购物
美术专业学生个人自我评价
2013/09/19 职场文书
市场营销管理制度
2014/01/29 职场文书
顶碗少年教学反思
2014/02/21 职场文书
企业出纳岗位职责
2014/03/12 职场文书
工程质量承诺书
2014/03/27 职场文书
社区两委对照检查材料
2014/08/23 职场文书
快递员岗位职责
2014/09/12 职场文书
2014年学校法制宣传日活动总结
2014/11/01 职场文书
详解CSS玩转图片Base64编码
2021/05/25 HTML / CSS