Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/teticio/kivy-tensorflow-helloworld
Run inference with Tensorflow Lite on iOS, Android, MacOS, Windows and Linux using Python.
https://github.com/teticio/kivy-tensorflow-helloworld
android ios kivy tensorflow-lite
Last synced: 3 months ago
JSON representation
Run inference with Tensorflow Lite on iOS, Android, MacOS, Windows and Linux using Python.
- Host: GitHub
- URL: https://github.com/teticio/kivy-tensorflow-helloworld
- Owner: teticio
- Created: 2021-04-05T11:09:01.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2023-03-17T13:03:15.000Z (almost 2 years ago)
- Last Synced: 2024-10-01T08:24:06.094Z (4 months ago)
- Topics: android, ios, kivy, tensorflow-lite
- Language: Jupyter Notebook
- Homepage:
- Size: 69.3 KB
- Stars: 46
- Watchers: 4
- Forks: 13
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Kivy Tensorflow Hello World
This is a "Hello World" for running Tensorflow Lite on iOS, Android, MacOS, Windows and Linux using Python and Kivy.
## Create a Tensorflow Lite model
You can use the Jupyter notebook in notebooks to create a Tensorflow Lite model file. A dummy example is provided for testing purposes.
## Install buildozer
Install basic Python requirements (all platforms)
```bash
pip install buildozer cython
```Follow the instructions for your platform [here](https://pypi.org/project/buildozer/).
## MacOS, Windows and Linux
```bash
pip install tensorflow numpy kivy
python3 main.py
```## Android
Currently you can only build for Android using `buildozer` on Linux.
Use the included `buildozer.spec` file or make the following changes to one created by `buildozer init`
```
source.include_exts = py,png,jpg,kv,atlas,tflite
requirements = python3,kivy,numpy
android.api = 30
android.minapi = 24
android.gradle_dependencies = org.tensorflow:tensorflow-lite:+,org.tensorflow:tensorflow-lite-support:+
```Note that if your `tflite` model file is too big to be packaged with your APK, you will have to find some other way of getting it on to the device. If this is the case then change this line to ensure it is not included in the package.
```
source.include_exts = py,png,jpg,kv,atlas
```Change the architecture you are building for to match that of your device or emulator
```
android.arch = x86
```Build the APK
```bash
buildozer android debug
```and install it with
```bash
adb install bin/myapp-0.1-x86-debug.apk
```## iOS
Remember that you will need an Apple developer account to be able to install your app on a real iPhone.
Install prerequisite system packages
```bash
brew install cocoapods pkg-config autoconf automake
```Install additional Python requirements
```bash
pip install pbxproj cookiecutter
```Build your app and install the Tensorflow Lite pod
```bash
buildozer ios debug
cd .buildozer/ios/platform/kivy-ios/myapp-ios/
cp YourApp/Podfile .
pod install
open -a Xcode myapp.xcworkspace
```As indicated in the warning messages, you will need to make some changes to the project configuration. You can either do this by editing `myapp-ios\myapp.xcodeproj` or by editing the Build Settings for `myapp` in Xcode. Search for `GCC_PREPROCESSOR_DEFINITIONS` and add `$(inherited)` to the Debug target. Then repeat the process for `HEADER_SEARCH_PATHS`, `OTHER_LDFLAGS` and (possibly) `EXCLUDED_ARCHS[sdk=iphonesimulator*]` for all targets. Now you should be able to build and run your app. All being well you should see the following output (give or take rounding errors)
```python
[[ 0.01647118, 1.0278152 , -0.7065112 , -1.0278157 , 0.12216613, 0.37980393, 0.5839217 , -0.04283606, -0.04240461, -0.58534086 ]]
```Every time you build you will need to run `buildozer ios debug` and then build and deploy from Xcode.