test region_shrink

just sets the option, does not verify accuracy :(
This commit is contained in:
John Cupitt 2018-07-07 17:07:35 +01:00
parent 92ff5be4b8
commit 2695916afb
2 changed files with 121 additions and 124 deletions

108
README.md
View File

@ -41,7 +41,7 @@ https://github.com/jcupitt/libvips/releases
Untar, then in the libvips directory you should just be able to do: Untar, then in the libvips directory you should just be able to do:
$ ./configure $ ./configure
Check the summary at the end of `configure` carefully. libvips must have Check the summary at the end of `configure` carefully. libvips must have
`build-essential`, `pkg-config`, `glib2.0-dev`, `libexpat1-dev`. `build-essential`, `pkg-config`, `glib2.0-dev`, `libexpat1-dev`.
@ -53,8 +53,8 @@ of the things that libvips can be configured to use.
Once `configure` is looking OK, compile and install with the usual: Once `configure` is looking OK, compile and install with the usual:
$ make $ make
$ sudo make install $ sudo make install
By default this will install files to `/usr/local`. By default this will install files to `/usr/local`.
@ -66,11 +66,15 @@ Windows](https://github.com/jcupitt/libvips/wiki/Build-for-Windows) and
Do a basic test of your build with: Do a basic test of your build with:
$ make check $ make check
Run the libvips test suite with: Run the libvips test suite with:
$ pytest $ pytest
Run a specific test with:
$ pytest test/test-suite/test_foreign.py -k test_tiff
YOu will need to install a variety of Python packages for this, including YOu will need to install a variety of Python packages for this, including
pyvips, the libvips Python binding. pyvips, the libvips Python binding.
@ -79,78 +83,78 @@ pyvips, the libvips Python binding.
Checkout the latest sources with: Checkout the latest sources with:
$ git clone git://github.com/jcupitt/libvips.git $ git clone git://github.com/jcupitt/libvips.git
Building from git needs more packages, you'll need at least `swig`, `gtk-doc` Building from git needs more packages, you'll need at least `swig`, `gtk-doc`
and `gobject-introspection`, see the dependencies section below. For example: and `gobject-introspection`, see the dependencies section below. For example:
$ brew install gtk-doc swig $ brew install gtk-doc swig
Then build the build system with: Then build the build system with:
$ ./autogen.sh $ ./autogen.sh
Debug build: Debug build:
$ CFLAGS="-g -Wall" CXXFLAGS="-g -Wall" \ $ CFLAGS="-g -Wall" CXXFLAGS="-g -Wall" \
./configure --prefix=/home/john/vips --enable-debug ./configure --prefix=/home/john/vips --enable-debug
$ make $ make
$ make install $ make install
Leak check: Leak check:
$ export G_DEBUG=gc-friendly $ export G_DEBUG=gc-friendly
$ valgrind --suppressions=libvips.supp \ $ valgrind --suppressions=libvips.supp \
--leak-check=yes \ --leak-check=yes \
vips ... > vips-vg.log 2>&1 vips ... > vips-vg.log 2>&1
Memory error debug: Memory error debug:
$ valgrind --vgdb=yes --vgdb-error=0 vips ... $ valgrind --vgdb=yes --vgdb-error=0 vips ...
valgrind threading check: valgrind threading check:
$ valgrind --tool=helgrind vips ... > vips-vg.log 2>&1 $ valgrind --tool=helgrind vips ... > vips-vg.log 2>&1
Clang build: Clang build:
$ CC=clang CXX=clang++ ./configure --prefix=/home/john/vips $ CC=clang CXX=clang++ ./configure --prefix=/home/john/vips
Clang static analysis: Clang static analysis:
$ scan-build ./configure --disable-introspection --disable-debug $ scan-build ./configure --disable-introspection --disable-debug
$ scan-build -o scan -v make $ scan-build -o scan -v make
$ scan-view scan/2013-11-22-2 $ scan-view scan/2013-11-22-2
Clang dynamic analysis: Clang dynamic analysis:
$ FLAGS="-O1 -g -fsanitize=address" $ FLAGS="-O1 -g -fsanitize=address"
$ FLAGS="$FLAGS -fno-omit-frame-pointer -fno-optimize-sibling-calls" $ FLAGS="$FLAGS -fno-omit-frame-pointer -fno-optimize-sibling-calls"
$ CC=clang CXX=clang++ LD=clang \ $ CC=clang CXX=clang++ LD=clang \
CFLAGS="$FLAGS" CXXFLAGS="$FLAGS" LDFLAGS=-fsanitize=address \ CFLAGS="$FLAGS" CXXFLAGS="$FLAGS" LDFLAGS=-fsanitize=address \
./configure --prefix=/home/john/vips ./configure --prefix=/home/john/vips
$ FLAGS="-O1 -g -fsanitize=thread" $ FLAGS="-O1 -g -fsanitize=thread"
$ FLAGS="$FLAGS -fPIC" $ FLAGS="$FLAGS -fPIC"
$ FLAGS="$FLAGS -fno-omit-frame-pointer -fno-optimize-sibling-calls" $ FLAGS="$FLAGS -fno-omit-frame-pointer -fno-optimize-sibling-calls"
$ CC=clang CXX=clang++ LD=clang \ $ CC=clang CXX=clang++ LD=clang \
CFLAGS="$FLAGS" CXXFLAGS="$FLAGS" \ CFLAGS="$FLAGS" CXXFLAGS="$FLAGS" \
LDFLAGS="-fsanitize=thread -fPIC" \ LDFLAGS="-fsanitize=thread -fPIC" \
./configure --prefix=/home/john/vips \ ./configure --prefix=/home/john/vips \
--without-magick \ --without-magick \
--disable-introspection --disable-introspection
$ G_DEBUG=gc-friendly vips copy ~/pics/k2.jpg x.jpg >& log $ G_DEBUG=gc-friendly vips copy ~/pics/k2.jpg x.jpg >& log
Build with the GCC auto-vectorizer and diagnostics (or just -O3): Build with the GCC auto-vectorizer and diagnostics (or just -O3):
$ FLAGS="-O2 -march=native -ffast-math" $ FLAGS="-O2 -march=native -ffast-math"
$ FLAGS="$FLAGS -ftree-vectorize -fdump-tree-vect-details" $ FLAGS="$FLAGS -ftree-vectorize -fdump-tree-vect-details"
$ CFLAGS="$FLAGS" CXXFLAGS="$FLAGS" \ $ CFLAGS="$FLAGS" CXXFLAGS="$FLAGS" \
./configure --prefix=/home/john/vips ./configure --prefix=/home/john/vips
Static analysis with: Static analysis with:
$ cppcheck --force --enable=style . &> cppcheck.log $ cppcheck --force --enable=style . &> cppcheck.log
# Dependencies # Dependencies
@ -168,19 +172,19 @@ them in the default path and in `$prefix`. If you have installed your own
versions of these libraries in a different location, libvips will not see versions of these libraries in a different location, libvips will not see
them. Use switches to libvips configure like: them. Use switches to libvips configure like:
./configure --prefix=/Users/john/vips \ ./configure --prefix=/Users/john/vips \
--with-giflib-includes=/opt/local/include \ --with-giflib-includes=/opt/local/include \
--with-giflib-libraries=/opt/local/lib \ --with-giflib-libraries=/opt/local/lib \
--with-tiff-includes=/opt/local/include \ --with-tiff-includes=/opt/local/include \
--with-tiff-libraries=/opt/local/lib \ --with-tiff-libraries=/opt/local/lib \
--with-jpeg-includes=/opt/local/include \ --with-jpeg-includes=/opt/local/include \
--with-jpeg-libraries=/opt/local/lib --with-jpeg-libraries=/opt/local/lib
or perhaps: or perhaps:
CFLAGS="-g -Wall -I/opt/local/include -L/opt/local/lib" \ CFLAGS="-g -Wall -I/opt/local/include -L/opt/local/lib" \
CXXFLAGS="-g -Wall -I/opt/local/include -L/opt/local/lib" \ CXXFLAGS="-g -Wall -I/opt/local/include -L/opt/local/lib" \
./configure --without-python --prefix=/Users/john/vips ./configure --without-python --prefix=/Users/john/vips
to get libvips to see your builds. to get libvips to see your builds.

View File

@ -320,54 +320,58 @@ class TestForeign:
assert x1.height == x2.width assert x1.height == x2.width
# OME support in 8.5 # OME support in 8.5
if pyvips.at_least_libvips(8, 5): x = pyvips.Image.new_from_file(OME_FILE)
x = pyvips.Image.new_from_file(OME_FILE) assert x.width == 439
assert x.width == 439 assert x.height == 167
assert x.height == 167 page_height = x.height
page_height = x.height
x = pyvips.Image.new_from_file(OME_FILE, n=-1) x = pyvips.Image.new_from_file(OME_FILE, n=-1)
assert x.width == 439 assert x.width == 439
assert x.height == page_height * 15 assert x.height == page_height * 15
x = pyvips.Image.new_from_file(OME_FILE, page=1, n=-1) x = pyvips.Image.new_from_file(OME_FILE, page=1, n=-1)
assert x.width == 439 assert x.width == 439
assert x.height == page_height * 14 assert x.height == page_height * 14
x = pyvips.Image.new_from_file(OME_FILE, page=1, n=2) x = pyvips.Image.new_from_file(OME_FILE, page=1, n=2)
assert x.width == 439 assert x.width == 439
assert x.height == page_height * 2 assert x.height == page_height * 2
x = pyvips.Image.new_from_file(OME_FILE, n=-1) x = pyvips.Image.new_from_file(OME_FILE, n=-1)
assert x(0, 166)[0] == 96 assert x(0, 166)[0] == 96
assert x(0, 167)[0] == 0 assert x(0, 167)[0] == 0
assert x(0, 168)[0] == 1 assert x(0, 168)[0] == 1
filename = temp_filename(self.tempdir, '.tif') filename = temp_filename(self.tempdir, '.tif')
x.write_to_file(filename) x.write_to_file(filename)
x = pyvips.Image.new_from_file(filename, n=-1) x = pyvips.Image.new_from_file(filename, n=-1)
assert x.width == 439 assert x.width == 439
assert x.height == page_height * 15 assert x.height == page_height * 15
assert x(0, 166)[0] == 96 assert x(0, 166)[0] == 96
assert x(0, 167)[0] == 0 assert x(0, 167)[0] == 0
assert x(0, 168)[0] == 1 assert x(0, 168)[0] == 1
# pyr save to buffer added in 8.6 # pyr save to buffer added in 8.6
if pyvips.at_least_libvips(8, 6): x = pyvips.Image.new_from_file(TIF_FILE)
x = pyvips.Image.new_from_file(TIF_FILE) buf = x.tiffsave_buffer(tile=True, pyramid=True)
buf = x.tiffsave_buffer(tile=True, pyramid=True) filename = temp_filename(self.tempdir, '.tif')
filename = temp_filename(self.tempdir, '.tif') x.tiffsave(filename, tile=True, pyramid=True)
x.tiffsave(filename, tile=True, pyramid=True) with open(filename, 'rb') as f:
with open(filename, 'rb') as f: buf2 = f.read()
buf2 = f.read() assert len(buf) == len(buf2)
assert len(buf) == len(buf2)
a = pyvips.Image.new_from_buffer(buf, "", page=2) a = pyvips.Image.new_from_buffer(buf, "", page=2)
b = pyvips.Image.new_from_buffer(buf2, "", page=2) b = pyvips.Image.new_from_buffer(buf2, "", page=2)
assert a.width == b.width assert a.width == b.width
assert a.height == b.height assert a.height == b.height
assert a.avg() == b.avg() assert a.avg() == b.avg()
# region-shrink added in 8.7
x = pyvips.Image.new_from_file(TIF_FILE)
buf = x.tiffsave_buffer(tile=True, pyramid=True, region_shrink="mean")
buf = x.tiffsave_buffer(tile=True, pyramid=True, region_shrink="mode")
buf = x.tiffsave_buffer(tile=True, pyramid=True, region_shrink="median")
@skip_if_no("magickload") @skip_if_no("magickload")
def test_magickload(self): def test_magickload(self):
@ -637,7 +641,7 @@ class TestForeign:
self.save_buffer_tempfile("radsave_buffer", ".hdr", self.save_buffer_tempfile("radsave_buffer", ".hdr",
self.rad, max_diff=0) self.rad, max_diff=0)
@skip_if_no("dzsaveload") @skip_if_no("dzsave")
def test_dzsave(self): def test_dzsave(self):
# dzsave is hard to test, there are so many options # dzsave is hard to test, there are so many options
# test each option separately and hope they all function together # test each option separately and hope they all function together
@ -706,16 +710,14 @@ class TestForeign:
# with 511x511, it'll fit exactly into 2x2 -- we we actually generate # with 511x511, it'll fit exactly into 2x2 -- we we actually generate
# 3x3, since we output the overlaps # 3x3, since we output the overlaps
# 8.6 revised the rules on overlaps, so don't test earlier than that filename = temp_filename(self.tempdir, '')
if pyvips.base.at_least_libvips(8, 6): self.colour.crop(0, 0, 511, 511).dzsave(filename, layout="google",
filename = temp_filename(self.tempdir, '') overlap=1, depth="one")
self.colour.crop(0, 0, 511, 511).dzsave(filename, layout="google",
overlap=1, depth="one")
x = pyvips.Image.new_from_file(filename + "/0/2/2.jpg") x = pyvips.Image.new_from_file(filename + "/0/2/2.jpg")
assert x.width == 256 assert x.width == 256
assert x.height == 256 assert x.height == 256
assert not os.path.exists(filename + "/0/3/3.jpg") assert not os.path.exists(filename + "/0/3/3.jpg")
# default zoomify layout # default zoomify layout
filename = temp_filename(self.tempdir, '') filename = temp_filename(self.tempdir, '')
@ -730,10 +732,6 @@ class TestForeign:
# test zip output # test zip output
filename = temp_filename(self.tempdir, '.zip') filename = temp_filename(self.tempdir, '.zip')
self.colour.dzsave(filename) self.colour.dzsave(filename)
# before 8.5.8, you needed a gc on pypy to flush small zip output to
# disc
if not pyvips.base.at_least_libvips(8, 6):
gc.collect()
assert os.path.exists(filename) assert os.path.exists(filename)
assert not os.path.exists(filename + "_files") assert not os.path.exists(filename + "_files")
assert not os.path.exists(filename + ".dzi") assert not os.path.exists(filename + ".dzi")
@ -741,10 +739,6 @@ class TestForeign:
# test compressed zip output # test compressed zip output
filename2 = temp_filename(self.tempdir, '.zip') filename2 = temp_filename(self.tempdir, '.zip')
self.colour.dzsave(filename2, compression=-1) self.colour.dzsave(filename2, compression=-1)
# before 8.5.8, you needed a gc on pypy to flush small zip output to
# disc
if not pyvips.base.at_least_libvips(8, 6):
gc.collect()
assert os.path.exists(filename2) assert os.path.exists(filename2)
assert os.path.getsize(filename2) < os.path.getsize(filename) assert os.path.getsize(filename2) < os.path.getsize(filename)
@ -771,24 +765,23 @@ class TestForeign:
assert y.height == 513 assert y.height == 513
# test save to memory buffer # test save to memory buffer
if have("dzsave_buffer"): filename = temp_filename(self.tempdir, '.zip')
filename = temp_filename(self.tempdir, '.zip') base = os.path.basename(filename)
base = os.path.basename(filename) root, ext = os.path.splitext(base)
root, ext = os.path.splitext(base)
self.colour.dzsave(filename) self.colour.dzsave(filename)
# before 8.5.8, you needed a gc on pypy to flush small zip with open(filename, 'rb') as f:
# output to disc buf1 = f.read()
if not pyvips.base.at_least_libvips(8, 6): buf2 = self.colour.dzsave_buffer(basename=root)
gc.collect() assert len(buf1) == len(buf2)
with open(filename, 'rb') as f:
buf1 = f.read()
buf2 = self.colour.dzsave_buffer(basename=root)
assert len(buf1) == len(buf2)
# we can't test the bytes are exactly equal -- the timestamps will # we can't test the bytes are exactly equal -- the timestamps will
# be different # be different
# added in 8.7
buf = self.colour.dzsave_buffer(region_shrink="mean")
buf = self.colour.dzsave_buffer(region_shrink="mode")
buf = self.colour.dzsave_buffer(region_shrink="median")
if __name__ == '__main__': if __name__ == '__main__':
pytest.main() pytest.main()