-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathdatasetBuilder.py
54 lines (47 loc) · 1.22 KB
/
datasetBuilder.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
'''
datasetBuilder.py
Arguements: -s <size>, -r <rangeLimit>, -o <outputName>
Author: Yi Liu
Build a data set
format:
size
id_1 x_1 y_1
......
id_m x_m y_m
......
'''
import sys
import getopt
import random
# write coordinates of a rtreePoint
def writePoint(f, rangeLimit):
x = round(random.uniform(-rangeLimit, rangeLimit),2)
y = round(random.uniform(-rangeLimit, rangeLimit),2)
f.write(str(x) + ' ' + str(y) + '\r\n')
# build data set
def buildDataSet(fileName, size, rangeLimit):
f = open(fileName, 'wt')
f.write(str(size) + '\r\n') # first line
# remained lines
for i in range(1, size+1):
f.write(str(i) + ' ')
writePoint(f, rangeLimit)
f.close()
print('Size: ', size, '. Range: ', -rangeLimit, ':', rangeLimit)
def main():
fileName = 'dataset.txt'
size = 10000
rangeLimit = 500
# parse arguements
options,args = getopt.getopt(sys.argv[1:],"s:r:o:")
for opt, para in options:
if opt == '-s':
size = int(para)
if opt == '-r':
rangeLimit = int(para)
if opt == '-o':
fileName = para
# build data set
buildDataSet(fileName, size, rangeLimit)
if __name__ == '__main__':
main()