-
Notifications
You must be signed in to change notification settings - Fork 10
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
Show a warning about large models being downloaded #65
Comments
The proper way to fix this would be to add an option upstream to MediaPipe so it optionally caches the model. This would have to happen here: A way to fix this just here for this project is to fetch the model out-of-bounds, store it in the Cache API, and then pass a blob URL to Agree that a warning would make sense, too. |
CC @maudnals |
Mediapipe accepts an So, the code to download the model while checking for progress and the loading the model can look something like this: const modelFileName = 'gemma-2b-it-gpu-int4.bin';
const modelResponse = await fetch(modelFileName);
const reader = modelResponse.body.getReader();
const contentLength = response.headers.get('Content-Length');
let receivedLength = 0;
let chunks = [];
while (true) {
const {done, chunk} = await reader.read();
if (done) {
break;
}
chunks.push(value);
receivedLength += value.length;
console.log(`Received ${receivedLength} of ${contentLength}`)
}
let modelData = new Uint8Array(receivedLength);
let position = 0;
for(let chunk of chunks) {
chunksAll.set(chunk, position);
position += chunk.length;
}
const llmInference = await LlmInference.createFromOptions(genaiFileset, {
baseOptions: { modelAssetBuffer: modelData },
maxTokens: 6144,
}); |
I tried some of the
web-ai-demos
on https://chrome.dev/, such as https://chrome.dev/web-ai-demos/perf-client-side-gemma-worker/Some demos say that the model will take about 30s or 1 minute to load. This took longer, as it turned the demo was downloading a model … of more than 1GB … which eventually took 15 minutes to complete.
Please add a warning message as per https://web.dev/articles/client-side-ai-performance#signal_large_downloads guidelines.
From the looks of it, the model doesn’t get cached on disk properly, so people end up downloading the model over and over again.
The text was updated successfully, but these errors were encountered: