bug in copy fallback

for bandmean, rank and bool on one band images.
This commit is contained in:
John Cupitt 2014-12-16 14:14:32 +00:00
parent 9b3351f73a
commit d62bec6ecc
5 changed files with 40 additions and 28 deletions

View File

@ -82,13 +82,14 @@ vips_bandbool_build( VipsObject *object )
if( vips_check_noncomplex( class->nickname, bandbool->in ) ) if( vips_check_noncomplex( class->nickname, bandbool->in ) )
return( -1 ); return( -1 );
bandary->n = 1;
bandary->in = &bandbool->in;
if( bandbool->in->Bands == 1 ) if( bandbool->in->Bands == 1 )
return( vips_bandary_copy( bandary ) ); return( vips_bandary_copy( bandary ) );
} }
bandary->out_bands = 1; bandary->out_bands = 1;
bandary->n = 1;
bandary->in = &bandbool->in;
if( VIPS_OBJECT_CLASS( vips_bandbool_parent_class )-> if( VIPS_OBJECT_CLASS( vips_bandbool_parent_class )->
build( object ) ) build( object ) )

View File

@ -163,13 +163,14 @@ vips_bandmean_build( VipsObject *object )
VipsBandary *bandary = (VipsBandary *) object; VipsBandary *bandary = (VipsBandary *) object;
VipsBandmean *bandmean = (VipsBandmean *) object; VipsBandmean *bandmean = (VipsBandmean *) object;
bandary->n = 1;
bandary->in = &bandmean->in;
if( bandmean->in && if( bandmean->in &&
bandmean->in->Bands == 1 ) bandmean->in->Bands == 1 )
return( vips_bandary_copy( bandary ) ); return( vips_bandary_copy( bandary ) );
bandary->out_bands = 1; bandary->out_bands = 1;
bandary->n = 1;
bandary->in = &bandmean->in;
if( VIPS_OBJECT_CLASS( vips_bandmean_parent_class )->build( object ) ) if( VIPS_OBJECT_CLASS( vips_bandmean_parent_class )->build( object ) )
return( -1 ); return( -1 );

View File

@ -189,8 +189,12 @@ vips_bandrank_build( VipsObject *object )
if( vips_check_noncomplex( class->nickname, in[i] ) ) if( vips_check_noncomplex( class->nickname, in[i] ) )
return( -1 ); return( -1 );
if( n == 1 ) if( n == 1 ) {
bandary->in = in;
bandary->n = 1;
return( vips_bandary_copy( bandary ) ); return( vips_bandary_copy( bandary ) );
}
/* We need to keep one band element for every input image /* We need to keep one band element for every input image
* on the stack. * on the stack.

View File

@ -147,7 +147,7 @@ class TestConversion(unittest.TestCase):
else: else:
return [reduce(lambda a, b: int(a) & int(b), x)] return [reduce(lambda a, b: int(a) & int(b), x)]
self.run_unary([self.colour], band_and, fmt = int_formats) self.run_unary(self.all_images, band_and, fmt = int_formats)
def test_band_or(self): def test_band_or(self):
def band_or(x): def band_or(x):
@ -156,7 +156,7 @@ class TestConversion(unittest.TestCase):
else: else:
return [reduce(lambda a, b: int(a) | int(b), x)] return [reduce(lambda a, b: int(a) | int(b), x)]
self.run_unary([self.colour], band_or, fmt = int_formats) self.run_unary(self.all_images, band_or, fmt = int_formats)
def test_band_eor(self): def test_band_eor(self):
def band_eor(x): def band_eor(x):
@ -165,7 +165,7 @@ class TestConversion(unittest.TestCase):
else: else:
return [reduce(lambda a, b: int(a) ^ int(b), x)] return [reduce(lambda a, b: int(a) ^ int(b), x)]
self.run_unary([self.colour], band_eor, fmt = int_formats) self.run_unary(self.all_images, band_eor, fmt = int_formats)
def test_bandjoin(self): def test_bandjoin(self):
def bandjoin(x, y): def bandjoin(x, y):
@ -183,7 +183,7 @@ class TestConversion(unittest.TestCase):
else: else:
return [sum(x) // len(x)] return [sum(x) // len(x)]
self.run_unary([self.colour], bandmean, fmt = noncomplex_formats) self.run_unary(self.all_images, bandmean, fmt = noncomplex_formats)
def test_bandrank(self): def test_bandrank(self):
def median(x, y): def median(x, y):

View File

@ -4,6 +4,7 @@ from __future__ import division
from builtins import zip from builtins import zip
from builtins import range from builtins import range
from numbers import Number from numbers import Number
from functools import reduce
import unittest import unittest
import operator import operator
@ -60,7 +61,7 @@ def conv(image, mask, x_position, y_position):
p = run_fn2(operator.mul, m, i) p = run_fn2(operator.mul, m, i)
s = run_fn2(operator.add, s, p) s = run_fn2(operator.add, s, p)
return run_fn2(operator.div, s, mask.get_scale()) return run_fn2(operator.truediv, s, mask.get_scale())
def compass(image, mask, x_position, y_position, n_rot, fn): def compass(image, mask, x_position, y_position, n_rot, fn):
acc = [] acc = []
@ -112,28 +113,33 @@ class TestConvolution(unittest.TestCase):
true = conv(im, msk, 49, 49) true = conv(im, msk, 49, 49)
self.assertAlmostEqualObjects(result, true) self.assertAlmostEqualObjects(result, true)
def test_x(self):
im = self.mono
msk = self.sobel
result = conv(im, msk, 24, 49)
msk = msk.rot45()
result = conv(im, msk, 24, 49)
msk = msk.rot45()
def test_compass(self): def test_compass(self):
for im in self.all_images: for im in self.all_images:
for msk in self.all_masks: for msk in self.all_masks:
for prec in [Vips.Precision.INTEGER, Vips.Precision.FLOAT]: for prec in [Vips.Precision.INTEGER, Vips.Precision.FLOAT]:
for times in range(1, 4):
convolved = im.compass(msk, convolved = im.compass(msk,
times = 3, times = times,
angle = Vips.Angle45.D45, angle = Vips.Angle45.D45,
combine = Vips.Combine.MAX, combine = Vips.Combine.MAX,
precision = prec) precision = prec)
result = convolved.getpoint(25, 50) result = convolved.getpoint(25, 50)
true = compass(im, msk, 24, 49, 3, max) true = compass(im, msk, 24, 49, times, max)
self.assertAlmostEqualObjects(result, true)
for im in self.all_images:
for msk in self.all_masks:
for prec in [Vips.Precision.INTEGER, Vips.Precision.FLOAT]:
for times in range(1, 4):
convolved = im.compass(msk,
times = times,
angle = Vips.Angle45.D45,
combine = Vips.Combine.SUM,
precision = prec)
result = convolved.getpoint(25, 50)
true = compass(im, msk, 24, 49, times, operator.add)
self.assertAlmostEqualObjects(result, true) self.assertAlmostEqualObjects(result, true)
if __name__ == '__main__': if __name__ == '__main__':