forked from alibaba/libgrape-lite
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkcore_context.h
61 lines (45 loc) · 1.86 KB
/
kcore_context.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
/** 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_KCORE_KCORE_CONTEXT_H_
#define EXAMPLES_ANALYTICAL_APPS_KCORE_KCORE_CONTEXT_H_
namespace grape {
template <typename FRAG_T>
class KCoreContext : public VertexDataContext<FRAG_T, int> {
public:
using oid_t = typename FRAG_T::oid_t;
using vid_t = typename FRAG_T::vid_t;
explicit KCoreContext(const FRAG_T& fragment)
: VertexDataContext<FRAG_T, int>(fragment, false),
partial_result(this->data()) {}
void Init(ParallelMessageManagerOpt& messages, int k_) { k = k_; }
void Output(std::ostream& os) override {
auto& frag = this->fragment();
auto inner_vertices = frag.InnerVertices();
vid_t num = 0;
for (auto v : inner_vertices) {
if (partial_result[v] >= k) {
++num;
}
}
LOG(INFO) << "[frag-" << frag.fid() << "] "
<< "KCore: " << num;
}
int k;
typename FRAG_T::template inner_vertex_array_t<int>& partial_result;
typename FRAG_T::template vertex_array_t<int> reduced_degrees;
DenseVertexSet<typename FRAG_T::inner_vertices_t> curr_inner_updated,
next_inner_updated;
DenseVertexSet<typename FRAG_T::outer_vertices_t> outer_updated;
DenseVertexSet<typename FRAG_T::inner_vertices_t> removed;
};
} // namespace grape
#endif // EXAMPLES_ANALYTICAL_APPS_KCORE_KCORE_CONTEXT_H_