-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathvenmo_dataloader.py
78 lines (57 loc) · 2.53 KB
/
venmo_dataloader.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
import pandas as pd
import networkx as nx
import seaborn as sns
import numpy as np
import matplotlib.pyplot as plt
import pickle
import glob
from generator import *
sns.set_theme()
def load_venmo_data_and_extract_components(export_wcc=True, min_size=50, densest=True):
df = pd.read_csv('data/venmo.csv', low_memory=True)
G = nx.from_pandas_edgelist(df, 'payment.actor.username', 'payment.target.user.username', create_using=nx.DiGraph)
pickle.dump(G, open('data/venmo_G.pickle', 'wb'))
wccs = []
if export_wcc:
wccs_gen = nx.weakly_connected_components(G)
max_density, argmax, argmax_idx = 0, None, -1
for i, wcc in enumerate(wccs_gen):
if len(wcc) >= min_size:
H = G.subgraph(wcc).copy()
if not densest:
pickle.dump(H, open('data/venmo_wcc_{}.pickle'.format(i), 'wb'))
wccs.append(wcc)
else:
if len(H.edges()) / len(H)**2 >= max_density:
max_density = len(H.edges()) / len(H)**2
argmax = H
argmax_idx = i
if densest:
pickle.dump(argmax, open('data/venmo_wcc_{}_densest.pickle'.format(argmax_idx), 'wb'))
return G, wccs
def load_venmo_dataset(filename='data/venmo_wcc_54415_densest.pickle'):
G = nx.nx.relabel.convert_node_labels_to_integers(nx.read_gpickle(filename))
n = len(G)
distribution = 'exponential'
alpha = 0.9
distributions = {
'exponential' : lambda size: np.random.exponential(1, size=size),
'pareto' : lambda size: np.random.pareto(2, size=size),
'lognormal' : lambda size: np.random.lognormal(0, 1, size=size)
}
adj = nx.to_numpy_array(G)
outdegree = adj.sum(0)
indegree = adj.sum(-1)
liabilities = adj * distributions[distribution]((n, n))
internal_assets = liabilities.sum(-1).reshape((n, 1))
internal_liabilities = liabilities.sum(0).reshape((n, 1))
external_assets = np.array([G.degree(u) for u in G]) * distributions[distribution]((n, 1))
external_liabilities = alpha * external_assets
P_bar = internal_liabilities + external_liabilities
A = np.copy(liabilities)
for i in range(liabilities.shape[0]):
A[i] /= P_bar[i]
wealth = internal_assets + external_assets - P_bar
return A, P_bar, liabilities, adj, internal_assets, internal_liabilities, outdegree, indegree, external_assets, external_liabilities, wealth, G
if __name__ == '__main__':
load_venmo_data_and_extract_components()