Я застрял с проблемой оболочки Python для OpenCv.
У меня есть эта функция, которая возвращает 1, если количество черных пикселей больше, чем порог
def checkBlackPixels( img, threshold ):
width = img.width
height = img.height
nchannels = img.nChannels
step = img.widthStep
dimtot = width * height
data = img.imageData
black = 0
for i in range( 0, height ):
for j in range( 0, width ):
r = data[i*step + j*nchannels + 0]
g = data[i*step + j*nchannels + 1]
b = data[i*step + j*nchannels + 2]
if r == 0 and g == 0 and b == 0:
black = black + 1
if black >= threshold * dimtot:
return 1
else:
return 0
Цикл (сканирует каждый пиксель данного изображения) работает хорошо, когда входной сигнал является RGB
изображение ... но если вход является одноканальным изображением, я получаю эту ошибку:
for j in range( width ):
TypeError: Nested sequences should have 2 or 3 dimensions
Входное одноканальное изображение (в следующем примере называемое «rg») берется из
RGB-изображение с именем 'src', обработанное с помощью cvSplit, а затем cvAbsDiff
cvSplit( src, r, g, b, 'NULL' )
rg = cvCreateImage( cvGetSize(src), src.depth, 1 ) # R - G
cvAbsDiff( r, g, rg )
Я также уже заметил, что проблема связана с различием изображения, полученного из cvSplit ...
Кто-нибудь может мне помочь?
Спасибо