- try disabling turbo-boost? see http://blog.tube42.se/?p=1225 for i in {0..3}; do sudo cpufreq-set -f 2.5GHz -c $i; done -r doesn't seem to work verify with cpufreq-info | more - lock CPUs at 2.5GHz $ time vips sharpen k2.jpg x.jpg --radius 20 --vips-concurrency=1 real 0m1.687s user 0m1.694s sys 0m0.028s $ time vips sharpen k2.jpg x.jpg --radius 20 --vips-concurrency=2 real 0m0.967s user 0m1.876s sys 0m0.028s 1.75x speedup $ time vips sharpen k2.jpg x.jpg --radius 20 --vips-concurrency=4 real 0m0.864s user 0m3.175s sys 0m0.060s 1.95x speedup - floating CPUs $ time vips sharpen k2.jpg x.jpg --radius 20 --vips-concurrency=1 real 0m1.395s user 0m1.414s sys 0m0.016s $ time vips sharpen k2.jpg x.jpg --radius 20 --vips-concurrency=2 real 0m0.841s user 0m1.626s sys 0m0.028s 1.65x speedup $ time vips sharpen k2.jpg x.jpg --radius 20 --vips-concurrency=4 real 0m0.755s user 0m2.759s sys 0m0.048s 1.85x speedup 1.687 vs 1.395 is about a 20% speedup ... turbo-boost! $ time vips sharpen k2.v x.v --radius 20 --vips-profile recording profile in vips-profile.txt real 0m1.187s user 0m4.167s sys 0m0.116s $ vipsprofile reading from vips-profile.txt loaded 3781 events last time = 1.120263 name alive wait% work% unknown% worker 20 1.1 0.19 98.7 1.09 worker 21 1.1 0.0292 98.1 1.9 worker 22 1.1 0.0228 98 1.96 worker 23 1.1 0.124 97.9 1.94 wbuffer 24 1.1 98.9 1.14 0.00236 wbuffer 25 1.1 98.9 1.15 0.00209 main 26 1.2 93.5 0 6.54 writing to vips-profile.svg $ eog vips-profile.svg - seen some leaks from vips dzsave --layout google wtc.jpg x investigate - vips_gaussblur() should switch to float prec if given a float image? same for vips_conv()? maybe precision is a dumb thing - do morph quickly as simple wrappers over the vips7 operations - support --strip for other writers - vipsthumbnail could shrink-on-load openslide and pyr tiff as well? - look again at gcc auto-vectorisation, what would we need to do to use this? - how about top -d 0.01 | grep vips > log to watch RES at 0.01s intervals? note on memuse page - use the webp advanced encoding api to set a write function for webp save to file - use g_log() instead of vips_info() - object construction is threadsafe, but class construction is not https://github.com/jcupitt/libvips/issues/64 we worked around this by adding vips_class_ping_all() to dsave build, but this is not a good fix find out why vips class construct fails, test on seurat, kirk's 24-core monster - quadratic doesn't work for order 3 start to get jaggies on lines --- the 3rd differential isn't being initialised correctly for the sub-region? seems fine vertically, only get errors on horizontal tile boundaries because we step across tiles left to right: y doesn't change, only x does - the operation cache needs to detect invalidate tricky! perhaps have operations always watching all of their inputs and resignalling "invalidate" themselves cache then just needs to watch for "invalidate" on operations it tracks need to add an "invalidate" signal to operation mosaic ====== - balance should use new meta stuff - histogram balance option? resample ======== - check mosaic1, global_balance, similarity etc. use of im__affine how can we move them to im_affinei ? - perspective transform with a matrix ... base it on the Lenz transformer, but partial foreign ======= - magick2vips should spot ICC profiles and attach them as meta - interlaced jpg needs massive memory, we should have two jpg read modes, like png - add more sequential mode readers $ grep -l write_line *.c csv.c matlab.c openexr2vips.c ppm.c radiance.c - foreign docs come up as "VipsForeignSave", annoying, why? - add nifti support http://niftilib.sourceforge.net/ - add matlab write - im_exr2vips can now use c++ api see TODO notes in openexr read (though they all need more openexr C API) consider openexr write - magick should set some header field for n_frames and frame_height? see also analyze - im_csv2vips() could use "-" for filename to mean stdin but then we'd have to read to a malloced buffer of some sort rather than an image, since we might need to grow it during the read, since we couldn't then seek packaging ========= - test _O_TEMPORARY thing on Windows - do we bundle "convert" in the OS X / win32 builds? if we don't we should convolution =========== - revisit orc conv use an 8.8 accumulator ... build the scale into the 8.8 coeffs ... no div at the end, just a shift need 8 x 8.8 -> 8.8 for each coeff though - im_conv()/im_morph() could have more than 10 programs? try 20 and see if we still have a speedup make a base class for vector area operations with a matrix with three vfuncs for init / generate code for one element / end and a gslist of programs, use that as the base for morph and conv wait for vipsobject for this - we have aconv and aconvsep test timing, make sure it;s worth having a separate aconvsep version if it is, make im_aconvsep an optimisation: call im_aconvsep_raw() from vips_conv() if mask width or height == 1 and prec == APPROX now we can get rid of im_aconvsep() since it's just vips_convsep() with prec set to approx aconv needs some more work, get it going at least with gaussian arithmetic ========== - avg/dev etc. should uncode images? eg. labq2lab etc. how about ifthenelse? - HAVE_HYPOT could define a hypot() macro? - fix a better NaN policy should we not generate images containing NaN (eg. divide tries to avoid /0), or should vips_max() etc. try to avoid NaN in images (eg. vips_max() takes a lot a care to skip NaN, though vips_stats() does not)? iofuncs ======= - need vips_image_invalidate_area() - look at libpeas for plugin support http://live.gnome.org/Libpeas - how about vips max add[babe.jpg,babe2.jpg] does that make any sense? vips copy add[babe.jpg,add[babe2.jpg,babe3.jpg]] sum.v perhaps use curly brackets for code? vips max add{babe.jpg,babe2.jpg} no brackets or square brackets for options - transform_g_string_array_image() can't handle quoted strings, so filenames with spaces will break is there an easy fix? can we reuse code from the csv parser? the csv parser just parses FILE* streams, we'd need to break it out - note member free stuff in vipsobject docs should boxed get freed in finalise rather than dispose? vipsobject has few docs atm :( - vips_object_set_argument_from_string() needs more arg types must be some way to make this more automatic - generate the code for vips_add() etc. automatically? it might be nice to have them all in one place at least - what does G_UNLIKELY() do? can we use it? - look into G_GNUC_DEPRECATED for back compat in vips8 - should im_rwcheck() copy to disc? maybe im_rwcheck_disc() copies to im->filename and maps that rather awkward to do atm with the way check.c is structured swig ==== - swig is not wrapping im_project() correctly ... returns an extra VImage via a param - doc strings would be nice, read the SWIG notes on this new bindings ============ - new binding is still missing constants how do boxed types work? confusing we need to be able to make a VipsArrayDouble - Vips.Image has members like chain, __subclasshook__ etc etc, are we really subclassing it correctly? - add __add__ etc overloads freq_filt ========= - fft with odd width or height is broken ... DC ends up in the wrong place libvipsCC ========= - need new C++ API - need an im_init_world() for C++ which does cmd-line args too, so C++ progs can get --vips-progress and stuff automatically tools ===== - need a way to make the vips.1 etc. man pages gtk has things like docs/reference/gtk/gtk-update-icon-cache.xml and man pages are made from that with xslt - get rid of a lot of the command-line programs, who wants to write a man page for batch_image_convert etc yuk - can we make man pages for the API as well? probably not from googling a bit - rename header, edvips as vipsheader, vipsedit maybe have back compat links? new operations ============== - bilateral filtering, see: http://en.wikipedia.org/wiki/Bilateral_filter http://www.shellandslate.com/fastmedian.html http://people.csail.mit.edu/sparis/bf_course/ also a mail from Martin Breidt has links to several fast free C implementations - http://en.wikipedia.org/wiki/Otsu%27s_method - non-linear sharpen: replace each pixel by the lightest or darkest neighbour depending on which is closer in value - look at There is an order 1 algorithm for doing medians over boxes (truly O(1) per pixel: I checked it carefully; it's like doing means over boxes in order 1 per pixel) in OpenCV since February 2012 I think, due to Perreault (and Hebert). It appears to be well respected, at least for 8-bit medians. Very memory intensive. Simple and elegant. No clue if it fits VIPS well (probably not?). Article: nomis80.org/ctmf.pdf - check CMC equations against web http://en.wikipedia.org/wiki/Color_difference#CMC_l:c_.281984.29 - see http://www.dentistry.bham.ac.uk/landinig/software/cdeconv/cdeconv.html sounds useful for BM?