mirror of
https://github.com/vale981/ray
synced 2025-03-06 10:31:39 -05:00
131 lines
4.5 KiB
C++
131 lines
4.5 KiB
C++
|
||
/// This is a complete example of writing a distributed program using the C ++ worker API.
|
||
|
||
/// including the header
|
||
#include <ray/api.h>
|
||
|
||
/// using namespace
|
||
using namespace ::ray::api;
|
||
|
||
/// general function of user code
|
||
int Return1() { return 1; }
|
||
int Plus1(int x) { return x + 1; }
|
||
int Plus(int x, int y) { return x + y; }
|
||
|
||
RAY_REMOTE(Return1, Plus1, Plus);
|
||
|
||
/// a class of user code
|
||
class Counter {
|
||
public:
|
||
int count;
|
||
|
||
Counter(int init) { count = init; }
|
||
static Counter *FactoryCreate() { return new Counter(0); }
|
||
static Counter *FactoryCreate(int init) { return new Counter(init); }
|
||
static Counter *FactoryCreate(int init1, int init2) {
|
||
return new Counter(init1 + init2);
|
||
}
|
||
/// non static function
|
||
int Plus1() {
|
||
count += 1;
|
||
return count;
|
||
}
|
||
int Add(int x) {
|
||
count += x;
|
||
return count;
|
||
}
|
||
};
|
||
|
||
RAY_REMOTE(RAY_FUNC(Counter::FactoryCreate), RAY_FUNC(Counter::FactoryCreate, int),
|
||
RAY_FUNC(Counter::FactoryCreate, int, int), &Counter::Plus1, &Counter::Add);
|
||
|
||
int main(int argc, char **argv) {
|
||
/// configuration
|
||
ray::api::RayConfig config;
|
||
|
||
/// initialization
|
||
Ray::Init(config, &argc, &argv);
|
||
|
||
/// put and get object
|
||
auto obj = Ray::Put(12345);
|
||
auto get_put_result = *(Ray::Get(obj));
|
||
std::cout << "get_put_result = " << get_put_result << std::endl;
|
||
|
||
/// common task without args
|
||
auto task_obj = Ray::Task(Return1).Remote();
|
||
int task_result1 = *(Ray::Get(task_obj));
|
||
std::cout << "task_result1 = " << task_result1 << std::endl;
|
||
|
||
/// common task with args
|
||
task_obj = Ray::Task(Plus1).Remote(5);
|
||
int task_result2 = *(Ray::Get(task_obj));
|
||
std::cout << "task_result2 = " << task_result2 << std::endl;
|
||
|
||
/// actor task without args
|
||
ActorHandle<Counter> actor1 = Ray::Actor(RAY_FUNC(Counter::FactoryCreate)).Remote();
|
||
auto actor_object1 = actor1.Task(&Counter::Plus1).Remote();
|
||
int actor_result1 = *(Ray::Get(actor_object1));
|
||
std::cout << "actor_result1 = " << actor_result1 << std::endl;
|
||
|
||
/// actor task with args
|
||
ActorHandle<Counter> actor2 =
|
||
Ray::Actor(RAY_FUNC(Counter::FactoryCreate, int)).Remote(1);
|
||
auto actor_object2 = actor2.Task(&Counter::Add).Remote(5);
|
||
int actor_result2 = *(Ray::Get(actor_object2));
|
||
std::cout << "actor_result2 = " << actor_result2 << std::endl;
|
||
|
||
/// actor task with args which pass by reference
|
||
ActorHandle<Counter> actor3 =
|
||
Ray::Actor(RAY_FUNC(Counter::FactoryCreate, int, int)).Remote(6, 0);
|
||
auto actor_object3 = actor3.Task(&Counter::Add).Remote(actor_object2);
|
||
int actor_result3 = *(Ray::Get(actor_object3));
|
||
std::cout << "actor_result3 = " << actor_result3 << std::endl;
|
||
|
||
/// general function remote call(args passed by value)
|
||
auto r0 = Ray::Task(Return1).Remote();
|
||
auto r2 = Ray::Task(Plus).Remote(3, 22);
|
||
int task_result3 = *(Ray::Get(r2));
|
||
std::cout << "task_result3 = " << task_result3 << std::endl;
|
||
|
||
/// general function remote call(args passed by reference)
|
||
auto r3 = Ray::Task(Return1).Remote();
|
||
auto r4 = Ray::Task(Plus1).Remote(r3);
|
||
auto r5 = Ray::Task(Plus).Remote(r4, r3);
|
||
auto r6 = Ray::Task(Plus).Remote(r4, 10);
|
||
int task_result4 = *(Ray::Get(r6));
|
||
int task_result5 = *(Ray::Get(r5));
|
||
std::cout << "task_result4 = " << task_result4 << ", task_result5 = " << task_result5
|
||
<< std::endl;
|
||
|
||
/// create actor and actor function remote call with args passed by value
|
||
ActorHandle<Counter> actor4 =
|
||
Ray::Actor(RAY_FUNC(Counter::FactoryCreate, int)).Remote(10);
|
||
auto r10 = actor4.Task(&Counter::Add).Remote(8);
|
||
int actor_result4 = *(Ray::Get(r10));
|
||
std::cout << "actor_result4 = " << actor_result4 << std::endl;
|
||
|
||
/// create actor and task function remote call with args passed by reference
|
||
ActorHandle<Counter> actor5 =
|
||
Ray::Actor(RAY_FUNC(Counter::FactoryCreate, int, int)).Remote(r10, 0);
|
||
auto r11 = actor5.Task(&Counter::Add).Remote(r0);
|
||
auto r12 = actor5.Task(&Counter::Add).Remote(r11);
|
||
auto r13 = actor5.Task(&Counter::Add).Remote(r10);
|
||
auto r14 = actor5.Task(&Counter::Add).Remote(r13);
|
||
auto r15 = Ray::Task(Plus).Remote(r0, r11);
|
||
auto r16 = Ray::Task(Plus1).Remote(r15);
|
||
int result12 = *(Ray::Get(r12));
|
||
int result14 = *(Ray::Get(r14));
|
||
int result11 = *(Ray::Get(r11));
|
||
int result13 = *(Ray::Get(r13));
|
||
int result16 = *(Ray::Get(r16));
|
||
int result15 = *(Ray::Get(r15));
|
||
std::cout << "Final result:" << std::endl;
|
||
std::cout << "result11 = " << result11 << ", result12 = " << result12
|
||
<< ", result13 = " << result13 << ", result14 = " << result14
|
||
<< ", result15 = " << result15 << ", result16 = " << result16 << std::endl;
|
||
|
||
/// shutdown
|
||
Ray::Shutdown();
|
||
|
||
return 0;
|
||
}
|