- 
                Notifications
    You must be signed in to change notification settings 
- Fork 40
Add offline module #200
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Add offline module #200
Conversation
| This is exciting to see thank you @ziyuan-linn for working on this! One consideration is that running a stand-along node.js script for downloading the models may involves concepts/steps unfamiliar to beginners especially those used to working only in the p5.js web editor. I think it's ok for this to be the primary way to get the models since this is an "edge" use case, however, we should probably include some detailed documentation for total beginners. I could also record a video tutorial on this topic. Alternatively we could consider providing links to some model downloads directly but this might be hard to maintain. | 
| @shiffman Thank you for the review! The node.js script for downloading models is meant to be only called by the ml5.js maintainers. I could also set it up as a postinstall script that automatically runs after  As far as the users are concerned, they only need to change  | 
| @ziyuan-linn Thank you for working on this!! I have been looking forward to the offline support! I think automatically downloading the models would be nice. I built this PR locally with  I am trying to add offline support to  @ziyuan-linn Can you shed some light on this? Let me know if you need more information. | 
| @jackbdu Thank you for looking into this and sorry for the late response! When I was working on this, the builds complete in minutes. I tried rerunning the build again today and it is taking a long time. It seems like the memory is hitting some sort of limit. My process is sitting at nearly 4 GB of memory with nearly no CPU. I am assuming the heavy memory usage is coming from building the giant  For FaceMesh, I think you would need two URLs: one for the landmarks model and one for the detector model. It seem like you have the landmark model and is missing the detector model? I stopped working on the offline module because after having a discussion with Dan we realized that the offline package will become very bloated with the model weights. I think having documentation on the website about using the ml5 library offline would be a better approach than maintaining an offline version of the library. The current library already have options like  However, I understand that there may be benefits to having a offline version of the library that just works out of the box. Let me know what you think! | 
| @ziyuan-linn Thank you for looking into this and the clarifications! I totally agree with your conclusion! As long as we have clear documentation on how to run the models offline, there is no need for us to maintain an offline version of the library! | 
The PR implements an offline version of the ml5.js library.
Webpack will now build
ml5-offline.jsandml5-offline.min.jsin addition toml5.jsandml5.min.js. The fileml5-offline.jsandml5-offline.min.jsis self-contained and will not make additional network requests. Once a user downloadsml5-offline.min.js, the ml5 library can run entirely without internet.The entry point for the offline model is
src/offline/index.js. It imports the ml5 object, injects aloadOfflineModelfunction into each ml5 model's prototype, and exports the ml5 object with the modified models. The approach keeps the offline implementation mostly separate from the main source code.Changes:
model.jsonis written to a JS file.Uint8Arrayand then written to JS files.loadOfflineModelfunction.Fileobjects and creates object URLs for them.landmarkModelURL) of the ml5 model.ml5-offline.jsbuild, add theloadOfflineModelfunctions into object prototypes of each ml5 model.loadOfflineModelfunction from each ml5 model during initialization if the function is defined.To test this implementation, find an example sketch and change
ml5.jstoml5-offline.jsinindex.html.Note: This is WIP,
ml5-offline.jsonly works forHandPosewithmodelType: "lite".