Skip to content

timukasr/object_detection_flutter

 
 

Repository files navigation

Testing TFLite Flutter Plugin speed

Object Detection app built using TFLite Flutter Plugin.

It seems that newer versions are significantly slower than older ones. It seems that issue is introduced with this commit Flutter Engine. It changed something with CPU affinity, which affects performance of tflite_flutter when more than one thread is used.

This repo can be used to test:

  • tflite_flutter versions 0.9.5 and 0.10.4
  • Flutter 3.13.9 and 3.16.9
  • Different number of threads

Important

For tflite_flutter 0.9.5, following is needed:

  • execute install.sh(linux) or install.bat(windows) for downloading tflite binaries. More info here.

Environment

This was tested on the following environment:

  • Built on Windows 10 with Java 11.0.12
  • Run on Pixel 5 (Android 14)

Just detected same blank(ish) camera image. Not too scientific (e.g. phone might heat up and give lower results), so few ms difference should not be taken too seriously, but the 7x or 16x difference is significant.

Test 1

This test tflite_flutter versions and Flutter versions, to see if difference is in tflite_flutter or Flutter. Number of threads: 4

Results

Average time until settles (times in ms).

Test Inference Pre-processing Total predict Total elapsed
tflite_flutter: 0.9.5
Flutter: 3.13.9
22 17 39 51
tflite_flutter: 0.9.5
Flutter: 3.16.9
359 18 378 387
tflite_flutter: 0.10.4
Flutter: 3.13.9
22 15 38 50
tflite_flutter: 0.10.4
Flutter: 3.16.9
351 16 368 376

Conclusion

  • Only inference speed is affected.
  • No difference between tflite_flutter 0.9.5 and 0.10.4
  • Big difference between Flutter 3.13.9 and Flutter 3.16.9 - 16x slower inference time and 7.5x slower total time.

Flutter 3.24.2 seemed to be as slow as 3.16.9. So it seems that the problem is not yet fixed.

Test 2

Because issue occurred with commit related to CPU, this test tests the number of threads, that can be changed in .

tflite_flutter 0.10.4 was used and only inference time was measured.

Test 1 thread 2 threads 4 threads
Flutter: 3.13.9 37 24 25
Flutter: 3.16.9 40 185 349

Conclusion

When using more than 1 thread, inference time is significantly slower with Flutter 3.16.0 and later.

About

Truly realtime object-detection in flutter

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Dart 88.2%
  • Ruby 4.2%
  • Batchfile 2.9%
  • Shell 2.9%
  • Swift 1.3%
  • Kotlin 0.4%
  • Objective-C 0.1%