AK_SW_BENCHMARKER that makes it possible to apply different sizing algorithms and allometric yield prediction models to manually labeled color and depth tree images.
Project description
AKFruitYield: AK_SW_BENCHMARKER - Azure Kinect Size Estimation & Weight Prediction Benchmarker
AKFruitYield is a modular software that allows orchard data from RGB-D Azure Kinect cameras to be processed for fruit size and fruit yield estimation. Specifically, two modules have been developed: i) AK_SW_BENCHMARKER that makes it possible to apply different sizing algorithms and allometric yield prediction models to manually labeled color and depth tree images; and ii) AK_VIDEO_ANALYSER that analyses videos on which to automatically detect apples, estimate their size and predict yield at the plot or per hectare scale using the appropriate simulated algorithms. Both modules have easy-to-use graphical interfaces and provide reports that can subsequently be used by other analysis tools.
AK_VIDEO_ANALYSER is part of the AKFruitData and AKFruitYield family (Fig 1.), a suite that offers field acquisition tools focused on the Azure Kinect DK sensor. Table 1-2 shows the links to the other developed tools.
Fig. 1. a) Proposed stages of data acquisition and extraction for AKFruitData and AKFruitYield. Dashed green lines correspond to processes related to acquisition, red lines to processes related to data creation and training, and black lines to processes for performance estimation. b) Interoperability between the data acquisition (AK_ACQS; AK_SM_RECORDER), data creation (AK_FRAEX), algorithm benchmarking (AK_SW_BENCHMARKER) and video analysis (AK_VIDEO_ANALYSER) modules. The processes proposed in Figure 1 are expanded and represented by the developed software. |
Package | Description |
---|---|
AK_ACQS Azure Kinect Acquisition System (https://github.com/GRAP-UdL-AT/ak_acquisition_system) | AK_ACQS is a software solution for data acquisition in fruit orchards using a sensor system boarded on a terrestrial vehicle. It allows the coordination of computers and sensors through the sending of remote commands via a GUI. At the same time, it adds an abstraction layer on library stack of each sensor, facilitating its integration. This software solution is supported by a local area network (LAN), which connects computers and sensors from different manufacturers ( cameras of different technologies, GNSS receiver) for in-field fruit yield testing. |
AK_SM_RECORDER - Azure Kinect Standalone Mode (https://github.com/GRAP-UdL-AT/ak_sm_recorder) | A simple GUI recorder based on Python to manage Azure Kinect camera devices in a standalone mode. https://pypi.org/project/ak-sm-recorder/ |
AK_FRAEX - Azure Kinect Frame Extractor (https://github.com/GRAP-UdL-AT/ak_frame_extractor) | AK_FRAEX is a desktop tool created for post-processing tasks after field acquisition. It enables the extraction of information from videos recorded in MKV format with the Azure Kinect camera. Through a GUI, the user can configure initial parameters to extract frames and automatically create the necessary metadata for a set of images. (https://pypi.org/project/ak-frame-extractor/) |
Table 1. | Modules developed under the AKFruitData family |
Package | Description |
---|---|
AK_SW_BENCHMARKER - Azure Kinect Size Estimation & Weight Prediction Benchmarker (https://github.com/GRAP-UdL-AT/ak_sw_benchmarker/) | Python based GUI tool for fruit size estimation and weight prediction. |
AK_VIDEO_ANALYSER - Azure Kinect Video Analyser (https://github.com/GRAP-UdL-AT/ak_video_analyser/) | Python based GUI tool for fruit size estimation and weight prediction from videos. |
Table 2. | Modules developed under the AKFruitYield family |
AK_SW_BENCHMARKER description
Python based GUI tool for fruit size estimation and weight prediction. It receives as input a data set in the format explained by Miranda et al., 2022 and a ground truth file to display various fruit measurements. ak-sw-benchmarker is part of the AKFruitYield family (Fig 2.), a suite that offers field acquisition tools focused on the Azure Kinect DK sensor. Table 1 shows the links to the other developed tools. This is the Github repository of ak-simulator, an installable version can be found published on Pypi.org at the following link https://pypi.org/project/ak-simulator/
Fig. 2. ak_sw_benchmarker module user interface. a) 'Dataset metrics' tab to select data (frames) and configure the sizing and yield prediction algorithms. b) 'Metric comparisons' tab to report results and error statistics. |
Contents
- Pre-requisites.
- Functionalities.
- Install and run.
- Files and folder description.
- Development tools, environment, build executables.
1. Pre-requisites
- SDK Azure Kinect installed.
- pyk4a library installed. If the operating system is Windows, follow this steps. You can find test basic examples with pyk4a here.
- In Ubuntu 20.04, we provide a script to install the camera drivers following the instructions in azure_kinect_notes.
- Videos recorded with the Azure Kinect camera, optional video samples are available at AK_FRAEX - Azure Kinect Frame Extractor demo videos
2. Functionalities
The functionalities of the software are briefly described. Supplementary material can be found in USER's Manual.
- Analyse dataset allows benchmarking to be performed with a final report of size estimates and weight prediction. The user has the option of introducing a file with values of real dimensions of fruits (ground truth) to compare with the set of images that it is desired to be analyzed. A final report with results (size and weight) grouped by image and fruit will be presented according to the selected parameters in addition to the test metrics.
- Export images makes it possible to visualize the geometric fitting of the ROIs on the objects (fruits) to be measured. Outputs are color images including binary masks of selected objects and fruit labeling. This functionality adds value to the software since the user can observe how sizing algorithms are applied to the images, enabling corrective adjustments in the algorithm configuration if necessary.
- Run tests in dataset calculates the test metrics. The user must first indicate the estimate to be analyzed (Report selector in Fig. 2b), namely the major geometric axis of the fruit (A1), the minor axis (A2) or the weight (WEIGHT). Since all sizing-yielding combinations are analyzed, this functionality allows the method with least error to be determined, also obtaining a final ranking of sizing algorithms or ranking of sizing-allometric model combinations.
3. Install and run
3.1 PIP quick install package
Create your Python virtual environment.
python3 -m venv ./ak_sw_benchmarker_venv
source ./ak_sw_benchmarker_venv/bin/activate
pip install --upgrade pip
** for Windows 10 is python.exe -m pip install --upgrade pip **
pip install python -m ak-simulator
python -m ak_sw_benchmarker
Download the dataset with images and the file with apples groundtruth from https://github.com/GRAP-UdL-AT/ak_sw_benchmarker/blob/main/data/.
3.2 Install and run virtual environments using scripts provided
- [Linux] Enter to the folder "ak_sw_benchmarker/"
Create virtual environment(only first time)
chmod 755 *.sh; ./creating_env_ak_sw_benchmarker.sh
Run script.
./ak_sw_benchmarker_start.sh
- [Windows] Enter to the folder "ak_sw_benchmarker/"
Create virtual environment(only first time)
TODO_HERE
Run script from CMD.
./ak_sw_benchmarker_start.bat
4.3 Files and folder description
Folder description:
Folders | Description |
---|---|
docs/ | Documentation |
src/ | Source code |
data/ | Dataset with images and the file with apples groundtruth. |
. | . |
Python environment files:
Files | Description | OS |
---|---|---|
activate_env.bat | Activate environments in Windows | WIN |
ak_sw_benchmarker_start.bat | Executing main script | WIN |
creating_env_ak_sw_benchmarker_sim.sh | Automatically creates Python environments | Linux |
ak_sw_benchmarker_start.sh | Executing main script | Linux |
Pypi.org PIP packages files:
Files | Description | OS |
---|---|---|
build_pip.bat | Build PIP package to distribution | WIN |
/src/ak_sw_benchmarker/main.py | Main function used in package compilation | Supported by Python |
setup.cfg | Package configuration PIP | Supported by Python |
pyproject.toml | Package description PIP | Supported by Python |
5. Development tools, environment, build executables
Some development tools are needed with this package, listed below:
5.1 Notes for developers
You can use the main.py for execute as first time in src/ak-size-estimation/_ _ main _ _.py Configure the path of the project, if you use Pycharm, put your folder root like this:
5.2 Creating virtual environment Windows / Linux
python3 -m venv ak_size_weight_sim_venv
source ./ak_size_weight_sim_venv/bin/activate
pip install --upgrade pip
pip install -r requirements_windows.txt or pip install -r requirements_linux.txt
** If there are some problems in Windows, follow this **
pip install pyk4a --no-use-pep517 --global-option=build_ext --global-option="-IC:\Program Files\Azure Kinect SDK v1.4.1\sdk\include" --global-option="-LC:\Program Files\Azure Kinect SDK v1.4.1\sdk\windows-desktop\amd64\release\lib"
5.3 Building PIP package
We are working to offer Pypi support for this package. At this time this software can be built by scripts automatically.
5.3.1 Build packages
py -m pip install --upgrade build
build_pip.bat
5.3.2 Download PIP package
pip install package.whl
5.3.3 Run ak_sw_benchmarker
python -m ak_sw_benchmarker
After the execution of the script, a new folder will be generated inside the project "/dist". You can copy ** ak_sw_benchmarker_f/** or a compressed file "ak_sw_benchmarker_f.zip" to distribute.
5.6 Package distribution format
At this time, the current supported format for the distribution is Python packages.
Package type | Package | Url | Description |
---|---|---|---|
PIP | .whl | .whl | PIP packages are stored in build/ |
Authorship
This project is contributed by GRAP-UdL-AT. Please contact authors to report bugs juancarlos.miranda@udl.cat
Citation
If you find this code useful, please consider citing:
@article{MIRANDA2022101231,
title = {AKFruitYield: Modular benchmarking and video analysis software for Azure Kinect cameras for fruit size and fruit yield estimation in apple orchards},
journal = {SoftwareX},
volume = {XX},
pages = {000000},
year = {2023},
issn = {0000-0000},
doi = {},
url = {},
author = {Juan Carlos Miranda and Jaume Arnó and Jordi Gené-Mola and Spyros Fountas and Eduard Gregorio},
keywords = {RGB-D camera, apple fruit sizing, yield prediction, detection and benchmarking algorithms, allometry},
abstract = {.}
}
Acknowledgements
This work was partly funded by the Department of Research and Universities of the Generalitat de Catalunya (grants 2017 SGR 646) and by the Spanish Ministry of Science and Innovation/AEI/10.13039/501100011033/ERDF (grant RTI2018-094222-B-I00 PAgFRUIT project and PID2021-126648OB-I00 PAgPROTECT project). The Secretariat of Universities and Research of the Department of Business and Knowledge of the Generalitat de Catalunya and European Social Fund (ESF) are also thanked for financing Juan Carlos Miranda’s pre-doctoral fellowship (2020 FI_B 00586). The work of Jordi Gené-Mola was supported by the Spanish Ministry of Universities through a Margarita Salas postdoctoral grant funded by the European Union - NextGenerationEU. The authors would also like to thank the Institut de Recerca i Tecnologia Agroalimentàries (IRTA) for allowing the use of their experimental fields, and in particular Dr. Luís Asín and Dr. Jaume Lordán who have contributed to the success of this work.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ak_sw_benchmarker-0.0.9.tar.gz
.
File metadata
- Download URL: ak_sw_benchmarker-0.0.9.tar.gz
- Upload date:
- Size: 102.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 95ac61919c00c6b620ebf3e9d23a38853914f23974ee5a37910db9d8b1bc6b2f |
|
MD5 | b379cd3824bd54bc7aeffa2eec40aa12 |
|
BLAKE2b-256 | 41dd43eca38c05ea5738d7411f293fc4b269bd2bec875116fc2415dbbb8911e4 |
File details
Details for the file ak_sw_benchmarker-0.0.9-py3-none-any.whl
.
File metadata
- Download URL: ak_sw_benchmarker-0.0.9-py3-none-any.whl
- Upload date:
- Size: 135.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 80ead13003de50df1e42a56ef8698d0de5b2de7b0a9802889bcf6bbccd94ffbb |
|
MD5 | d82768c3d4746b5513a62131e1a8d85c |
|
BLAKE2b-256 | d70ccf5682fec7967dd682e7c886ea41d30d849c68f302775038cba258dfbdb3 |