add () overload to python
for vips_getpoint()
This commit is contained in:
parent
ded01df512
commit
5ccb5ad70d
14
TODO
14
TODO
@ -3,20 +3,6 @@
|
|||||||
|
|
||||||
python people are not going to want to use the glib arg parser, for example
|
python people are not going to want to use the glib arg parser, for example
|
||||||
|
|
||||||
- need to add [] overload to Ruby bindings
|
|
||||||
|
|
||||||
- overload (x, y) to be getpoint()? py/rb
|
|
||||||
|
|
||||||
c++ has:
|
|
||||||
|
|
||||||
std::vector<double> operator()( int x, int y )
|
|
||||||
{
|
|
||||||
return( this->getpoint( x, y ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -349,7 +349,8 @@ result_image = ((image * [1, 2, 3]).abs() < 128) | 4
|
|||||||
</para>
|
</para>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
The wrapper overloads <code>[]</code> to be band indexing. You can write:
|
The wrapper overloads <code>[]</code> to be vips_extract_band(). You
|
||||||
|
can write:
|
||||||
|
|
||||||
<programlisting language="Python">
|
<programlisting language="Python">
|
||||||
result_image = image[2]
|
result_image = image[2]
|
||||||
@ -367,6 +368,19 @@ result_image = [x.avg() for x in image]
|
|||||||
|
|
||||||
and so on.
|
and so on.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
The wrapper overloads <code>()</code> to be vips_getpoint(). You can
|
||||||
|
write:
|
||||||
|
|
||||||
|
<programlisting language="Python">
|
||||||
|
r, g, b = image(10, 10)
|
||||||
|
</programlisting>
|
||||||
|
|
||||||
|
to read out the value of the pixel at coordinates (10, 10) from an RGB
|
||||||
|
image.
|
||||||
|
</para>
|
||||||
|
|
||||||
</refsect3>
|
</refsect3>
|
||||||
|
|
||||||
<refsect3 id="python-expansions">
|
<refsect3 id="python-expansions">
|
||||||
|
@ -783,6 +783,9 @@ class Image(Vips.Image):
|
|||||||
|
|
||||||
return self.extract_band(i, n = n)
|
return self.extract_band(i, n = n)
|
||||||
|
|
||||||
|
def __call__(self, x, y):
|
||||||
|
return self.getpoint(x, y)
|
||||||
|
|
||||||
# the cast operators int(), long() and float() must return numeric types,
|
# the cast operators int(), long() and float() must return numeric types,
|
||||||
# so we can't define them for images
|
# so we can't define them for images
|
||||||
|
|
||||||
|
@ -66,10 +66,10 @@ class TestArithmetic(unittest.TestCase):
|
|||||||
# run a function on an image and on a single pixel, the results
|
# run a function on an image and on a single pixel, the results
|
||||||
# should match
|
# should match
|
||||||
def run_cmp(self, message, im, x, y, fn):
|
def run_cmp(self, message, im, x, y, fn):
|
||||||
a = im.getpoint(x, y)
|
a = im(x, y)
|
||||||
v1 = fn(a)
|
v1 = fn(a)
|
||||||
im2 = fn(im)
|
im2 = fn(im)
|
||||||
v2 = im2.getpoint(x, y)
|
v2 = im2(x, y)
|
||||||
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
||||||
|
|
||||||
# run a function on (image, constant), and on (constant, image).
|
# run a function on (image, constant), and on (constant, image).
|
||||||
@ -90,11 +90,11 @@ class TestArithmetic(unittest.TestCase):
|
|||||||
# run a function on a pair of images and on a pair of pixels, the results
|
# run a function on a pair of images and on a pair of pixels, the results
|
||||||
# should match
|
# should match
|
||||||
def run_cmp2(self, message, left, right, x, y, fn):
|
def run_cmp2(self, message, left, right, x, y, fn):
|
||||||
a = left.getpoint(x, y)
|
a = left(x, y)
|
||||||
b = right.getpoint(x, y)
|
b = right(x, y)
|
||||||
v1 = fn(a, b)
|
v1 = fn(a, b)
|
||||||
after = fn(left, right)
|
after = fn(left, right)
|
||||||
v2 = after.getpoint(x, y)
|
v2 = after(x, y)
|
||||||
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
||||||
|
|
||||||
# run a function on a pair of images
|
# run a function on a pair of images
|
||||||
@ -392,22 +392,22 @@ class TestArithmetic(unittest.TestCase):
|
|||||||
|
|
||||||
for fmt in all_formats:
|
for fmt in all_formats:
|
||||||
hist = test.cast(fmt).hist_find()
|
hist = test.cast(fmt).hist_find()
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(0,0), [5000])
|
self.assertAlmostEqualObjects(hist(0,0), [5000])
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(10,0), [5000])
|
self.assertAlmostEqualObjects(hist(10,0), [5000])
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(5,0), [0])
|
self.assertAlmostEqualObjects(hist(5,0), [0])
|
||||||
|
|
||||||
test = test * [1, 2, 3]
|
test = test * [1, 2, 3]
|
||||||
|
|
||||||
for fmt in all_formats:
|
for fmt in all_formats:
|
||||||
hist = test.cast(fmt).hist_find(band = 0)
|
hist = test.cast(fmt).hist_find(band = 0)
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(0,0), [5000])
|
self.assertAlmostEqualObjects(hist(0,0), [5000])
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(10,0), [5000])
|
self.assertAlmostEqualObjects(hist(10,0), [5000])
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(5,0), [0])
|
self.assertAlmostEqualObjects(hist(5,0), [0])
|
||||||
|
|
||||||
hist = test.cast(fmt).hist_find(band = 1)
|
hist = test.cast(fmt).hist_find(band = 1)
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(0,0), [5000])
|
self.assertAlmostEqualObjects(hist(0,0), [5000])
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(20,0), [5000])
|
self.assertAlmostEqualObjects(hist(20,0), [5000])
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(5,0), [0])
|
self.assertAlmostEqualObjects(hist(5,0), [0])
|
||||||
|
|
||||||
def test_histfind_indexed(self):
|
def test_histfind_indexed(self):
|
||||||
im = Vips.Image.black(50, 100)
|
im = Vips.Image.black(50, 100)
|
||||||
@ -420,8 +420,8 @@ class TestArithmetic(unittest.TestCase):
|
|||||||
b = index.cast(y)
|
b = index.cast(y)
|
||||||
hist = a.hist_find_indexed(b)
|
hist = a.hist_find_indexed(b)
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(0,0), [0])
|
self.assertAlmostEqualObjects(hist(0,0), [0])
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(1,0), [50000])
|
self.assertAlmostEqualObjects(hist(1,0), [50000])
|
||||||
|
|
||||||
def test_histfind_ndim(self):
|
def test_histfind_ndim(self):
|
||||||
im = Vips.Image.black(100, 100) + [1, 2, 3]
|
im = Vips.Image.black(100, 100) + [1, 2, 3]
|
||||||
@ -429,12 +429,12 @@ class TestArithmetic(unittest.TestCase):
|
|||||||
for fmt in noncomplex_formats:
|
for fmt in noncomplex_formats:
|
||||||
hist = im.cast(fmt).hist_find_ndim()
|
hist = im.cast(fmt).hist_find_ndim()
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(0,0)[0], 10000)
|
self.assertAlmostEqualObjects(hist(0,0)[0], 10000)
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(5,5)[5], 0)
|
self.assertAlmostEqualObjects(hist(5,5)[5], 0)
|
||||||
|
|
||||||
hist = im.cast(fmt).hist_find_ndim(bins = 1)
|
hist = im.cast(fmt).hist_find_ndim(bins = 1)
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(hist.getpoint(0,0)[0], 10000)
|
self.assertAlmostEqualObjects(hist(0,0)[0], 10000)
|
||||||
self.assertEqual(hist.width, 1)
|
self.assertEqual(hist.width, 1)
|
||||||
self.assertEqual(hist.height, 1)
|
self.assertEqual(hist.height, 1)
|
||||||
self.assertEqual(hist.bands, 1)
|
self.assertEqual(hist.bands, 1)
|
||||||
@ -447,7 +447,7 @@ class TestArithmetic(unittest.TestCase):
|
|||||||
hough = im.hough_circle(min_radius = 35, max_radius = 45)
|
hough = im.hough_circle(min_radius = 35, max_radius = 45)
|
||||||
|
|
||||||
v, x, y = hough.maxpos()
|
v, x, y = hough.maxpos()
|
||||||
vec = hough.getpoint(x, y)
|
vec = hough(x, y)
|
||||||
r = vec.index(v) + 35
|
r = vec.index(v) + 35
|
||||||
|
|
||||||
self.assertAlmostEqual(x, 50)
|
self.assertAlmostEqual(x, 50)
|
||||||
@ -634,8 +634,8 @@ class TestArithmetic(unittest.TestCase):
|
|||||||
for x in noncomplex_formats:
|
for x in noncomplex_formats:
|
||||||
a = test.cast(x)
|
a = test.cast(x)
|
||||||
matrix = a.measure(2, 1)
|
matrix = a.measure(2, 1)
|
||||||
[p1] = matrix.getpoint(0, 0)
|
[p1] = matrix(0, 0)
|
||||||
[p2] = matrix.getpoint(0, 1)
|
[p2] = matrix(0, 1)
|
||||||
|
|
||||||
self.assertAlmostEqual(p1, 0)
|
self.assertAlmostEqual(p1, 0)
|
||||||
self.assertAlmostEqual(p2, 10)
|
self.assertAlmostEqual(p2, 10)
|
||||||
@ -663,10 +663,10 @@ class TestArithmetic(unittest.TestCase):
|
|||||||
for fmt in noncomplex_formats:
|
for fmt in noncomplex_formats:
|
||||||
columns, rows = test.cast(fmt).project()
|
columns, rows = test.cast(fmt).project()
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(columns.getpoint(10,0), [0])
|
self.assertAlmostEqualObjects(columns(10,0), [0])
|
||||||
self.assertAlmostEqualObjects(columns.getpoint(70,0), [50 * 10])
|
self.assertAlmostEqualObjects(columns(70,0), [50 * 10])
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(rows.getpoint(0,10), [50 * 10])
|
self.assertAlmostEqualObjects(rows(0,10), [50 * 10])
|
||||||
|
|
||||||
def test_stats(self):
|
def test_stats(self):
|
||||||
im = Vips.Image.black(50, 50)
|
im = Vips.Image.black(50, 50)
|
||||||
@ -676,19 +676,19 @@ class TestArithmetic(unittest.TestCase):
|
|||||||
a = test.cast(x)
|
a = test.cast(x)
|
||||||
matrix = a.stats()
|
matrix = a.stats()
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(0, 0), [a.min()])
|
self.assertAlmostEqualObjects(matrix(0, 0), [a.min()])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(1, 0), [a.max()])
|
self.assertAlmostEqualObjects(matrix(1, 0), [a.max()])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(2, 0), [50 * 50 * 10])
|
self.assertAlmostEqualObjects(matrix(2, 0), [50 * 50 * 10])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(3, 0), [50 * 50 * 100])
|
self.assertAlmostEqualObjects(matrix(3, 0), [50 * 50 * 100])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(4, 0), [a.avg()])
|
self.assertAlmostEqualObjects(matrix(4, 0), [a.avg()])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(5, 0), [a.deviate()])
|
self.assertAlmostEqualObjects(matrix(5, 0), [a.deviate()])
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(0, 1), [a.min()])
|
self.assertAlmostEqualObjects(matrix(0, 1), [a.min()])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(1, 1), [a.max()])
|
self.assertAlmostEqualObjects(matrix(1, 1), [a.max()])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(2, 1), [50 * 50 * 10])
|
self.assertAlmostEqualObjects(matrix(2, 1), [50 * 50 * 10])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(3, 1), [50 * 50 * 100])
|
self.assertAlmostEqualObjects(matrix(3, 1), [50 * 50 * 100])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(4, 1), [a.avg()])
|
self.assertAlmostEqualObjects(matrix(4, 1), [a.avg()])
|
||||||
self.assertAlmostEqualObjects(matrix.getpoint(5, 1), [a.deviate()])
|
self.assertAlmostEqualObjects(matrix(5, 1), [a.deviate()])
|
||||||
|
|
||||||
def test_sum(self):
|
def test_sum(self):
|
||||||
for fmt in all_formats:
|
for fmt in all_formats:
|
||||||
|
@ -79,20 +79,20 @@ class TestColour(unittest.TestCase):
|
|||||||
# run a function on an image and on a single pixel, the results
|
# run a function on an image and on a single pixel, the results
|
||||||
# should match
|
# should match
|
||||||
def run_cmp(self, message, im, x, y, fn):
|
def run_cmp(self, message, im, x, y, fn):
|
||||||
a = im.getpoint(x, y)
|
a = im(x, y)
|
||||||
v1 = fn(a)
|
v1 = fn(a)
|
||||||
im2 = fn(im)
|
im2 = fn(im)
|
||||||
v2 = im2.getpoint(x, y)
|
v2 = im2(x, y)
|
||||||
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
||||||
|
|
||||||
# run a function on a pair of images and on a pair of pixels, the results
|
# run a function on a pair of images and on a pair of pixels, the results
|
||||||
# should match
|
# should match
|
||||||
def run_cmp2(self, message, left, right, x, y, fn):
|
def run_cmp2(self, message, left, right, x, y, fn):
|
||||||
a = left.getpoint(x, y)
|
a = left(x, y)
|
||||||
b = right.getpoint(x, y)
|
b = right(x, y)
|
||||||
v1 = fn(a, b)
|
v1 = fn(a, b)
|
||||||
after = fn(left, right)
|
after = fn(left, right)
|
||||||
v2 = after.getpoint(x, y)
|
v2 = after(x, y)
|
||||||
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
||||||
|
|
||||||
# run a function on a pair of images
|
# run a function on a pair of images
|
||||||
@ -126,7 +126,7 @@ class TestColour(unittest.TestCase):
|
|||||||
h = im.extract_band(i).max()
|
h = im.extract_band(i).max()
|
||||||
self.assertAlmostEqual(l, h)
|
self.assertAlmostEqual(l, h)
|
||||||
|
|
||||||
pixel = im.getpoint(10, 10)
|
pixel = im(10, 10)
|
||||||
self.assertAlmostEqual(pixel[3], 42, places = 2)
|
self.assertAlmostEqual(pixel[3], 42, places = 2)
|
||||||
|
|
||||||
# alpha won't be equal for RGB16, but it should be preserved if we go
|
# alpha won't be equal for RGB16, but it should be preserved if we go
|
||||||
@ -134,8 +134,8 @@ class TestColour(unittest.TestCase):
|
|||||||
im = im.colourspace(Vips.Interpretation.RGB16)
|
im = im.colourspace(Vips.Interpretation.RGB16)
|
||||||
im = im.colourspace(Vips.Interpretation.LAB)
|
im = im.colourspace(Vips.Interpretation.LAB)
|
||||||
|
|
||||||
before = test.getpoint(10, 10)
|
before = test(10, 10)
|
||||||
after = im.getpoint(10, 10)
|
after = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(before, after, places = 1)
|
self.assertAlmostEqualObjects(before, after, places = 1)
|
||||||
|
|
||||||
# go between every pair of colour spaces
|
# go between every pair of colour spaces
|
||||||
@ -145,15 +145,15 @@ class TestColour(unittest.TestCase):
|
|||||||
im2 = im.colourspace(end)
|
im2 = im.colourspace(end)
|
||||||
im3 = im2.colourspace(Vips.Interpretation.LAB)
|
im3 = im2.colourspace(Vips.Interpretation.LAB)
|
||||||
|
|
||||||
before = test.getpoint(10, 10)
|
before = test(10, 10)
|
||||||
after = im3.getpoint(10, 10)
|
after = im3(10, 10)
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(before, after, places = 1)
|
self.assertAlmostEqualObjects(before, after, places = 1)
|
||||||
|
|
||||||
# test Lab->XYZ on mid-grey
|
# test Lab->XYZ on mid-grey
|
||||||
# checked against http://www.brucelindbloom.com
|
# checked against http://www.brucelindbloom.com
|
||||||
im = test.colourspace(Vips.Interpretation.XYZ)
|
im = test.colourspace(Vips.Interpretation.XYZ)
|
||||||
after = im.getpoint(10, 10)
|
after = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(after, [17.5064, 18.4187, 20.0547, 42])
|
self.assertAlmostEqualObjects(after, [17.5064, 18.4187, 20.0547, 42])
|
||||||
|
|
||||||
# grey->colour->grey should be equal
|
# grey->colour->grey should be equal
|
||||||
@ -163,8 +163,8 @@ class TestColour(unittest.TestCase):
|
|||||||
for col in colour_colourspaces + [mono_fmt]:
|
for col in colour_colourspaces + [mono_fmt]:
|
||||||
im = im.colourspace(col)
|
im = im.colourspace(col)
|
||||||
self.assertEqual(im.interpretation, col)
|
self.assertEqual(im.interpretation, col)
|
||||||
[before, alpha_before] = test_grey.getpoint(10, 10)
|
[before, alpha_before] = test_grey(10, 10)
|
||||||
[after, alpha_after] = im.getpoint(10, 10)
|
[after, alpha_after] = im(10, 10)
|
||||||
self.assertLess(abs(alpha_after - alpha_before), 1)
|
self.assertLess(abs(alpha_after - alpha_before), 1)
|
||||||
if mono_fmt == Vips.Interpretation.GREY16:
|
if mono_fmt == Vips.Interpretation.GREY16:
|
||||||
# GREY16 can wind up rather different due to rounding
|
# GREY16 can wind up rather different due to rounding
|
||||||
@ -184,7 +184,7 @@ class TestColour(unittest.TestCase):
|
|||||||
sample = sample.copy(interpretation = Vips.Interpretation.LAB)
|
sample = sample.copy(interpretation = Vips.Interpretation.LAB)
|
||||||
|
|
||||||
difference = reference.dE00(sample)
|
difference = reference.dE00(sample)
|
||||||
result, alpha = difference.getpoint(10, 10)
|
result, alpha = difference(10, 10)
|
||||||
self.assertAlmostEqual(result, 30.238, places = 3)
|
self.assertAlmostEqual(result, 30.238, places = 3)
|
||||||
self.assertAlmostEqual(alpha, 42.0, places = 3)
|
self.assertAlmostEqual(alpha, 42.0, places = 3)
|
||||||
|
|
||||||
@ -196,7 +196,7 @@ class TestColour(unittest.TestCase):
|
|||||||
sample = sample.copy(interpretation = Vips.Interpretation.LAB)
|
sample = sample.copy(interpretation = Vips.Interpretation.LAB)
|
||||||
|
|
||||||
difference = reference.dE76(sample)
|
difference = reference.dE76(sample)
|
||||||
result, alpha = difference.getpoint(10, 10)
|
result, alpha = difference(10, 10)
|
||||||
self.assertAlmostEqual(result, 33.166, places = 3)
|
self.assertAlmostEqual(result, 33.166, places = 3)
|
||||||
self.assertAlmostEqual(alpha, 42.0, places = 3)
|
self.assertAlmostEqual(alpha, 42.0, places = 3)
|
||||||
|
|
||||||
@ -210,7 +210,7 @@ class TestColour(unittest.TestCase):
|
|||||||
sample = sample.copy(interpretation = Vips.Interpretation.LAB)
|
sample = sample.copy(interpretation = Vips.Interpretation.LAB)
|
||||||
|
|
||||||
difference = reference.dECMC(sample)
|
difference = reference.dECMC(sample)
|
||||||
result, alpha = difference.getpoint(10, 10)
|
result, alpha = difference(10, 10)
|
||||||
self.assertLess(abs(result - 4.97), 0.5)
|
self.assertLess(abs(result - 4.97), 0.5)
|
||||||
self.assertAlmostEqual(alpha, 42.0, places = 3)
|
self.assertAlmostEqual(alpha, 42.0, places = 3)
|
||||||
|
|
||||||
|
@ -100,20 +100,20 @@ class TestConversion(unittest.TestCase):
|
|||||||
# run a function on an image and on a single pixel, the results
|
# run a function on an image and on a single pixel, the results
|
||||||
# should match
|
# should match
|
||||||
def run_cmp_unary(self, message, im, x, y, fn):
|
def run_cmp_unary(self, message, im, x, y, fn):
|
||||||
a = im.getpoint(x, y)
|
a = im(x, y)
|
||||||
v1 = fn(a)
|
v1 = fn(a)
|
||||||
im2 = fn(im)
|
im2 = fn(im)
|
||||||
v2 = im2.getpoint(x, y)
|
v2 = im2(x, y)
|
||||||
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
||||||
|
|
||||||
# run a function on a pair of images and on a pair of pixels, the results
|
# run a function on a pair of images and on a pair of pixels, the results
|
||||||
# should match
|
# should match
|
||||||
def run_cmp_binary(self, message, left, right, x, y, fn):
|
def run_cmp_binary(self, message, left, right, x, y, fn):
|
||||||
a = left.getpoint(x, y)
|
a = left(x, y)
|
||||||
b = right.getpoint(x, y)
|
b = right(x, y)
|
||||||
v1 = fn(a, b)
|
v1 = fn(a, b)
|
||||||
after = fn(left, right)
|
after = fn(left, right)
|
||||||
v2 = after.getpoint(x, y)
|
v2 = after(x, y)
|
||||||
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
self.assertAlmostEqualObjects(v1, v2, msg = message)
|
||||||
|
|
||||||
# run a function on a pair of images
|
# run a function on a pair of images
|
||||||
@ -242,20 +242,20 @@ class TestConversion(unittest.TestCase):
|
|||||||
im = test.embed(20, 20,
|
im = test.embed(20, 20,
|
||||||
self.colour.width + 40,
|
self.colour.width + 40,
|
||||||
self.colour.height + 40)
|
self.colour.height + 40)
|
||||||
pixel = im.getpoint(10, 10)
|
pixel = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(pixel, [0, 0, 0])
|
self.assertAlmostEqualObjects(pixel, [0, 0, 0])
|
||||||
pixel = im.getpoint(30, 30)
|
pixel = im(30, 30)
|
||||||
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
||||||
pixel = im.getpoint(im.width - 10, im.height - 10)
|
pixel = im(im.width - 10, im.height - 10)
|
||||||
self.assertAlmostEqualObjects(pixel, [0, 0, 0])
|
self.assertAlmostEqualObjects(pixel, [0, 0, 0])
|
||||||
|
|
||||||
im = test.embed(20, 20,
|
im = test.embed(20, 20,
|
||||||
self.colour.width + 40,
|
self.colour.width + 40,
|
||||||
self.colour.height + 40,
|
self.colour.height + 40,
|
||||||
extend = Vips.Extend.COPY)
|
extend = Vips.Extend.COPY)
|
||||||
pixel = im.getpoint(10, 10)
|
pixel = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
||||||
pixel = im.getpoint(im.width - 10, im.height - 10)
|
pixel = im(im.width - 10, im.height - 10)
|
||||||
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
||||||
|
|
||||||
im = test.embed(20, 20,
|
im = test.embed(20, 20,
|
||||||
@ -263,20 +263,20 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.colour.height + 40,
|
self.colour.height + 40,
|
||||||
extend = Vips.Extend.BACKGROUND,
|
extend = Vips.Extend.BACKGROUND,
|
||||||
background = [7, 8, 9])
|
background = [7, 8, 9])
|
||||||
pixel = im.getpoint(10, 10)
|
pixel = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(pixel, [7, 8, 9])
|
self.assertAlmostEqualObjects(pixel, [7, 8, 9])
|
||||||
pixel = im.getpoint(im.width - 10, im.height - 10)
|
pixel = im(im.width - 10, im.height - 10)
|
||||||
self.assertAlmostEqualObjects(pixel, [7, 8, 9])
|
self.assertAlmostEqualObjects(pixel, [7, 8, 9])
|
||||||
|
|
||||||
im = test.embed(20, 20,
|
im = test.embed(20, 20,
|
||||||
self.colour.width + 40,
|
self.colour.width + 40,
|
||||||
self.colour.height + 40,
|
self.colour.height + 40,
|
||||||
extend = Vips.Extend.WHITE)
|
extend = Vips.Extend.WHITE)
|
||||||
pixel = im.getpoint(10, 10)
|
pixel = im(10, 10)
|
||||||
# uses 255 in all bytes of ints, 255.0 for float
|
# uses 255 in all bytes of ints, 255.0 for float
|
||||||
pixel = [int(x) & 0xff for x in pixel]
|
pixel = [int(x) & 0xff for x in pixel]
|
||||||
self.assertAlmostEqualObjects(pixel, [255, 255, 255])
|
self.assertAlmostEqualObjects(pixel, [255, 255, 255])
|
||||||
pixel = im.getpoint(im.width - 10, im.height - 10)
|
pixel = im(im.width - 10, im.height - 10)
|
||||||
pixel = [int(x) & 0xff for x in pixel]
|
pixel = [int(x) & 0xff for x in pixel]
|
||||||
self.assertAlmostEqualObjects(pixel, [255, 255, 255])
|
self.assertAlmostEqualObjects(pixel, [255, 255, 255])
|
||||||
|
|
||||||
@ -284,17 +284,17 @@ class TestConversion(unittest.TestCase):
|
|||||||
for fmt in all_formats:
|
for fmt in all_formats:
|
||||||
test = self.colour.cast(fmt)
|
test = self.colour.cast(fmt)
|
||||||
|
|
||||||
pixel = test.getpoint(30, 30)
|
pixel = test(30, 30)
|
||||||
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
||||||
|
|
||||||
sub = test.extract_area(25, 25, 10, 10)
|
sub = test.extract_area(25, 25, 10, 10)
|
||||||
|
|
||||||
pixel = sub.getpoint(5, 5)
|
pixel = sub(5, 5)
|
||||||
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
||||||
|
|
||||||
sub = test.extract_band(1, n = 2)
|
sub = test.extract_band(1, n = 2)
|
||||||
|
|
||||||
pixel = sub.getpoint(30, 30)
|
pixel = sub(30, 30)
|
||||||
self.assertAlmostEqualObjects(pixel, [3, 4])
|
self.assertAlmostEqualObjects(pixel, [3, 4])
|
||||||
|
|
||||||
def test_slice(self):
|
def test_slice(self):
|
||||||
@ -326,12 +326,12 @@ class TestConversion(unittest.TestCase):
|
|||||||
for fmt in all_formats:
|
for fmt in all_formats:
|
||||||
test = self.colour.cast(fmt)
|
test = self.colour.cast(fmt)
|
||||||
|
|
||||||
pixel = test.getpoint(30, 30)
|
pixel = test(30, 30)
|
||||||
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
||||||
|
|
||||||
sub = test.crop(25, 25, 10, 10)
|
sub = test.crop(25, 25, 10, 10)
|
||||||
|
|
||||||
pixel = sub.getpoint(5, 5)
|
pixel = sub(5, 5)
|
||||||
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
self.assertAlmostEqualObjects(pixel, [2, 3, 4])
|
||||||
|
|
||||||
def test_falsecolour(self):
|
def test_falsecolour(self):
|
||||||
@ -344,7 +344,7 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(im.height, test.height)
|
self.assertEqual(im.height, test.height)
|
||||||
self.assertEqual(im.bands, 3)
|
self.assertEqual(im.bands, 3)
|
||||||
|
|
||||||
pixel = im.getpoint(30, 30)
|
pixel = im(30, 30)
|
||||||
self.assertAlmostEqualObjects(pixel, [20, 0, 41])
|
self.assertAlmostEqualObjects(pixel, [20, 0, 41])
|
||||||
|
|
||||||
def test_flatten(self):
|
def test_flatten(self):
|
||||||
@ -365,14 +365,14 @@ class TestConversion(unittest.TestCase):
|
|||||||
alpha = mx / 2.0
|
alpha = mx / 2.0
|
||||||
nalpha = mx - alpha
|
nalpha = mx - alpha
|
||||||
test = self.colour.bandjoin(black + alpha).cast(fmt)
|
test = self.colour.bandjoin(black + alpha).cast(fmt)
|
||||||
pixel = test.getpoint(30, 30)
|
pixel = test(30, 30)
|
||||||
|
|
||||||
predict = [int(x) * alpha / mx for x in pixel[:-1]]
|
predict = [int(x) * alpha / mx for x in pixel[:-1]]
|
||||||
|
|
||||||
im = test.flatten()
|
im = test.flatten()
|
||||||
|
|
||||||
self.assertEqual(im.bands, 3)
|
self.assertEqual(im.bands, 3)
|
||||||
pixel = im.getpoint(30, 30)
|
pixel = im(30, 30)
|
||||||
for x, y in zip(pixel, predict):
|
for x, y in zip(pixel, predict):
|
||||||
# we use float arithetic for int and uint, so the rounding
|
# we use float arithetic for int and uint, so the rounding
|
||||||
# differs ... don't require huge accuracy
|
# differs ... don't require huge accuracy
|
||||||
@ -380,12 +380,12 @@ class TestConversion(unittest.TestCase):
|
|||||||
|
|
||||||
im = test.flatten(background = [100, 100, 100])
|
im = test.flatten(background = [100, 100, 100])
|
||||||
|
|
||||||
pixel = test.getpoint(30, 30)
|
pixel = test(30, 30)
|
||||||
predict = [int(x) * alpha / mx + (100 * nalpha) / mx
|
predict = [int(x) * alpha / mx + (100 * nalpha) / mx
|
||||||
for x in pixel[:-1]]
|
for x in pixel[:-1]]
|
||||||
|
|
||||||
self.assertEqual(im.bands, 3)
|
self.assertEqual(im.bands, 3)
|
||||||
pixel = im.getpoint(30, 30)
|
pixel = im(30, 30)
|
||||||
for x, y in zip(pixel, predict):
|
for x, y in zip(pixel, predict):
|
||||||
self.assertLess(abs(x - y), 2)
|
self.assertLess(abs(x - y), 2)
|
||||||
|
|
||||||
@ -410,8 +410,8 @@ class TestConversion(unittest.TestCase):
|
|||||||
|
|
||||||
norm = mx ** exponent / mx
|
norm = mx ** exponent / mx
|
||||||
result = test.gamma()
|
result = test.gamma()
|
||||||
before = test.getpoint(30, 30)
|
before = test(30, 30)
|
||||||
after = result.getpoint(30, 30)
|
after = result(30, 30)
|
||||||
predict = [x ** exponent / norm for x in before]
|
predict = [x ** exponent / norm for x in before]
|
||||||
for a, b in zip(after, predict):
|
for a, b in zip(after, predict):
|
||||||
# ie. less than 1% error, rounding on 7-bit images means this is
|
# ie. less than 1% error, rounding on 7-bit images means this is
|
||||||
@ -425,8 +425,8 @@ class TestConversion(unittest.TestCase):
|
|||||||
|
|
||||||
norm = mx ** exponent / mx
|
norm = mx ** exponent / mx
|
||||||
result = test.gamma(exponent = 1.0 / 1.2)
|
result = test.gamma(exponent = 1.0 / 1.2)
|
||||||
before = test.getpoint(30, 30)
|
before = test(30, 30)
|
||||||
after = result.getpoint(30, 30)
|
after = result(30, 30)
|
||||||
predict = [x ** exponent / norm for x in before]
|
predict = [x ** exponent / norm for x in before]
|
||||||
for a, b in zip(after, predict):
|
for a, b in zip(after, predict):
|
||||||
# ie. less than 1% error, rounding on 7-bit images means this is
|
# ie. less than 1% error, rounding on 7-bit images means this is
|
||||||
@ -444,12 +444,12 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(result.width, self.colour.width * 3)
|
self.assertEqual(result.width, self.colour.width * 3)
|
||||||
self.assertEqual(result.height, self.colour.height * 4)
|
self.assertEqual(result.height, self.colour.height * 4)
|
||||||
|
|
||||||
before = im.getpoint(10, 10)
|
before = im(10, 10)
|
||||||
after = result.getpoint(10 + test.width * 2, 10 + test.width * 2)
|
after = result(10 + test.width * 2, 10 + test.width * 2)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
before = im.getpoint(50, 50)
|
before = im(50, 50)
|
||||||
after = result.getpoint(50 + test.width * 2, 50 + test.width * 2)
|
after = result(50 + test.width * 2, 50 + test.width * 2)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
def test_ifthenelse(self):
|
def test_ifthenelse(self):
|
||||||
@ -464,12 +464,12 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(r.height, self.colour.height)
|
self.assertEqual(r.height, self.colour.height)
|
||||||
self.assertEqual(r.bands, self.colour.bands)
|
self.assertEqual(r.bands, self.colour.bands)
|
||||||
|
|
||||||
predict = e.getpoint(10, 10)
|
predict = e(10, 10)
|
||||||
result = r.getpoint(10, 10)
|
result = r(10, 10)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
predict = t.getpoint(50, 50)
|
predict = t(50, 50)
|
||||||
result = r.getpoint(50, 50)
|
result = r(50, 50)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
test = self.colour > 3
|
test = self.colour > 3
|
||||||
@ -483,20 +483,20 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(r.height, self.colour.height)
|
self.assertEqual(r.height, self.colour.height)
|
||||||
self.assertEqual(r.bands, self.colour.bands)
|
self.assertEqual(r.bands, self.colour.bands)
|
||||||
|
|
||||||
cp = test.getpoint(10, 10)
|
cp = test(10, 10)
|
||||||
tp = t.getpoint(10, 10) * 3
|
tp = t(10, 10) * 3
|
||||||
ep = e.getpoint(10, 10) * 3
|
ep = e(10, 10) * 3
|
||||||
predict = [te if ce != 0 else ee
|
predict = [te if ce != 0 else ee
|
||||||
for ce, te, ee in zip(cp, tp, ep)]
|
for ce, te, ee in zip(cp, tp, ep)]
|
||||||
result = r.getpoint(10, 10)
|
result = r(10, 10)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
cp = test.getpoint(50, 50)
|
cp = test(50, 50)
|
||||||
tp = t.getpoint(50, 50) * 3
|
tp = t(50, 50) * 3
|
||||||
ep = e.getpoint(50, 50) * 3
|
ep = e(50, 50) * 3
|
||||||
predict = [te if ce != 0 else ee
|
predict = [te if ce != 0 else ee
|
||||||
for ce, te, ee in zip(cp, tp, ep)]
|
for ce, te, ee in zip(cp, tp, ep)]
|
||||||
result = r.getpoint(50, 50)
|
result = r(50, 50)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
test = self.colour > 3
|
test = self.colour > 3
|
||||||
@ -510,7 +510,7 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(r.height, self.colour.height)
|
self.assertEqual(r.height, self.colour.height)
|
||||||
self.assertEqual(r.bands, self.colour.bands)
|
self.assertEqual(r.bands, self.colour.bands)
|
||||||
|
|
||||||
result = r.getpoint(10, 10)
|
result = r(10, 10)
|
||||||
self.assertAlmostEqualObjects(result, [3, 3, 13])
|
self.assertAlmostEqualObjects(result, [3, 3, 13])
|
||||||
|
|
||||||
test = self.mono > 3
|
test = self.mono > 3
|
||||||
@ -520,9 +520,9 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(r.bands, self.colour.bands)
|
self.assertEqual(r.bands, self.colour.bands)
|
||||||
self.assertEqual(r.format, self.colour.format)
|
self.assertEqual(r.format, self.colour.format)
|
||||||
self.assertEqual(r.interpretation, self.colour.interpretation)
|
self.assertEqual(r.interpretation, self.colour.interpretation)
|
||||||
result = r.getpoint(10, 10)
|
result = r(10, 10)
|
||||||
self.assertAlmostEqualObjects(result, [2, 3, 4])
|
self.assertAlmostEqualObjects(result, [2, 3, 4])
|
||||||
result = r.getpoint(50, 50)
|
result = r(50, 50)
|
||||||
self.assertAlmostEqualObjects(result, [1, 2, 3])
|
self.assertAlmostEqualObjects(result, [1, 2, 3])
|
||||||
|
|
||||||
test = self.mono
|
test = self.mono
|
||||||
@ -532,9 +532,9 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(r.bands, self.colour.bands)
|
self.assertEqual(r.bands, self.colour.bands)
|
||||||
self.assertEqual(r.format, self.colour.format)
|
self.assertEqual(r.format, self.colour.format)
|
||||||
self.assertEqual(r.interpretation, self.colour.interpretation)
|
self.assertEqual(r.interpretation, self.colour.interpretation)
|
||||||
result = r.getpoint(10, 10)
|
result = r(10, 10)
|
||||||
self.assertAlmostEqualObjects(result, [2, 3, 4], places = 1)
|
self.assertAlmostEqualObjects(result, [2, 3, 4], places = 1)
|
||||||
result = r.getpoint(50, 50)
|
result = r(50, 50)
|
||||||
self.assertAlmostEqualObjects(result, [3.0, 4.9, 6.9], places = 1)
|
self.assertAlmostEqualObjects(result, [3.0, 4.9, 6.9], places = 1)
|
||||||
|
|
||||||
def test_insert(self):
|
def test_insert(self):
|
||||||
@ -548,12 +548,12 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(r.height, main.height)
|
self.assertEqual(r.height, main.height)
|
||||||
self.assertEqual(r.bands, sub.bands)
|
self.assertEqual(r.bands, sub.bands)
|
||||||
|
|
||||||
a = r.getpoint(10, 10)
|
a = r(10, 10)
|
||||||
b = sub.getpoint(0, 0)
|
b = sub(0, 0)
|
||||||
self.assertAlmostEqualObjects(a, b)
|
self.assertAlmostEqualObjects(a, b)
|
||||||
|
|
||||||
a = r.getpoint(0, 0)
|
a = r(0, 0)
|
||||||
b = main.getpoint(0, 0) * 3
|
b = main(0, 0) * 3
|
||||||
self.assertAlmostEqualObjects(a, b)
|
self.assertAlmostEqualObjects(a, b)
|
||||||
|
|
||||||
for x in all_formats:
|
for x in all_formats:
|
||||||
@ -566,7 +566,7 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(r.height, main.height + 10)
|
self.assertEqual(r.height, main.height + 10)
|
||||||
self.assertEqual(r.bands, sub.bands)
|
self.assertEqual(r.bands, sub.bands)
|
||||||
|
|
||||||
a = r.getpoint(r.width - 5, 5)
|
a = r(r.width - 5, 5)
|
||||||
self.assertAlmostEqualObjects(a, [100, 100, 100])
|
self.assertAlmostEqualObjects(a, [100, 100, 100])
|
||||||
|
|
||||||
def test_msb(self):
|
def test_msb(self):
|
||||||
@ -576,14 +576,14 @@ class TestConversion(unittest.TestCase):
|
|||||||
test = (self.colour + mx / 8.0).cast(fmt)
|
test = (self.colour + mx / 8.0).cast(fmt)
|
||||||
im = test.msb()
|
im = test.msb()
|
||||||
|
|
||||||
before = test.getpoint(10, 10)
|
before = test(10, 10)
|
||||||
predict = [int(x) >> ((size - 1) * 8) for x in before]
|
predict = [int(x) >> ((size - 1) * 8) for x in before]
|
||||||
result = im.getpoint(10, 10)
|
result = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
before = test.getpoint(50, 50)
|
before = test(50, 50)
|
||||||
predict = [int(x) >> ((size - 1) * 8) for x in before]
|
predict = [int(x) >> ((size - 1) * 8) for x in before]
|
||||||
result = im.getpoint(50, 50)
|
result = im(50, 50)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
for fmt in signed_formats:
|
for fmt in signed_formats:
|
||||||
@ -592,14 +592,14 @@ class TestConversion(unittest.TestCase):
|
|||||||
test = (self.colour + mx / 8.0).cast(fmt)
|
test = (self.colour + mx / 8.0).cast(fmt)
|
||||||
im = test.msb()
|
im = test.msb()
|
||||||
|
|
||||||
before = test.getpoint(10, 10)
|
before = test(10, 10)
|
||||||
predict = [128 + (int(x) >> ((size - 1) * 8)) for x in before]
|
predict = [128 + (int(x) >> ((size - 1) * 8)) for x in before]
|
||||||
result = im.getpoint(10, 10)
|
result = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
before = test.getpoint(50, 50)
|
before = test(50, 50)
|
||||||
predict = [128 + (int(x) >> ((size - 1) * 8)) for x in before]
|
predict = [128 + (int(x) >> ((size - 1) * 8)) for x in before]
|
||||||
result = im.getpoint(50, 50)
|
result = im(50, 50)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
for fmt in unsigned_formats:
|
for fmt in unsigned_formats:
|
||||||
@ -608,14 +608,14 @@ class TestConversion(unittest.TestCase):
|
|||||||
test = (self.colour + mx / 8.0).cast(fmt)
|
test = (self.colour + mx / 8.0).cast(fmt)
|
||||||
im = test.msb(band = 1)
|
im = test.msb(band = 1)
|
||||||
|
|
||||||
before = [test.getpoint(10, 10)[1]]
|
before = [test(10, 10)[1]]
|
||||||
predict = [int(x) >> ((size - 1) * 8) for x in before]
|
predict = [int(x) >> ((size - 1) * 8) for x in before]
|
||||||
result = im.getpoint(10, 10)
|
result = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
before = [test.getpoint(50, 50)[1]]
|
before = [test(50, 50)[1]]
|
||||||
predict = [int(x) >> ((size - 1) * 8) for x in before]
|
predict = [int(x) >> ((size - 1) * 8) for x in before]
|
||||||
result = im.getpoint(50, 50)
|
result = im(50, 50)
|
||||||
self.assertAlmostEqualObjects(result, predict)
|
self.assertAlmostEqualObjects(result, predict)
|
||||||
|
|
||||||
def test_recomb(self):
|
def test_recomb(self):
|
||||||
@ -640,12 +640,12 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(test.width, self.colour.width * 10)
|
self.assertEqual(test.width, self.colour.width * 10)
|
||||||
self.assertEqual(test.height, self.colour.height * 10)
|
self.assertEqual(test.height, self.colour.height * 10)
|
||||||
|
|
||||||
before = im.getpoint(10, 10)
|
before = im(10, 10)
|
||||||
after = test.getpoint(10 + im.width * 2, 10 + im.width * 2)
|
after = test(10 + im.width * 2, 10 + im.width * 2)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
before = im.getpoint(50, 50)
|
before = im(50, 50)
|
||||||
after = test.getpoint(50 + im.width * 2, 50 + im.width * 2)
|
after = test(50 + im.width * 2, 50 + im.width * 2)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
def test_rot45(self):
|
def test_rot45(self):
|
||||||
@ -655,8 +655,8 @@ class TestConversion(unittest.TestCase):
|
|||||||
im = test.cast(fmt)
|
im = test.cast(fmt)
|
||||||
|
|
||||||
im2 = im.rot45()
|
im2 = im.rot45()
|
||||||
before = im.getpoint(50, 50)
|
before = im(50, 50)
|
||||||
after = im2.getpoint(25, 50)
|
after = im2(25, 50)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
for a, b in zip(rot45_angles, rot45_angle_bonds):
|
for a, b in zip(rot45_angles, rot45_angle_bonds):
|
||||||
@ -672,8 +672,8 @@ class TestConversion(unittest.TestCase):
|
|||||||
im = test.cast(fmt)
|
im = test.cast(fmt)
|
||||||
|
|
||||||
im2 = im.rot(Vips.Angle.D90)
|
im2 = im.rot(Vips.Angle.D90)
|
||||||
before = im.getpoint(50, 50)
|
before = im(50, 50)
|
||||||
after = im2.getpoint(0, 50)
|
after = im2(0, 50)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
for a, b in zip(rot_angles, rot_angle_bonds):
|
for a, b in zip(rot_angles, rot_angle_bonds):
|
||||||
@ -701,8 +701,8 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(im.width, test.width // 3)
|
self.assertEqual(im.width, test.width // 3)
|
||||||
self.assertEqual(im.height, test.height // 3)
|
self.assertEqual(im.height, test.height // 3)
|
||||||
|
|
||||||
before = test.getpoint(60, 60)
|
before = test(60, 60)
|
||||||
after = im.getpoint(20, 20)
|
after = im(20, 20)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
def test_zoom(self):
|
def test_zoom(self):
|
||||||
@ -713,8 +713,8 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(im.width, test.width * 3)
|
self.assertEqual(im.width, test.width * 3)
|
||||||
self.assertEqual(im.height, test.height * 3)
|
self.assertEqual(im.height, test.height * 3)
|
||||||
|
|
||||||
before = test.getpoint(50, 50)
|
before = test(50, 50)
|
||||||
after = im.getpoint(150, 150)
|
after = im(150, 150)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
def test_wrap(self):
|
def test_wrap(self):
|
||||||
@ -725,12 +725,12 @@ class TestConversion(unittest.TestCase):
|
|||||||
self.assertEqual(im.width, test.width)
|
self.assertEqual(im.width, test.width)
|
||||||
self.assertEqual(im.height, test.height)
|
self.assertEqual(im.height, test.height)
|
||||||
|
|
||||||
before = test.getpoint(0, 0)
|
before = test(0, 0)
|
||||||
after = im.getpoint(50, 50)
|
after = im(50, 50)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
before = test.getpoint(50, 50)
|
before = test(50, 50)
|
||||||
after = im.getpoint(0, 0)
|
after = im(0, 0)
|
||||||
self.assertAlmostEqualObjects(before, after)
|
self.assertAlmostEqualObjects(before, after)
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
@ -70,8 +70,8 @@ def conv(image, mask, x_position, y_position):
|
|||||||
s = 0.0
|
s = 0.0
|
||||||
for x in range(0, mask.width):
|
for x in range(0, mask.width):
|
||||||
for y in range(0, mask.height):
|
for y in range(0, mask.height):
|
||||||
m = mask.getpoint(x, y)
|
m = mask(x, y)
|
||||||
i = image.getpoint(x + x_position, y + y_position)
|
i = image(x + x_position, y + 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)
|
||||||
|
|
||||||
@ -119,11 +119,11 @@ class TestConvolution(unittest.TestCase):
|
|||||||
for prec in [Vips.Precision.INTEGER, Vips.Precision.FLOAT]:
|
for prec in [Vips.Precision.INTEGER, Vips.Precision.FLOAT]:
|
||||||
convolved = im.conv(msk, precision = prec)
|
convolved = im.conv(msk, precision = prec)
|
||||||
|
|
||||||
result = convolved.getpoint(25, 50)
|
result = convolved(25, 50)
|
||||||
true = conv(im, msk, 24, 49)
|
true = conv(im, msk, 24, 49)
|
||||||
self.assertAlmostEqualObjects(result, true)
|
self.assertAlmostEqualObjects(result, true)
|
||||||
|
|
||||||
result = convolved.getpoint(50, 50)
|
result = convolved(50, 50)
|
||||||
true = conv(im, msk, 49, 49)
|
true = conv(im, msk, 49, 49)
|
||||||
self.assertAlmostEqualObjects(result, true)
|
self.assertAlmostEqualObjects(result, true)
|
||||||
|
|
||||||
@ -138,7 +138,7 @@ class TestConvolution(unittest.TestCase):
|
|||||||
combine = Vips.Combine.MAX,
|
combine = Vips.Combine.MAX,
|
||||||
precision = prec)
|
precision = prec)
|
||||||
|
|
||||||
result = convolved.getpoint(25, 50)
|
result = convolved(25, 50)
|
||||||
true = compass(im, msk, 24, 49, times, max)
|
true = compass(im, msk, 24, 49, times, max)
|
||||||
self.assertAlmostEqualObjects(result, true)
|
self.assertAlmostEqualObjects(result, true)
|
||||||
|
|
||||||
@ -152,7 +152,7 @@ class TestConvolution(unittest.TestCase):
|
|||||||
combine = Vips.Combine.SUM,
|
combine = Vips.Combine.SUM,
|
||||||
precision = prec)
|
precision = prec)
|
||||||
|
|
||||||
result = convolved.getpoint(25, 50)
|
result = convolved(25, 50)
|
||||||
true = compass(im, msk, 24, 49, times, operator.add)
|
true = compass(im, msk, 24, 49, times, operator.add)
|
||||||
self.assertAlmostEqualObjects(result, true)
|
self.assertAlmostEqualObjects(result, true)
|
||||||
|
|
||||||
@ -172,8 +172,8 @@ class TestConvolution(unittest.TestCase):
|
|||||||
a = im.conv(gmask, precision = prec)
|
a = im.conv(gmask, precision = prec)
|
||||||
b = im.convsep(gmask_sep, precision = prec)
|
b = im.convsep(gmask_sep, precision = prec)
|
||||||
|
|
||||||
a_point = a.getpoint(25, 50)
|
a_point = a(25, 50)
|
||||||
b_point = b.getpoint(25, 50)
|
b_point = b(25, 50)
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(a_point, b_point, places = 1)
|
self.assertAlmostEqualObjects(a_point, b_point, places = 1)
|
||||||
|
|
||||||
@ -210,8 +210,8 @@ class TestConvolution(unittest.TestCase):
|
|||||||
a = im.conv(gmask, precision = prec)
|
a = im.conv(gmask, precision = prec)
|
||||||
b = im.gaussblur(sigma, min_ampl = 0.2, precision = prec)
|
b = im.gaussblur(sigma, min_ampl = 0.2, precision = prec)
|
||||||
|
|
||||||
a_point = a.getpoint(25, 50)
|
a_point = a(25, 50)
|
||||||
b_point = b.getpoint(25, 50)
|
b_point = b(25, 50)
|
||||||
|
|
||||||
self.assertAlmostEqualObjects(a_point, b_point, places = 1)
|
self.assertAlmostEqualObjects(a_point, b_point, places = 1)
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
for i in range (0, 100):
|
for i in range (0, 100):
|
||||||
pixel = im.getpoint(i, i)
|
pixel = im(i, i)
|
||||||
self.assertEqual(len(pixel), 1)
|
self.assertEqual(len(pixel), 1)
|
||||||
self.assertEqual(pixel[0], 0)
|
self.assertEqual(pixel[0], 0)
|
||||||
|
|
||||||
@ -54,7 +54,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
||||||
self.assertEqual(im.bands, 3)
|
self.assertEqual(im.bands, 3)
|
||||||
for i in range (0, 100):
|
for i in range (0, 100):
|
||||||
pixel = im.getpoint(i, i)
|
pixel = im(i, i)
|
||||||
self.assertEqual(len(pixel), 3)
|
self.assertEqual(len(pixel), 3)
|
||||||
self.assertAlmostEqualObjects(pixel, [0, 0, 0])
|
self.assertAlmostEqualObjects(pixel, [0, 0, 0])
|
||||||
|
|
||||||
@ -65,11 +65,11 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(lut.width, 256)
|
self.assertEqual(lut.width, 256)
|
||||||
self.assertEqual(lut.height, 1)
|
self.assertEqual(lut.height, 1)
|
||||||
self.assertEqual(lut.bands, 1)
|
self.assertEqual(lut.bands, 1)
|
||||||
p = lut.getpoint(0, 0)
|
p = lut(0, 0)
|
||||||
self.assertEqual(p[0], 0.0)
|
self.assertEqual(p[0], 0.0)
|
||||||
p = lut.getpoint(255, 0)
|
p = lut(255, 0)
|
||||||
self.assertEqual(p[0], 100.0)
|
self.assertEqual(p[0], 100.0)
|
||||||
p = lut.getpoint(10, 0)
|
p = lut(10, 0)
|
||||||
self.assertEqual(p[0], 100 * 10.0 / 255.0)
|
self.assertEqual(p[0], 100 * 10.0 / 255.0)
|
||||||
|
|
||||||
M = Vips.Image.new_from_array([[0, 0, 100],
|
M = Vips.Image.new_from_array([[0, 0, 100],
|
||||||
@ -79,9 +79,9 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(lut.width, 256)
|
self.assertEqual(lut.width, 256)
|
||||||
self.assertEqual(lut.height, 1)
|
self.assertEqual(lut.height, 1)
|
||||||
self.assertEqual(lut.bands, 2)
|
self.assertEqual(lut.bands, 2)
|
||||||
p = lut.getpoint(0, 0)
|
p = lut(0, 0)
|
||||||
self.assertAlmostEqualObjects(p, [0.0, 100.0])
|
self.assertAlmostEqualObjects(p, [0.0, 100.0])
|
||||||
p = lut.getpoint(64, 0)
|
p = lut(64, 0)
|
||||||
self.assertAlmostEqualObjects(p, [5.0, 95.0])
|
self.assertAlmostEqualObjects(p, [5.0, 95.0])
|
||||||
|
|
||||||
def test_eye(self):
|
def test_eye(self):
|
||||||
@ -118,7 +118,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
total = im.avg() * im.width * im.height
|
total = im.avg() * im.width * im.height
|
||||||
scale = im.get("scale")
|
scale = im.get("scale")
|
||||||
self.assertEqual(total, scale)
|
self.assertEqual(total, scale)
|
||||||
p = im.getpoint(im.width / 2, im.height / 2)
|
p = im(im.width / 2, im.height / 2)
|
||||||
self.assertEqual(p[0], 20.0)
|
self.assertEqual(p[0], 20.0)
|
||||||
|
|
||||||
im = Vips.Image.gaussmat(1, 0.1,
|
im = Vips.Image.gaussmat(1, 0.1,
|
||||||
@ -131,7 +131,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
total = im.avg() * im.width * im.height
|
total = im.avg() * im.width * im.height
|
||||||
scale = im.get("scale")
|
scale = im.get("scale")
|
||||||
self.assertEqual(total, scale)
|
self.assertEqual(total, scale)
|
||||||
p = im.getpoint(im.width / 2, im.height / 2)
|
p = im(im.width / 2, im.height / 2)
|
||||||
self.assertEqual(p[0], 1.0)
|
self.assertEqual(p[0], 1.0)
|
||||||
|
|
||||||
def test_gaussnoise(self):
|
def test_gaussnoise(self):
|
||||||
@ -160,13 +160,13 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
|
|
||||||
p = im.getpoint(0, 0)
|
p = im(0, 0)
|
||||||
self.assertEqual(p[0], 0.0)
|
self.assertEqual(p[0], 0.0)
|
||||||
p = im.getpoint(99, 0)
|
p = im(99, 0)
|
||||||
self.assertEqual(p[0], 1.0)
|
self.assertEqual(p[0], 1.0)
|
||||||
p = im.getpoint(0, 89)
|
p = im(0, 89)
|
||||||
self.assertEqual(p[0], 0.0)
|
self.assertEqual(p[0], 0.0)
|
||||||
p = im.getpoint(99, 89)
|
p = im(99, 89)
|
||||||
self.assertEqual(p[0], 1.0)
|
self.assertEqual(p[0], 1.0)
|
||||||
|
|
||||||
im = Vips.Image.grey(100, 90, uchar = True)
|
im = Vips.Image.grey(100, 90, uchar = True)
|
||||||
@ -175,13 +175,13 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
||||||
|
|
||||||
p = im.getpoint(0, 0)
|
p = im(0, 0)
|
||||||
self.assertEqual(p[0], 0)
|
self.assertEqual(p[0], 0)
|
||||||
p = im.getpoint(99, 0)
|
p = im(99, 0)
|
||||||
self.assertEqual(p[0], 255)
|
self.assertEqual(p[0], 255)
|
||||||
p = im.getpoint(0, 89)
|
p = im(0, 89)
|
||||||
self.assertEqual(p[0], 0)
|
self.assertEqual(p[0], 0)
|
||||||
p = im.getpoint(99, 89)
|
p = im(99, 89)
|
||||||
self.assertEqual(p[0], 255)
|
self.assertEqual(p[0], 255)
|
||||||
|
|
||||||
def test_identity(self):
|
def test_identity(self):
|
||||||
@ -191,11 +191,11 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
||||||
|
|
||||||
p = im.getpoint(0, 0)
|
p = im(0, 0)
|
||||||
self.assertEqual(p[0], 0.0)
|
self.assertEqual(p[0], 0.0)
|
||||||
p = im.getpoint(255, 0)
|
p = im(255, 0)
|
||||||
self.assertEqual(p[0], 255.0)
|
self.assertEqual(p[0], 255.0)
|
||||||
p = im.getpoint(128, 0)
|
p = im(128, 0)
|
||||||
self.assertEqual(p[0], 128.0)
|
self.assertEqual(p[0], 128.0)
|
||||||
|
|
||||||
im = Vips.Image.identity(ushort = True)
|
im = Vips.Image.identity(ushort = True)
|
||||||
@ -204,11 +204,11 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.USHORT)
|
self.assertEqual(im.format, Vips.BandFormat.USHORT)
|
||||||
|
|
||||||
p = im.getpoint(0, 0)
|
p = im(0, 0)
|
||||||
self.assertEqual(p[0], 0)
|
self.assertEqual(p[0], 0)
|
||||||
p = im.getpoint(99, 0)
|
p = im(99, 0)
|
||||||
self.assertEqual(p[0], 99)
|
self.assertEqual(p[0], 99)
|
||||||
p = im.getpoint(65535, 0)
|
p = im(65535, 0)
|
||||||
self.assertEqual(p[0], 65535)
|
self.assertEqual(p[0], 65535)
|
||||||
|
|
||||||
def test_invertlut(self):
|
def test_invertlut(self):
|
||||||
@ -221,15 +221,15 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 3)
|
self.assertEqual(im.bands, 3)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.DOUBLE)
|
self.assertEqual(im.format, Vips.BandFormat.DOUBLE)
|
||||||
|
|
||||||
p = im.getpoint(0, 0)
|
p = im(0, 0)
|
||||||
self.assertAlmostEqualObjects(p, [0, 0, 0])
|
self.assertAlmostEqualObjects(p, [0, 0, 0])
|
||||||
p = im.getpoint(255, 0)
|
p = im(255, 0)
|
||||||
self.assertAlmostEqualObjects(p, [1, 1, 1])
|
self.assertAlmostEqualObjects(p, [1, 1, 1])
|
||||||
p = im.getpoint(0.2 * 255, 0)
|
p = im(0.2 * 255, 0)
|
||||||
self.assertAlmostEqual(p[0], 0.1, places = 2)
|
self.assertAlmostEqual(p[0], 0.1, places = 2)
|
||||||
p = im.getpoint(0.3 * 255, 0)
|
p = im(0.3 * 255, 0)
|
||||||
self.assertAlmostEqual(p[1], 0.1, places = 2)
|
self.assertAlmostEqual(p[1], 0.1, places = 2)
|
||||||
p = im.getpoint(0.1 * 255, 0)
|
p = im(0.1 * 255, 0)
|
||||||
self.assertAlmostEqual(p[2], 0.1, places = 2)
|
self.assertAlmostEqual(p[2], 0.1, places = 2)
|
||||||
|
|
||||||
def test_logmat(self):
|
def test_logmat(self):
|
||||||
@ -242,7 +242,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
total = im.avg() * im.width * im.height
|
total = im.avg() * im.width * im.height
|
||||||
scale = im.get("scale")
|
scale = im.get("scale")
|
||||||
self.assertEqual(total, scale)
|
self.assertEqual(total, scale)
|
||||||
p = im.getpoint(im.width / 2, im.height / 2)
|
p = im(im.width / 2, im.height / 2)
|
||||||
self.assertEqual(p[0], 20.0)
|
self.assertEqual(p[0], 20.0)
|
||||||
|
|
||||||
im = Vips.Image.logmat(1, 0.1,
|
im = Vips.Image.logmat(1, 0.1,
|
||||||
@ -255,7 +255,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
total = im.avg() * im.width * im.height
|
total = im.avg() * im.width * im.height
|
||||||
scale = im.get("scale")
|
scale = im.get("scale")
|
||||||
self.assertEqual(total, scale)
|
self.assertEqual(total, scale)
|
||||||
p = im.getpoint(im.width / 2, im.height / 2)
|
p = im(im.width / 2, im.height / 2)
|
||||||
self.assertEqual(p[0], 1.0)
|
self.assertEqual(p[0], 1.0)
|
||||||
|
|
||||||
def test_mask_butterworth_band(self):
|
def test_mask_butterworth_band(self):
|
||||||
@ -265,7 +265,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
self.assertAlmostEqual(im.max(), 1, places = 2)
|
self.assertAlmostEqual(im.max(), 1, places = 2)
|
||||||
p = im.getpoint(32, 32)
|
p = im(32, 32)
|
||||||
self.assertEqual(p[0], 1.0)
|
self.assertEqual(p[0], 1.0)
|
||||||
|
|
||||||
im = Vips.Image.mask_butterworth_band(128, 128, 2, 0.5, 0.5, 0.7, 0.1,
|
im = Vips.Image.mask_butterworth_band(128, 128, 2, 0.5, 0.5, 0.7, 0.1,
|
||||||
@ -275,9 +275,9 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
||||||
self.assertEqual(im.max(), 255)
|
self.assertEqual(im.max(), 255)
|
||||||
p = im.getpoint(32, 32)
|
p = im(32, 32)
|
||||||
self.assertEqual(p[0], 255.0)
|
self.assertEqual(p[0], 255.0)
|
||||||
p = im.getpoint(64, 64)
|
p = im(64, 64)
|
||||||
self.assertEqual(p[0], 255.0)
|
self.assertEqual(p[0], 255.0)
|
||||||
|
|
||||||
im = Vips.Image.mask_butterworth_band(128, 128, 2, 0.5, 0.5, 0.7, 0.1,
|
im = Vips.Image.mask_butterworth_band(128, 128, 2, 0.5, 0.5, 0.7, 0.1,
|
||||||
@ -288,9 +288,9 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
||||||
self.assertEqual(im.max(), 255)
|
self.assertEqual(im.max(), 255)
|
||||||
p = im.getpoint(32, 32)
|
p = im(32, 32)
|
||||||
self.assertEqual(p[0], 255.0)
|
self.assertEqual(p[0], 255.0)
|
||||||
p = im.getpoint(64, 64)
|
p = im(64, 64)
|
||||||
self.assertNotEqual(p[0], 255)
|
self.assertNotEqual(p[0], 255)
|
||||||
|
|
||||||
def test_mask_butterworth(self):
|
def test_mask_butterworth(self):
|
||||||
@ -301,7 +301,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
self.assertAlmostEqual(im.min(), 0, places = 2)
|
self.assertAlmostEqual(im.min(), 0, places = 2)
|
||||||
p = im.getpoint(0, 0)
|
p = im(0, 0)
|
||||||
self.assertEqual(p[0], 0.0)
|
self.assertEqual(p[0], 0.0)
|
||||||
v, x, y = im.maxpos()
|
v, x, y = im.maxpos()
|
||||||
self.assertEqual(x, 64)
|
self.assertEqual(x, 64)
|
||||||
@ -314,7 +314,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
self.assertEqual(im.format, Vips.BandFormat.UCHAR)
|
||||||
self.assertAlmostEqual(im.min(), 0, places = 2)
|
self.assertAlmostEqual(im.min(), 0, places = 2)
|
||||||
p = im.getpoint(64, 64)
|
p = im(64, 64)
|
||||||
self.assertEqual(p[0], 255)
|
self.assertEqual(p[0], 255)
|
||||||
|
|
||||||
def test_mask_butterworth_ring(self):
|
def test_mask_butterworth_ring(self):
|
||||||
@ -324,7 +324,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.height, 128)
|
self.assertEqual(im.height, 128)
|
||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
p = im.getpoint(45, 0)
|
p = im(45, 0)
|
||||||
self.assertAlmostEqual(p[0], 1.0, places = 4)
|
self.assertAlmostEqual(p[0], 1.0, places = 4)
|
||||||
v, x, y = im.minpos()
|
v, x, y = im.minpos()
|
||||||
self.assertEqual(x, 64)
|
self.assertEqual(x, 64)
|
||||||
@ -344,7 +344,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
self.assertAlmostEqual(im.max(), 1, places = 2)
|
self.assertAlmostEqual(im.max(), 1, places = 2)
|
||||||
p = im.getpoint(32, 32)
|
p = im(32, 32)
|
||||||
self.assertEqual(p[0], 1.0)
|
self.assertEqual(p[0], 1.0)
|
||||||
|
|
||||||
def test_mask_gaussian(self):
|
def test_mask_gaussian(self):
|
||||||
@ -355,7 +355,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
self.assertAlmostEqual(im.min(), 0, places = 2)
|
self.assertAlmostEqual(im.min(), 0, places = 2)
|
||||||
p = im.getpoint(0, 0)
|
p = im(0, 0)
|
||||||
self.assertEqual(p[0], 0.0)
|
self.assertEqual(p[0], 0.0)
|
||||||
|
|
||||||
def test_mask_gaussian_ring(self):
|
def test_mask_gaussian_ring(self):
|
||||||
@ -365,7 +365,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.height, 128)
|
self.assertEqual(im.height, 128)
|
||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
p = im.getpoint(45, 0)
|
p = im(45, 0)
|
||||||
self.assertAlmostEqual(p[0], 1.0, places = 3)
|
self.assertAlmostEqual(p[0], 1.0, places = 3)
|
||||||
|
|
||||||
def test_mask_ideal_band(self):
|
def test_mask_ideal_band(self):
|
||||||
@ -375,7 +375,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
self.assertAlmostEqual(im.max(), 1, places = 2)
|
self.assertAlmostEqual(im.max(), 1, places = 2)
|
||||||
p = im.getpoint(32, 32)
|
p = im(32, 32)
|
||||||
self.assertEqual(p[0], 1.0)
|
self.assertEqual(p[0], 1.0)
|
||||||
|
|
||||||
def test_mask_ideal(self):
|
def test_mask_ideal(self):
|
||||||
@ -386,7 +386,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
self.assertAlmostEqual(im.min(), 0, places = 2)
|
self.assertAlmostEqual(im.min(), 0, places = 2)
|
||||||
p = im.getpoint(0, 0)
|
p = im(0, 0)
|
||||||
self.assertEqual(p[0], 0.0)
|
self.assertEqual(p[0], 0.0)
|
||||||
|
|
||||||
def test_mask_gaussian_ring(self):
|
def test_mask_gaussian_ring(self):
|
||||||
@ -396,7 +396,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.height, 128)
|
self.assertEqual(im.height, 128)
|
||||||
self.assertEqual(im.bands, 1)
|
self.assertEqual(im.bands, 1)
|
||||||
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
self.assertEqual(im.format, Vips.BandFormat.FLOAT)
|
||||||
p = im.getpoint(45, 0)
|
p = im(45, 0)
|
||||||
self.assertAlmostEqual(p[0], 1.0, places = 3)
|
self.assertAlmostEqual(p[0], 1.0, places = 3)
|
||||||
|
|
||||||
def test_sines(self):
|
def test_sines(self):
|
||||||
@ -429,7 +429,7 @@ class TestCreate(unittest.TestCase):
|
|||||||
self.assertEqual(im.format, Vips.BandFormat.UINT)
|
self.assertEqual(im.format, Vips.BandFormat.UINT)
|
||||||
self.assertEqual(im.width, 128)
|
self.assertEqual(im.width, 128)
|
||||||
self.assertEqual(im.height, 128)
|
self.assertEqual(im.height, 128)
|
||||||
p = im.getpoint(45, 35)
|
p = im(45, 35)
|
||||||
self.assertAlmostEqualObjects(p, [45, 35])
|
self.assertAlmostEqualObjects(p, [45, 35])
|
||||||
|
|
||||||
def test_zone(self):
|
def test_zone(self):
|
||||||
|
@ -38,21 +38,21 @@ class TestDraw(unittest.TestCase):
|
|||||||
def test_draw_circle(self):
|
def test_draw_circle(self):
|
||||||
im = Vips.Image.black(100, 100)
|
im = Vips.Image.black(100, 100)
|
||||||
im = im.draw_circle(100, 50, 50, 25)
|
im = im.draw_circle(100, 50, 50, 25)
|
||||||
pixel = im.getpoint(25, 50)
|
pixel = im(25, 50)
|
||||||
self.assertEqual(len(pixel), 1)
|
self.assertEqual(len(pixel), 1)
|
||||||
self.assertEqual(pixel[0], 100)
|
self.assertEqual(pixel[0], 100)
|
||||||
pixel = im.getpoint(26, 50)
|
pixel = im(26, 50)
|
||||||
self.assertEqual(len(pixel), 1)
|
self.assertEqual(len(pixel), 1)
|
||||||
self.assertEqual(pixel[0], 0)
|
self.assertEqual(pixel[0], 0)
|
||||||
|
|
||||||
im = Vips.Image.black(100, 100)
|
im = Vips.Image.black(100, 100)
|
||||||
im = im.draw_circle(100, 50, 50, 25, fill = True)
|
im = im.draw_circle(100, 50, 50, 25, fill = True)
|
||||||
pixel = im.getpoint(25, 50)
|
pixel = im(25, 50)
|
||||||
self.assertEqual(len(pixel), 1)
|
self.assertEqual(len(pixel), 1)
|
||||||
self.assertEqual(pixel[0], 100)
|
self.assertEqual(pixel[0], 100)
|
||||||
pixel = im.getpoint(26, 50)
|
pixel = im(26, 50)
|
||||||
self.assertEqual(pixel[0], 100)
|
self.assertEqual(pixel[0], 100)
|
||||||
pixel = im.getpoint(24, 50)
|
pixel = im(24, 50)
|
||||||
self.assertEqual(pixel[0], 0)
|
self.assertEqual(pixel[0], 0)
|
||||||
|
|
||||||
def test_draw_flood(self):
|
def test_draw_flood(self):
|
||||||
@ -82,10 +82,10 @@ class TestDraw(unittest.TestCase):
|
|||||||
def test_draw_line(self):
|
def test_draw_line(self):
|
||||||
im = Vips.Image.black(100, 100)
|
im = Vips.Image.black(100, 100)
|
||||||
im = im.draw_line(100, 0, 0, 100, 0)
|
im = im.draw_line(100, 0, 0, 100, 0)
|
||||||
pixel = im.getpoint(0, 0)
|
pixel = im(0, 0)
|
||||||
self.assertEqual(len(pixel), 1)
|
self.assertEqual(len(pixel), 1)
|
||||||
self.assertEqual(pixel[0], 100)
|
self.assertEqual(pixel[0], 100)
|
||||||
pixel = im.getpoint(0, 1)
|
pixel = im(0, 1)
|
||||||
self.assertEqual(len(pixel), 1)
|
self.assertEqual(len(pixel), 1)
|
||||||
self.assertEqual(pixel[0], 0)
|
self.assertEqual(pixel[0], 0)
|
||||||
|
|
||||||
|
@ -96,7 +96,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
def jpeg_valid(self, im):
|
def jpeg_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(a, [6, 5, 3])
|
self.assertAlmostEqualObjects(a, [6, 5, 3])
|
||||||
profile = im.get_value("icc-profile-data")
|
profile = im.get_value("icc-profile-data")
|
||||||
self.assertEqual(len(profile), 1352)
|
self.assertEqual(len(profile), 1352)
|
||||||
@ -115,7 +115,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
def png_valid(self, im):
|
def png_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(a, [38671.0, 33914.0, 26762.0])
|
self.assertAlmostEqualObjects(a, [38671.0, 33914.0, 26762.0])
|
||||||
self.assertEqual(im.width, 290)
|
self.assertEqual(im.width, 290)
|
||||||
self.assertEqual(im.height, 442)
|
self.assertEqual(im.height, 442)
|
||||||
@ -132,7 +132,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
def tiff_valid(self, im):
|
def tiff_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(a, [38671.0, 33914.0, 26762.0])
|
self.assertAlmostEqualObjects(a, [38671.0, 33914.0, 26762.0])
|
||||||
self.assertEqual(im.width, 290)
|
self.assertEqual(im.width, 290)
|
||||||
self.assertEqual(im.height, 442)
|
self.assertEqual(im.height, 442)
|
||||||
@ -159,7 +159,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
def gif_valid(self, im):
|
def gif_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqual(a, [33, 33, 33])
|
self.assertAlmostEqual(a, [33, 33, 33])
|
||||||
self.assertEqual(im.width, 159)
|
self.assertEqual(im.width, 159)
|
||||||
self.assertEqual(im.height, 203)
|
self.assertEqual(im.height, 203)
|
||||||
@ -174,7 +174,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
def webp_valid(self, im):
|
def webp_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(a, [71, 166, 236])
|
self.assertAlmostEqualObjects(a, [71, 166, 236])
|
||||||
self.assertEqual(im.width, 550)
|
self.assertEqual(im.width, 550)
|
||||||
self.assertEqual(im.height, 368)
|
self.assertEqual(im.height, 368)
|
||||||
@ -186,7 +186,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
|
|
||||||
def test_analyzeload(self):
|
def test_analyzeload(self):
|
||||||
def analyze_valid(self, im):
|
def analyze_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqual(a[0], 3335)
|
self.assertAlmostEqual(a[0], 3335)
|
||||||
self.assertEqual(im.width, 128)
|
self.assertEqual(im.width, 128)
|
||||||
self.assertEqual(im.height, 8064)
|
self.assertEqual(im.height, 8064)
|
||||||
@ -200,7 +200,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
def matlab_valid(self, im):
|
def matlab_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(a, [38671.0, 33914.0, 26762.0])
|
self.assertAlmostEqualObjects(a, [38671.0, 33914.0, 26762.0])
|
||||||
self.assertEqual(im.width, 290)
|
self.assertEqual(im.width, 290)
|
||||||
self.assertEqual(im.height, 442)
|
self.assertEqual(im.height, 442)
|
||||||
@ -214,7 +214,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
def exr_valid(self, im):
|
def exr_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(a, [0.124512, 0.159668,
|
self.assertAlmostEqualObjects(a, [0.124512, 0.159668,
|
||||||
0.040375, 1.0],
|
0.040375, 1.0],
|
||||||
places = 5)
|
places = 5)
|
||||||
@ -230,7 +230,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
def fits_valid(self, im):
|
def fits_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(a, [-0.165013, -0.148553, 1.09122,
|
self.assertAlmostEqualObjects(a, [-0.165013, -0.148553, 1.09122,
|
||||||
-0.942242],
|
-0.942242],
|
||||||
places = 5)
|
places = 5)
|
||||||
@ -247,7 +247,7 @@ class TestForeign(unittest.TestCase):
|
|||||||
return
|
return
|
||||||
|
|
||||||
def openslide_valid(self, im):
|
def openslide_valid(self, im):
|
||||||
a = im.getpoint(10, 10)
|
a = im(10, 10)
|
||||||
self.assertAlmostEqualObjects(a, [244, 250, 243, 255])
|
self.assertAlmostEqualObjects(a, [244, 250, 243, 255])
|
||||||
self.assertEqual(im.width, 2220)
|
self.assertEqual(im.width, 2220)
|
||||||
self.assertEqual(im.height, 2967)
|
self.assertEqual(im.height, 2967)
|
||||||
|
@ -42,7 +42,7 @@ class TestHistogram(unittest.TestCase):
|
|||||||
|
|
||||||
cum = im.hist_cum()
|
cum = im.hist_cum()
|
||||||
|
|
||||||
p = cum.getpoint(255, 0)
|
p = cum(255, 0)
|
||||||
self.assertEqual(p[0], sum)
|
self.assertEqual(p[0], sum)
|
||||||
|
|
||||||
def test_hist_equal(self):
|
def test_hist_equal(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user