forked from mohamm-alsaid/EGoT_KAnonymity
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgenerate_rand_data.py
More file actions
67 lines (61 loc) · 2.22 KB
/
generate_rand_data.py
File metadata and controls
67 lines (61 loc) · 2.22 KB
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
import enum, re, sys
import numpy as np
from numpy.lib.function_base import append
import pandas as pd
import string
from itertools import cycle
from tree_handler import Dist
# In 13 node feeder:
# - segs are nodes
# - we have 13 nodes
# - we are only using 11 nodes (1 is 480v node - not used in res areas {634} & the other is a branch of the main nodes {6321})
# - each seg has 5 xformers
# - each transformer has 40 sp
def create_13_node_feeder(dist):
_,feeders = dist.add_level('feeder',5) # feeder should before the segment
_,seg1 = dist.add_level('segment',1,lvls=feeders[1:2])
_,seg2 = dist.add_level('segment',3,lvls=feeders[2:]) # feeder should before the segment
seg1.extend(seg2[:1])
seg2 = seg2[1:]
# segs.extend(seg)
_,xformer = dist.add_level('xformer',5,lvls=seg1)
_,xformers = dist.add_level('xformer',10,lvls=seg2[:2])
xformers.extend(xformer)
# add 15 xformers to the remaining segs
_,xformer = dist.add_level('xformer',15,lvls=seg2[2:])
xformers.extend(xformer)
_,ders = dist.add_level('DER',8,leave=True,lvls=xformers)
# dist.add_level('xformer',5)
# dist.add_level('DER',8,leave=True)
# ------------------- adding 10 more segs to the middle segs ---------------
# _,lvl=dist.add_level('xformer',10,lvls=seg_names[2:-2],id_range=list(range(5,15)))
# dist.add_level('DER',8,leave=True,lvls=lvl)
# ------------------ adding 5 more segs to the last segs -------------------
# _,lvl=dist.add_level('xformer',5,lvls=seg_names[-2:],id_range=list(range(5,10)))
# dist.add_level('DER',8,leave=True,lvls=lvl)
df = dist.export_to_df()
return df
def create_random_data(dist,size=50):
# randomly add parents
dist.add_level_rand('segment',10)
dist.add_level_rand('xformer',5)
dist.add_level_rand('DER',size)
df = dist.export_to_df()
return df
dist = Dist('substation')
print(dist)
print('-'*5,'CONSTRUCTING...','-'*5)
fname = 'random_ids.csv'
# if sys.argc > 3:
mode = sys.argv[1]
size = sys.argv[-1]
if mode != 'r':
df = create_13_node_feeder(dist)
else:
if size == mode:
df = create_random_data(dist)
else:
df = create_random_data(dist,int(size))
print(dist)
print(df)
df.to_csv(fname,index = False)