2017-02-10 2 views
2

Я хочу применить пользовательский цветной стол (LUT) на изображении.Применить openCV Look Up Table (LUT) к изображению

Я просмотрел openCVLUT Api, но я не могу понять, что это правильно.

#!/bin/bash 
# -*- coding: utf-8 -*- 

import os 
import numpy as np 
import cv2 

b_max = 230 
g_max = 220 
r_max = 250 

identity = np.arange(256, dtype = np.dtype('uint8')) 

b_channel = np.arange(b_max, dtype = np.dtype('uint8')) 
b_channel = np.append(b_channel, (256-b_max)*[b_max]) 
g_channel = np.arange(g_max, dtype = np.dtype('uint8')) 
g_channel = np.append(g_channel, (256-g_max)*[g_max]) 
r_channel = np.arange(r_max, dtype = np.dtype('uint8')) 
r_channel = np.append(r_channel, (256-r_max)*[r_max]) 

if 256 != b_channel.size or 256 != g_channel.size or 256 != r_channel.size: 
    print "size of arrays don't match!" 

lut = np.dstack((identity, identity, b_channel, g_channel, r_channel)) 

# Load the image 
img = cv2.imread('input.jpg',cv2.IMREAD_COLOR) 
dstImage = cv2.LUT(img, lut) 
cv2.imwrite('output.jpg', dstImage) 

Я получаю следующее сообщение об ошибке:

OpenCV Error: Assertion failed ((lutcn == cn || lutcn == 1) && _lut.total() == 256 && _lut.isContinuous() && (depth == CV_8U || depth == CV_8S)) in cv::LUT, file C:\build\master_winpack-bindings-win32-vc14-static\opencv\modules\core\src\convert.cpp, line 5690 
Traceback (most recent call last): 
    File "ApplyCLUT.py", line 33, in <module> 
    dstImage = cv2.LUT(img, lut) 
cv2.error: C:\build\master_winpack-bindings-win32-vc14-static\opencv\modules\core\src\convert.cpp:5690: error: (-215) (lutcn == cn || lutcn == 1) && _lut.total() == 256 && _lut.isContinuous() && (depth == CV_8U || depth == CV_8S) in function cv::LUT 

EDIT: изменение этой линии:

lut = np.dstack((b_channel, g_channel, r_channel)) 

и он будет работать!

+0

«lut is not numpy array» - может быть, это массив numpy? Как в 'np.array (....)' –

ответ

2

Ниже приведен пример построения LUT:

identity = np.arange(256, dtype = np.dtype('uint8')) 
zeros = np.zeros(256, np.dtype('uint8')) 
lut = np.dstack((identity, identity, zeros)) 

Note, есть намного проще и простой способ обнуления красный канал:

img[:,:,2] = 0 

Также вызов функции LUT должен выглядеть следующим образом:

dstImage = cv2.LUT(img, lut) 

Установите значения синего цвета, превышающие b_max, на b_max:

b_max = 20 
img[img[:,:,0] > b_max, 0] = b_max; 
+0

Спасибо за ответ, я хочу опустить максимальное значение каждого канала отдельно. Я сейчас обновил этот вопрос. – theAlse

+0

Работает ли это с моими предложениями? –

+0

Да, в вашем коде удаляются все красные цвета, но я хочу применить изменения ко всем 3-мя каналам напрямую. – theAlse

Смежные вопросы