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

MobileNetV2 #1

Open
EduardShaid opened this issue Apr 1, 2019 · 5 comments
Open

MobileNetV2 #1

EduardShaid opened this issue Apr 1, 2019 · 5 comments

Comments

@EduardShaid
Copy link

Thanks for the example, but a number of questions arise:

  1. Will such a method work correctly on an already trained MobileNet model ? After all, we violated the internal architecture of the model. Or do I need to train this model again ?

  2. You have an example on the MobileNet model. Will your method work for MobileNetV2 ?

@alessandrocapotondi
Copy link
Owner

Ciao @EduardShaid,

This project starts from a pre-trained Mobilenet model downloaded by the module keras.applications. You can find the script here: https://github.com/alessandrocapotondi/mobilenet_stmcube_ai/blob/master/keras_model/keras_mobilenet_stm_cubemx_ai.ipynb

The main problem is that not all the layers are supported by STMCubeMX.AI. For example it do not support ReLU directly. Such layers require to be converted to Activation('relu').
This operation is done as well by the script above.

By the way, at the moment I am not able to link the generated code because contrary to what STMCubeMX.AI the activations do not inside the SRAM...I am posting an issue right now on the STM Community Forum.

About the MobileNetV2, I did test it, so I do not have so much feedbacks. Sorry.

Alessandro

@EduardShaid
Copy link
Author

The launch of the test_and_compare_models(...) function shows that the old model and the new one work differently ! It turns out that after the transformation of the model, it stops working correctly. Is it so ? and is it necessary to retrain the model ?

alessandrocapotondi added a commit that referenced this issue Apr 2, 2019
Converted model was using unbounded `Activation(ReLU)` layers, while pre-trained mobilenets rely on `ReLU6`.

 ## Changed
 - Fixed Keras notebook
 - Updated `.h5` models
 - Updated CubeMX.ai project and generated files
@alessandrocapotondi
Copy link
Owner

alessandrocapotondi commented Apr 2, 2019

Ciao @EduardShaid,

You don't need to retrain the model. There was an issue on the conversion. I was using unbounded relu activations while the pretrained model was based on relu6.

I fixed the model and the script on the last commit 1adeb45.

Thanks,
Alessandro

@EduardShaid
Copy link
Author

Yes, thank you, the example works.
I have another question about MobilenetV2: can I use the already trained MobilenetV2 model, but converted by your method, to recognize faces on the STM32 platform ?

@EduardShaid
Copy link
Author

Can you give an example of your approach for MobileNetV2 ?
It does not work out for me.

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

No branches or pull requests

2 participants