Name | sunray JSON |
Version |
0.11.1
JSON |
| download |
home_page | None |
Summary | More robust ray |
upload_time | 2025-02-11 02:40:00 |
maintainer | None |
docs_url | None |
author | ZhengYu, Xu |
requires_python | <4.0,>=3.9 |
license | None |
keywords |
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# Sunray
[data:image/s3,"s3://crabby-images/4f499/4f499ccfefe7c980b835b627fc125bafe5a40d11" alt="Tests"](https://github.com/zen-xu/sunray/actions/workflows/test.yaml)
[data:image/s3,"s3://crabby-images/e6cd0/e6cd09f41c5d1bbf18134f124169b21878b1b14c" alt="Mypy"](https://github.com/zen-xu/sunray/actions/workflows/test-mypy.yaml)
[data:image/s3,"s3://crabby-images/bb84d/bb84dc32711e619e8a01447ce61d7b95f0ccc259" alt="codecov"](https://codecov.io/gh/zen-xu/sunray)
data:image/s3,"s3://crabby-images/91725/9172584f60ae6f821832c92de8e82f9c64ca06ac" alt="GitHub License"
data:image/s3,"s3://crabby-images/30df0/30df02cfff7b7cb376a3e8393df41a046152a0d7" alt="PyPI - Python Version"
data:image/s3,"s3://crabby-images/e1387/e138707985dde940b89838c0a5fac4b58ca802a6" alt="PyPI - Version"
data:image/s3,"s3://crabby-images/3460a/3460a672288c59cd4a06bdaddbfe5ea31a138601" alt="Static Badge"
[Ray](https://github.com/ray-project/ray) is a unified framework for scaling AI and Python applications. However, it falls short in offering friendly type hints, particularly when it comes to working with the `Actor`.
To address this shortfall, sunray provides enhanced and more robust type hints.
## install
```shell
pip install sunray
```
## Let's vs.
### Round 1: Build an actor
| sunray | ray |
| :-------------------------------------------------------------------------: | :----------------------------------------------------------------------: |
| data:image/s3,"s3://crabby-images/e3a60/e3a6034957c8412ebe63978f2c865ac76a9b4896" alt="" | data:image/s3,"s3://crabby-images/1ac02/1ac02ca21eb6360975c615f9ce34c31981ba095c" alt="" |
- sunray returns `Actor[Demo]`, but ray returns `ObjectRef[Demo]`
- ray mypy raise error `Type[Demo] has no attribute "remote"`
### Round 2: Get actor remote methods
| sunray | ray |
| :---------------------------------------------------------------------------------: | :------------------------------------------------------------------------------: |
| data:image/s3,"s3://crabby-images/29343/293439835b5a3380758b814ab26c75b933e6dbd4" alt="" | data:image/s3,"s3://crabby-images/6ccd4/6ccd41aa5a4c70fbdd61db3207a14ded5626be1d" alt="" |
- sunray list all remote methods
- ray list nothing
### Round 3: Actor remote method call
| sunray | ray |
| :--------------------------------------------------------------------------------------: | :-----------------------------------------------------------------------------------: |
| data:image/s3,"s3://crabby-images/fa8a1/fa8a1ab8bad7dcc8aec89654ad4ddca22a412c6d" alt="" | data:image/s3,"s3://crabby-images/fce7f/fce7f2a10b00dc9eb2a999ff7f5a99bccc6eca90" alt="" |
- sunray correctly provided parameter hints.
- ray ...
### Round 4: Annotate with Actor
| sunray | ray |
| :------------------------------------------------------------------------------------: | :---------------------------------------------------------------------------------: |
| data:image/s3,"s3://crabby-images/d5314/d53141e45d42a134fa8e3e48428a3fa03550b321" alt="" | data:image/s3,"s3://crabby-images/356df/356df580d3458f34827927af83850c1dcefda743" alt="" |
- with sunray, just annotate it with `Actor[Demo]`.
- with ray, I don't known.
### Round 5: Stream
| sunray | ray |
| :--------------------------------------------------------------------------: | :-----------------------------------------------------------------------: |
| data:image/s3,"s3://crabby-images/7893c/7893cbddb98b8c121f9745ea037a57a29292da53" alt="" | data:image/s3,"s3://crabby-images/f121d/f121d4e87f680e5e94d7decd1be908ea09cacf10" alt="" |
- sunray correctly identified that `stream` returns a generator.
- ray still returns ObjectRef.
### Round 6: Unpack result
| sunray | ray |
| :--------------------------------------------------------------------------: | :-----------------------------------------------------------------------: |
| data:image/s3,"s3://crabby-images/f5074/f50748d65af150172a3415ed3bf8fae2295e8ca2" alt="" | data:image/s3,"s3://crabby-images/fca59/fca592e04986ade742282b2f76e4c3cf836f686f" alt="" |
- sunray will auto unpack tuple result if options specify `unpack=True`.
- ray need to specify how many return numbers, so you need to count it.
- ray mypy raise error 'RemoteFunctionNoArgs has no attribute "options"'.
### Round 7: Get actor
| sunray | ray |
| :-----------------------------------------------------------------------------: | :--------------------------------------------------------------------------: |
| data:image/s3,"s3://crabby-images/85b0c/85b0cdd345990b04c272da01d5f4e402749c6efa" alt="" | data:image/s3,"s3://crabby-images/9dc4d/9dc4d55646d4a62635b4cebcccc87b316e45444c" alt="" |
- sunray get_actor will return `ActorHandle`, and return `Actor[Demo]` if you specify with generic type.
- ray just return `Any`.
### Round 8: Call self remote method
| sunray | ray |
| :-------------------------------------------------------------------------------------------: | :----------------------------------------------------------------------------------------: |
| data:image/s3,"s3://crabby-images/36ccd/36ccdcd80a044490cc20c8360de7112d07bd5226" alt="" | data:image/s3,"s3://crabby-images/f0793/f07934897748a364a00a50a7d4398207e07657ef" alt="" |
- sunray maintains a consistent calling convention, whether it's from internal or external functions.
- ray, you need to first obtain the current actor from the running context, and then call through the actor.
### Round 9: Lazy Computation
| sunray | ray |
| :------------------------------------------------------------------------: | :---------------------------------------------------------------------: |
| data:image/s3,"s3://crabby-images/4254c/4254cd3bac50b1d8cf71689623cc3d37a8a6cc5a" alt="" | data:image/s3,"s3://crabby-images/ecd9c/ecd9cdb9b8b07f250f12545b3e057530c09f1e65" alt="" |
- sunray can successfully track the input parameter types and output types.
- ray does not have this capability.
## API
`sunray` re-export all apis from `ray.core` with friendly type hints. In addition, `sunray` provides `ActorMixin` which is used to help creating more robust actors.
### ActorMixin
`ActorMixin` is a mixin, and provides a classmethod `new_actor`
```python
import sunray
class Demo(
# Here to specify default actor options
sunray.ActorMixin, name="DemoActor", num_cpus=1, concurrency_groups={"g1": 1}
):
def __init__(self, init_v: int):
self.init_v = init_v
# annotate `add` is a remote_method
@sunray.remote_method
def add(self, v: int) -> int:
return self.init_v + v
# support directly call remote_method
@sunray.remote_method
def calculate(self, v: int) -> int:
return self.add(v)
# support specify remote method options
@sunray.remote_method(concurrency_group="g1")
async def sleep(self): ...
# construct the actor
actor = Demo.new_actor().remote(1)
# call remote method
ref = actor.methods.add.remote(1)
print(sunray.get(ref))
```
Raw data
{
"_id": null,
"home_page": null,
"name": "sunray",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0,>=3.9",
"maintainer_email": null,
"keywords": null,
"author": "ZhengYu, Xu",
"author_email": "zen-xu@outlook.com",
"download_url": null,
"platform": null,
"description": "# Sunray\n\n[data:image/s3,"s3://crabby-images/4f499/4f499ccfefe7c980b835b627fc125bafe5a40d11" alt="Tests"](https://github.com/zen-xu/sunray/actions/workflows/test.yaml)\n[data:image/s3,"s3://crabby-images/e6cd0/e6cd09f41c5d1bbf18134f124169b21878b1b14c" alt="Mypy"](https://github.com/zen-xu/sunray/actions/workflows/test-mypy.yaml)\n[data:image/s3,"s3://crabby-images/bb84d/bb84dc32711e619e8a01447ce61d7b95f0ccc259" alt="codecov"](https://codecov.io/gh/zen-xu/sunray)\ndata:image/s3,"s3://crabby-images/91725/9172584f60ae6f821832c92de8e82f9c64ca06ac" alt="GitHub License"\ndata:image/s3,"s3://crabby-images/30df0/30df02cfff7b7cb376a3e8393df41a046152a0d7" alt="PyPI - Python Version"\ndata:image/s3,"s3://crabby-images/e1387/e138707985dde940b89838c0a5fac4b58ca802a6" alt="PyPI - Version"\ndata:image/s3,"s3://crabby-images/3460a/3460a672288c59cd4a06bdaddbfe5ea31a138601" alt="Static Badge"\n\n[Ray](https://github.com/ray-project/ray) is a unified framework for scaling AI and Python applications. However, it falls short in offering friendly type hints, particularly when it comes to working with the `Actor`.\n\nTo address this shortfall, sunray provides enhanced and more robust type hints.\n\n## install\n\n```shell\npip install sunray\n```\n\n## Let's vs.\n\n### Round 1: Build an actor\n\n| sunray | ray |\n| :-------------------------------------------------------------------------: | :----------------------------------------------------------------------: |\n| data:image/s3,"s3://crabby-images/e3a60/e3a6034957c8412ebe63978f2c865ac76a9b4896" alt="" | data:image/s3,"s3://crabby-images/1ac02/1ac02ca21eb6360975c615f9ce34c31981ba095c" alt="" |\n\n- sunray returns `Actor[Demo]`, but ray returns `ObjectRef[Demo]`\n- ray mypy raise error `Type[Demo] has no attribute \"remote\"`\n\n### Round 2: Get actor remote methods\n| sunray | ray |\n| :---------------------------------------------------------------------------------: | :------------------------------------------------------------------------------: |\n| data:image/s3,"s3://crabby-images/29343/293439835b5a3380758b814ab26c75b933e6dbd4" alt="" | data:image/s3,"s3://crabby-images/6ccd4/6ccd41aa5a4c70fbdd61db3207a14ded5626be1d" alt="" |\n\n- sunray list all remote methods\n- ray list nothing\n\n### Round 3: Actor remote method call\n| sunray | ray |\n| :--------------------------------------------------------------------------------------: | :-----------------------------------------------------------------------------------: |\n| data:image/s3,"s3://crabby-images/fa8a1/fa8a1ab8bad7dcc8aec89654ad4ddca22a412c6d" alt="" | data:image/s3,"s3://crabby-images/fce7f/fce7f2a10b00dc9eb2a999ff7f5a99bccc6eca90" alt="" |\n\n- sunray correctly provided parameter hints.\n- ray ...\n\n### Round 4: Annotate with Actor\n| sunray | ray |\n| :------------------------------------------------------------------------------------: | :---------------------------------------------------------------------------------: |\n| data:image/s3,"s3://crabby-images/d5314/d53141e45d42a134fa8e3e48428a3fa03550b321" alt="" | data:image/s3,"s3://crabby-images/356df/356df580d3458f34827927af83850c1dcefda743" alt="" |\n\n- with sunray, just annotate it with `Actor[Demo]`.\n- with ray, I don't known.\n\n### Round 5: Stream\n| sunray | ray |\n| :--------------------------------------------------------------------------: | :-----------------------------------------------------------------------: |\n| data:image/s3,"s3://crabby-images/7893c/7893cbddb98b8c121f9745ea037a57a29292da53" alt="" | data:image/s3,"s3://crabby-images/f121d/f121d4e87f680e5e94d7decd1be908ea09cacf10" alt="" |\n\n- sunray correctly identified that `stream` returns a generator.\n- ray still returns ObjectRef.\n\n### Round 6: Unpack result\n| sunray | ray |\n| :--------------------------------------------------------------------------: | :-----------------------------------------------------------------------: |\n| data:image/s3,"s3://crabby-images/f5074/f50748d65af150172a3415ed3bf8fae2295e8ca2" alt="" | data:image/s3,"s3://crabby-images/fca59/fca592e04986ade742282b2f76e4c3cf836f686f" alt="" |\n\n- sunray will auto unpack tuple result if options specify `unpack=True`.\n- ray need to specify how many return numbers, so you need to count it.\n- ray mypy raise error 'RemoteFunctionNoArgs has no attribute \"options\"'.\n\n### Round 7: Get actor\n| sunray | ray |\n| :-----------------------------------------------------------------------------: | :--------------------------------------------------------------------------: |\n| data:image/s3,"s3://crabby-images/85b0c/85b0cdd345990b04c272da01d5f4e402749c6efa" alt="" | data:image/s3,"s3://crabby-images/9dc4d/9dc4d55646d4a62635b4cebcccc87b316e45444c" alt="" |\n\n- sunray get_actor will return `ActorHandle`, and return `Actor[Demo]` if you specify with generic type.\n- ray just return `Any`.\n\n### Round 8: Call self remote method\n| sunray | ray |\n| :-------------------------------------------------------------------------------------------: | :----------------------------------------------------------------------------------------: |\n| data:image/s3,"s3://crabby-images/36ccd/36ccdcd80a044490cc20c8360de7112d07bd5226" alt="" | data:image/s3,"s3://crabby-images/f0793/f07934897748a364a00a50a7d4398207e07657ef" alt="" |\n\n- sunray maintains a consistent calling convention, whether it's from internal or external functions.\n- ray, you need to first obtain the current actor from the running context, and then call through the actor.\n\n### Round 9: Lazy Computation\n| sunray | ray |\n| :------------------------------------------------------------------------: | :---------------------------------------------------------------------: |\n| data:image/s3,"s3://crabby-images/4254c/4254cd3bac50b1d8cf71689623cc3d37a8a6cc5a" alt="" | data:image/s3,"s3://crabby-images/ecd9c/ecd9cdb9b8b07f250f12545b3e057530c09f1e65" alt="" |\n\n- sunray can successfully track the input parameter types and output types.\n- ray does not have this capability.\n\n## API\n\n`sunray` re-export all apis from `ray.core` with friendly type hints. In addition, `sunray` provides `ActorMixin` which is used to help creating more robust actors.\n\n### ActorMixin\n\n`ActorMixin` is a mixin, and provides a classmethod `new_actor`\n\n```python\nimport sunray\n\n\nclass Demo(\n # Here to specify default actor options\n sunray.ActorMixin, name=\"DemoActor\", num_cpus=1, concurrency_groups={\"g1\": 1}\n):\n def __init__(self, init_v: int):\n self.init_v = init_v\n\n # annotate `add` is a remote_method\n @sunray.remote_method\n def add(self, v: int) -> int:\n return self.init_v + v\n\n # support directly call remote_method\n @sunray.remote_method\n def calculate(self, v: int) -> int:\n return self.add(v)\n\n # support specify remote method options\n @sunray.remote_method(concurrency_group=\"g1\")\n async def sleep(self): ...\n\n\n# construct the actor\nactor = Demo.new_actor().remote(1)\n\n# call remote method\nref = actor.methods.add.remote(1)\nprint(sunray.get(ref))\n```\n",
"bugtrack_url": null,
"license": null,
"summary": "More robust ray",
"version": "0.11.1",
"project_urls": null,
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "870bd1f076ca7a76312c399040fe084e1628a86dc7b25d479d0476208d26e06a",
"md5": "66f6bd866a495a7aafe4ad029e3a6256",
"sha256": "7bd65a6054329e457251477d2da3214288cd4d6959454f8f9d2aea62cd8eb30f"
},
"downloads": -1,
"filename": "sunray-0.11.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "66f6bd866a495a7aafe4ad029e3a6256",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.9",
"size": 23634,
"upload_time": "2025-02-11T02:40:00",
"upload_time_iso_8601": "2025-02-11T02:40:00.314287Z",
"url": "https://files.pythonhosted.org/packages/87/0b/d1f076ca7a76312c399040fe084e1628a86dc7b25d479d0476208d26e06a/sunray-0.11.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-02-11 02:40:00",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "sunray"
}