一、实验目的
利用python 语言编程实现缩小放大,对比两种方法得到放大图像的差异,进一步理解计算机视觉中图像缩小及放大的各种方法及其原理。同时培养学生的编程能力。
二、实验硬、软件环境
电脑、windows系统,Visual Studio Code编辑器,opencv视觉库,numpy库, matplolib库。
三、实验内容及步骤
(一)实验内容
使用python编程,实现图片的缩小与放大。
(二)实验过程
1.读取图像
主要代码如下:
import cv2
import numpy as np
import matplotlib.pyplot as plt
img=cv2.imread('be.jpg')
cv2.imshow('photo1',img)
图1原始图像
2.编程实现图像的缩小
主要代码如下:
img2=img.shape
height=img2[0]
weight=img2[1]
mode=img2[2]
ReduceHeight = int(height*0.25)
ReduceWidth = int(weight*0.25)
lessen = cv2.resize(img,(ReduceWidth,ReduceHeight))
cv2.imshow('photo2',lessen)
cv2.imwrite(r"D:\Desktop\Three\python\phoyto2.jpg",lessen)
图2 缩小后的图像
3.最近邻插值法恢复图像大小
主要代码如下:
NEAREST=cv2.resize(lessen,dsize=None,fx=4,fy=4,interpolation=cv2.INTER_NEAREST)
cv2.imshow('photo3',NEAREST)
cv2.imwrite(r"D:\Desktop\Three\python\photo3.jpg",NEAREST)
图3最近邻插值放大后的图像
4.双线性插值恢复图像大小
主要代码如下:
DoubleLINEAR = cv2.resize(lessen, (weight, height), interpolation = cv2.INTER_LINEAR)
cv2.imshow('photo4',DoubleLINEAR)
cv2.imwrite(r"D:\Desktop\Three\python\photo4.jpg",DoubleLINEAR)
cv2.waitKey(0)
图4双线性插值放大后的图像
5.记录过程图片
图5文件夹图片