Hello everyone,
I downloaded and built the Image Classification app on my PC (latest version of Android Studio). I ran it on my smartphone, getting predictions in less than 1 second.
Then I noticed a message suggesting to upgrade Gradle Plugin, so I did it:
Then I launched the app on my smartphone, to check it still worked, but now I am getting predictions in more than 3 seconds!
Any idea about the possible cause?
Hello Francesco, welcome to the community.
There might be various possible reasons for this. Mostly due to updates in gradle (which is like the build platform), which might not be compatible with the dependency libraries versions, or might not be using old slow code which the build platform might not be optimizing while compiling the java files.
For example, one place I can think of in your project, is that you have updated gralde plugin, but since your inference time is slow, I suspect the tensorflow dependency in your build.gradle.
The github link has an old version of TFLite (0.0.0-nightly), while if you see the latest release of TFLite, the latest release is 2.8.0. You can try checking this latest version in your code, if this works better.
Okay. So then you might need to debug this further. You could start adding logs in your code. Logs around the inference code should give you time taken by tflite tp infer the model. Similarly other places you can add. Once you note down times, then revert your gradle changes and capture same logs indicating time.
This should point out which part in your android project is taking time after gradle update.
Then, if you’re brave enough, you can edit the Image Detection app for Rock, Paper and Scissors only, instead of the 1,000 classes it could recognize!
If so, how did you do it? What code must be changed in android studio in order for the custom app to work?
Hi @Jaime_Gonzalez,
I meant the ready-made app. However, I did manage to modify the app to work with my model. To do that, please follow these steps (assuming you can run the ready-made app):
Build the .tflite file for your application (be sure it is compatible with the example, i.e. it accepts RGB 224x224 images)
Locate the folder “your_path”\image_classification\app\src\main\assets
substitute “mobilenet_v1_1.0_224_quant.tflite” with your model file
edit “labels_mobilenet_quant_v1_224.txt” to match your application and rename it appropriately
update mModelPath and mLabelPath in “your_path”\image_classification\app\src\main\java\com\google\tflite\imageclassification\sample\camera\Camera2BasicFragment.kt with the values of the files you just created
In this image classification android app, if you simply change the model given (“model.tflite”) with your own (“converted_model.tflite”), and change the labels given {“Banana”, “Orange”, “Pen”, “Sticky Notes”} with your own {“Rock”, “Paper”, “Scissors”}, the app works well. i.e.: the accuracy of predictions is reasonable.
Hi @Jaime_Gonzalez
actually my model is up to a completely different task, but it is not that bad.
As you wrote in the dedicated thread you created, I think that for Rock Paper Scissors the problem is related to data format compatibility. This is something I had to work on a lot (on the model side) as well.
A simple test: take a picture that gives bad result in the app and verify if the model on the PC gives the right prediction.
However, there is no need to spend a long time in this investigation, since you found another suitable app.
actually I was interested in the root cause of the problem: do you have any idea about why upgrading Gradle Plugin made the execution of ImageUtils.convertYUV420ToARGB8888() so worse?
Difficult to say, it’s not a standard function provided by android. It’s a function implemented for the demo it seems. Not sure how it would behave across different environments/ build tool versions. To speed it up, maybe you can run it in background thread if your app logic/UI allows it, or see an alternative to using the function (using opencv might be faster)
Hi @gopiramena,
after several attempts with different Android Studio releases, I give up: this community is about deep learning, not Android. As you highlighted in your last post, the problem is the different behaviour of the same code across different build tool versions, so I am marking that as the solution.
I did the 6 steps that @Francesco_Tessitore mentioned except step 5 where the file to change is tracking\DetectorActivity.kt instead of Camera2BasicFragment.kt (I believe there were some slight changes between 2022 and 2023 to the project). As far as I can tell, there’s nowhere else that points to the model and label files and even did a string search of all files containing the old model name on command prompt.
I’ve also rebuilt the app (step 6), somehow it’s still displaying the old classes instead of rock, paper and scissors.
I did not get the error that @Jaime_Gonzalez faced although I tried those steps too, but without any difference in the outcome. Any ideas?