-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathview7.py
97 lines (73 loc) · 2.56 KB
/
view7.py
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
87
88
89
90
91
92
93
94
95
96
97
from typing import *
from concurrent.futures import ProcessPoolExecutor, Future
from collections import defaultdict
import networkx as nx
import numpy as np
from utils import *
from pymongo import MongoClient
from flask import Blueprint, jsonify, url_for, redirect
import itertools
from pprint import pprint
from colorhash import ColorHash
page = Blueprint('view7', __name__)
client = MongoClient('localhost', 27017)
db = client['diva-proj']
mycol4=db['authors_cas']
# pool = ProcessPoolExecutor()
# graph_frames: List[Future] = []
def format_for_g6(g: nx.Graph):
nodes = [{
'id': nid,
'label': g.nodes[nid]['label'],
'concept': g.nodes[nid]['concept'],
'style': {'fill': ColorHash(g.nodes[nid]['concept']).hex}
} for nid in g.nodes]
edges = [{'source': p, 'target': q} for p,q in g.edges]
#edges = [{'source': p, 'target': q} | g.edges[p,q] for p,q in g.edges]
data = {
'nodes': nodes,
'edges': edges
}
return data
def authors_cas():
author_works = list(mycol4.find())
author_works = author_works[0]['Casimir Kulikowski']
g2=nx.Graph()
author_name='Casimir Kulikowski'
all_referenced = dict()
for auth_paper, references in author_works.items():
for r in references:
all_referenced[r['id']] = r
all_referenced = list(all_referenced.values())
all_referenced = [p for p in all_referenced]
filtered = []
for p in all_referenced:
if p['cited_by_count'] is not None:
if p['cited_by_count'] > 0:
filtered.append(p)
# print(filtered)
g2.add_node(author_name)
g2.nodes[author_name]['label'] = author_name
g2.nodes[author_name]['concept'] = author_name
for paper in filtered:
paper_id = paper['id']
g2.add_node(paper_id)
g2.nodes[paper_id]['label'] = paper['display_name']
g2.nodes[paper_id]['concept'] = [c['display_name'] for c in paper['concepts'] if c['level'] == 0][0]
# print(g2.nodes[paper_id]['concept'])
for paper in filtered:
g2.add_edge(author_name, paper['id'])
for paper in filtered:
for citation in paper['referenced_works']:
if citation in g2.nodes:
g2.add_edge(paper['id'], citation)
author_data = format_for_g6(g2)
return author_data
@page.route("/view7")
def view7_index():
return redirect(url_for('static', filename='view7/index.html'))
@page.route("/view7/authorscas")
def get_author_data4():
data = authors_cas()
#print(data)
return jsonify(data)