Metadata-Version: 2.4
Name: distry-py
Version: 0.2.0
Summary: Distributed task execution framework
Author: Carlo Moro
License: MIT
Project-URL: Homepage, https://github.com/cnmoro/distry
Keywords: distributed,computing,parallel,processing
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Requires-Python: >=3.8
Description-Content-Type: text/markdown
License-File: LICENSE
Provides-Extra: client
Requires-Dist: requests; extra == "client"
Requires-Dist: cloudpickle; extra == "client"
Provides-Extra: worker
Requires-Dist: fastapi; extra == "worker"
Requires-Dist: uvicorn[standard]; extra == "worker"
Requires-Dist: cloudpickle; extra == "worker"
Requires-Dist: pydantic; extra == "worker"
Provides-Extra: dev
Requires-Dist: pytest; extra == "dev"
Requires-Dist: pytest-asyncio; extra == "dev"
Requires-Dist: requests; extra == "dev"
Requires-Dist: black; extra == "dev"
Requires-Dist: flake8; extra == "dev"
Requires-Dist: mypy; extra == "dev"
Provides-Extra: all
Requires-Dist: requests; extra == "all"
Requires-Dist: cloudpickle; extra == "all"
Requires-Dist: fastapi; extra == "all"
Requires-Dist: uvicorn[standard]; extra == "all"
Requires-Dist: cloudpickle; extra == "all"
Requires-Dist: pydantic; extra == "all"
Dynamic: license-file

<img src="data:image/svg+xml;base64,<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 25.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
	 viewBox="0 0 1111.9 803.7" style="enable-background:new 0 0 1111.9 803.7;" xml:space="preserve">
