diff options
Diffstat (limited to 'python-learning-loop-node.spec')
-rw-r--r-- | python-learning-loop-node.spec | 403 |
1 files changed, 403 insertions, 0 deletions
diff --git a/python-learning-loop-node.spec b/python-learning-loop-node.spec new file mode 100644 index 0000000..44ee464 --- /dev/null +++ b/python-learning-loop-node.spec @@ -0,0 +1,403 @@ +%global _empty_manifest_terminate_build 0 +Name: python-learning-loop-node +Version: 0.7.50 +Release: 1 +Summary: Python Library for Nodes which connect to the Zauberzeug Learning Loop +License: MIT +URL: https://github.com/zauberzeug/learning_loop_node +Source0: https://mirrors.nju.edu.cn/pypi/web/packages/98/47/888df685a94bb8156e97e03e4122d655c426d5fc76f5eea4926e4bc6c9c0/learning_loop_node-0.7.50.tar.gz +BuildArch: noarch + +Requires: python3-requests +Requires: python3-socketio[asyncio_client] +Requires: python3-fastapi-socketio +Requires: python3-fastapi +Requires: python3-uvicorn +Requires: python3-fastapi-utils +Requires: python3-simplejson +Requires: python3-icecream +Requires: python3-aiofiles +Requires: python3-async_generator +Requires: python3-werkzeug +Requires: python3-pytest-watch +Requires: python3-multipart +Requires: python3-psutil +Requires: python3-numpy +Requires: python3-Pillow +Requires: python3-tqdm +Requires: python3-pytest-mock +Requires: python3-pynvml + +%description +# Learning Loop Node + +This Python library helps you to write your own Detection Nodes, Training Nodes and Converter Nodes for the Zauberzeug Learning Loop. + +## General Usage + +You can configure connection to our Learning Loop by specifying the following environment variables before starting: + +- LOOP_HOST=learning-loop.ai +- LOOP_USERNAME=<your username> +- LOOP_PASSWORD=<your password> + +## Detector Node + +Detector Nodes are normally deployed on edge devices like robots or machinery but can also run in the cloud to provide backend services for an app or similar. These nodes register themself at the Learning Loop to make model deployments very easy. They also provide REST and Socket.io APIs to run inferences. By default the images will automatically used for active learning: high uncertain predictions will be submitted to the Learning Loop inbox. + +#### Additinal environment variables + +- LOOP_ORGANIZATION=<your organization> +- LOOP_PROJECT=<your project> + +## Trainer Node + +Trainers fetch the images and anntoations from the Learning Loop to generate new and improved models. + +- if the command line tool "jpeginfo" is installed, the downloader will drop corrupted images automatically + +## Converter Node + +A Conveter Node converts models from one format into another. + +### How to test the operability? + +Assumend there is a Converter Node which converts models of format 'format_a' into 'format_b'. +Upload a model with +`curl --request POST -F 'files=@my_model.zip' https://learning-loop.ai/api/zauberzeug/projects/demo/format_a` +The model should now be available for the format 'format_a' +`curl "https://learning-loop.ai/api/zauberzeug/projects/demo/models?format=format_a"` + +``` +{ + "models": [ + { + "id": "3c20d807-f71c-40dc-a996-8a8968aa5431", + "version": "4.0", + "formats": [ + "format_a" + ], + "created": "2021-06-01T06:28:21.289092", + "comment": "uploaded at 2021-06-01 06:28:21.288442", + ... + } + ] +} + +``` + +but not in the format_b +`curl "https://learning-loop.ai/api/zauberzeug/projects/demo/models?format=format_b"` + +``` +{ + "models": [] +} +``` + +Connect the Node to the Learning Loop by simply starting the container. +After a short time the converted model should be available as well. +`curl https://learning-loop.ai/api/zauberzeug/projects/demo/models?format=format_b` + +``` +{ + "models": [ + { + "id": "3c20d807-f71c-40dc-a996-8a8968aa5431", + "version": "4.0", + "formats": [ + "format_a", + "format_b", + ], + "created": "2021-06-01T06:28:21.289092", + "comment": "uploaded at 2021-06-01 06:28:21.288442", + ... + } + ] +} +``` + +## About Models (the currency between Nodes) + +- Models are packed in zips and saved on the Learning Loop (one for each format) +- Nodes and users can upload and download models with which they want to work +- In each zip there is a file called `model.json` which contains the metadata to interpret the other files in the package +- for base models (pretrained models from external sources) no `model.json` has to be sent, ie. these models should simply be zipped in such a way that the respective trainer can work with them. +- the loop adds or corrects the following properties in the `model.json` after receiving; it also creates the file if it is missing: + - `host`: uri to the loop + - `organization`: the ID of the organization + - `project`: the id of the project + - `version`: the version number that the loop assigned for this model (e.g. 1.3) + - `id`: the model UUID (currently not needed by anyone, since host, org, project, version clearly identify the model) + - `format`: the format e.g. yolo, tkdnn, yolor etc. +- Nodes add properties to `model.json`, which contains all the information which are needed by subsequent nodes. These are typically the properties: + - `resolution`: resolution in which the model expects images (as `int`, since the resolution is mostly square - later, ` resolution_x`` resolution_y ` would also be conceivable or `resolutions` to give a list of possible resolutions) + - `categories`: list of categories with name, id, (later also type), in the order in which they are used by the model -- this is neccessary to be robust about renamings + + +%package -n python3-learning-loop-node +Summary: Python Library for Nodes which connect to the Zauberzeug Learning Loop +Provides: python-learning-loop-node +BuildRequires: python3-devel +BuildRequires: python3-setuptools +BuildRequires: python3-pip +%description -n python3-learning-loop-node +# Learning Loop Node + +This Python library helps you to write your own Detection Nodes, Training Nodes and Converter Nodes for the Zauberzeug Learning Loop. + +## General Usage + +You can configure connection to our Learning Loop by specifying the following environment variables before starting: + +- LOOP_HOST=learning-loop.ai +- LOOP_USERNAME=<your username> +- LOOP_PASSWORD=<your password> + +## Detector Node + +Detector Nodes are normally deployed on edge devices like robots or machinery but can also run in the cloud to provide backend services for an app or similar. These nodes register themself at the Learning Loop to make model deployments very easy. They also provide REST and Socket.io APIs to run inferences. By default the images will automatically used for active learning: high uncertain predictions will be submitted to the Learning Loop inbox. + +#### Additinal environment variables + +- LOOP_ORGANIZATION=<your organization> +- LOOP_PROJECT=<your project> + +## Trainer Node + +Trainers fetch the images and anntoations from the Learning Loop to generate new and improved models. + +- if the command line tool "jpeginfo" is installed, the downloader will drop corrupted images automatically + +## Converter Node + +A Conveter Node converts models from one format into another. + +### How to test the operability? + +Assumend there is a Converter Node which converts models of format 'format_a' into 'format_b'. +Upload a model with +`curl --request POST -F 'files=@my_model.zip' https://learning-loop.ai/api/zauberzeug/projects/demo/format_a` +The model should now be available for the format 'format_a' +`curl "https://learning-loop.ai/api/zauberzeug/projects/demo/models?format=format_a"` + +``` +{ + "models": [ + { + "id": "3c20d807-f71c-40dc-a996-8a8968aa5431", + "version": "4.0", + "formats": [ + "format_a" + ], + "created": "2021-06-01T06:28:21.289092", + "comment": "uploaded at 2021-06-01 06:28:21.288442", + ... + } + ] +} + +``` + +but not in the format_b +`curl "https://learning-loop.ai/api/zauberzeug/projects/demo/models?format=format_b"` + +``` +{ + "models": [] +} +``` + +Connect the Node to the Learning Loop by simply starting the container. +After a short time the converted model should be available as well. +`curl https://learning-loop.ai/api/zauberzeug/projects/demo/models?format=format_b` + +``` +{ + "models": [ + { + "id": "3c20d807-f71c-40dc-a996-8a8968aa5431", + "version": "4.0", + "formats": [ + "format_a", + "format_b", + ], + "created": "2021-06-01T06:28:21.289092", + "comment": "uploaded at 2021-06-01 06:28:21.288442", + ... + } + ] +} +``` + +## About Models (the currency between Nodes) + +- Models are packed in zips and saved on the Learning Loop (one for each format) +- Nodes and users can upload and download models with which they want to work +- In each zip there is a file called `model.json` which contains the metadata to interpret the other files in the package +- for base models (pretrained models from external sources) no `model.json` has to be sent, ie. these models should simply be zipped in such a way that the respective trainer can work with them. +- the loop adds or corrects the following properties in the `model.json` after receiving; it also creates the file if it is missing: + - `host`: uri to the loop + - `organization`: the ID of the organization + - `project`: the id of the project + - `version`: the version number that the loop assigned for this model (e.g. 1.3) + - `id`: the model UUID (currently not needed by anyone, since host, org, project, version clearly identify the model) + - `format`: the format e.g. yolo, tkdnn, yolor etc. +- Nodes add properties to `model.json`, which contains all the information which are needed by subsequent nodes. These are typically the properties: + - `resolution`: resolution in which the model expects images (as `int`, since the resolution is mostly square - later, ` resolution_x`` resolution_y ` would also be conceivable or `resolutions` to give a list of possible resolutions) + - `categories`: list of categories with name, id, (later also type), in the order in which they are used by the model -- this is neccessary to be robust about renamings + + +%package help +Summary: Development documents and examples for learning-loop-node +Provides: python3-learning-loop-node-doc +%description help +# Learning Loop Node + +This Python library helps you to write your own Detection Nodes, Training Nodes and Converter Nodes for the Zauberzeug Learning Loop. + +## General Usage + +You can configure connection to our Learning Loop by specifying the following environment variables before starting: + +- LOOP_HOST=learning-loop.ai +- LOOP_USERNAME=<your username> +- LOOP_PASSWORD=<your password> + +## Detector Node + +Detector Nodes are normally deployed on edge devices like robots or machinery but can also run in the cloud to provide backend services for an app or similar. These nodes register themself at the Learning Loop to make model deployments very easy. They also provide REST and Socket.io APIs to run inferences. By default the images will automatically used for active learning: high uncertain predictions will be submitted to the Learning Loop inbox. + +#### Additinal environment variables + +- LOOP_ORGANIZATION=<your organization> +- LOOP_PROJECT=<your project> + +## Trainer Node + +Trainers fetch the images and anntoations from the Learning Loop to generate new and improved models. + +- if the command line tool "jpeginfo" is installed, the downloader will drop corrupted images automatically + +## Converter Node + +A Conveter Node converts models from one format into another. + +### How to test the operability? + +Assumend there is a Converter Node which converts models of format 'format_a' into 'format_b'. +Upload a model with +`curl --request POST -F 'files=@my_model.zip' https://learning-loop.ai/api/zauberzeug/projects/demo/format_a` +The model should now be available for the format 'format_a' +`curl "https://learning-loop.ai/api/zauberzeug/projects/demo/models?format=format_a"` + +``` +{ + "models": [ + { + "id": "3c20d807-f71c-40dc-a996-8a8968aa5431", + "version": "4.0", + "formats": [ + "format_a" + ], + "created": "2021-06-01T06:28:21.289092", + "comment": "uploaded at 2021-06-01 06:28:21.288442", + ... + } + ] +} + +``` + +but not in the format_b +`curl "https://learning-loop.ai/api/zauberzeug/projects/demo/models?format=format_b"` + +``` +{ + "models": [] +} +``` + +Connect the Node to the Learning Loop by simply starting the container. +After a short time the converted model should be available as well. +`curl https://learning-loop.ai/api/zauberzeug/projects/demo/models?format=format_b` + +``` +{ + "models": [ + { + "id": "3c20d807-f71c-40dc-a996-8a8968aa5431", + "version": "4.0", + "formats": [ + "format_a", + "format_b", + ], + "created": "2021-06-01T06:28:21.289092", + "comment": "uploaded at 2021-06-01 06:28:21.288442", + ... + } + ] +} +``` + +## About Models (the currency between Nodes) + +- Models are packed in zips and saved on the Learning Loop (one for each format) +- Nodes and users can upload and download models with which they want to work +- In each zip there is a file called `model.json` which contains the metadata to interpret the other files in the package +- for base models (pretrained models from external sources) no `model.json` has to be sent, ie. these models should simply be zipped in such a way that the respective trainer can work with them. +- the loop adds or corrects the following properties in the `model.json` after receiving; it also creates the file if it is missing: + - `host`: uri to the loop + - `organization`: the ID of the organization + - `project`: the id of the project + - `version`: the version number that the loop assigned for this model (e.g. 1.3) + - `id`: the model UUID (currently not needed by anyone, since host, org, project, version clearly identify the model) + - `format`: the format e.g. yolo, tkdnn, yolor etc. +- Nodes add properties to `model.json`, which contains all the information which are needed by subsequent nodes. These are typically the properties: + - `resolution`: resolution in which the model expects images (as `int`, since the resolution is mostly square - later, ` resolution_x`` resolution_y ` would also be conceivable or `resolutions` to give a list of possible resolutions) + - `categories`: list of categories with name, id, (later also type), in the order in which they are used by the model -- this is neccessary to be robust about renamings + + +%prep +%autosetup -n learning-loop-node-0.7.50 + +%build +%py3_build + +%install +%py3_install +install -d -m755 %{buildroot}/%{_pkgdocdir} +if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi +if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi +if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi +if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi +pushd %{buildroot} +if [ -d usr/lib ]; then + find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/lib64 ]; then + find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/bin ]; then + find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/sbin ]; then + find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst +fi +touch doclist.lst +if [ -d usr/share/man ]; then + find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst +fi +popd +mv %{buildroot}/filelist.lst . +mv %{buildroot}/doclist.lst . + +%files -n python3-learning-loop-node -f filelist.lst +%dir %{python3_sitelib}/* + +%files help -f doclist.lst +%{_docdir}/* + +%changelog +* Mon May 15 2023 Python_Bot <Python_Bot@openeuler.org> - 0.7.50-1 +- Package Spec generated |