-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathDifferenceOfVibrations(Graph).py
57 lines (49 loc) · 2.08 KB
/
DifferenceOfVibrations(Graph).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
import cv2
import numpy as np
import matplotlib.pyplot as plt
def generate_waveform(video_path_org):
video_path_mag = video_path_org[:-4] + 'Out.mp4'
graph_path_org = video_path_org[:-4] + '_time_waveform.png'
cap_org = cv2.VideoCapture(video_path_org)
time_waveform_org = []
frame_rate = 0
while cap_org.isOpened():
ret_org, frame_org = cap_org.read()
if not ret_org:
break
frame_rate = cap_org.get(cv2.CAP_PROP_FPS)
mean_value_org = np.mean(frame_org)
time_waveform_org.append(mean_value_org)
cap_org.release()
min_value_org = np.min(time_waveform_org)
max_value_org = np.max(time_waveform_org)
mid_value_org = (max_value_org + min_value_org) / 2
time_waveform_org_mid = np.subtract(time_waveform_org, mid_value_org)
cap_mag = cv2.VideoCapture(video_path_mag)
time_waveform_mag = []
while cap_mag.isOpened():
ret_mag, frame_mag = cap_mag.read()
if not ret_mag:
break
mean_value_mag = np.mean(frame_mag)
time_waveform_mag.append(mean_value_mag)
cap_mag.release()
min_value_mag = np.min(time_waveform_mag)
max_value_mag = np.max(time_waveform_mag)
mid_value_mag = (max_value_mag + min_value_mag) / 2
time_waveform_mag_mid = np.subtract(time_waveform_mag, mid_value_mag)
time_waveform_mag = np.array(time_waveform_mag)
vibration = np.subtract(time_waveform_mag, time_waveform_org)
vibration_mid = np.subtract(vibration, np.mean(vibration))
time_waveform_org = np.array(time_waveform_org)
time_axis = np.arange(len(time_waveform_org)) / frame_rate
plt.plot(time_axis, time_waveform_org_mid, 'r')
plt.plot(time_axis, time_waveform_mag_mid, 'b')
plt.plot(time_axis, vibration_mid, 'g')
plt.plot(time_axis, np.zeros_like(time_axis), 'black', alpha=0.5)
plt.xlabel('Time (seconds)')
plt.ylabel('Pixel Vibration')
plt.title('Time Waveform')
plt.legend(['Original', 'Magnified', 'Vibration'])
plt.savefig(graph_path_org, dpi=1600)
plt.show()