mirror of https://github.com/opencv/opencv.git
Open Source Computer Vision Library
https://opencv.org/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
74 lines
1.5 KiB
74 lines
1.5 KiB
#!/usr/bin/env python |
|
|
|
''' An example of Laplacian Pyramid construction and merging. |
|
|
|
Level : Intermediate |
|
|
|
Usage : python lappyr.py [<video source>] |
|
|
|
References: |
|
http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.54.299 |
|
|
|
Alexander Mordvintsev 6/10/12 |
|
''' |
|
|
|
import numpy as np |
|
import cv2 as cv |
|
|
|
import video |
|
from common import nothing, getsize |
|
|
|
def build_lappyr(img, leveln=6, dtype=np.int16): |
|
img = dtype(img) |
|
levels = [] |
|
for _i in range(leveln-1): |
|
next_img = cv.pyrDown(img) |
|
img1 = cv.pyrUp(next_img, dstsize=getsize(img)) |
|
levels.append(img-img1) |
|
img = next_img |
|
levels.append(img) |
|
return levels |
|
|
|
def merge_lappyr(levels): |
|
img = levels[-1] |
|
for lev_img in levels[-2::-1]: |
|
img = cv.pyrUp(img, dstsize=getsize(lev_img)) |
|
img += lev_img |
|
return np.uint8(np.clip(img, 0, 255)) |
|
|
|
|
|
def main(): |
|
import sys |
|
|
|
try: |
|
fn = sys.argv[1] |
|
except: |
|
fn = 0 |
|
cap = video.create_capture(fn) |
|
|
|
leveln = 6 |
|
cv.namedWindow('level control') |
|
for i in range(leveln): |
|
cv.createTrackbar('%d'%i, 'level control', 5, 50, nothing) |
|
|
|
while True: |
|
_ret, frame = cap.read() |
|
|
|
pyr = build_lappyr(frame, leveln) |
|
for i in range(leveln): |
|
v = int(cv.getTrackbarPos('%d'%i, 'level control') / 5) |
|
pyr[i] *= v |
|
res = merge_lappyr(pyr) |
|
|
|
cv.imshow('laplacian pyramid filter', res) |
|
|
|
if cv.waitKey(1) == 27: |
|
break |
|
|
|
print('Done') |
|
|
|
|
|
if __name__ == '__main__': |
|
print(__doc__) |
|
main() |
|
cv.destroyAllWindows()
|
|
|