-
Notifications
You must be signed in to change notification settings - Fork 93
/
Copy pathutils.h
86 lines (70 loc) · 2.48 KB
/
utils.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/** Copyright 2020 Alibaba Group Holding Limited.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
#ifndef EXAMPLES_ANALYTICAL_APPS_UTILS_H_
#define EXAMPLES_ANALYTICAL_APPS_UTILS_H_
#include <glog/logging.h>
#include <grape/grape.h>
#include "flags.h"
#include "timer.h"
#ifndef __AFFINITY__
#define __AFFINITY__ false
#endif
namespace grape {
void Init() {
if (FLAGS_deserialize && FLAGS_serialization_prefix.empty()) {
LOG(FATAL) << "Please assign a serialization prefix.";
} else if (FLAGS_efile.empty()) {
LOG(FATAL) << "Please assign input edge file.";
}
if (!FLAGS_out_prefix.empty() && access(FLAGS_out_prefix.c_str(), 0) != 0) {
mkdir(FLAGS_out_prefix.c_str(), 0777);
}
InitMPIComm();
CommSpec comm_spec;
comm_spec.Init(MPI_COMM_WORLD);
if (comm_spec.worker_id() == kCoordinatorRank) {
VLOG(1) << "Workers of libgrape-lite initialized.";
}
}
void Finalize() {
FinalizeMPIComm();
VLOG(1) << "Workers finalized.";
}
template <typename FRAG_T, typename APP_T, typename... Args>
void DoQuery(std::shared_ptr<FRAG_T> fragment, std::shared_ptr<APP_T> app,
const CommSpec& comm_spec, const ParallelEngineSpec& spec,
const std::string& out_prefix, Args... args) {
timer_next("load application");
auto worker = APP_T::CreateWorker(app, fragment);
worker->Init(comm_spec, spec);
MPI_Barrier(comm_spec.comm());
timer_next("run algorithm");
worker->Query(std::forward<Args>(args)...);
timer_next("print output");
if (!out_prefix.empty()) {
std::ofstream ostream;
std::string output_path =
grape::GetResultFilename(out_prefix, fragment->fid());
ostream.open(output_path);
worker->Output(ostream);
ostream.close();
worker->Finalize();
VLOG(1) << "Worker-" << comm_spec.worker_id()
<< " finished: " << output_path;
} else {
worker->Finalize();
VLOG(1) << "Worker-" << comm_spec.worker_id() << " finished without output";
}
timer_end();
}
} // namespace grape
#endif // EXAMPLES_ANALYTICAL_APPS_UTILS_H_