[ImageJ-devel] ImgLib2 Release Announcement
Tobias Pietzsch
pietzsch at mpi-cbg.de
Tue Dec 16 08:12:39 CST 2014
Hi everyone,
We are happy to announce the first stable release version of the ImgLib2 core library!
This release was a central goal of the recent hackathon at LOCI in Madison, during the week of October 13 - 17.
The ImgLib2 core library is now available on Maven Central [1], and the source code for all ImgLib2 projects is accessible on GitHub [2].
Like the SciJava and ImageJ2 projects, ImgLib2 releases now follow the “semantic versioning” scheme [3]. Also, the project and git repository structure has changed. The main imglib repository has been split into multiple repositories, named consistently with the artifact names and java package prefixes [4]. Projects are now coupled using non-SNAPSHOT versions, in order to achieve reproducible builds [5].
For further technical details on project structure, see http://imagej.net/Architecture
Before coming out of beta, we have made several last-minute changes to the
code:
• All @Deprecated methods and classes have been removed.
• All metadata handling (formerly imglib2-meta subproject) is being moved
into imagej-common. From ImgLib2 core, the classes AnnotatedSpace,
AbstractAnnotatedSpace, and Axis where moved to imagej-common.
• The current ROI representation wss not considered stable enough to be
included in a release. The net.imglib2.roi and net.imglib2.labeling
packages where moved to the new imglib2-roi subproject which will remain
in beta for now.
• The net.imglib2.multithreading package was moved to imglib2-algorithm and
deprecated.
• We merged work by Albert Cardona and Stephan Preibisch on "fractional"
types. ImgLib2 NativeTypes map pixels into primitive arrays, where often
the mapping is one-to-one. For example, a UnsignedByteType pixel maps into
one byte of a primitive byte[] array. With fractional types this mapping
maybe non-integral, for example Unsigned12BitType maps pixels into a long[]
array, where each pixel occupies 12/64 longs.
• Superfluous generic parameters were removed from Projector<A,B> interface
which is now only Projector. Projector implementations were fixed
accordingly.
• Several classes were renamed or moved to more suitable places:
◦ Extended[Real]RandomAccessibleInterval moved to the net.imglib2.view
package.
◦ RandomAccessibleOnRealRandomAccessible moved to the net.imglib2.view
package.
◦ Binning moved to the net.imglib2.util package.
◦ The contents of package net.imglib2.collection (KDTree etc) moved to the
net.imglib2 package.
◦ net.imglib2.concatenate.Util was renamed to
net.imglib2.concatenate.ConcatenateUtils.
◦ Bounded moved to the net.imglib2.outofbounds package.
◦ The class NearestNeighborInterpolator from package
net.imglib2.interpolation.neighborsearch was renamed to
NearestNeighborSearchInterpolator (to avoid confusion with the
net.imglib2.interpolation.randomaccess.NearestNeighborInterpolator
class).
◦ The Pair interface moved to the net.imglib2.util package.
• The net.imglib2.util.Util class was cleaned up:
◦ Methods getTypeFromRandomAccess() and getTypeFromRealRandomAccess() were
removed. We considered them too dangerous because the RandomAccess may
be pointing to invalid position.
◦ Unused methods setCoordinateRecursive() and getRecursiveCoordinates()
were removed.
◦ Some variants of computeLength() and computeDistance() were removed. Use
methods distance() and length() from net.imglib2.util.LinAlgHelpers
instead.
◦ Methods computeMedian(), computeAverage(), etc. were renamed to
median(), average(), etc.
• These unused classes were removed:
◦ IterableIntervalSubsetT
◦ Triple
◦ RealPositionableFloorPositionable
◦ RealPositionableRoundPositionable
◦ ImgTranslationAdapter
• Packages net.imglib2.img.constant and net.imglib2.sampler.special were
removed (ConstantImg, ConstantRandomAccessible, etc). Similar functionality
can now be achieved through the net.imglib2.util.ConstantUtils class and
Views.
All ImgLib2 subprojects have been adapted to these changes and released (in some cases as new beta versions).
One thing still pending is to upload these new ImgLib2 releases to the ImageJ and Fiji update sites, making them available to users of ImageJ and Fiji. This change has been rather involved, since there is a lot of downstream code affected by the API changes. But we expect to make the new ImgLib2 available to users before the end of the calendar year. Stay tuned for further announcements!
Best regards from the ImgLib2 release team,
Tobias Pietzsch
Stephan Saalfeld
Stephan Preibisch
Curtis Rueden
Johannes Schindelin
Mark Hiner
[1] http://search.maven.org/#search%7Cga%7C1%7Cg%3A%22net.imglib2%22
[2] https://github.com/imglib
[3] http://imagej.net/Architecture#Versioning
[4] http://imagej.net/Architecture#Git_repositories
[5] http://imagej.net/Architecture#Reproducible_builds
More information about the ImageJ-devel
mailing list