Skip to content

A repository for lab work in CMSC 174 (Computer Vision) with OpenCV-Python.

License

Notifications You must be signed in to change notification settings

WhiteLicorice/Ren-s-Computer-Vision

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

85 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

😎 Ren's Computer Vision 😎

This is a repository for lab work in CMSC 174 (Computer Vision) with OpenCV-Python.

Lab 01

Create a Python script that replicates the process in this video using OpenCV-Python.

Figure 1.1: Playing Around With Perspective
Output

Lab 02

Create an image filtering function and use it to create hybrid images using a simplified version of the SIGGRAPH 2006 paper by Oliva, Torralba, and Schyns. Hybrid images are static images that change in interpretation as a function of the viewing distance. The basic idea is that high frequency tends to dominate perception when it is available, but, at a distance, only the low frequency (smooth) part of the signal can be seen. By blending the high frequency portion of one image with the low-frequency portion of another, you get a hybrid image that leads to different interpretations at different distances. Use your own solution to create your own hybrid images. The provided file hybrid.py contains functions that you need to implement.

For just this laboratory exercise, you are forbidden from using any Numpy, Scipy, OpenCV, or other preimplemented functions for filtering. You are allowed to use basic matrix operations like np.shape, np.zeros, and np.transpose. This limitation will be lifted in future laboratory exercises , but for now, you should use for loops or Numpy vectorization to apply a kernel to each pixel in the image. The bulk of your code will be in cross_correlation, and gaussian_blur with the other functions using these functions either directly or through one of the other functions you implement.

Your pair of images needs to be aligned using an image manipulation software, e.g., Photoshop, Gimp. Alignments can map the eyes to eyes and nose to nose, edges to edges, etc. It is encouraged to create additional examples (e.g. change of expression, morph between different objects, change over time, etc.). See the hybrid images project page for some inspiration. The project page also contains materials from their Siggraph presentation.

Figure 2.1: Hondarrari Construction
Honda Ferrari Hondarrari

Lab 03

The goal of this laboratory exercise is to blend two images seamlessly using a multi resolution blending as described in the 1983 paper by Burt and Adelson. An image spline is a smooth seam joining two image together by gently distorting them. Multiresolution blending computes a gentle seam between the two images seperately at each band of image frequencies, resulting in a much smoother seam. You are to create and visualize the Gaussian and Laplacian stacks of the input images, blending together images with the help of the completed stacks, and explore creative outcomes. If you would rather work with pyramids, you may implement pyramids rather than stacks. However, in any case, you are not allowed to use existing pyramid (pyrDown, pyrUp) functions. You must implement your stacks/pyramids from scratch.

The results are as follows.

Figure 3.1: Blending an Apple and an Orange with a Vertical Mask (Orapple)
apple orange
mask blended apple orange
Figure 3.2: Blending Two Chessboards with an Irregular Mask (Not Your Typical Endgame)
pawn bishop
crazymask crazy

Lab 04

The goal of this laboratory exercise is to estimate the amount of liquid contained in a bottle. Given images of a bottle with unknown amounts of liquid, you are to devise a method for guessing these amounts. OpenCV image filtering, thresholding, or morphology operations are allowed.

Known Amounts
Amount Bottle
50ml 50ml
100ml 100ml
150ml 150ml
200ml 200ml
250ml 250ml
300ml 300ml
350ml 350ml
Predicted Amounts
Amount Bottle
122ml 122ml
207ml 207ml
345ml 345ml

Lab 05

With this article as basis, stitch the provided images of a spread from a book. Once you have devised a method for stitching images, acquire a video and generate an actionshot image. Actionshot is a method of capturing an object in action and displaying it in a single image with multiple sequential appearances of the object. SAFETY FIRST. Be sure you know what you are doing should you choose to record your own video.

Figure 5.1: An Odd Book Spread
stitched_image
Figure 5.2: Spike Action Shot
action_shot