<style type="text/css">
	.st0{fill:#131616;}
	.st1{fill:#131717;}
	.st2{fill:#141717;}
	.st3{fill:#8B8E92;}
	.st4{fill:#888A8D;}
	.st5{fill:#888A8E;}
	.st6{fill:#494A4D;}
	.st7{fill:#888B8E;}
	.st8{fill:#4A4A4E;}
	.st9{fill:#4A4B4E;}
	.st10{fill:#4B4B4F;}
	.st11{fill:#FACA20;}
	.st12{fill:#FACA21;}
	.st13{fill:#FDFDFD;}
	.st14{fill:#FCFCFC;}
</style>
<g>
	<path d="M875.2,455c4-11.1,5.4-11.7,3-22c-5.8-8-13.4-11-22.6-9.7c-0.5-2.4-2.2-3.6-3.6-4.8c-4.1-3.3-8.9-4.7-14.2-4.3
		c-2.1,1.8-5.1,1.1-7.3,2.9c-2,1.6-4.8,2.1-7,3.5c-6.4,4.2-12.7,8.7-19.1,13c-4.4,2.9-8.8,5.9-13.5,8.4c-7.9,4.2-16.3,7.3-25.4,7.8
		c0-0.3-0.2-0.8-0.1-0.9c2.6-3.4,5.2-6.9,8-10.1c3.1-3.5,5.1-7.5,7.3-11.5c2.2-3.9,4.6-7.8,4.6-12.5c2.7-7,0.2-13.7-4.5-18.2
		c-6-5.7-13.3-6.9-21.6-3.6c-9.3,3.7-16.4,10.1-22.5,17.7c-2.9,3.7-5.2,7.8-7.8,11.7c-3.2,4.7-6.4,9.4-9.9,13.8
		c-2.5,3.2-4.6,6.9-8.1,9.1c-3.4,2.1-6.6,4.4-9.5,6.9c-8,6.8-14.3,15-18,24.9c-13.1,4.8-26.1,9.4-39.1,14.2
		c-13,4.8-25.9,9.7-38.8,14.8c-12.9,5-26.1,9.3-38.3,15.3c-26.7-16.1-52.4-33-78.4-49.3c0.1-2.3-0.2-4.3-0.9-6.3
		c-1.7-5-5.9-13.8-8.6-16.4c-4.5-4.5-8.7-9.5-14.1-13c-3-1.9-5.8-4-9.4-5.1c-3.5-1.2-6.9-3-9.6-5.8c-4.2-4.5-8.6-8.8-13.9-12.1
		c-4.6-2.9-9.3-5.9-14.3-7.7c-10.1-3.5-20.3-7.2-31.1-8.2c-2-1.5-4.7-0.2-6.5-1.2c-2-1.1-3.9-0.8-5.7-0.7c-2.2,0.1-3.9-1.4-6.1-1.2
		c-3.3,0.4-6.7,0.2-9.6-1.4c0-2.6,0-5,0-7.5c5,0.2,9.5-2.3,14.3-2.1c1.2-1.7,3.1-0.5,4.6-1c4.1-1.4,8.5-2.1,12.6-3.3
		c4.1-1.2,8.4-2.2,12.5-3.7c5.8-2.1,11.6-4.2,17.2-6.7c4.4-2,8.4-4.6,12.5-7.2c7.9-4.9,14.7-11.1,20.2-18.6
		c2.7-3.8,5.1-7.8,6.4-12.3c1.1-3.8,2.7-7.4,2.5-11.4c1.9-1.6,0.8-3.7,0.9-5.6c0.1-1.9,1.2-3.5,1.1-5.6c-0.3-6.5,0-13-0.1-19.5
		c-0.2-6.4,0.6-12.7-0.8-19.1c-0.8-3.7,0.1-7.7-1-11.6c-0.8-2.7,0-5.7-1-8.6c-0.8-2.2-0.2-4.7-1-7.1c-0.7-2.2-0.7-4.7-0.9-7.1
		c-0.3-2.7-1-5.4-1.4-8c-0.4-2-0.3-4.2-1-6c-1.3-3.5-1.7-7.3-2.6-10.9c-0.6-2.4-0.9-5-1.7-7.3c-0.8-2.4-1.1-4.8-2-7.1
		c-2.5-6.5-3.6-13.5-7.4-19.4c-0.5-4-3-7.1-4.6-10.6c-1.6-3.5-3.8-6.8-5.9-10c-2.6-4-5.6-7.7-8.4-11.6c-2.6-3.7-6-6.4-9-9.7
		c-3-3.3-6.3-6.4-9.5-9.6c-2.2,0-3-2.3-4.6-3.2c-4.6-2.6-9.1-5.4-13.5-8.3c-5.4-3.5-11.7-5-17-8.6c-10.7-2.7-20.9-7.2-32.1-8.2
		c-2.3-0.2-4.9-0.2-7-1c-2.4-0.8-4.8-1.1-7.1-0.8c-2.6,0.4-4.6-1.2-7.1-1.1c-8.8,0.1-17.6,0.1-26.5,0c-1.2,0-2.3,0.3-3,0.7
		c-1.4-0.7-1.7-1.6-1.5-2.6c0.3-3.3-1.6-6.3-1-9.6c-2.3-4.5-1.7-9.5-2.8-14.3c-0.7-3.1-0.1-6.6-0.1-9.6c1.5-2,3.9-1.9,5.4-3.4
		c1.5-1.5,3.2-3,4.6-4.6c4.2-4.9,7.5-10.2,7-17.1c-0.1-1.7,0-3.3,0-5c-0.2-6.4-2.6-11.9-6.8-16.6c-2.2-2.5-4.9-4.4-7.8-6.2
		c-2.8-1.7-5.9-1.9-8.6-3.5c-7.4-0.3-14.7-0.1-21.3,4c-3.8,2.4-6.9,5.4-9.4,9c-3,4.2-5.4,8.5-5,13.9c-2.7,3.6,1.2,7.1,0.1,10.6
		c1.3,5.1,6.8,13.3,11.3,16.2c2.3,1.5,4.7,2.9,7.4,3.7c2.3,0.7,5,0.8,7.1,3c-1,11.1,2,21.9,3.5,33.3c-0.5,0-1.4,0.2-2,1.1
		c-4,0-7.8,1.1-11.6,2c-5.5,1.3-11,2.3-16.3,4c-8.1,2.6-16,5.5-23.7,9.1c-3.5,1.6-7,3.3-10.4,5.1c-3.5,1.8-6.7,4-9.9,6.2
		c-6.2,4.2-11.9,9.4-17.6,14.3c-3.1,2.7-5.5,6-8.3,9c-3.5,3.8-6.7,7.9-9.5,12.1c-4.5,6.6-8.8,13.5-11.7,21.1
		c-2.3,6.2-4.8,12.3-6.8,18.7c-2.6,8.2-3.6,16.6-4.9,25.1c-4.5,2-7.9,5.8-11.3,9.5c-2.7,3-8,13.1-8.4,16c-0.4,3-1.6,5.7-2,8.7
		c-0.4,3-0.3,6-0.9,9.1c-0.6,3.1,0.1,6.3,0.6,9.6c0.6,3.9,1.1,7.8,2.1,11.7c2,7.6,5.1,14.5,9.6,21c5.2,7.4,12.4,11.5,20.4,14.6
		c1.6,0.6,3.5,2,5.6,0.9c0.7,1,1.3,1.6,1.4,2.1c0.3,4,2,7.5,3.5,11c2.1,4.7,4.7,9.1,7.6,13.3c2,3,4.3,5.9,6.6,8.8
		c3.1,3.9,7.1,6.9,11,9.7c6.9,4.9,14.5,9,22.6,11.7c5.1,1.8,10.2,3.7,15.6,4.5c1.8,0.3,4.1,0.2,5.5,1c2,1.3,4.1,0,5.6,0.9
		c2.6,1.7,5.4,0.1,8,1.3c2.6,1.3,5.5,0.3,8.3,0.5c0.6,0.1,1.3-0.2,1.5,0.2c0,3.1,0,5.9,0,9.1c-2-1.5-3,0.9-4.7,0.7
		c-6-0.8-11.7,2-17.6,1.9c-2.2,1.5-4.8,0.4-7,1.2c-3.7,1.3-7.7,1.4-11.3,2.8c-2.2,0.9-4.7,0.7-6.9,1.4c-7.6,2.5-15.5,4.5-22.7,7.9
		c-10.9,5-21.4,10.8-29.9,19.6c-3.1,0.5-6.2,0.1-9.5,0.9c-7.8,1.9-15.1,4.8-21.6,9.4c-4.8,3.4-9.4,6.9-13.1,11.8
		c-3.3,4.3-6.3,8.6-8.3,13.6c-2.1,5.1-4,10.2-3.9,15.9c0.1,2.3,0,4.7,0,6.8c-9.4,10.3-19.8,19.2-28.7,29.7
		c-6.8,8-14.9,14.9-21.9,22.9c-7.9,8.9-16.7,17-24.7,25.8c-5.8,6.3-6.8,6.2-13.7,19.8c-2.4,4.7-3.5,9.7-3.8,14.9
		c-0.2,3.7,0,7.3-0.1,11c-0.1,4.7,1.3,9,3.2,13.1c1.8,3.9,4.6,7.1,7.2,10.6c2.5,3.3,5.8,5.3,8.8,7.7c1.8,1.5,3.7,3,5.8,4
		c2.6,1.2,3.4,3.9,4.9,5.8c2.3,3,4.9,5.7,7.6,8.3c10.9,10.4,20.8,21.8,32.4,31.5c3.5,2.9,6.5,6.5,10.3,9.1c2.6,1.8,4.6,4.2,7,6
		c5.4,4.1,11,7.9,16.6,11.7c2.6,1.8,5.2,3.4,7.9,5.1c2.4,5.2,4.2,10.8,8,15.6c2.6,3.3,5.7,5.7,9,7.8c4,2.6,8.5,4.3,13.1,5.7
		c3.4,1,7,1.9,10.5,2.2c4.3,0.5,8.5,1.4,12.6,2.3c3.7,0.8,7.3,2.6,10.2,5.6c6.7,6.8,13.2,13.9,20.7,19.9c5,4,10.7,6.6,17,7.2
		c5.2,0.5,10.1-1,13.8-5.2c1-1.1,2.1-2.1,3.2-3.2c-0.5-1.8,0.9-3,1.4-4.4c2.2-0.1,2.1,0.3,4.1,0.8c2.8,0.8,4.7,3,7.3,4.1
		c4.8,2,9.3,4.8,14.3,6.6c4.9,1.7,9.7,3.9,14.8,5.2c2.1,0.5,4.2,1.9,6.5,1.2c1.5,2.3,4.6-0.3,6.2,2c2.2,0.1,4.5-0.4,6.6,1
		c4.6-0.6,9,1.3,13.6,1.1c5.8-0.3,11.7-0.1,17.5-0.1c0.8,0,1.9,0.3,2.5-0.1c2-1.2,4.1-1.2,6.1-0.9c2.2,0.3,4-1.1,6.1-1
		c4.4,0.2,8.2-2.5,12.6-2.1c6.2-2.9,12.9-4,19.2-6.7c7.5-3.3,14.8-7,21.8-11.3c3.4-2.1,6.3-5,9.5-7.3c6.6-4.7,11.8-10.9,16.7-17.1
		c4.5-5.8,8.1-12.5,11.2-19.3c3.6-7.8,5.6-15.9,6-24.5c0.1-2.1,0-4.3,0-6.3c1.1-0.9,1.9-1.8,2.8-2.3c7.1-3.9,12.1-10.1,16.1-16.9
		c4-6.7,5.6-14.4,7.1-22c0.5-2.5,0.4-5.2,1.1-7.5c1-3.1,1.4-6.2,1.6-9.2c0.3-4,1.9-7.9,1.2-12.1c1.3-1.9,1.2-4,0.9-6.1
		c-0.3-2.2,0.9-4,1.1-6.1c0.2-3.2,0.2-6.4,0.8-9.6c0.8-4.1,0.3-8.3,1-12.6c0.9-4.9-0.5-10.1,1.2-15c-0.7-10.2,1.5-20.3,1-30.5
		c0-1.1-0.6-2.3,0.5-3.2c0.5,0.5,0.9,1.1,1.4,1.4c6,3.2,11.8,7,17.6,10.5c2.8,1.7,5.7,3,8.5,4.7c5.2,3.1,10.3,6.3,15.6,9.3
		c4.3,2.4,8.9,4.2,13.2,6.6c4.3,2.4,9.3,3.5,13.4,6.3c2.9,0,5.3,1.8,8.1,2.2c2.8,0.3,4.5,3.2,7.2,4.2c0.3,0.1,0.4,0.6,0.7,0.7
		c5.4,1.2,10.6,3.3,16.2,3.1c3.4-0.2,6.7,0,10.1-0.9c4.9-1.4,10.3-1.2,14.8-4.1c9.5-2.3,18.2-6.8,27.1-10.4
		c5.4-2.2,10.7-4.6,16.1-7.1c9.1-4.2,18.2-8.3,27.3-12.6c11.7-5.5,23.2-11.5,34.9-17c5.6-2.6,11.5-4.6,16.2-7.6
		c3.9-1.2,6.8,1,10.1,0.8c9.2-0.7,18.4,1.1,27.6-1.1c3.1,0.8,6-1.5,9.1-1c5.5-2.2,11.3-3.1,16.9-4.9c10.8-3.4,21.2-7.5,31.4-12.3
		c6.6-3.1,12.8-6.9,19.1-10.6c4.6-2.7,8.8-5.9,13.3-8.7c3.2-2,6.3-4.4,9-7.1c4.9-4.9,10.2-9.4,14.2-15c5.1-7.2,9.9-14.4,8.7-23.6
		C877.1,458.7,876.1,456.8,875.2,455z M150.9,673.4c-2.7-3.1-5.1-5.5-6.9-8.3c-0.8-1.3-1.7-2.5-2.8-3.3c-1.3-1-1.3-2.5-2.4-3.6
		c-3.9-4-6.8-8.9-10.4-13.1c-2.2-2.6-4.3-5.3-6.5-7.9c-2.1-2.5-4.3-5-6.2-7.8c-1.8-2.6-4.1-5-6.3-7.4c-2.7-2.8-5.1-6-7.5-9
		c-2.5-3-5.3-5.7-8.1-9c15.5-13.6,29.8-28.5,45-43.6c1.5,2.2,3.9,1,6.1,1.6c0,2.6,0,5.3,0,7.9c0,12.5,0.2,24.9-0.1,37.4
		c-0.1,3.8,1.3,7.3,1.1,11.1c-0.2,3.8-0.6,7.8,0.1,11.4c0.8,3.9,0.6,7.7,0.9,11.6c0.1,2.2,1.3,4.2,1.1,6.6c-0.2,2.2-0.6,4.5,0.9,6.6
		c0.3,0.4,0,1.3,0,2c0.1,2.1-0.2,4.1,0.9,6.1c0.8,1.6-0.5,3.7,1,5.6C151.5,669.4,150.9,671.3,150.9,673.4z"/>
	<path class="st0" d="M804.7,138.5c-10.5-6.5-21.2-12.6-31.5-19.4c-5-3.3-10.4-6.2-15.5-9.6c-5.3-3.4-11.1-6.1-15.6-10.6
		c-3.6-3.7-4.2-7.8-2.9-13c2.4-9.5,7-18.1,9.1-27.7c3.4-6.1,4.5-13.1,7.1-19.5c1.9-4.7,3.6-9.5,5-14.4c0.3-1.1,0.9-2.6,2.2-3.6
		c1.8-1.4,3.3-3.2,5-4.9c2.8-0.2,5.4-1.5,8-2.3c2.9-0.9,5.9-2,8.8-2.6c2.9-0.6,5.6-1.9,8.6-2.3c4.2-0.7,8.2-2.8,12.5-3.5
		c4.6-0.8,9.1-2.2,13.6-3.5c4.6-1.4,9-1.9,13.5-1.7c4.5,2.4,9.1,4.4,13.2,7.1c5.7,3.8,12,6.7,17.7,10.5c3.1,2,6.5,3.5,9.8,5.3
		c6.5,3.6,13.2,6.9,19.3,11.1c5.5,3.7,6.7,9.3,5.1,14.9c-2,7.1-4.7,14-7.1,21c-3.4,10.2-6.6,20.5-10.5,30.6
		c-2.1,5.3-3.7,10.8-5.8,16.1c-1.7,4.5-5.1,6.7-9.1,8.2c-3.8,1.4-7.8,2.1-11.7,3.1c-4.4,1-8.7,2.4-13.1,3.4
		c-6,1.4-11.9,3.5-18.1,4.6c-1.9,0.3-3.8,1.7-5.7,1.8c-1.9,0.2-3.5,1.5-5.6,1.2C809.2,138.2,807.2,138.5,804.7,138.5z"/>
	<path class="st0" d="M1000.4,81.7c7,2.8,12.3,7.7,18.1,11.7c5.3,3.7,10.5,7.6,15.8,11.5c4.5,3.3,9.2,6.5,13.9,9.6
		c3.8,2.5,7.7,5,11.2,7.8c2.9,2.3,5.5,4.9,6.7,9.8c0,1.1,0,3.5,0,5.6c-2,2.8-2.6,6.1-3.9,9c-2.6,5.7-4.6,11.7-7,17.6
		c-2.5,6-4.7,12-7.2,18c-2.3,5.5-4.1,11.3-6.8,16.7c-2.6,5.3-6.3,8.4-12.1,9.4c-2.7,0.5-5.4,1.4-8.1,2.1c-2.5,0.6-5.2,1.1-7.5,2.3
		c-1.8,0.9-3.5-0.1-5.2,0.9c-1.3,0.7-2.9,1.7-4.3,1.6c-1.9-0.1-3.4,0.9-5.1,1.2c-6,1.4-12.1,3-18.1,4.5c-2.9,0.7-5.8,2.1-8.9,1.3
		c-3.2-0.8-6.2-2.3-8.6-4.4c-6.1-5.2-12.8-9.6-19-14.6c-5.6-4.5-11.6-8.8-17.5-13c-3.6-2.6-6.9-5.7-10.6-8.2
		c-2.4-1.7-4.6-3.6-6.6-5.7c-4.8-4.8-5.5-9.7-2.9-16c3.3-8,6.4-16,9.6-24c1.9-4.7,3.9-9.4,5.9-14c2.6-6.2,5.9-12.3,7.8-18.7
		c1.5-5.2,5-7.5,9.4-9c3.9-1.4,8.1-2,12.2-3.1c6.3-1.6,12.7-3.1,19-4.7c3.4-0.9,7.1-1.5,10.5-2.4c3.8-0.9,7.6-1.7,11.4-2.6
		C995,81.2,997.8,81.7,1000.4,81.7z"/>
	<path class="st1" d="M911.8,354.2c-7.8,2.1-15.6,0.6-23.3,1.1c-3.4-1.8-7-1-10.6-0.9c-8.9,0.1-17.7-1.5-26.6-1.2
		c-2.8,0.1-5.7-1.2-8.1-3.3c-2.7-2.4-4.9-5.3-6.8-8.2c-1.6-2.4-4.4-3.8-5.1-6.8c-5.2-5.9-9.7-12.3-14.6-18.4
		c-2.1-2.6-4.2-5.3-6.5-7.9c-3.8-4.3-7.2-8.9-10.6-13.5c-3.3-4.5-3-10.6,0.5-14.9c4.1-5.1,7.6-10.6,11.8-15.5
		c4.4-5.2,8.2-10.7,12.4-15.9c4.6-5.8,9.2-11.6,13.3-17.9c1.2-1.9,3.1-3.6,4.9-4.9c3.4-2.5,7.4-3.3,11.4-2.1
		c1.4,0.4,2.9,0.8,4.2,0.6c1.7-0.3,2.5,1.4,4.1,1.1c3.9-0.8,7.6,1.5,11.6,1c1.6-0.2,2.8,1.3,4.6,1.1c1.5-0.2,3.3-0.7,4.6,0.9
		c0.2,0.2,1,0,1.5,0c2.1,0,4.1,0,6.1,0.9c1.7,0.7,3.8-0.4,5.6,1c0.6,0.5,1.9,0.1,2.9,0.1c3.5,0,6.8,1.2,10.2,1.9
		c2.6,0.5,4.7,1.7,6,3.6c4.4,6.6,9.7,12.5,14.3,19c2.6,3.6,5.5,7.1,8.3,10.6c4.8,6,9.5,12,14.1,18.1c0.9,1.2,1.3,2.8,2.3,4.7
		c0-0.3,0,0,0.1,0.3c1,5.9-2,10.4-5.5,14.7c-1.5,1.8-2.5,4-3.9,5.8c-5.7,7.2-10.6,15-16,22.4c-4.3,6-9,11.7-12.6,18.2
		C915.2,351.4,913.4,352.6,911.8,354.2z"/>
	<path class="st2" d="M1111.7,319.5c1.7,7.2-1.5,12.7-3.9,18.3c-1.5,3.4-3.3,6.6-4.7,10c-1.4,3.4-3,6.8-4.6,10.1
		c-2.7,5.7-4.8,11.7-8,17.2c-1.6,2.8-1.6,6.5-4.5,8.6c-0.8,3.5-4.6,3.4-6.6,5.5c-4.2,0-8.1,1.5-12.1,2.2c-4.6,0.7-9.4,0.7-13.8,2.8
		c-2.8-0.4-5.4,0.4-8.1,1c-4.6,1.2-9.3,1.5-13.8,2.6c-2.8,0.7-5.9,1.2-9,1.4c-3.2,0.1-6-1.2-8.1-3.2c-2.8-2.7-6.1-5-7.9-8.7
		c-0.3-0.6-0.9-1-1.4-1.4c-6.4-5.7-11.6-12.5-17.5-18.8c-3.8-4-7.9-7.9-11.3-12.3c-1.8-2.2-3.8-4.3-5.4-6.7c-3-4.6-2.5-9.3-0.4-14
		c1.8-3.9,3.8-7.8,5.6-11.6c3.1-6.4,6.3-12.7,9.1-19.2c2.3-5.4,5.1-10.5,7.6-15.8c1.3-2.8,2.2-5.7,4-8.3c1.6-2.2,3.4-3.5,6.1-4
		c4.2-0.6,8.4-1.4,12.6-2.1c5.9-0.9,11.8-2,17.7-3c2.2-0.4,4.6-0.3,6.5-1c2.1-0.8,4.2-0.4,6.1-0.9c3.5-1,7-1.9,10.7-2
		c3.1,0,5.7,1.2,7.7,3.1c8.6,8.3,17.4,16.5,25.3,25.5c4.8,5.4,10,10.4,15,15.6C1107.6,313.3,1110,316.3,1111.7,319.5z"/>
	<path class="st3" d="M153.9,217.7c0-4.5,1.2-8.2,2.2-11.9c1.3-4.6,2.6-9.2,4.7-13.5c2-4,3.2-8.3,5.6-12.2c2.5-4.1,4.9-8.3,7.3-12.5
		c1-1.8,3.3-2.7,3.5-5c4.9-6.2,10.4-12,16.3-17.1c5.9-5.1,12.1-9.8,18.8-13.7c9.4-5.5,19.4-10.1,30-13.2c7-2.1,14-4.5,21.4-5
		c1.7-2,4.3-0.3,6.3-1.6c1.9-1.1,4.4,0.3,6.3-0.5c3.4-1.5,7.1-0.2,10.4-1.3c3.5-1.2,7.2-0.4,10.7-0.5c3.5-0.2,7,0,10.5,0
		c3.7,0,7.4-0.5,11,0.1c5.4,1,11.1,0.5,16.3,2.8c1.1,0.5,2.6,0.2,3.9,0.1c1.4-0.1,2.2,1.1,3.6,1.1c2.6,0.1,21.2,6,23.6,6.9
		c9.6,3.8,18.5,9,26.6,15.1c5.9,4.4,11.7,9.2,16.1,15.5c2.7,3.9,6,7.4,8.6,11.4c4.3,6.6,8.1,13.5,11,20.9c3.1,8.1,6.3,16.1,8,24.6
		c0.9,4.5,2.5,9,3.6,13.5c0.5,2.1,1.1,4.4,1.2,6.4c0.1,3.1,1.8,5.9,1.2,9.1c2,4.9,1.1,10.3,3,15.2c0.1,0.3,0,0.7,0,1
		c-0.4,5.6,0.8,11.1,1.3,16.5c0.5,5.7,0.6,11.4,0.7,17.1c0.1,5.7,0.2,11.3,0,17c-0.2,5.7-1.3,11.2-2.6,16.8
		c-0.9,3.9-2.7,7.3-4.5,10.7c-1.5,2.7-3.8,5.2-5.9,7.6c-6.1,6.7-13.5,11.7-21.7,15.2c-6.8,2.9-13.7,5.5-21,7.1
		c-4.1,0.9-8,2.4-12.1,3.4c-3.6,0.9-7.3,2-10.9,2.5c-2.5,0.3-4.8,1.3-7.3,1.7c-2.6,0.5-5.3,0.8-8,1.3c-5.2,1-10.3,2.1-15.6,2.1
		c-2.9,1.7-6.1,0.6-9.1,1c-2.2,0.3-4.3,1.2-6.6,1c-2.2-0.2-4.5-0.4-6.6,0.9c-0.7,0.4-2,0.1-3,0.1c-11.3,0-22.6-0.3-34,0.1
		c-8.1,0.3-16-1-24.1-1.3c-5.5-0.2-11.1-1.3-16.7-1.8c-2.4-2.1-5.8,0.1-8.2-2c-3,0.5-5.8-0.7-8.5-1.3c-2.9-0.6-5.9-1.6-8.8-2.6
		c-2.9-1-5.8-2.1-8.5-3.5c-2.8-1.4-5.6-2.8-8.1-4.6c-9.9-7.1-18.3-15.5-23.4-26.9c-0.6-1.4-1.1-2.9-1.6-4.3c-0.1-0.4,0-1,0.1-1.6
		c6.8-0.4,12.5-3.4,18.1-6.9c5.2-3.3,8.3-8.3,11.8-13c3.5-4.7,4.5-10.5,6.9-15.6c-0.4-2.9,1.3-5.6,1.2-8.5c-0.2-5,0.1-10-0.1-15
		c-0.3-6.1-2.1-12-4.1-17.8c-1.5-4.1-3.6-8-6-11.5c-3.1-4.5-6.6-8.6-11.2-12c-4.2-3.1-8.6-5.6-13.5-7.2c-2.7-0.9-5.4-1.9-8.3-1.7
		C161.9,216.7,158,215.6,153.9,217.7z"/>
	<path class="st4" d="M160.9,563.2c5.6-1,10.7-2.4,15.5-4.4c3.8-1.6,7.5-4,10.7-6.7c2.7-2.3,6.3-3.8,8.1-7c1.7-3,4.6-4.8,6.1-7.9
		c1.4-2.9,3.3-5.6,4.5-8.6c2.4-5.7,4.2-11.6,5.3-17.8c1.1-6.7,1-13.4,0.6-20.1c-0.3-6.3-2.2-12.5-4.3-18.6
		c-3.6-10.4-10.1-18.7-18.1-25.9c-4.4-3.9-9.8-6.7-15.2-8.9c-0.7-0.3-1.7,0.4-2.1-0.7c-0.1-1.2,0.7-1,1.4-1.4
		c2.2-1.1,4.1-2.8,6.4-3.9c4.8-2.2,9.6-4.2,14.5-6c6.5-2.4,13.4-3.9,20.1-5.8c2.2-0.6,4.6-1.4,7-1.2c1.9,0.1,3.4-0.7,5.1-1
		c1.7-0.4,3.6,0.7,5.1-1c3.3,0.7,6.3-1.5,9.6-1c2.7,0.5,4.9-1.6,7.6-1c0.6,0.1,1.3,0,1.9,0c1.3,1.8,2.5,3.5,3.8,5.1
		c3.7,4.5,9.4,5.7,13.9,8.8c5.1,0.2,9.6,2.8,14.7,3.3c3.5,0.3,7.2,0.2,10.6,1c2.6,0.5,5.1,1.1,7.6,0.8c5.2-0.7,10.4-1.1,15.6-0.9
		c1.9-1.3,4-1,6.1-1c2,0.1,3.7-0.8,5.5-1.2c7.7-1.6,15.5-3.8,22-8.2c4.6-3,8.8-7.2,9.6-14.1c1.1,1.7,2.3,1.3,3.5,1.4
		c2.5,0.3,5.1-0.6,7.7,0.7c2.3,1.1,5.2-0.6,7.5,1.3c4.7-0.5,9,1.9,13.7,2.1c1.7,0.1,3.5,0.6,5,1.1c6.5,2.3,13.3,3.9,19.5,7.2
		c5.7,3,11,6.1,15.6,10.7c4.3,4.4,8.3,8.8,10.6,14.6c2.3,5.8,4.4,11.5,5.8,17.6c1.2,5.4,1.8,10.9,3.1,16.2c0.7,2.9,0.3,5.8,1,8.6
		c0.9,3.6,0.3,7.2,1,10.6c1.4,6.7,0,13.5,1,20.1c1.5,9.5,0.3,19.1,0.9,28.6c0.3,5.2-1.4,10.3-1.1,15.6c0.4,5.3,0.8,10.8-0.1,15.9
		c-1,5.7,0,11.5-1,17.1c-0.7,4.1-0.2,8.2-1,12.1c-0.7,3.7-0.3,7.5-1,11.1c-0.7,3.4-0.3,6.8-1,10.1c-0.6,2.9-0.2,5.9-1,8.6
		c-0.9,2.8-0.2,5.6-1,8.1c-0.7,2.1-0.9,4.1-0.8,6.1c0,1.9-0.8,3.7-1.2,5.6c-1.4,8.1-2.8,16.2-6.6,23.7c-2.9,5.9-7.8,9.5-13.1,12.7
		c-4.3,2.6-9.1,3.9-13.6,5.7c-3.7,1.4-7.7,2.6-11.6,3.2c-3.4,0.5-6.6,2.3-10.1,2.1c-2.1,1.9-4.8,0.9-7.2,1.8c-2.1,0.8-4.5,1.9-7,1.2
		c-4.5,2-9.6,1.4-14.3,2.9c-2.3,0.7-5.2-0.3-7.5,1.1c-4.6-0.8-9,1.5-13.6,1c-2.2-0.3-3.9,1.4-6.1,1.1c-2.1-0.3-4.5-0.6-6.5,0
		c-5.2,1.7-10.4,0.7-15.6,0.8c-6.5,0.2-13.1,2.2-19.5,0.9c-6.9-1.4-13.7-0.4-20.8-1c-1-0.9-1.9-2.2-2.8-3.5
		c-4.4-6.5-9.6-12.4-15.5-17.6c-4.2-3.7-8.5-7.3-13.3-10.2c-5.4-3.3-10.8-6.7-16.9-8.7c-2.9-1-5.7-2.4-8.7-3.1
		c-4.4-1.1-8.8-2.1-13.3-3c-6.7-1.2-13.4-0.3-20.1-0.9c-4.4-0.3-8.6,1.7-13.1,1.1c-0.8-0.1-1.1,1.3-2.2,0.9c-1.2-0.5-1.8-1.5-1.7-3
		c0.1-2.1,0-4.1-0.9-6.1c-0.7-1.7,0.5-3.9-1.1-5.5c-0.1-0.1,0-0.3,0-0.5c0.8-4.6-1.4-9-1-13.6c0.2-2.8-1.5-5.2-1.1-8.1
		c0.4-2.8,0.7-5.8,0-8.4c-1.6-5.4-0.8-10.8-0.8-16.1C160.8,594.1,160.9,578.8,160.9,563.2z"/>
	<path class="st5" d="M861.5,436.1c1.8,1.2,3.8,1.5,4.6,3.5c-0.2,4.7-1.8,9-5.2,12.4c-1.8,0-3.4,0-4.8,0c-4.1,2.2-7.9,4.4-11.5,6.9
		c-3.1,2.1-6.2,4.4-9.2,6.7c-7.7,6-15.9,11.1-24.7,15.3c-3.3,1.6-6.5,3.5-10.1,4.5c-2.8,0.8-5.5,2.5-7.3,5.3c0,1.5,0,3.2,0,4.8
		c0.8,1.4,2.4,1.5,3.6,2.5c3.8,0.4,7.5-0.9,10.9-2.3c7.6-3.1,14.9-6.7,21.8-11.4c5.9-4,11.7-8,17.3-12.4c4.1-3.2,7.8-6.9,13.3-8.8
		c0.9,0,2.4,0,3.9,0c0,1.8,0,3.4,0,5.1c-3.6,8.9-11,14.9-17.9,20.9c-6.6,5.9-14.3,10.6-22.2,15c-5.6,3.1-11.1,6.1-16.9,8.7
		c-6.6,3-13.3,5.6-20.1,8.2c-3.9,1.5-8,2.4-11.9,3.9c-3.8,1.4-7.8,2-11.7,3.1c-2.4,0.7-4.8,0.4-7.1,0.9c-7.8,1.8-15.7,0.5-23.6,0.9
		c-1.2,0.1-2.5,0.4-3.5-0.1c-3.2-1.5-6.8-0.8-10.1-2.3c-2.7-1.2-5.6-2.1-7.9-3.7c-3-2.2-6.2-4-8.5-7.5c-2.4-3.6-4.6-7-5.9-11.1
		c-0.9-2.9-1.9-5.7-1.7-8.8c0.2-3.7-0.2-7.4,0.9-11.1c1.8-5.7,3.9-11.2,7.9-15.7c2.8-3.1,5.9-5.9,8.8-8.9c1.7-1.8,3.8-3.1,5.7-4.4
		c4.7-3.2,8.3-7.5,12.1-11.5c2.7-2.8,4.6-6.3,6.5-9.7c3.1-5.4,6.4-10.8,10.3-15.7c3.3-4.2,7.1-8.2,11.9-10.9
		c2.1-1.2,4.7-1.9,7.4-1.5c1,0.1,2,0,3,0c0.8,0.8,1.6,1.7,2.5,2.5c0.3,3.2-0.9,6.3-2.2,9c-2.5,5.4-6.2,10.1-9.7,15
		c-4.3,6-9.4,11.2-14.6,16.4c-2.9,3-3,4.8-1.6,8.1c0.8,1.8,2.5,2.7,3.6,2.8c3.5,0.3,5.5,2.5,7.5,4.8c3.4,3.8,6.5,7.9,8.8,12.3
		c2.1,3.9,3.3,8.3,4.2,12.7c0.6,3.2,0.9,6.4,0.8,9.6c0,1.4,1.2,2.2,1.3,3.5c1.8,1.1,3.8,1.5,6.2,1.1c3.5-2.4,4.4-6,4.6-10.3
		c0.5-10.4-4.8-23.1-10.8-31.3c6.6-1.2,13-3,19-6c3.2-1.6,6.4-3,9.6-4.6c5.9-3,11.1-7,16.6-10.6c4-2.6,7.7-5.6,11.6-8.3
		c4.3-2.9,9-5.5,14.3-5.9c1.1,0.8,0.5,1.7,0.7,2.6c-6,6-11.7,12.2-18,17.8c-4.3,3.8-9.3,6.8-14.3,9.8c-4.9,3-10.5,4.8-15,8.6
		c-1.3,1-3,1.5-4.5,2.2c-1.8,0.8-3,2.3-4.1,3.9c-0.9,1.4-1.2,2.9-0.9,4.7c0.7,0.7,1.5,1.5,2.4,2.4c1.1,0,2.3-0.2,3.1,1
		c1-1.7,3-0.3,4-1.1c2.6-2.2,5.9-2.8,8.8-4.3c2.9-1.5,5.6-3.3,8.6-4.6c3-1.3,5.7-3.2,8.4-4.9c2.8-1.8,5.3-4.1,8.1-5.8
		c2.9-1.8,5.7-3.6,7.9-6.1c1.3-1.5,3.3-2,4.6-3.4c3-3.1,5.7-6.5,8.2-10.1c2.1-3.1,5.6-3.9,9.1-4.4
		C859.5,436,860.5,436.1,861.5,436.1z"/>
	<path class="st6" d="M278.8,730.8c11.9,0,23.4-0.2,34.9,0.1c6.3,0.2,12.3-1.8,18.6-1.1c3.6-1.7,7.4-0.9,11.1-1
		c2.1,0,3.9-1.4,6.1-1.1c2,0.2,4,0.2,6.1-0.7c2.2-0.9,5-0.8,7.5-1c3.5-0.3,6.9-1.5,10.6-1.3c2.1,0.1,4.4-0.7,6.5-1.1
		c1.9-0.4,4-0.4,5.9-1.5c1-0.6,2.6-0.5,3.8-0.3c1.5,0.3,2.3-0.9,3.6-1.2c4.6-0.9,9.1-1.9,13.5-3.5c2.9-1,6-1.5,9-2.2
		c1.1-0.3,1.8-1.4,3.2-1.1c1,1,0.8,2.6,0.4,3.5c-1.4,3.7-1.6,7.6-2.8,11.3c-1.3,3.8-2.8,7.5-4.7,11c-2.1,3.9-4.6,7.6-7.7,10.8
		c-3.7,3.9-7.5,7.5-11.3,11.3c-4,4-8.8,6.8-13.4,9.9c-2.6,1.7-5.3,3.3-8.1,4.6c-6,2.8-12.1,5.5-18.4,7.2c-4.9,1.4-10,2.7-15.1,3.4
		c-5.4,0.7-10.7,1.7-16.2,2c-2.6,0.1-5.4,0.6-8.1,0.9c-2.9,0.3-5.3-1.2-8.1-1.1c-2.8,0.1-5.9,0.8-8.4-0.2c-2.9-1.1-5.9-0.5-8.9-1.4
		c-2.8-0.8-5.8-1.8-8.9-1.4c-5.6-2.6-11.9-3.2-17.4-6.2c-2-1.1-4.2-1.9-6.3-2.8c-0.9-0.4-1.6-1-2-2c2.3-3.2,4-6.6,5.5-10.6
		c1-0.5,2.6-1.1,4.2-1.6c4.3-1.6,7.6-4.8,10.3-8.5c3.6-4.8,5.4-10.3,5.1-16.4C278.7,735.5,278.8,733.3,278.8,730.8z"/>
	<path class="st7" d="M680.3,493.1c-0.2,17.9,7.1,32,21.4,42.9c-1.1,1.4-2.8,1.9-4.3,2.4c-5.9,2-11.1,5.3-16.7,7.9
		c-10.3,4.8-20.5,9.9-30.8,14.7c-7.4,3.5-14.7,7.1-22.2,10.2c-8.8,3.5-17.4,7.8-26.4,10.9c-5.1,1.8-10,3.9-15.4,5.1
		c-5.4,1.3-10.8,2.3-16.2,1.6c-2.6-0.4-5.5-1-8-2.3c-4.4-2.1-7-5.9-9-10.1c-1.6-3.3-1.1-10.4-0.4-14.7c0.6-3.4,1.4-6.6,2.9-9.8
		c2.6-5.5,7-9.2,11.5-12.8c1.7-1.4,3.3-2.9,5.3-4c7.7-4,15.7-6.9,23.7-10.1c6.3-2.5,12.6-4.8,18.9-7.4c7.7-3.2,15.5-5.9,23.2-9.1
		c7.5-3.1,15.3-5.6,23-8.3C667.1,497.8,673.5,495.5,680.3,493.1z"/>
	<path class="st4" d="M244.4,765.5c-1.3,0.7-2.7,1.4-4.4,2.3c-2.7,0.8-5.4-1.9-8.8-0.8c-1.4-6.9-6.2-11.8-9.3-17.7
		c-5-4.2-7.8-10.3-13.6-13.8c-2.8-1.7-5-4.6-7.8-6.6c-5.4-3.9-11.3-6.6-16.8-7c-3.4,0.9-4.9,2.7-6.7,4.6c0,0.9-0.3,2.1,0.1,3.1
		c0.5,1.3,0.6,2.7,2.4,3.5c1.7,0.9,3.4,2.1,5.2,3c8.4,4.5,16.1,10,22.2,17.3c3.3,3.9,6.5,8.2,8.7,12.9c1.4,2.9,3.3,6.3,2,10.4
		c-0.8,1.3-2.5,2.2-4.4,3.1c-3.7-0.9-6.9-3-9.9-5.8c-2.5-2.3-5.6-4.2-7.5-6.9c-2.3-3.3-5.2-5.8-7.9-8.7c-3.6-3.8-8-6.7-12.8-8.8
		c-3.1-1.4-6.3-3-9.9-2.7c-1.7,0.1-2.9-1.3-4.6-1.1c-1.4,0.1-2.8,0.4-4.2-0.7c-0.8-0.7-2.6-0.3-3.9-0.2c-1.4,0.2-2.3-0.9-3.6-1.2
		c-3.2-0.6-6.2-1.9-9.3-2.9c-2.5-0.8-3.8-3.4-6.3-4c-2.3-4.2-5.6-7.7-6.7-12.8c-0.7-3.4-1.2-6.9-0.6-10.1c0.7-3.5,1.4-7.3,3.6-10.5
		c2.4-3.5,5.3-6.4,8.8-8.8c6.7-4.6,14.5-6,21.8-8.7c1.6-0.6,3.7,0.7,5-1.1c3.1,0.6,6-0.8,9-1.2c6.2-0.8,12.4-0.8,18.6-0.8
		c2.6,0,5.1,0.4,7.6,0.8c2.7,0.4,5.4,0.8,8,1.3c2.4,0.4,4.7,1.4,7,2.3c9,3.6,17.5,8,25.2,14c5.6,4.4,10.6,9.4,15.2,14.7
		c3,3.5,6.1,7.5,7,12.5c0.1,0.7,0.4,2.3,1.6,2.8c0.6,1.7-0.1,3.3,0.9,5.2c1.2,2.3-0.5,4.9-1.2,7.3c-0.9,3.2-3.4,5.1-6.2,7
		c-1.7-4.1-4.4-7.9-6.3-11.9c-0.9-1.8-3.1-2.4-3.3-4.6c-4.6-5.2-9-10.6-14.7-14.9c-3.9-2.9-7.7-6.1-11.8-8.8
		c-2.2-1.5-4.8-2.3-6.8-3.9c-2.2-1.7-4.7-1.8-7-2.4c-3.1-0.9-6.2,0.6-8.3,3.3c0,1.7,0,3.4,0,5.1c2.3,1.5,4.6,3.1,7.2,4.4
		c5.5,2.7,10.6,6,15.4,9.9c4.4,3.5,8.1,7.7,12.2,11.4c3.1,2.8,5.3,6.3,7.1,10c1,1.9,2.3,3.6,3.2,5.6
		C246.7,757.8,246.9,761.4,244.4,765.5z"/>
	<path class="st4" d="M87.6,589.6c-3-5.6-6-10.6-10.2-14.8c-4.1-4.1-8.6-7.6-14-9.8c-5.5-2.2-11.1-3.7-18.1-2.9
		c5.4-5.4,10.4-9.9,14.8-14.9c13-14.9,27.7-28,41.4-42.2c3.9-4,8.5-7.2,13.4-9.9c4.8-2.6,10.3-4.1,15.7-2.9c4.9,1,9.5,3.1,13.1,7
		c2.3,2.6,4.8,5,5.7,8.6c0.2,0.9,0.5,1.8,0.5,2.8c0.1,2-0.1,4,0,6c0.5,5.5-2.1,10.1-4.7,14.5c-2.2,3.7-5.2,6.9-7.9,10.3
		c-3.9,4.7-8,9.2-12.6,13.1c-8.5,7.2-15.6,15.7-24,22.9C96.5,581.2,92.5,585.3,87.6,589.6z"/>
	<path class="st4" d="M136.4,678.1c-13.6,6.6-22.3,16.6-24.8,31.9c-2-1-4.2-1.5-5.7-2.9c-5.1-4.4-10.8-8-15.9-12.5
		c-4.9-4.4-9.9-8.8-15-13.1c-10.8-9.1-20-19.7-30.2-29.4c-1.3-1.2-2.2-2.8-3.3-4c-1.9-2-1-4.6-2.5-6.5c1-4.7,1.7-9.6,4.5-13.6
		c4.6-6.6,10.3-12,18-15.3c5.8-2.5,11.4-2.3,17.2-0.6c0.6,0.2,1.5,0.5,2.1,1c3.4,3.4,7.3,6.5,10.1,10.3c2.2,2.9,4.5,5.8,6.9,8.5
		c5.2,5.8,9.8,12,14.8,17.8c2.2,2.6,4.5,5.2,6.5,7.8c3.6,4.6,7.8,8.9,11,13.8c0.8,1.2,2.1,2.1,3.1,3.2
		C134.3,675.7,135.2,676.8,136.4,678.1z"/>
	<path class="st6" d="M151.2,548c0.4-3,2.5-4.1,3.8-6c4.1-5.9,6.3-12.7,8.7-19.4c0.3-0.9,0.1-1.9,0.3-2.9c0.3-2.2-0.7-4.5,0.9-6.6
		c1-1.3-1-2.2-1-3.5c0.1-6.4-2.5-12-6.1-16.9c-4.3-5.9-10.2-9.9-17-12.7c-6.4-2.7-13.1-2.4-19.6-1.7c-3.8,0.4-7.8,1.7-11.4,3.6
		c-0.4,0.2-0.9,0.2-1.5,0.2c1.9-6.8,5.4-12.6,9.4-18c3.6-4.8,9.4-7.2,13.9-11c5.2-0.9,9.7-4.6,15.3-4c2.9-1.7,6.1-1.1,9.1-0.9
		c6.1,0.4,11.9,2,17.3,5.3c2.7,1.6,5.5,3.2,7.8,5.2c4.6,3.9,8.6,8.8,11,14.4c2.9,6.8,5.6,13.7,5.1,21.4c-0.2,3.5,0.1,7-0.1,10.5
		c-0.1,1.7-0.2,3.5-0.4,5.3c-0.9,6.6-3.5,12.6-6.7,18.2c-4.8,8.4-15.3,15.4-25.1,18.6C160.2,548.5,155.7,547.7,151.2,548z"/>
	<path class="st4" d="M538,577.3c-1.8-1-2.7-1.9-3.6-1.9c-3.4-0.1-5.2-3.5-8.5-3.6c-3.9-3.5-9.1-4.7-13.4-7.4
		c-4.6-2.9-9.4-5.4-14.2-8c-5.2-2.8-10-6.1-15.3-8.7c-3.9-1.9-7.5-4.5-11.1-7c-0.7-0.5-1.5-0.4-2.2-1c0-4.6,0-9.2,0-14.4
		c11.7-9.3,17.6-22.2,20.2-37.1c21.4,14.1,42.8,28.1,65,41.3c-7,5.9-12.3,12.7-15.3,21.3C536.5,559.2,535.6,567.7,538,577.3z"/>
	<path class="st6" d="M149.6,307.3c-2.7-1.9-5.7-2.6-7.9-4.7c-4.8-4.6-7.7-10.3-9.7-16.5c-1.2-3.8-2.1-7.6-2.2-11.6
		c-0.1-2.7-1.2-5.3-0.8-8.1c0.4-3,0.7-6,1.4-8.9c1.2-4.8,3.3-9.3,5.7-13.6c1.7-3,4.7-5.3,10.1-6.7c6.1-0.4,11.6,3.2,16,9.7
		c3.6,5.5,5.1,9.4,6.9,16.1c0.6,2.1,0.3,4.2,1,6.1c0.8,2.1,1,4.1,0.8,6.1c-0.2,2.2,0.5,4.4-0.8,6.7c-1,1.6,0.7,4.2-1.1,6
		c0.3,5.3-2.8,9.4-4.9,13.9c-1.7,3.7-4.9,4.7-8.3,5.3C153.8,307.6,151.7,307.3,149.6,307.3z"/>
	<path class="st8" d="M343.6,388.2c0,5.9,0,11.5,0,17.5c-3,3.4-7,5.4-11.8,6.6c-3.1,0.8-6.4,1.1-9.4,2.6c-0.4,0.2-0.9,0.2-1.4,0.2
		c-7,0.4-14,1.5-21.1,1c-3.2-0.2-6.3,0-9.5,0c-7.9,0-15.1-2.5-22-6c-1-0.5-1.7-1.5-2.7-2.3c0-5.4,0-10.9,0-16.7
		c5.5,0,11-0.4,16.4,0.2c2.7,0.3,5.5,1.3,8.1,0.7c7.5-1.6,15.1-0.1,22.6-1c5.2-0.6,10.4-0.8,15.6-0.9c3.6-2.2,8,0.1,11.7-1.9
		C341,387.8,342.4,388.2,343.6,388.2z"/>
	<path class="st6" d="M26.9,634.7c-4.1-3.9-8.8-7.3-10.3-12.8c-0.6-2.2-1.7-4.4-1.6-6.8c0-1.7,0.1-3.3,0-5
		c-0.6-8.1,3.2-14.8,6.9-21.6c3.2-5.7,8.8-8.4,14.2-11.2c1.4-0.8,3.4,0.6,4.4-1.3c4.7,0.3,9.5-0.9,14,1c3.5,1.5,7,2.7,9.6,5.7
		c1.8,2.1,4,3.9,5.7,6.1c1.6,2.1,2.7,4.5,4,6.8c-3.2,0.4-6.3,1.1-9.5,1.5c-4,0.5-8.2,1.9-11.8,3.9c-5.1,2.9-10,6.3-14.1,10.6
		c-5.4,5.7-8.5,12.7-11.5,19.7C26.7,632.3,27,633.6,26.9,634.7z"/>
	<path class="st9" d="M162.7,229.6c2.8-0.6,5.1,0.8,7.3,1.5c3,1,5.4,3,8.1,4.7c5.2,3.4,8.1,8.4,11.1,13.4c2.6,4.4,3.8,9.4,4.9,14.5
		c1.1,4.9,0.7,9.7,0.7,14.6c0,3-0.7,6-1.4,8.9c-1.1,4.8-3.2,9.5-5.8,13.5c-2.2,3.4-5.5,6.5-9.3,8.6c-2.3,1.3-4.6,2.3-7.3,2.9
		c4.6-5,6.2-11.3,8.6-17.3c0.7-1.8,0.7-4.1,1-6c0.3-2.4,1.6-4.5,1.3-7.1c-0.3-2.5-0.3-5,0-7.5c0.5-4.1-1.4-8-1.1-12.1
		c-2.9-8.6-4.9-17.6-11.2-24.9C167.5,234.9,165.1,232.4,162.7,229.6z"/>
	<path class="st6" d="M283.8,25.6c-0.2,4.6,0.9,9.4-2.3,13.5c-3.7,2.9-7.5,5.8-12.5,6.5c-2.4,0.4-4.4-0.7-6.5-1.2
		c-2.7-0.6-4.4-3.2-6.1-4.9c-2.1-4.2-1.4-8.4-1.5-12c2.9-6.7,7.1-11.4,14.1-11.9C276,15.1,280.4,19.6,283.8,25.6z"/>
	<path class="st10" d="M460.8,451.3c7.4,6.7,13.5,14.4,14.7,24.5c1.1,9.9,0.1,19.8-6.5,28.1C467.1,486.3,465.4,468.6,460.8,451.3z"
		/>
	<path class="st11" d="M804.9,121c-17.1-10.8-33.6-21.1-50.2-31.5c-1.1-2.5,0.4-4.7,1.1-6.8c3.8-11.1,8.1-21.9,11.7-33.1
		c1.3-4.1,2.7-8.2,4.5-12.1c0.4-1-0.2-2,0.6-2.7c1.1-0.3,2-0.1,3.1,0.6c5.2,3.4,10.5,6.7,15.8,9.9c5.8,3.6,11.6,7.2,17.6,10.5
		c5.2,2.9,9.8,6.6,15.2,9.1C818,83.6,811.5,102.1,804.9,121z"/>
	<path class="st11" d="M819.8,121.1c1.5-4.8,2.5-8.6,3.7-12.2c1.5-4.5,3.1-9,4.8-13.5c2.3-5.9,4.1-11.9,6.4-17.8
		c1.2-3.1,2.8-6.3,2.7-9.6c1.6-2.4,4.2-1.5,6.2-2.3c6.8-2.6,13.7-4.7,20.7-6.7c4.6-1.3,9.2-2.5,13.6-4.4c0.6-0.3,1.6-0.4,2.1,0.3
		c-6.3,18.1-12.7,36.1-19.1,54.4C848,113.7,834.2,116.5,819.8,121.1z"/>
	<path class="st11" d="M876.9,41.3c-6.9,1.4-12.5,4-18.6,5.4c-4.2,0.9-8.1,2.8-12.3,4c-3.4,1-6.5,2.9-10.2,3c-0.4,0-0.7,0.7-1.1,0.9
		c-0.3,0.1-0.7,0-1.4,0c-15.5-9.5-31.3-19.2-47.7-29.3c14.9-3.8,28.9-8.1,43.7-11.3c6.4,3.9,13.5,8.1,20.5,12.3
		c3.4,2.1,6.9,4.1,10.5,5.8c4.6,2.3,9,4.9,13.4,7.5C874.5,40.1,875.3,40.5,876.9,41.3z"/>
	<path class="st12" d="M969.5,203.8c-16.1-13-32.7-24.8-48.7-38c7.1-17.2,14.1-34.2,21.2-51.6c16.4,12.1,32.8,24.3,49.1,36.4
		c-1.8,3.9-3.5,7.7-4.7,11.6c-1.3,4-3.9,7.5-4.2,11.7c-3.4,5.6-4.9,11.9-7.6,17.8C972.8,195.6,971.6,199.7,969.5,203.8z"/>
	<path class="st11" d="M1044.9,130c-14.8,3.7-28.6,7.2-42.5,10.8c-0.3,0.1-0.5,0.4-0.8,0.7c-15.8-11.8-31.6-23.6-47.8-35.7
		c7.5-2.1,14.6-3.5,21.7-5.2c7-1.7,14-3.1,21.4-4.7C1012.4,106.9,1028.3,118.2,1044.9,130z"/>
	<path class="st12" d="M1027.4,193.4c-13.9,3.9-28.5,7.2-43.3,11.1c4.5-10.8,8.5-21.2,12.7-31.5c2.3-5.5,4.9-11,6.4-16.8
		c0.3-1,1.4-1.7,2.3-2.7c4.7,0.2,8.9-2.4,13.6-3.1c4.7-0.8,9.4-2.2,14-3.4c4.5-1.1,9-2.3,14-3.6c-2.8,8.6-6.6,16.5-9.5,24.8
		C1034.8,176.7,1031,184.8,1027.4,193.4z"/>
	<path class="st12" d="M845.7,244c11.7,15.7,23.1,30.9,34.8,46.6c-10.5,14-21.1,28.1-31.9,42.6c-12.1-15-24.2-30.2-36.3-45.3
		C823.4,273.3,834.3,258.9,845.7,244z"/>
	<path class="st12" d="M904,342.1c-0.9-0.1-1.2-1-2.1-0.9c-2.7,0.1-5.3,0.2-8,0c-2.7-0.2-5.3,0.5-8.2-0.7c-2.3-0.9-5.2-0.4-7.9-0.2
		c-5.5,0.3-11-0.4-16.7-1.4c10.2-13.8,20.4-27.4,30.9-41.6c4.6,0,10-0.7,15.2,0.2c6.2,1.1,12.4,0.5,18.6,0.8c2.7,0.1,5.2,2,8.2,0.6
		c-0.6,3.6-3.2,5.4-4.8,7.7c-4.5,6.3-9,12.6-13.5,18.9C911.8,331,907.6,336.4,904,342.1z"/>
	<path class="st12" d="M902.6,244.3c3.6,1.7,5.2,5.2,7.5,7.9c2.8,3.2,5.1,6.8,7.7,10.3c4.8,6.5,10.2,12.5,14.5,19.4
		c0.8,1.3,2.2,2.4,3.2,3.4c-1.1,1.6-2.5,1.2-3.4,0.9c-5.3-1.7-10.8-0.1-16-1c-7.7-1.4-15.4-0.5-23.5-1c-5.7-7.1-10.9-15-16.6-22.6
		c-5.7-7.5-10.9-15.3-17.2-22.7c1.6-0.7,1.8,0.6,2.7,0.5c4.1-0.8,8.1,0.5,12,1.2c5.2,0.9,10.7,0.8,15.7,2.8
		C893.8,242.6,898.2,245.1,902.6,244.3z"/>
	<path class="st12" d="M1005.8,294.7c12.1,14,23.6,27.5,35.2,41c-7.6,14.4-15.3,28.8-22.3,43.5c-6.7-5.4-11.7-12.4-17.5-18.6
		c-3.1-3.3-6.5-6.5-9.2-10.1c-2.6-3.4-5.6-6.3-8.7-9.6c3.5-6.9,7.4-13.6,10.3-20.8C997.2,311.5,1002,303.6,1005.8,294.7z"/>
	<path class="st12" d="M1051.1,326.9c-3.2-4.1-7-8-10.4-12.3c-2.3-2.9-4.8-5.7-7.4-8.4c-5.6-5.9-10-12.8-16.1-18.3
		c-0.2-0.2-0.1-0.6-0.1-1.1c12.7-2.1,25.4-4.1,38.4-6.3c13.5,12.2,25.2,26.6,38.8,39.5C1079.9,322.2,1065.8,324.5,1051.1,326.9z"/>
	<path class="st12" d="M1074,376.2c-3.8-0.3-7,0.8-10.1,1.7c-2.3,0.6-4.7,0.5-7,1c-2.6,0.5-5.3,1.2-8,1.5c-2.5,0.3-5.4,0.2-7.7,1.8
		c-3.4-0.8-6.5,1.8-10,0.8c1.4-2,3.2-3.7,3-6.3c2.7-2.5,3.7-6.1,5.3-9.3c3.9-7.8,7.8-15.7,11.7-23.5c0.9-1.7,1.7-3.4,3.3-4.4
		c13.2-2.1,26.3-4.2,39.8-6.4c-5.2,9.9-8.7,20.1-13.9,29.4C1079.3,367.5,1076.1,371.4,1074,376.2z"/>
	<path class="st0" d="M335.8,245c0,2.2-0.1,4.3,0,6.5c0.3,4.1-1,7.9-2.3,11.5c-2.5,6.8-6.5,12.8-12.3,17.3c-6.3,4.9-13.2,8.5-21.6,8
		c-1.8-0.1-3.7,0-5.5,0c-9.2,0.1-16.7-3.8-23.4-9.7c-1.2-1.1-2.4-2.3-3.5-3.5c-5.6-5.6-8.1-12.8-10.4-20.1
		c-2.5-8.1-2.2-16.4-1.8-24.6c0.3-4.7,1.4-9.6,3.4-14c2-4.4,4.3-8.6,7.2-12.5c4.4-5.9,10.3-9.5,16.7-12.6c2.5-1.2,5-2,7.7-1.9
		c2.2,0.1,4.3,0,6.5,0c8.5-0.1,15.6,3.2,21.7,9c0.1,0.1,0.2,0.2,0.4,0.4c7.7,6.2,11.3,14.9,14.1,24.1C335,230,336.4,237.4,335.8,245
		z"/>
	<path class="st0" d="M364.7,226.4c0-2.3-0.2-4.7,0-7c1-10.1,3.9-19.4,11.2-26.8c1.4-1.4,2.6-3.1,4.3-4.1c3.6-2.2,7.2-4.4,11.8-4.2
		c1.9,0.1,3.5-1.4,5.8-0.1c1.6,0.9,3.9,0.3,6,1.1c5.9,2.3,10.8,6,14.8,10.8c2.9,3.5,4.7,7.7,6.8,11.6c2.1,4,3.2,8.3,4.2,12.7
		c1.5,6.3,2.1,12.7,2,19.1c-0.1,4.7-1.5,9-2.4,13.5c-0.9,4.3-3,8.3-5.7,11.5c-4.7,5.6-9.8,11.2-18,11.6c-6.4,2.8-14.4-0.1-20.1-3.8
		c-9-5.9-14.4-14.4-17.8-24.5C365.3,241,364.2,233.8,364.7,226.4z"/>
	<path class="st0" d="M314.8,312.7c1.4-1.4,2.8-2.8,4.3-4.3c3.4-0.8,6.5,0.8,9.7,1.3c3.9,0.7,7.6,1.8,11.4,2.7
		c6.4,1.4,12.8,1.3,19.1,0.6c7.7-0.8,15.5-1.8,22.7-5.3c2.3-1.1,4.8-2,7.5-3.4c2.2,0,4.9,0,7.8,0c0.9,1.1,1.9,2.3,3.3,4.1
		c0.2,5.8-0.5,6.6-6.3,10.9c-5.5,4-11.6,6-19.2,7.9c-4.2,1.1-8.5,1.3-12.6,2.2c-4.8,1-9.4,0.7-14.1,0.7c-2.3,0-4.7,0.6-7.2-0.7
		c-1.8-1-4.5,0.4-6.5-1.2c-4.7,0.1-8.7-2-12.8-4C315.9,321.3,314.7,319.4,314.8,312.7z"/>
	<path class="st2" d="M425.6,489.5c2.1,15.2,0.8,30.6,1,45.9c0.2,15.5,0,31,0.1,46.4c0,3.1-1.5,5.9-1.1,9.1c0.4,3.1,0.7,6.5-0.1,9.4
		c-1.1,4.1-0.8,8.1-0.7,12.1c0,1.9-1.5,3.1-1.2,5.1c0.3,1.7,0.4,3.5-0.8,5.1c-0.6,0.8-0.1,2.3-0.1,3.1c-0.8,1.8-1.3,3.5-2.3,4.8
		c-2.1,2.4-4.6,4.1-7.7,5.5c-3.3,1.5-6.8,1.9-10.1,3.4c-2,0.9-4.3,0.6-6.4,1.3c-1.7,0.6-3.8,0-5.5,1.1c-3.6-0.8-7,1.4-10.6,1
		c-2-0.2-3.5,1.5-5.6,1.1c-1.8-0.3-3.9-0.5-5.6,0.9c-0.3,0.2-1,0.1-1.5,0c-4.4-0.6-8.6,1.6-13.1,1c-3.6,2.2-8-0.2-11.7,2
		c-0.1,0.1-0.3,0-0.5,0c-5.1-0.6-10,1.5-15.1,1.1c-2.2-0.2-4.2,1.3-6.6,1c-2.2-0.2-4.6-0.7-6.6,0.9c-0.1,0.1-0.3,0-0.5,0
		c-5.1-0.7-10,1.1-15.1,1c-7.2-0.2-14.3,1.9-21.6,1c-6.1-0.8-12.2-2-16.5-7.1c-3.3-3.9-5.3-8.5-5.4-13.7c-0.1-4-0.6-8.1,0.1-12
		c1.4-8-0.1-16.2,1.1-24c1.2-8.2-0.2-16.5,0.9-24.6c1.4-10.4,0.7-20.7,0.8-31.1c0.2-10.5-0.1-21,0.1-31.4c0.1-5,1.8-9.5,5.6-13.2
		c3-3,6.4-5.1,10.4-6.3c0.3-0.1,0.6-0.4,0.8-0.4c3.8,0.5,7.3-1.9,11.1-1c2.4,0.6,4.3-1.1,6.6-1c2.2,0.1,4.6,0.7,6.4-0.1
		c2.8-1.2,5.5-0.9,8.1-0.7c2.5,0.1,4.6-1.4,7.1-1.1c2.5,0.2,5.2,0.7,7.4-0.1c3.4-1.2,6.8-0.8,10.1-0.8c2.6,0,4.9-1.4,7.6-1.2
		c2.5,0.2,5.2,0.9,7.6-0.9c0.2-0.2,0.7-0.1,1,0c7.4,0.8,14.7-1.6,22.1-1c2.6,0.2,4.9-1.4,7.6-1.1c2.6,0.3,5.5,0.7,7.9-0.1
		c4.2-1.3,8.4-0.9,12.6-0.7c3.7,0.2,7-1.5,10.6-1.1c7.2,0.8,13.6,3,16.4,10.7C425,489,425.3,489.2,425.6,489.5z"/>
	<path class="st13" d="M306.3,255.3c-1.8,0-3.4,0-5,0c-4.7-2.5-5.9-7-6.4-11.7c-0.4-3.1-0.1-6.3-0.1-9.4c0.7-2.3,2.3-3.8,4-5.3
		c2.6-2.2,5.5-2.1,8.1,0.1c3.1,2.5,4.6,5.9,4.9,9.9c0.1,2,0,4,0,6c0,3.3-0.8,6.3-3.5,8.5C307.7,253.8,307.1,254.5,306.3,255.3z"/>
	<path class="st14" d="M400.2,243.3c-6.3-5.4-6.8-12.7-6.5-20.3c0.7-2.3,2.7-3.8,4.3-5.5c2.5-0.6,4.7-0.1,6.1,1
		c5.5,6.1,4.7,13,4.4,19.7c-0.1,2.1-1.4,4.5-4.2,5.2c-0.4,0.1-0.8,0.6-1.1,0.9C402.5,243.1,401.3,243.3,400.2,243.3z"/>
	<path class="st6" d="M272.6,507.7c2-1.8,3.3-3.7,6.4-4.5c2.3,0.8,5.1-1.3,8.2-1.2c3,0.1,6.2,0.6,8.9-0.1c3.4-0.9,6.9-0.1,10.1-1
		c3.1-0.8,6.3,0,9-1.1c3-1.3,5.9,0,8.6-0.8c3.7-1.2,7.5-0.3,11.1-1.1c3.7-0.9,7.6-0.1,11.1-1c4.4-1.1,8.8-0.1,13.1-1
		c4.7-0.9,9.5-0.1,14-1.1c4.9-1,9.8-0.7,14.6-0.7c2.5,0,4.6-1.4,7.1-1.2c2.5,0.2,5.3,0.8,7.4-0.1c3.1-1.4,5.5-0.1,8.3,0.4
		c2.3,2.7,3,6.2,3.1,9.6c0.2,16.8,0.1,33.6,0.1,50.4c-2.1,10.6-0.1,21.4-1.2,32c-0.5,5.4-0.1,10.8-1,16c-0.7,3.9-0.7,7.7-0.7,11.6
		c0,1.6-1.4,2.5-1.1,4.1c0.2,1.4,0.1,3,0.1,4.4c-3.7,1.9-7.6,2.8-11.6,3.6c-6.1,1.2-12.2,1.9-18.2,3c-2.6,0.5-5.2,0.2-7.6,0.9
		c-2.6,0.8-5.1,0.9-7.6,0.8c-1.8,0-3.1,1.6-5.1,1.1c-1.5-0.4-3.3-0.5-4.6,0.9c-0.1,0.1-0.3,0-0.5,0c-4.6-0.8-9,1.5-13.6,1
		c-2.2-0.3-3.9,1.2-6.1,1.1c-1.8-0.1-4-1-5.6,0.9c-0.1,0.2-0.6,0.1-1,0c-5.6-0.6-11.1,0.7-16.5,1.2c-6.4,0.6-12.8,0-19.1,1
		c-4.4,0.6-8.7,0.7-13.1,0.8c-4.2,0.1-8-0.9-9.8-6.3c0-7-0.7-15.1,0.2-22.9c0.8-7.2-0.2-14.5,1-21.5c1.5-9.2-0.2-18.5,1-27.5
		c1.2-9.2,0.6-18.4,0.9-27.6c0.1-4.4-1.2-8.6-1.1-13.1C271.8,515.1,273.7,511.6,272.6,507.7z"/>
</g>
</svg>
" alt="Logo" width="220" />

## Distry

Distributed task execution framework. Scale your Python functions across multiple workers.

## Features

* **Zero-config setup** - Auto-detects and installs dependencies
* **Simple API** - Just `client.map(func, inputs)`
* **Fault-tolerant** - Handles worker failures gracefully
* **Automatic Job Batching** - Large jobs are automatically split to fit worker RAM limits.
* **Package management** - Installs required packages on workers
* **Global indexing** - Results returned in input order

## Installation

```plaintext
# Client only (for task submission)
pip install distry-py[client]

# Worker only (for task execution)
pip install distry-py[worker]

# Full installation
pip install distry-py[all]
```

## Quick Start

### 1. Start Workers

```plaintext
# Terminal 1 - Worker 1
distry-worker --port 8001

# Terminal 2 - Worker 2 (with RAM limit)
distry-worker --port 8002 --max-ram 2g
```

### 2. Run Tasks

```python
from distry import Client

# Connect to workers
client = Client(["http://127.0.0.1:8001", "http://127.0.0.1:8002"])

# Define function (any Python function works!)
import numpy as np

def process_data(x):
    return np.mean([x, x**2, x**3])

# Process inputs in parallel
results = client.map(process_data, [1, 2, 3, 4, 5])

print(results)
# [1.0, 6.0, 19.0, 40.0, 69.0]

client.close()
```

### 2b. Using the Decorator (for single function calls)

For simpler cases where you want to execute a single function call on a worker, you can use the `@distry` decorator.

```python
from distry import register_workers, distry
import numpy as np

# Connect to workers
register_workers(["http://127.0.0.1:8001", "http://127.0.0.1:8002"])

@distry
def process_data(x, power=2):
    return np.mean([x, x**power])

# Process a single input on a randomly selected worker
result = process_data(10)
print(result)
# 55.0

# With keyword arguments
result_power_3 = process_data(10, power=3)
print(result_power_3)
# 505.0
```

### 3. Advanced Usage

```python
from distry import Client

client = Client(worker_urls)

# Custom packages (optional - auto-detection works too)
def scipy_func(x):
    from scipy.special import factorial
    return float(factorial(x))

results = client.map(
    scipy_func,
    [1, 2, 3, 4],
    required_packages=['scipy'],  # Manual specification
    max_workers=2
)

# Results with error handling
def risky_func(x):
    if x == 3:
        raise ValueError("Oops!")
    return x * 2

results = client.map(risky_func, [1, 2, 3, 4])  # [2, 4, None, 8]

client.close()
```

## API Reference

### Client

```python
from distry import Client

client = Client(worker_urls, max_concurrent_jobs=10)

# Map function across inputs
results = client.map(
    func,           # Any Python function
    inputs,         # List of inputs
    max_workers=4,  # Limit concurrent workers
    timeout=60,     # Timeout per input
    required_packages=None  # Auto-detected
)

# Cluster status
status = client.get_cluster_status()

client.close()
```

### Worker

```python
from distry import WorkerServer

# Programmatic worker
server = WorkerServer(host="0.0.0.0", port=8000)
server.run()

# Or use CLI
# distry-worker --host 0.0.0.0 --port 8000
```

## CLI

```plaintext
# Start worker
distry-worker --help
distry-worker --host 0.0.0.0 --port 8000 --max-ram 4g

# The client will automatically split large jobs into batches
# to fit the worker's RAM limit.

# View worker endpoints
# GET /health
# GET /status
# GET /installed_packages
```

## What Happens Under the Hood?

1. **Function Analysis**: Auto-detects imports from your function
2. **Package Installation**: Installs missing packages on workers
3. **Task Distribution**: Splits inputs across available workers
4. **Result Collection**: Gathers results with global indexing
5. **Error Handling**: Failed inputs return `None`, others succeed

## Use Cases

* **Data Processing**: Apply functions to large datasets
* **ML Inference**: Scale model predictions across workers
* **API Calls**: Parallelize HTTP requests
* **Computational Tasks**: CPU-intensive calculations
* **Batch Processing**: Process files, images, or documents

## Limitations

* Single function per job (no complex workflows)
* 30s timeout per input (configurable)
* Synchronous function execution on workers
* Basic package management (no virtual environments)
