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 相关文章推荐
JavaScript设计模式之观察者模式(发布者-订阅者模式)
Sep 24 Javascript
超精准的javascript验证身份证号的具体实现方法
Nov 18 Javascript
Angular.js回顾ng-app和ng-model使用技巧
Apr 26 Javascript
VUEJS实战之修复错误并且美化时间(2)
Jun 13 Javascript
JS常用加密编码与算法实例总结
Dec 22 Javascript
基于AngularJS实现的工资计算器实例
Jun 16 Javascript
jQuery实现base64前台加密解密功能详解
Aug 29 jQuery
关于redux-saga中take使用方法详解
Feb 27 Javascript
Vue单页及多页应用全局配置404页面实践记录
May 22 Javascript
Vue实现调节窗口大小时触发事件动态调节更新组件尺寸的方法
Sep 15 Javascript
详解Vue的常用指令v-if, v-for, v-show,v-else, v-bind, v-on
Oct 12 Javascript
Echarts之悬浮框中的数据排序问题
Nov 08 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
thinkphp3.0输出重复两次的解决方法
2014/12/19 PHP
Yii2中datetime类的使用
2016/12/17 PHP
javascript下过滤数组重复值的代码
2007/09/10 Javascript
jQueryUI如何自定义组件实现代码
2010/11/14 Javascript
javascript写的日历类(基于pj)
2010/12/28 Javascript
js 获取class的元素的方法 以及创建方法getElementsByClassName
2013/03/11 Javascript
jQuery点击弹出下拉菜单的小例子
2013/08/01 Javascript
表单序列化与jq中的serialize使用示例
2014/02/21 Javascript
jQuery实现TAB风格的全国省份城市滑动切换效果代码
2015/08/24 Javascript
jquery实现可自动收缩的TAB网页选项卡代码
2015/09/06 Javascript
JavaScript实现的伸展收缩型菜单代码
2015/10/14 Javascript
jQuery EasyUI Pagination实现分页的常用方法
2016/05/21 Javascript
使用jsonp实现跨域获取数据实例讲解
2016/12/25 Javascript
layui中table表头样式修改方法
2018/08/15 Javascript
详解javascript appendChild()的完整功能
2018/08/18 Javascript
微信小程序中的店铺评分组件及vue中用svg实现的评分显示组件
2018/11/16 Javascript
详解js加减乘除精确计算
2019/03/19 Javascript
ES6入门教程之Array.from()方法
2019/03/23 Javascript
Vue中通过Vue.extend动态创建实例的方法
2019/08/13 Javascript
python中urllib模块用法实例详解
2014/11/19 Python
Python multiprocessing模块中的Pipe管道使用实例
2015/04/11 Python
图解Python变量与赋值
2018/04/03 Python
python zip()函数的使用示例
2020/09/23 Python
python判断元素是否存在的实例方法
2020/09/24 Python
Lookfantastic挪威官网:英国知名美妆购物网站
2017/07/26 全球购物
奥地利婴儿用品和玩具购物网站:baby-markt.at
2020/01/26 全球购物
畜牧兽医本科生的自我评价
2014/03/03 职场文书
母亲节演讲稿
2014/05/27 职场文书
电子信息工程专业求职信
2014/06/28 职场文书
2014年十一国庆节活动方案
2014/09/16 职场文书
学校施工安全责任书
2015/01/29 职场文书
停发工资证明范本
2015/06/12 职场文书
医生行业员工的辞职信
2019/06/24 职场文书
《没有任何借口》读后感:完美的执行能力
2020/01/07 职场文书
理解深度学习之深度学习简介
2021/04/14 Python
Ajax实现三级联动效果
2021/10/05 Javascript