两种图像灰度变换的手动实现方法(内附实现代码)

##两种图像灰度变换的手动实现方法(内附实现代码)
处理处理图像时直接调用相关函数外,自己手动实现也很重要噢!接下来介绍两种灰度转换的方法。
1、R,G,B 三通道像素值取均值来获得灰度图像。
2、NTSC方法 将 R,G,B 三通道采用不同加权系数来获得灰度图像。这种方法更符合人眼对颜色的感知。

实现结果图:
在这里插入图片描述

具体实现代码如下:
通过手动输入不同参数,选择不同的处理方式!

import cv2 as cv
import numpy as np

def rgb1gray(f,method):

    rows=img.shape[0]
    cols=img.shape[1]
    img_1=np.zeros((rows,cols),dtype=np.uint8)
    img_2=np.zeros((rows,cols),dtype=np.uint8)

    if method=='average':
        for i in range(rows):
            for j in range(cols):
                img_1[i][j] = int((int(img[i][j][0]) + int(img[i][j][1]) + int(img[i][j][2])) / 3)
        cv.imshow('average',img_1)

    elif method=='NTSC':
        for m in range(rows):
            for n in range(cols):
                img_2[m][n]=int((int(img[m][n][0])*0.2989+int(img[m][n][1])*0.5870+int(img[m][n][2])*0.1140))
        cv.imshow('NTSC', img_2)

    else:
        for m in range(rows):
            for n in range(cols):
                img_2[m][n]=int((int(img[m][n][0])*0.2989+int(img[m][n][1])*0.5870+int(img[m][n][2])*0.1140))
        cv.imshow('NTSC', img_2)
    print("结果图像已输出")


img=cv.imread("D://lena512color.tiff")
print("选择灰度图像转换方式'average'还是'NTSC:")
method=str(input())
if len(method.split(" "))==1:
    g=rgb1gray(img,method)
cv.waitKey(0)

如果觉得有用的话,记得点个赞,鼓励一下!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值