-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
90 lines (71 loc) · 2.97 KB
/
main.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
import os
import cv2
from timeit import default_timer as timer
startTimer = timer()
textDir = "./inputData"
imageDir = "./images"
imagesFiles = os.listdir(imageDir)
textFiles = os.listdir(textDir)
objects = {
"plane": 0,
"ship": 1,
# "storage-tank": 2,
# "baseball-diamond": 3,
# "tennis-court": 4,
# "basketball-court": 5,
# "ground-track-field": 6,
# "harbor": 7,
# "bridge": 8,
# "large-vehicle": 9,
# "helicopter": 10,
# "roundabout": 11,
# "soccer-ball-field": 12,
# "swimming-pool": 13,
# "container-crane": 14,
# "airport": 15,
# "helipad": 16
}
#? iterate over the files in both directories
def main():
for imageFile, textFile in zip(imagesFiles, textFiles):
#? check if the file extensions match
if imageFile.endswith(".png") and textFile.endswith(".txt"):
#? if the filenames match, process the files
if imageFile[:-4] == textFile[:-4]:
imagePath = os.path.join(imageDir, imageFile)
textPath = os.path.join(textDir, textFile)
img = cv2.imread(imagePath)
coordinatesList = []
with open(textPath, "r") as unreadText:
contents = unreadText.read()
contentsSplitLine = contents.splitlines()[2:]
for i in range(len(contentsSplitLine)):
splitLine = ' '.join(contentsSplitLine[i].rsplit(' ', 2)[:-2]).split()
coordinatesList.append(splitLine)
imageHeight, imageWidth, _ = img.shape
print(f"{imageWidth}x{imageHeight}")
for coordinates in coordinatesList:
coordinates = [eval(i) for i in coordinates]
coordsX = coordinates[::2] # get every other element starting from the first (x coordinates)
coordsY = coordinates[1::2] # get every other element starting from the second (y coordinates)
minX = min(coordsX)
maxX = max(coordsX)
minY = min(coordsY)
maxY = max(coordsY)
centerX = ((maxX + minX)/2) * (1/imageWidth)
centerY = ((maxY + minY)/2) * (1/imageHeight)
boundingWidth = (maxX - minX) * (1/imageWidth)
boundingHeight = (maxY - minY) * (1/imageHeight)
out = (f"0 {centerX} {centerY} {boundingWidth} {boundingHeight}\n")
finalFile = open(f"./outputData/{textFile[:-4]}.txt", "a")
finalFile.write(out)
finalFile.close()
else:
continue
else:
# If the file extensions do not match, skip this iteration
continue
if __name__ == "__main__":
main()
endTimer = timer()
print(f"Time to execute: {endTimer - startTimer}s")