数字图像处理之图像基础

最近在学数字图像处理,图像基础包括以下部分:
在这里插入图片描述
导入库

import numpy as np
import matplotlib.pyplot as plt
import cv2 as cv

图片展示函数

def show(img):
    if img.ndim == 2:
        plt.imshow(img,cmap='gray')
    else:
        plt.imshow(cv.cvtColor(img,cv.COLOR_RGB2BGR))
    plt.show()

图像的矩阵表示

A = np.random.randint(0,256,(2,4),dtype=np.uint8)
print(A)
show(A)
B = np.random.randint(0,256,(2,4,3),dtype=np.uint8)
print(B)
show(B)

结果如下图所示:
A
在这里插入图片描述

通道合并与分离

img = cv.imread('C:\PerfLogs\pc.jpg')
b,g,r = cv.split(img)#分离
show(b)
show(g)
show(r)
img_new = cv.merge([b,g,r])#合并通道

分离后的三通道显示出来的图像
在这里插入图片描述
合并后的图片为:
在这里插入图片描述

彩色图转灰度图

gray1 = 0.299*b + 0.587*g + 0.114*r
#opencv自己提供的函数实现彩色图转灰度图
img_gray = cv.cvtColor(img,cv.COLOR_BGR2GRAY)
show(np.hstack([gray1,img_gray])

在这里插入图片描述

图像的二值化

thresh = 125
gray2[gray2>thresh] = 255
gray2[gray2<=thresh] = 0
#opencv自带的函数
ignore,img_bin = cv.threshold(gray2,125,200,cv.THRESH_BINARY)

在这里插入图片描述

两图像的加减乘除

#图片的加载+调整图片大小
obj = cv.imread('C:\PerfLogs\pc.jpg',0)
obj = cv.resize(obj,(550,550),)#调整图片大小
bg = cv.imread('C:\PerfLogs\pc1.jpg',0)
bg = cv.resize(bg,(550,550),)
mask = cv.imread('C:\PerfLogs\pc2.jpg',0)
mask = cv.resize(mask,(550,550),)
noise = cv.imread('C:\PerfLogs\pc3.jpg',0)
noise = cv.resize(noise,(550,550),)

图像根据一定比例相加

img_add1 = cv.add(noise*0.5,bg*0.5)
img_add2 = cv.addWeighted(noise,0.5,bg,0.5,0)#opencv自带的函数
show(np.hstack([img_add1,img_add2]))

在这里插入图片描述
两图像相减

img_sub = img_add2 - noise*0.5
show(np.hstack([bg,img_sub*2]))

在这里插入图片描述
两图像相乘

mask = mask/255.#归一化
img_mul = obj*mask
img_mul2 = cv.multiply(obj*1.0,mask)
show(np.hstack([img_mul,img_mul2]))

在这里插入图片描述
两图像相除

img_div = obj/(np.float64(noise)+1)
img_div2 = cv.divide(obj,noise+1)
show(np.hstack([img_div,img_div2]))

(不知道弄了啥)
在这里插入图片描述

图像的线性和非线性变换

在这里插入图片描述
图像的线性变换

#线性变换
img = cv.imread('C:\PerfLogs\pc.jpg',0)
b = 20
k=2
img2 = b+k*img.astype(np.int32)
show(np.hstack([img,img2]))

在这里插入图片描述
图像的非线性变换

img01 = img/255
img05 = np.power(img01,0.5) * 255
img15 = np.power(img01,1.5) * 255
show(np.hstack([img05 , img , img15]))

在这里插入图片描述
由三张图片对比可得,幂次越小,图片越亮,幂次越大,图片越暗。符合如下的图像。
在这里插入图片描述

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

starlet_kiss

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值