conversion tests done

This commit is contained in:
John Cupitt 2014-09-29 21:40:08 +01:00
parent 86910e2e72
commit d9ee892077
3 changed files with 118 additions and 11 deletions

View File

@ -86,9 +86,9 @@
/** /**
* VipsAngle: * VipsAngle:
* @VIPS_ANGLE_D0: no rotate * @VIPS_ANGLE_D0: no rotate
* @VIPS_ANGLE_D90: 90 degrees anti-clockwise * @VIPS_ANGLE_D90: 90 degrees clockwise
* @VIPS_ANGLE_D180: 180 degree rotate * @VIPS_ANGLE_D180: 180 degree rotate
* @VIPS_ANGLE_D270: 90 degrees clockwise * @VIPS_ANGLE_D270: 90 degrees anti-clockwise
* *
* See vips_rot() and so on. * See vips_rot() and so on.
* *
@ -100,13 +100,13 @@
/** /**
* VipsAngle45: * VipsAngle45:
* @VIPS_ANGLE45_D0: no rotate * @VIPS_ANGLE45_D0: no rotate
* @VIPS_ANGLE45_D45: 45 degrees anti-clockwise * @VIPS_ANGLE45_D45: 45 degrees clockwise
* @VIPS_ANGLE45_D90: 90 degrees anti-clockwise * @VIPS_ANGLE45_D90: 90 degrees clockwise
* @VIPS_ANGLE45_D135: 135 degrees anti-clockwise * @VIPS_ANGLE45_D135: 135 degrees clockwise
* @VIPS_ANGLE45_D180: 180 degrees * @VIPS_ANGLE45_D180: 180 degrees
* @VIPS_ANGLE45_D225: 135 degrees clockwise * @VIPS_ANGLE45_D225: 135 degrees anti-clockwise
* @VIPS_ANGLE45_D270: 90 degrees clockwise * @VIPS_ANGLE45_D270: 90 degrees anti-clockwise
* @VIPS_ANGLE45_D315: 45 degrees clockwise * @VIPS_ANGLE45_D315: 45 degrees anti-clockwise
* *
* See vips_rot45() and so on. * See vips_rot45() and so on.
* *

10
python/test_all.py Executable file
View File

@ -0,0 +1,10 @@
#!/usr/bin/python
import unittest
from test_arithmetic import TestArithmetic
from test_colour import TestColour
from test_conversion import TestConversion
if __name__ == '__main__':
unittest.main()

View File

@ -54,6 +54,25 @@ rot45_angles = [Vips.Angle45.D0,
Vips.Angle45.D270, Vips.Angle45.D270,
Vips.Angle45.D315] Vips.Angle45.D315]
rot45_angle_bonds = [Vips.Angle45.D0,
Vips.Angle45.D315,
Vips.Angle45.D270,
Vips.Angle45.D225,
Vips.Angle45.D180,
Vips.Angle45.D135,
Vips.Angle45.D90,
Vips.Angle45.D45]
rot_angles = [Vips.Angle.D0,
Vips.Angle.D90,
Vips.Angle.D180,
Vips.Angle.D270]
rot_angle_bonds = [Vips.Angle.D0,
Vips.Angle.D270,
Vips.Angle.D180,
Vips.Angle.D90]
# an expanding zip ... if either of the args is not a list, duplicate it down # an expanding zip ... if either of the args is not a list, duplicate it down
# the other # the other
def zip_expand(x, y): def zip_expand(x, y):
@ -487,14 +506,14 @@ class TestConversion(unittest.TestCase):
for y in all_formats: for y in all_formats:
main = self.mono.cast(x) main = self.mono.cast(x)
sub = self.colour.cast(y) sub = self.colour.cast(y)
r = main.insert(sub, 10, 10, expand = True, background = 128) r = main.insert(sub, 10, 10, expand = True, background = 100)
self.assertEqual(r.width, main.width + 10) self.assertEqual(r.width, main.width + 10)
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.getpoint(r.width - 5, 5)
self.assertAlmostEqualObjects(a, [128, 128, 128]) self.assertAlmostEqualObjects(a, [100, 100, 100])
def test_msb(self): def test_msb(self):
for fmt in unsigned_formats: for fmt in unsigned_formats:
@ -577,11 +596,89 @@ class TestConversion(unittest.TestCase):
self.assertAlmostEqualObjects(before, after) self.assertAlmostEqualObjects(before, after)
def test_rot45(self): def test_rot45(self):
# test has a quarter-circle in the bottom right
test = self.colour.crop(0, 0, 51, 51) test = self.colour.crop(0, 0, 51, 51)
for fmt in all_formats: for fmt in all_formats:
im = test.cast(fmt) im = test.cast(fmt)
im.write_to_file("x.v") im2 = im.rot45()
before = im.getpoint(50, 50)
after = im2.getpoint(25, 50)
self.assertAlmostEqualObjects(before, after)
for a, b in zip(rot45_angles, rot45_angle_bonds):
im2 = im.rot45(angle = a)
after = im2.rot45(angle = b)
diff = (after - im).abs().max()
self.assertEqual(diff, 0)
def test_rot(self):
# test has a quarter-circle in the bottom right
test = self.colour.crop(0, 0, 51, 51)
for fmt in all_formats:
im = test.cast(fmt)
im2 = im.rot(Vips.Angle.D90)
before = im.getpoint(50, 50)
after = im2.getpoint(0, 50)
self.assertAlmostEqualObjects(before, after)
for a, b in zip(rot_angles, rot_angle_bonds):
im2 = im.rot(a)
after = im2.rot(b)
diff = (after - im).abs().max()
self.assertEqual(diff, 0)
def test_scale(self):
for fmt in noncomplex_formats:
test = self.colour.cast(fmt)
im = test.scale()
self.assertEqual(im.max(), 255)
self.assertEqual(im.min(), 0)
im = test.scale(log = True)
self.assertEqual(im.max(), 255)
def test_subsample(self):
for fmt in all_formats:
test = self.colour.cast(fmt)
im = test.subsample(3, 3)
self.assertEqual(im.width, test.width / 3)
self.assertEqual(im.height, test.height / 3)
before = test.getpoint(60, 60)
after = im.getpoint(20, 20)
self.assertAlmostEqualObjects(before, after)
def test_zoom(self):
for fmt in all_formats:
test = self.colour.cast(fmt)
im = test.zoom(3, 3)
self.assertEqual(im.width, test.width * 3)
self.assertEqual(im.height, test.height * 3)
before = test.getpoint(50, 50)
after = im.getpoint(150, 150)
self.assertAlmostEqualObjects(before, after)
def test_wrap(self):
for fmt in all_formats:
test = self.colour.cast(fmt)
im = test.wrap()
self.assertEqual(im.width, test.width)
self.assertEqual(im.height, test.height)
before = test.getpoint(0, 0)
after = im.getpoint(50, 50)
self.assertAlmostEqualObjects(before, after)
before = test.getpoint(50, 50)
after = im.getpoint(0, 0)
self.assertAlmostEqualObjects(before, after)
if __name__ == '__main__': if __name__ == '__main__':
unittest.main() unittest.main()