mirror of
https://github.com/vale981/ray
synced 2025-03-10 13:26:39 -04:00

- Currently not all code under ray-core/doc_code is covered by CI. - tf_example.py and torch_example.py are not used anywhere. Signed-off-by: Jiajun Yao <jeromeyjj@gmail.com>
99 lines
2 KiB
Python
99 lines
2 KiB
Python
# flake8: noqa
|
|
|
|
# fmt: off
|
|
# __dag_tasks_begin__
|
|
import ray
|
|
|
|
ray.init()
|
|
|
|
@ray.remote
|
|
def func(src, inc=1):
|
|
return src + inc
|
|
|
|
a_ref = func.bind(1, inc=2)
|
|
assert ray.get(a_ref.execute()) == 3 # 1 + 2 = 3
|
|
b_ref = func.bind(a_ref, inc=3)
|
|
assert ray.get(b_ref.execute()) == 6 # (1 + 2) + 3 = 6
|
|
c_ref = func.bind(b_ref, inc=a_ref)
|
|
assert ray.get(c_ref.execute()) == 9 # ((1 + 2) + 3) + (1 + 2) = 9
|
|
# __dag_tasks_end__
|
|
# fmt: on
|
|
|
|
ray.shutdown()
|
|
|
|
# fmt: off
|
|
# __dag_actors_begin__
|
|
import ray
|
|
|
|
ray.init()
|
|
|
|
@ray.remote
|
|
class Actor:
|
|
def __init__(self, init_value):
|
|
self.i = init_value
|
|
|
|
def inc(self, x):
|
|
self.i += x
|
|
|
|
def get(self):
|
|
return self.i
|
|
|
|
a1 = Actor.bind(10) # Instantiate Actor with init_value 10.
|
|
val = a1.get.bind() # ClassMethod that returns value from get() from
|
|
# the actor created.
|
|
assert ray.get(val.execute()) == 10
|
|
|
|
@ray.remote
|
|
def combine(x, y):
|
|
return x + y
|
|
|
|
a2 = Actor.bind(10) # Instantiate another Actor with init_value 10.
|
|
a1.inc.bind(2) # Call inc() on the actor created with increment of 2.
|
|
a1.inc.bind(4) # Call inc() on the actor created with increment of 4.
|
|
a2.inc.bind(6) # Call inc() on the actor created with increment of 6.
|
|
|
|
# Combine outputs from a1.get() and a2.get()
|
|
dag = combine.bind(a1.get.bind(), a2.get.bind())
|
|
|
|
# a1 + a2 + inc(2) + inc(4) + inc(6)
|
|
# 10 + (10 + ( 2 + 4 + 6)) = 32
|
|
assert ray.get(dag.execute()) == 32
|
|
# __dag_actors_end__
|
|
# fmt: on
|
|
|
|
ray.shutdown()
|
|
|
|
# fmt: off
|
|
# __dag_input_node_begin__
|
|
import ray
|
|
|
|
ray.init()
|
|
|
|
from ray.dag.input_node import InputNode
|
|
|
|
@ray.remote
|
|
def a(user_input):
|
|
return user_input * 2
|
|
|
|
@ray.remote
|
|
def b(user_input):
|
|
return user_input + 1
|
|
|
|
@ray.remote
|
|
def c(x, y):
|
|
return x + y
|
|
|
|
with InputNode() as dag_input:
|
|
a_ref = a.bind(dag_input)
|
|
b_ref = b.bind(dag_input)
|
|
dag = c.bind(a_ref, b_ref)
|
|
|
|
# a(2) + b(2) = c
|
|
# (2 * 2) + (2 * 1)
|
|
assert ray.get(dag.execute(2)) == 7
|
|
|
|
# a(3) + b(3) = c
|
|
# (3 * 2) + (3 * 1)
|
|
assert ray.get(dag.execute(3)) == 10
|
|
# __dag_input_node_end__
|
|
# fmt: on
|