# Demo Mode For Demo and Testing Purpose, the device can use pre-recorded images. You need to enable it in the configuration (`TakeImage > Demo`) and also provide the needed files on the SD card. For each round one image gets used, starting with the first image for the first round. For the reference image and the alignment also the first image gets used. Once the last image got reached, it starts again with the first one. ## SD Card Structure ``` demo/ ├── 520.8983.jpg ├── 520.9086.jpg ├── 520.9351.jpg ├── ... └── files.txt ``` - The jpg files can have any name - The jpg files must be smaller than 30'000 bytes - The `files.txt` must contains a list of those files, eg: 520.8983.jpg 520.9086.jpg 520.9351.jpg ## Recording To record real images of a meter, you have to periodically fetch `http:///img_tmp/raw.jpg`. To automate this, you can use the following shell script (Linux only): ```bash #!/bin/bash while [[ true ]]; do echo "fetching value..." wget -q http://192.168.1.151/value -O value.txt value=`cat value.txt` echo "Value: $value" diff=`diff value.txt value_previous.txt` changed=$? #echo "Diff: $diff" if [[ $changed -ne 0 ]]; then echo "Value changed:" echo $diff echo "fetching image..." wget -q http://192.168.1.151/img_tmp/raw.jpg -O $value.jpg else echo "Value did not change, skipping image fetching!" fi cp value.txt value_previous.txt echo "waiting 60s..." sleep 60 done ``` ## Installation Just install the zip file using the OTA Update functionality. ## How does it work The Demo Mode tries to interfere as less as possible with the normal behavior. Whenever a Cam framebuffer gets taken (`esp_camera_fb_get()`), it replaces the framebuffer with the image from the SD card. ## Example Data of a Water Meter You can use the following demo images if you want: ![530 00688](https://user-images.githubusercontent.com/1783586/211902363-1b8e4115-5f08-4e25-ace6-bb52e43b3741.jpg){:style="width:400px"} It covers a meter range from `530.00688` to `531.85882`. ### Animation [Animation of the watermeter (77 MB!)](img/demo-watermeter-animated.png) ### Selection of 84 images [![grafik](https://user-images.githubusercontent.com/1783586/211915870-aa5c1342-c61c-4e1f-afe0-10e222f1499d.png){:style="width:400px"}](https://user-images.githubusercontent.com/1783586/211915870-aa5c1342-c61c-4e1f-afe0-10e222f1499d.png) [Demo_Images_Watermeter_530.00688-532.08243_84_images.zip](https://github.com/jomjol/AI-on-the-edge-device-docs/files/10395892/Demo_Images_Watermeter_530.00688-532.08243_84_images.zip) ### Selection of 42 images [![grafik](https://user-images.githubusercontent.com/1783586/211915898-b499e109-7b63-4e21-ba5b-c0a370022f7a.png){:style="width:400px"}](https://user-images.githubusercontent.com/1783586/211915898-b499e109-7b63-4e21-ba5b-c0a370022f7a.png) [Demo_Images_Watermeter_530.00688-532.08243_42_images.zip](https://github.com/jomjol/AI-on-the-edge-device-docs/files/10395893/Demo_Images_Watermeter_530.00688-532.08243_42_images.zip) ### All images (843 images) [![grafik](https://user-images.githubusercontent.com/1783586/211915731-9a2a3cd3-390b-4b1f-a064-5e7e443ab113.png){:style="width:400px"}](https://user-images.githubusercontent.com/1783586/211915731-9a2a3cd3-390b-4b1f-a064-5e7e443ab113.png) [Demo_Images_Watermeter_530.00688-532.08243_843_images.zip](https://github.com/jomjol/AI-on-the-edge-device-docs/files/10395941/Demo_Images_Watermeter_530.00688-532.08243_843_images.zip)