Skip to content
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

Add an example using second tile for weights #912

Merged
merged 1 commit into from
Jul 22, 2024

Conversation

panickal-xmos
Copy link
Collaborator

No description provided.

@panickal-xmos
Copy link
Collaborator Author

Closes #910

@andresovela
Copy link
Contributor

This is a great addition to the examples, and another good approach to try for optimizations, but this is not the scenario I had in mind in #910.

What I meant with splitting the models was actually splitting the model graph into two smaller models, each with its own weights and arenas. Each tile would then run a model, and the output of one would be the input of the other.

So if I had a model.tflite with nodes A -> B -> C -> D, we would split it into model_1.tflite with A -> B in it, and model_2.tflite with C -> D in it.

We would compile each model separately, generating model_1.tflite.cpp/.h out of model_1.tflite and model_2.tflite.cpp/.h out of model_2.tflite. tile[0] would run model_1 and tile[1] would run model_2. Lastly we would somehow use a channel to connect B with C, effectively reconstructing the original model but using both tiles.

The models we have right now have more than 1 MB in weights, so it wouldn't be feasible to place the weights in tile[0] for our current models. However, we might explore different architectures that require fewer parameters, which would allow us to do try this out, so in the end this example is still very valuable :) Thank you!

@panickal-xmos panickal-xmos merged commit a275b99 into develop Jul 22, 2024
5 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants