forked from udacity/CarND-Advanced-Lane-Lines
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathundistort_image.py
39 lines (25 loc) · 955 Bytes
/
undistort_image.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
import glob
import pickle
import cv2
import util
RESULT_PATH = '../data/camera_calibration.p'
camera_matrix = None
distortion_coefficients = None
def get_calibration():
if camera_matrix is None or distortion_coefficients is None:
with open(RESULT_PATH, 'rb') as file:
return pickle.load(file)
return camera_matrix, distortion_coefficients
def undistort(image):
camera_matrix, distortion_coefficients = get_calibration()
return cv2.undistort(image, camera_matrix, distortion_coefficients)
if __name__ == '__main__':
test_images = glob.glob('../test_images/*.jpg')
output_images = []
for test_image in test_images:
image = cv2.imread(test_image)
undistorted = undistort(image)
output_images.append(image)
output_images.append(undistorted)
collage = util.collage(output_images, len(test_images), 2)
cv2.imwrite('../output_images/undistorted.png', collage)