New minimum dependencies:
- CMake minimum is now 3.12. #2348 (2.1.5)
New file format support:
- Support for HEIC/HEIF images. HEIC is the still-image sibling of HEVC (a.k.a. H.265), and compresses to about half the size of JPEG but with higher visual quality. #2160 #2188 (2.1.0)
Public API changes:
- Python: define
__version__
for the module. #2096 (2.1.0/2.0.4) - ImageSpec::find_attribute now will retrive "datawindow" and "displaywindow" (type int[4] for images int[6] for volumes) giving the OpenEXR-like bounds even though there is no such named metadata for OIIO (the results will assembled from x, y, width, height, etc.). #2110 (2.1.0/2.0.4)
- "Compression" names (where applicable) can now have the quality appended
to the name (e.g.,
"jpeg:85"
) insead of requiring quality to be passed as a separate piece of metadata. #2111 (2.1.0/2.0.5) - Python error reporting for
ImageOutput
andImageBuf.set_pixels
involving transferring pixel arrays have changed from throwing exceptions to reporting errors through the usual OIIO error return codes and queries. #2127 (2.1.0/2.0.5) - New shell environment variable
OPENIMAGEIO_OPTIONS
can now be used to set globalOIIO::attribute()
settings upon startup (comma separated name=value syntax). #2128 (2.1.0/2.0.5) - ImageInput open-with-config new attribute
"missingcolor"
can supply a value for missing tiles or scanlines in a file in lieu of treating it as an error (for example, how OpenEXR allows missing tiles, or when reading an incompletely-written image file). A new globalOIIO::attribute()
setting (same name) also accomplishes the same thing for all files read. Note that this is only advisory, and not all file times are able to do this (OpenEXR is the main one of interest, so that works). #2129 (2.1.0/2.0.5) ImageCache::invalidate()
andTextureSystem::invalidate()
now take an optionalforce
parameter (default: true) that if false, will only invalidate a file if it has been updated on disk since it was first opened. #2133, #2166 (2.1.0/2.0.5)- New filter name
"nuke-lanczos6"
matches the "lanczos6" filter from Nuke. In reality, it's identical to our "lanczos3", but the name alias is supposed to make it more clear which one to use to match Nuke, which uses a different nomenclature (our "3" is radius, their "6" is full width). #2136 (2.1.0/2.0.5) - ImageSpec new methods
getattribute()
andgetattributetype()
. #2204 (2.1.1) - ImageSpec and ParamValueList now support operator
["name"]
as a way to set and retrieve attributes. For example, myimagespec["compression"] = "zip"; myimagespec["PixelAspectRatio"] = 1.0f; int dither = myimagespec["oiio:dither"].get(); std::string cs = myimagespec["colorspace"]; See the documentation about "Attribute Delegates" for more information, or the new headerattrdelegate.h
. #2204 (2.1.1) #2297 (2.1.3) - New helper functions in
typedesc.h
:tostring()
converts nearly any TypeDesc-described data to a readable string,convert_type()
does data type conversions as instructed by TypeDesc's. #2204 (2.1.1) - ImageBuf:
- Construction from an ImageSpec now takes an optional
zero
parameter that directly controls whether the new ImageBuf should have its buffer zeroed out or left uninitialized. #2237 (2.1.2) set_write_format()
method has a new flavor that takes acspan<TypeDesc>
that can supply per-channel data types. #2239 (2.1.1)
- Construction from an ImageSpec now takes an optional
- ColorConfig:
- Added
getColorSpaceFamilyByName()
,getColorSpaceNames()
,getLookNames()
,getDisplayNames()
,getDefaultDisplayName()
,getViewNames()
,getDefaultViewName()
. #2248 (2.1.2) - Added Python bindings for ColorConfig. #2248 (2.1.2)
- Added
- Formal version numbers are now four parts: MAJOR.MINOR.PATCH.TWEAK. #2313,#2319 (2.1.3)
- ImageInput now sets "oiio:subimages" attribute to an int representing the number of subimages in a multi-image file -- if known from reading just the header. A positive value can be relied upon (including 1), but a value of 0 or no such metadata does not necessarily mean there are not multiple subimages, it just means it could not be known from inexpensively reading only the header. #2344 (2.1.4)
- The
imagesize_t
andstride_t
values now have revised definitions. It should be fully API/ABI compatible (at least for 64 bit systems), but is a simpler, more modern, more platform-independent definition. #2351 (2.1.5) DeepData
has been altered to make pixel indices and total counts int64_t rather than int, in order to be safe for very large images that have > 2 Gpixels. #2363 (2.1.5)- On OSX, we now expect non-embedded plugins to follow the convention of
naming runtime-loaded modules
foo.imageio.so
(just like on Linux), whereas we previously used the convention offoo.imageio.dylib
. Turns out that dylib is supposed to be only for shared libraries, not runtime loadable modules. #2376 (2.1.6)
Performance improvements:
- ImageCache/TextureSystem:
- Improved perf of the tile and file cache lookups, especially under heavy thread contention, from improvement in performance and properties of the hashing used by the caches. #2314, #2316 (2.1.3)
- Improved performance for ustring creation and lookup. #2315 (2.1.3)
- Fix huge DPX reading performance regression. Technically this is a bug fix that restores performance we once had, but it's a huge speedup. #2333 (2.1.4)
- Reading individual frames from very-multi-image files (movie files) has been greatly sped up (10x or more). #2345 (2.1.4)
Fixes and feature enhancements:
- oiiotool:
- New
-evaloff
and-evalon
lets you disable and enable the expression substitution for regions of arguments (for example, if you have an input image filename that contains{}
brace characters that you want interpreted literally, not evaluated as an expression). #2100 (2.1.0/2.0.4) --dumpdata
has more intelligible output for uint8 images. #2124 (2.1.0/2.0.4)- Fixed but that could prevent
-iconvert oiio:UnassociatedApha 1
from correctly propagating to the input reader. #2172 (2.1.0/2.0.6) -o:all=1
(which outputs all subimages to separate files) fixed a crash that would occur if any of the subimages were 0x0 (it could happen; now it just skips outputting those subimages). #2171 (2.1.0)- Improved support of files with multiple subimages: Several commands
honored
-a
but did not respect individualallsubimages=
modifiers (--ch, --sattrib, --attrib, --caption, --clear-keywords, --iscolorspace, --orientation, --clamp, -fixnan); Several commands always worked on all subimages, but now properly respect-a
andallsubimages=
(--origin, --fullpixels, --croptofull, --trim); Several commands were totally unaware of subimages, but now are so and respect-a
andallsubimages=
(--crop, --fullsize, --zover, --fill, --resize, --resample). #2202 #2219, #2242 (2.1.1, 2.1.2) --ociodisplay
: empty display or view names imply using the default display or view. #2273 (2.0.10/2.1.3)--metamerge
option causes binary image operations to try to "merge" the metadata of their inputs, rather than simply copy the metadata from the first input and ignore the others. #2311 (2.1.3)--colormap
now supports a new "turbo" color map option. #2320 (2.1.4)- Expression evaluation has been extended to support operators
//
for integer division (whereas/
is floating point division), and%
for integer modulus. #2362 (2.1.5) - New
--originoffset
resets the data window origin relative to its previous value (versus the existing--origin
that sets it absolutely). #2369 (2.1.5) --paste
has two new optional modifiers::all=1
pastes the entire stack of images together (versus the default of just pasting the top two images on the stack), and:mergeroi=1
causes the result to have the merged data window of all inputs, instead of the foreground image clipping against the boundary of the background image data. #2369 (2.1.5)--paste
now works with deep images. #2369 (2.1.5)--paste
semantics have changed: the meaning of pasting FG into BG at (x,y) now means that the (0,0) origin of FG ends up at (x,y), whereas before it placed the corner of FG's data window at (x,y). This will not change behavior for ordinary images where FG's data window is (0,0), but it makes behavior more sensible for "cropped" or "shrink-wrapped" FG images that have non-zero data window origin. #2369 (2.1.5)paste()
is now multithreaded and therefore much faster. #2369 (2.1.5)--ociotransform
no longer issues an error message when no valid OCIO configuration is found (because it's not needed for this operation). #2371 (2.1.5)
- New
- ImageBuf/ImageBufAlgo:
IBA::channel_append()
previously always forced its result to be float, if it wasn't previously initialized. Now it uses the uaual type-merging logic, making the result the "widest" type of the inputs. #2095 (2.1.0/2.0.4)- IBA
resize()
,fit()
, andresample()
are no longer restricted to source and destination images having the same numer of channels. #2125 (2.1.0/2.0.5) - Improve numerical precision of the unpremult/premult part of certain color transformations. #2164 (2.1.0)
ImageBuf::read()
now properly forwards the "progress" parameters to any underlying call toread_image
. #2196 (2.1.1)- The
OIIO_DISPATCH_COMMON_TYPES2/3
macros used internally by many IBA functions have been expanded to handle a few more cases "natively" without conversion to/from float. This may make a few cases of odd data type combinations have higher precision. #2203 (2.0.8/2.1.1) - IBA
resize()
fix precision issues for 'double' images. #2211 (2.0.8/2.1.1) IBA::ociodisplay()
: empty display or view names imply using the default display or view. #2273 (2.0.10/2.1.3)IBA::fixNonFinite()
: fixed impicit float/double casts to half. #2301 (2.0.10/2.1.3)IBA::color_map()
: now supports a new "turbo" color map option. #2320 (2.1.4)IBA::paste()
now works with deep images. #2369 (2.1.5)paste
semantics have changed: the meaning of pasting FG into BG at (x,y) now means that the (0,0) origin of FG ends up at (x,y), whereas before it placed the corner of FG's data window at (x,y). This will not change behavior for ordinary images where FG's data window is (0,0), but it makes behavior more sensible for "cropped" or "shrink-wrapped" FG images that have non-zero data window origin. #2369 (2.1.5)paste()
is now multithreaded and therefore much faster. #2369 (2.1.5)ociotransform()
no longer issues an error message when no valid OCIO configuration is found (because it's not needed for this operation). #2371 (2.1.5)- Python
ociotransform
andociolook
mixed up the names and orders of theinverse
andunpremult
params, making it so that you couldn't properly specify the inverse. #2371 (2.1.5)
- ImageInput read_image/scanline/tile fixed subtle bugs for certain combination of strides and channel subset reads. #2108 (2.1.0/2.0.4)
- ImageCache / TextureSystem / maketx:
- More specific error message when tile reads appear to be due to the file having changed or been overwritten on disk since it was first opened. #2115 (2.1.0/2.0.4)
- maketx: the
-u
(update mode) is slightly less conservative now, no longer forcing a rebuild of the texture just because the file uses a different relative directory path than last time. #2109 (2.1.0/2.0.4) - Protection against certain divide-by-zero errors when using very blurry latong environment map lookups. #2121 (2.1.0/2.0.5)
maketx -u
is smarter about which textures to avoid re-making because they are repeats of earlier commands. #2140 (2.1.0/2.05)- Fix possible maketx crash on Windows due to a stack overflow within MSVS's implementation of std::regex_replace! #2173 (2.1.0/2.0.6)
- TS: New attribute "max_mip_res" limits filtered texture access to MIP levels that are no higher than this resolution in any dimension. The default is 1<<30, meaning no effective limit. #2174 (2.1.1)
- Stats now count the number of
TS::get_texture_info/IC::get_image_info
calls, like it did before for texture, etc. #2223 (2.1.1) TS::environment()
can resolve subimage by name, as we do for texture() and texture3d(). #2263- Improvements to error message propagation. (2.1.3)
- Avoid creating a new thread info struct while resolving udims. #2318 (2.1.4)
- Work around bug in OpenEXR, where dwaa/dwab compression can crash when used on 1-channel tiled images with a tile size < 16. This can crop up for MIP-maps (high levels where rez < 16), so we detect this case and switch automatically to "zip" compression. #2378 (2.1.6)
- iv viewer:
- Image info window now sorts the metadata, in the same manner as
iinfo -v
oroiiotool -info -v
. #2159 (2.1.0/2.0.5)
- Image info window now sorts the metadata, in the same manner as
- All command line utilities, when run with just
--help
, will exit with return code 0. In other words,utility --help
is not an error. #2364 (2.1.5) - Python bindings:
- Fix inability for Python to set timecode attributes (specifically, it was trouble setting ImageSpec attributes that were unnsigned int arrays). #2279 (2.0.9/2.1.3)
- DPX:
- Now recognizes the new transfer/colorimetric code for ADX. #2119 (2.1.0/2.0.4)
- Fix potential crash when file open fails. #2186 (2.0.7/2.1.1)
- Support for reading and writing 1-channel (luma, etc.) images. #2294 (2.0.10/2.1.3)
- Fix huge DPX reading performance regression. #2333 (2.1.4)
- ffmpeg/Movie files:
- Reading individual frames from very-multi-image files (movie files) has been greatly sped up (10x or more). #2345 (2.1.4)
- Support for reading movie files that (a) contain alpha channels, and (b) have bit depths > 8 bits per channel. Previously, such files would be read, but would be presented to the app as a 3-channel 8 bit/channel RGB. #2349 (2.1.5)
- FITS:
- Fix 16 and 32 bit int pixels which FITS spec says are signed, but we were treating as unsigned. #2178 (2.1.0)
- JPEG:
- Read-from-memory is now supported via IOProxy use. #2180. (2.1.1)
- JPEG-2000:
- Disable JPEG-2000 support for the (rare) combination of an older OpenJPEG 1.x and EMBEDPLUGINS=0 mode, which was buggy. The solution if you really need EMBEDPLUGINS and JPEG-2000 support is to please use OpenJPEG >= 2.0. #2183. (2.0.7/2.1.1)
- OpenEXR:
- Avoid some OpenEXR/libIlmImf internal errors with DWA compression by switching to zip for single channel images with certain small tile sizes. #2147 (2.1.0/2.0.5)
- Suppress empty string subimage name (fixes a problem with certain V-Ray written multi-part exr images). #2190 (2.1.1/2.0.7)
- Fixed bug that broke th ability to specify compression of multipart OpenEXR files. #2252 (2.1.2)
- PNG:
- More careful catching and reporting errors and corrupt PNG files. #2167 (2.1.0/2.0.6)
- IOProxy reading is now supported. #2180. (2.1.1)
- PSD:
- When reading PSD files with multiple PhotoShop "layers", properly set ImageSpec x, y to the image plane offset (upper left corner) of the layer, and set and metadata "oiio:subimagename" to the layer name. #2170 (2.1.0)
- RAW:
- Clarification about color spaces: The open-with-config hint "raw:ColorSpace" is more careful about color primaries versus transfer curve. Asking for "sRGB" (which is the default) gives you true sRGB -- both color primaries and transfer. Asking for "linear" gives you linear transfer with sRGB/Rec709 primaries. The default is true sRGB, because it will behave just like JPEG. #2260 (2.1.2)
- Added "raw:half_size" and "raw:user_mul" configuration attributes. #2307 (2.1.3)
- RLA:
- Improved logic for determining the single best data type to report for all channels. #2282 (2.1.3)
- TIFF:
- Fix problems with JPEG compression in some cases. #2117 (2.1.0/2.0.4)
- Fix error where reading just a subset of channels, if that subset did not include the alpha channel but the image was "unassociated alpha", the attempt to automatically associate (i.e. "premultiply" the alpha) upon read would get bogus values because the alpha channel was not actually read. Now in this case it will not do the premultiplication. So if you are purposely reading RGB only from an RGBA file that is specifically "unassociated alpha", beware that you will not get the automatic premultiplication. #2122 (2.1.0/2.0.4)
- More careful check and error reporting when user tries to request writing to a TIFF file mixed channel data types (which is not supported by the underlying libtiff). #2112 (2.1.0/2.0.5)
- Fix crash reading certain old nconvert-written TIFF files. #2207 (2.0.8/2.1.1)
- Fix bugs when reading TIFF "cmyk" files. #2292. (2.0.10/2.1.3)
- Correctly handle read and write of 6, 14, and 24 bit per sample images. #2296 (2.1.3)
- Fix potential deadlock in TIFF I/O: minor flaw with threadpool method #2327 (2.1.4)
- WebP: fix bug that gave totally incorrect image read for webp images that had a smaller width than height. #2120 (2.1.0/2.0.4)
- Fix potential threadpool deadlock issue that could happen if you were (among possibly other things?) simultaneously calling make_texture from multiple application threads. #2132 (2.1.0/2.0.4)
- ImageInput/ImageOutput
create()
now properly lets you specify the type for reader/writer from the format name itself (versus just the extension, for example "openexr" versus "exr"). #2185 (2.1.1) - Make all the various "could not open" messages across the writers use the same phrasing. #2189 (2.1.1)
- Better care in some image readers/writers to avoid errors stemming from integer overflow when compting the size of large images. #2232 (2.1.2)
Build/test system improvements and platform ports:
- Major overhaul of the CMake build system now that our CMake minimum is
3.12. #2348 #2352 #2357 #2360 #2368 #2370 #2372 #2373 (2.1.5)
Highlights:
- All optional dependencies (e.g. "Pkg") now can be disabled (even if found) with cmake -DUSE_PKG=0 or environment variable USE_PKG=0. Previously, some packages supported this, others did not.
- All dependencies can be given find hints via -DPkg_ROOT=path or by setting environment variable Pkg_ROOT=path. Previously, some did, some didn't, and the ones that did had totally inconsistent names for the path hint variable (PKG_HOME, PKG_ROOT_DIR, PKG_PATH, etc).
- Nice color coded status messages making it much more clear which dependencies were found, which were not, which were disabled.
- Use standard BUILD_SHARED_LIBS to control shared vs static libraries, replacing the old nonstandard BUILDSTATIC name.
- Use correct PUBLIC/PRIVATE marks with target_link_libraries and target_include_directories, and rely on cmake properly understanding the transitive dependencies.
- CMAKE_DEBUG_POSTFIX adds an optional suffix to debug libraries.
- CMAKE_CXX_STANDARD to control C++ standard (instead of our nonstandard USE_CPP).
- CXX_VISIBILITY_PRESET controls symbol visibility defaults now, not our nonstandard HIDE_SYMBOLS. And the default is to keep everything hidden that is not part of the public API.
- At config time,
ENABLE_<name>=0
(either as a CMake variable or an env variable) can be used to disable any individual file format or command line utility. E.g.,cmake -DENABLE_PNG=0 -DENABLE_oiiotool=0
This makes it easier to greatly reduce build time if you are 100% sure there are formats or components you don't want or need.
- Deprecate "missingmath.h". What little of it is still needed (it mostly addressed shortcomings of old MSVS releases) is now in fmath.h. #2086
- Remove "osdep.h" header that was no longer needed. #2097
- Appveyor scripts have been overhauled and simplified by relying on
vcpkg
to build dependencies. #2113 (2.1.0/2.0.4) - Detect and error if builder is trying to use a pybind11 that's too old. #2144 (2.1.0/2.0.5)
- New CMake build-time option
OIIO_LIBNAME_SUFFIX
(default: empty) lets you append an optional name to the libraries produced (to disambiguate two builds at the same facility or distro, much like you could do before for symbols with custom namespaces). #2148 (2.1.0) - On MacOS 10.14 Mojave, fix warnings during
iv
compiler about OpenGL being deprecated in future releases. #2151 (2.1.0/2.0.5) - At build time, the Python version used can be controlled by setting the
environment variable
$OIIO_PYTHON_VERSION
, which if set will initialize the default value of the CMake variablePYTHON_VERSION
. #2161 (2.0.5/2.1.0) - On non-Windows systems, the build now generates a PkgConfig file, installed
at
CMAKE_INSTALL_PREFIX/lib/pkgconfig/OpenImageIO.pc
. #2158 (2.0.5/2.1.0) - A new unit test has been backported from master, which tries to perform a series of read/write tests on every file format. In partcular, this tests certain error conditions, like files not existing, or the directory not being writeable, etc. #2181, #2189 (2.0.8/2.1.1)
- Support for CI tests on CircleCI. #2194 (2.1.1)
- New build-time flag
USE_WEBP=0
can be used to disable building WebP format support even on platforms where webp libraries are found. #2200 (2.1.1) - Fix compiler warnings on Windows. #2209 #2213 #2214
- Crashes in the command line utilities now attempt to print a stack trace to aid in debugging (but only if OIIO is built with Boost >= 1.65, because it relies on the Boost stacktrace library). #2229 (2.0.8/2.1.1)
- Add gcc9 to Travis tet matrix and fix gcc9 related warnings. #2235 (2.1.2)
- VDB reader pulled in the TBB libraries using the wrong CMake variable. #2274 (2.1.3)
- The embedded
fmt
implementation has been updated to fix windows warnings. #2280 (2.1.3) - Improvements for finding certain new Boost versions. #2293 (2.0.10/2.1.3)
- Build fixes for MinGW. #2304, #2308 (2.0.10/2.1.3)
- libraw: Fixes to make it build properly against some changes in the libraw development master. #2306 (2.1.3)
- Phase in use of GitHub Actions CI beta. We anticipate that this may eventually replace both Travis-CI and Appveyor, but for now is still experimental. #2334 (2.1.4) #2356 (2.1.5)
- Updated and improved finding of OpenEXR and
build_openexr.bash
script that we use for CI. #2343 (2.1.4) - Upgrade the pybind11 verson that we auto-install when not found (to 2.4.2), and add logic to detect the presence of some pybind11 versions that are known to be (buggily) incompatible with C++11. #2347 (2.1.5)
- Fix errors in very new MSVS versions where it identified a suspicious practice of ImageBuf's use of a unique_ptr of an undefined type. Jump through some hoops to make that legal. #2350 (2.1.5)
- All Python scripts in the tests have been modified as needed to make them correct for both Python 2.7 and 3.x. #2355, #2358 (2.1.5)
- Tests are now safe to run in parallel and in unspecified order. Running with env variable CTEST_PARALLEL_LEVEL=[something more than 1] greatly speeds up the full testsuite on multi-core machines. #2365 (2.1.5)
Developer goodies / internals:
- argparse.h:
- Add unit tests. #2192 (2.1.1)
- Add "%1" which is like "%*" but its list receives only arguments that come before any other dash-led arguments. #2192 (2.1.1)
- Allow specifiers such as "%d:WIDTH" the part before the colon is the type specifier, the part after the colon is the name of the parameter for documentation purposes. #2312 (2.1.3)
- attrdelegate.h:
- New header implements "attribute delegates." (Read header for details) #2204 (2.1.1)
- dassert.h:
- Spruce up ASSERT macros: more uniform wording, and use pretty function printing to show what function the failure was in. #2262
string_view
now adds an optionalpos
parameter to thefind_first_of
/find_last_of
family of methods. #2114 (2.1.0/2.0.4)- strutil.h:
Strutil::wordwrap()
now lets you specify the separation characters more flexibly (rather than being hard-coded to spaces as separators). #2116 (2.1.0/2.0.4)Strutil::parse_while()
. #2139 (2.1.0/2.0.5)
- fmath.h:
safe_mod()
does integer modulus but protects against mod-by-zero exceptions. #2121 (2.1.0/2.0.5)- powwroundup/pow2rounddown have been renamed ceil2/floor2 to reflect future C++20 standard. The old names still work, so it's a fully back compatible change. #2199 (2.0.8/2.1.1)
- To match C++20 notation, use
rotl()
template innstead of separate rotl32/rotl64 funnctions. #2299, #2309 (2.1.3)
- platform.h:
- New
OIIO_RETURNS_NONNULL
macro implements an attribute that marks a function that returns a pointer as guaranteeing that it's never NULL. #2150 (2.1.0/2.0.5)
- New
- SHA1.h:
- Upgraded this embedded code from version 1.8 (2008) to the newest release, 2.1 (2012). This fixes some Windows warnings. #2342 (2.1.4)
- simd.h:
- Added vec4 * matrix44 multiplication. #2165 (2.1.0/2.0.6)
- Guard against shenanigans when Xlib.h having been included and
#define
ing True and False. #2272 (2.0.9/2.1.3)
- strutil.h:
- Added
excise_string_after_head()
. #2173 (2.1.0/2.0.6) - Fixed incorrect return type of
stof()
. #2254 (2.1.2) - Added
remove_trailing_whitespace()
andtrim_whitespace()
. #2298 (2.1.3)
- Added
- sysutil.h:
- Added
stacktrace()
andsetup_crash_stacktrace()
. (Only functional if OIIO is built with Boost >= 1.65, because it relies on the Boost stacktrace library). #2229 (2.0.8/2.1.1)
- Added
- unordered_map_concurrent.h:
- Performance improvement by avoiding redundant hashing of keys, and improving the speed and properties of the hash functionn. #2313, #2316 (2.1.3)
- ustring.h:
- Bug fix in
ustring::compare(string_view)
, in cases where the string_view was longer than the ustring, but had the same character sequennce up to the length of the ustring. #2283 (2.0.10/2.1.3)
- Bug fix in
- Wide use of declaring methods
noexcept
when we want to promise that they won't throw exceptions. #2156, #2243 (2.1.0, 2.1.2)
Notable documentation changes:
- The whole documentation system has been overhauled. The main docs have been converted from LaTeX to Sphinx (using Doxygen and Breathe) for beautiful HTML as well as PDF docs and automatic hosting on https://openimageio.readthedocs.io #2247,2250,2253,2255,2268,2265,2270
- Copyright notices have been changed for clarity and conformance with SPDX conventions. #2264
- New GitHub issue templates, making separate issue types for bug reports, feature requests, build problems, and questions. #2271,#2346
- Fix compiler warnings on some platform. #2375
- Work around bug in OpenEXR, where dwaa/dwab compression can crash when used on 1-channel tiled images with a tile size < 16. This can crop up for MIP-maps (high levels where rez < 16), so we detect this case and switch automatically to "zip" compression. #2378
- Fixes to build against LibRaw master. #2306
- Fix DPX reading performance regression. #2333
- Guard against buggy pybind11 versions. #2347
- Fixes for safe Cuda compilation of
invert<>
in fmath.h. #2197
- ColorConfig improvements: (a) new getColorSpaceFamilyByName(); (b) new methods to return the list of all color spaces, looks, displays, or views for a display; (c) all of ColorConfig now exposed to Python. #2248
IBA::ociodisplay()
andoiiotool --ociodisplay
: empty display or view names imply using the default display or view. #2273- Bug fix in
ustring::compare(string_view)
, in cases where the string_view was longer than the ustring, but had the same character sequennce up to the length of the ustring. #2283 oiiotool --stats
: Fixed bug where-iconfig
hints were not being applied to the file as it was opened to compute the stats. #2288- Bug fix:
IBA::computePixelStats()
was not properly controlling the number of threads with thenthreads
parameter. #2289 - Bug fix when reading TIFF bugs: In cases where the reader needed to close and re-open the file silently (it could happen for certain scanline traversal patterns), the re-open was not properly honorig any previous "rawcolor" hints from the original open. #2285
- Nuke txWriter updates that expose additional make_texture controls. #2290
- Build system: Improvements for finding certain new Boost versions. #2293
- Build system: Improvements finding OpenEXR installation.
- Fix bugs when reading TIFF "cmyk" files. #2292.
- DPX: support for reading and writing 1-channel (luma, etc.) DPX images. #2294
IBA::fixNonFinite()
: fixed impicit float/double casts to half. #2301- Build fixes for MinGW. #2304
- RAW: Clarification about color spaces: The open-with-config hint "raw:ColorSpace" is more careful about color primaries versus transfer curve. Asking for "sRGB" (which is the default) gives you true sRGB -- both color primaries and transfer. Asking for "linear" gives you linear transfer with sRGB/Rec709 primaries. The default is true sRGB, because it will behave just like JPEG. #2260 (2.1.2)
- Improved oiiotool support of files with multiple subimages: Several
commands honored
-a
but did not respect individualallsubimages=
modifiers (--ch, --sattrib, --attrib, --caption, --clear-keywords, --iscolorspace, --orientation, --clamp, -fixnan); Several commands always worked on all subimages, but now properly respect-a
andallsubimages=
(--origin, --fullpixels, --croptofull, --trim); Several commands were totally unaware of subimages, but now are so and respect-a
andallsubimages=
(--crop, --fullsize, --zover, --fill, --resize, --resample). #2202 #2219, #2242 - Fix broken ability to specify compression of multipart exr files. #2252
- Fix Strutil::stof() return type error and other windows warnings. #2254
- IBA::colortmatrixtransform() and
oiiotool --ccmatrix
allow you to perform a matrix-based color space transformation. #2168 - Guard simd.h against shenanigans when Xlib.h having been included and
#define
ing True and False. #2272 - RAW: Clarification about color spaces: The open-with-config hint "raw:ColorSpace" is more careful about color primaries versus transfer curve. Asking for "sRGB" (which is the default) gives you true sRGB -- both color primaries and transfer. Asking for "linear" gives you linear transfer with sRGB/Rec709 primaries. The default is true sRGB, because it will behave just like JPEG. #2260
- Fix inability for python to set timecode attributes (specifically, it was trouble setting ImageSpec attributes that were unnsigned int arrays). #2279
- Fix Windows broken read of JPEG & PNG in some circumstances. #2231
- Some minor fixes to JPEG & PNG reading and file error robustness. #2187
- Fix crash reading certain old nconvert-written TIFF files. #2207
- Internals: The
OIIO_DISPATCH_COMMON_TYPES2/3
macros used by many ImageBufAlgo functions have been expanded to handle a few more cases "natively" without conversion to/from float. This may make a few cases of odd data type combinations have higher precision. #2203 - ImageBufAlgo::resize() fixes precision issues for 'double' images. #2211
- Testing: A new unit test has been backported from master, which tries to perform a series of read/write tests on every file format. In partcular, this tests certain error conditions, like files not existing, or the directory not being writeable, etc. #2181
- Crashes in the command line utilities now attempt to print a stack trace to aid in debugging (but only if OIIO is built with Boost >= 1.65, because it relies on the Boost stacktrace library). #2229
- Dev goodies: fmath.h's powwroundup/pow2rounddown have been renamed ceil2/floor2 to reflect future C++ standard. The old names still work, so it's a fully back compatible change. #2199
- DPX: fix potential crash when file open fails. #2186
- EXR: Suppress empty string for subimage name (fixes a problem when reading files written by V-Ray). #2190
- Disable JPEG-2000 support for the (rare) combination of an older OpenJPEG 1.x and EMBEDPLUGINS=0 mode, which was buggy. The solution if you really need EMBEDPLUGINS and JPEG-2000 support is to please use OpenJPEG >= 2.0. #2183.
- New build flag
USE_WEBP=0
can be set to 0 to force disabled support of WebP even when the webp package is found. #2200 - Bug fix:
ImageInput::create(name)
andImageOutput::create(name)
worked ifname
was a filename (such asfoo.exr
), or the extension (such asexr
), but previously did not work if it was the name of the format (such asopenexr
), despite having been documented as working in that case. #2185
- PNG: more careful catching of errors and corrupt png files. #2167
- PSD: read now properly extracts layer/subimage name and data window offset coordinates. #2170
- ImageBuf: Fix bug in propagating unassociated alpha behavior request. #2172
oiiotool -o:all=1
fix crash when outputting 0x0 subimages. #2171- Developer goodies: simd.h ops for vec4 * mat44 multiplication. #2165
- Developer goodies:
Strutil::excise_string_after_head()
#2173 - Fix crashes on Windows from certain regex replacement happening as part of MakeTexture (internally avoid MSVS implementation of std::regex). #2173
resize()
,fit()
, andresample()
are no longer restricted to source and destination images having the same numer of channels. #2125- Python error reporting for
ImageOutput
andImageBuf.set_pixels
involving transferring pixel arrays have changed from throwing exceptions to reporting errors through the usual OIIO error return codes and queries. #2127 - Protection against certain divide-by-zero errors when using very blurry latlong environment map lookups. #2121
- New shell environment variable
OPENIMAGEIO_OPTIONS
can now be used to set globalOIIO::attribute()
settings upon startup (comma separated name=value syntax). #2128 - ImageInput open-with-config new attribute
"missingcolor"
can supply a value for missing tiles or scanlines in a file in lieu of treating it as an error (for example, how OpenEXR allows missing tiles, or when reading an incompletely-written image file). A new globalOIIO::attribute()
setting (same name) also accomplishes the same thing for all files read. Note that this is only advisory, and not all file times are able to do this (OpenEXR is the main one of interest, so that works). #2129 - New filter name
"nuke-lanczos6"
matches the "lanczos6" filter from Nuke. In reality, it's identical to our "lanczos3", but the name alias is supposed to make it more clear which one to use to match Nuke, which uses a different nomenclature (our "3" is radius, their "6" is full width). #2136 maketx -u
is smarter about which textures to avoid re-making because they are repeats of earlier commands. #2140- Detect/error if builder is trying to use a pybind11 that's too old. #2144
- OpenEXR: avoid some OpenEXR/libIlmImf internal errors with DWA compression by switching to zip for single channel images with certain small tile sizes. #2147
- On MacOS 10.14 Mojave, fix warnings during
iv
compile about OpenGL being deprecated in future releases. #2151 iv
info window now sorts the metadata. #2159- At build time, the Python version used can be controlled by setting the
environment variable
$OIIO_PYTHON_VERSION
, which if set will initialize the default value of the CMake variablePYTHON_VERSION
. #2161 (2.0.5) - On non-Windows systems, the build now generates a PkgConfig file, installed
at
CMAKE_INSTALL_PREFIX/lib/pkgconfig/OpenImageIO.pc
. #2158 (2.0.5)
- Fix potential threadpool deadlock issue that could happen if you were (among possibly other things?) simultaneously calling make_texture from multiple application threads. #2132
- ImageInput read_image/scanline/tile fixed subtle bugs for certain combination of strides and channel subset reads. #2108
- TIFF: Fix problems with JPEG compression in some cases. #2117
- TIFF: Fixed error where reading just a subset of channels, if that subset did not include the alpha channel but the image was "unassociated alpha", the attempt to automatically associate (i.e. "premultiply" the alpha) upon read would get bogus values because the alpha channel was not actually read. Now in this case it will not do the premultiplication. So if you are purposely reading RGB only from an RGBA file that is specifically "unassociated alpha", beware that you will not get the automatic premultiplication. #2122
- Python: define
__version__
for the module. #2096 - IBA::channel_append() previously always forced its result to be float, if it wasn't previously initialized. Now it uses the uaual type-merging logic, making the result the "widest" type of the inputs. #2095
- ImageSpec::find_attribute now will retrive "datawindow" and "displaywindow" (type int[4] for images int[6] for volumes) giving the OpenEXR-like bounds even though there is no such named metadata for OIIO (the results will assembled from x, y, width, height, etc.). #2110
- ImageCache/TextureSystem: more specific error message when tile reads appear to be due to the file having changed or been overwritten on disk since it was first opened. #2115
- oiiotool: New
-evaloff
and-evalon
lets you disable and enable the expression substitution for regions of arguments (for example, if you have an input image filename that contains{}
brace characters that you want interpreted literally, not evaluated as an expression). #2100 - oiiotool
--dumpdata
has more intelligible output for uint8 images. #2124 - maketx: the
-u
(update mode) is slightly less conservative now, no longer forcing a rebuild of the texture just because the file uses a different relative directory path than last time. #2109 - WebP: fix bug that gave totally incorrect image read for webp images that had a smaller width than height. #2120
- Developer goodies: string_view now adds an optional
pos
parameter to thefind_first_of
/find_last_of
family of methods. #2114 - Dev goodies: Strutil::wordwrap() now lets you specify the separation characters more flexibly (rather than being hard-coded to spaces as separators). #2116
New minimum dependencies:
- On Windows compiling with MSVS, the new minimum version is MSVS 2015.
Major new features and improvements:
- ImageInput and ImageOutput static create() and open() methods now return
unique_ptr
rather than raw pointers. #1934, #1945 (1.9.3). - ImageInput improvements to thread safety and concurrency, including some new API calls (see "Public API changes" section below).
- ImageBufAlgo overhaul (both C++ and Python): Add IBA functions that
return image results directly rather than passing ImageBuf references
as parameters for output (the old kind of calls still exist, too, and
have their uses). Also in C++, change all IBA functions that took raw
pointers to per-channel colors into
span<>
for safety. #1961 (1.9.4) - For some readers and writers, an "IOProxy" can be passed that customizes the I/O methods. An important use of this is to write an image "file" to memory or to read an image "file" from a memory, rather than disk. Currently, OpenEXR supports this for both reading and writing, and PNG supports it for writing. You specify a pointer to the proxy via the configuration option "oiio:ioproxy". #1931 (1.9.3)
- New Image Format support:
- OpenVDB file read (as volume images or accessing via texture3d()). #2010,2018 (1.9.4)
- "null" images -- null reader just returns black (or constant colored) pixels, null writer just returns. This can be used for benchmarking (to eliminate all actual file I/O time), "dry run" where you want to test without creating output files. #1778 (1.9.0), #2042 (1.9.4)
- TIFF I/O of multiple scanlines or tiles at once (or whole images, as is typical use case for oiiotool and maketx) is sped up by a large factor on modern multicore systems. We've seen 10x or more faster oiiotool performance for uint8 and uint16 TIFF files using "zip" (deflate) compression, on modern 12-16 core machines. #1853 (1.9.2)
- Major refactor of Exif metadata handling, including much more complete metadata support for RAW formats and support of camera "maker notes" for Canon cameras. #1774 (1.9.0)
- New
maketx
option--bumpslopes
specifically for converting bump maps, saves additional channels containing slope distribution moments that can be used in shaders for "bump to roughness" calculations. #1810,#1913,2005 (1.9.2), #2044 (1.9.4) - An official FindOpenImageIO.cmake that we invite you to use in other cmake-based projects that needs to find OIIO. #2027 (1.9.4)
Public API changes:
- Python binding overhaul
The Python bindings have been reimplemented with
pybind11
, no longer with Boost.Python. #1801 (1.9.1) In the process (partly due to what's easy or hard in pybind11, but partly just because it caused us to revisit the python APIs), there are some minor API changes, some of which are breaking! To wit:- All of the functions that are passed or return blocks of pixels
(such as
ImageInput.read_image()
) now use Numpyndarray
objects indexed as[y][x][channel]
(no longer using old-style Pythonarray.array
and flattened to 1D). - Specilized enum type
ImageInput.OpenMode
has been replaced by string parameters, so for example, oldImageInput.open(filename, ImageInput.Create)
is nowImageInput.open (filename, "Create")
- Any function that previously took a parameter of type
TypeDesc
orTypeDesc.BASETYPE
now will accept a string that signifies the type. For example,ImageBuf.set_write_format("float")
is now a synonym forImageBuf.set_write_format(oiio.TypeDesc(oiio.FLOAT))
. - For several color conversion functions, parameter names were changed
from "from" to "fromspace" and "to" to "tospace" to avoid a clash with
the Python reserved word
from
. #2084
- All of the functions that are passed or return blocks of pixels
(such as
- ImageInput API changes for thread safety and statelessness #1927 (1.9.2)
seek_subimage()
no longer takes anImageSpec&
, to avoid the obligatory copy. (If the copy is desired, just callspec()
to get it afterwards.)- All of the
read_*()
methods now have varieties that take arguments specifying the subimage and mip level. Theread_native_*()
methods supplied by ImageInput subclass implementations now ONLY come in the variety that takes a subimage and miplevel. - All of the
read_*()
calls that take subimage/miplevel explicitly are guaranteed to be stateless and thread-safe against each other (it's not necessary to callseek_subimage
first, nor to have to lock a mutex to ensure that another thread doesn't change the subimage before you get a chance to call read). For back-compatibility, there are still versions that don't take subimage/miplevel, require a prior call to seek_subimge, and are thus not considered thread-safe. - New methods
spec(subimage,miplevel)
andspec_dimensions(s,m)
let you retrieve a copy of the ImageSpec for a given subimage and MIP level (thread-safe, and without needing a priorseek_subimage
) call. Note that to be stateless and thread-safe, these return a COPY of the spec, rather than the reference returned by the statefulspec()
call that has no arguments and requires a priorseek_subimage
. However,spec_dimensions()
does not copy the channel names or the arbitrary metadata, and is thus very inexpensive if the only thing you need from the spec copy is the image dimensions and channel formats.
- ImageInput and ImageOutput create/open changes
- The static
create()
andopen()
methods have been changed so that instead of returning anImageInput *
(orImageOutput *
) and requiring the caller to correctly manage that resource and eventually destroy it, now they return aunique_ptr
that automatically deletes when it leaves scope. In the process we also clean up some edge cases on Windows where it was possible for ImageInput/ImageOutput to have been allocated in one DLL's heap but freed in a different DLL's heap, which could cause subtle heap corruption problems. #1934,#1945 (1.9.3).
- The static
- ImageBuf
- New method
set_origin()
changes the pixel data window origin. #1949 (1.9.4) - Assignment (
operator=
) is now enabled for ImageBuf, both the copying and moving variety. Also, an explicit copy() method has been added that returns a full copy of the ImageBuf. #1952 (1.9.4) - write() method has had its arguments changed and now takes an optional TypeDesc that lets you specify a requested data type when writing the output file, rather than requiring a previous and separate call to set_write_format(). The old call signature of write() still exists, but it will be considered deprecated in the future. #1953 (1.9.4)
- New method
- ImageBufAlgo
- In C++, functions that take raw pointers for per-channel constant
values or results are deprecated, in favor of new versions that
heavily rely on
span<>
to safely pass array references and their lengths. #1961 (1.9.4) - In both C++ and Python, every IBA function that takes a parameter giving an ImageBuf destination reference for results have an additional variant that directly returns an ImageBuf result. This makes much cleaner, more readable code, in cases where it's not necessary to write partial results into an existing IB. #1961 (1.9.4)
- In C++, many IBA functions that came in multiple versions for whether
certain parameters could be an image, a per-channel constant, or a
single constant, have been replaced by a single version that takes
a new parameter-passing helper class,
Image_or_Const
that will match against any of those choices. (No changes are necessary for calling programs, but it makes the header and documentation a lot simpler.) #1961 (1.9.4) - IBA compare(), computePixelStats(), and histogram() now directly return their result structures, intead of requiring the passing of a destination reference. #1961 (1.9.4)
- New IBA::fit() resizes and image to just fit in the given size, but
preserve its aspect ratio (padding with black as necessary). It's just
like what
oiiotool --fit
has always done, but now you can call it directly from C++ or Python. #1993 (1.9.4) - New
contrast_remap()
allows flexible linear or sigmoidal contrast remapping. #2043 (1.9.4) ImageBufAlgo::colorconvert
and variousocio
transformations have changed the default value of theirunpremult
parameter fromfalse
totrue
, reflecting the fact that we believe this is almost always the more correct choice. Also, if their input image is clearly marked as having unasociated alpha already, they will not bracket the color conversion with the requested unpremult/premult. #1864 (1.9.2)- Updated the OpenCV interoperability with new functions to_OpenCV (make an ImageBuf out of a cv::Mat) and from_OpenCV (fill in a cv::Mat with the contents of an ImageBuf). Deprecated the old from_IplImage and to_IplImage, which are very OpenCV-1.x-centric. (2.0.2)
- In C++, functions that take raw pointers for per-channel constant
values or results are deprecated, in favor of new versions that
heavily rely on
- ImageCache/TextureSystem:
- ImageCache and TextureSystem now have
close(filename)
andclose_all()
methods, which for one file or all files will close the files and release any open file handles (also unlocking write access to those files on Windows), but without invalidating anything it knows about the ImageSpec or any pixel tiles already read from the files, as would happen with a call to the much more drasticinvalidate()
orinvalidate_all()
. #1950 (1.9.4) TextureSystem::create()
has an additional optional argument that allows the caller to pass an existing app-owned custom ImageCache. #2019 (1.9.4)- New
TextureSystem::imagecache()
method returns a blind, non-owning pointer to the underlying ImageCache of that TS. #2019 (1.9.4) - ImageCache: extended add_tile() with an optional
copy
parameter (which defaults totrue
), which when set tofalse
will make a tile that references an app buffer without allocating, copying, and owning the memory. In short, this makes it possible to reference existing memory holding an image array, as if it were a texture. #2012 (1.9.4) ImageCache::add_file()
extended with an optionalreplace
parameter (default: false), that if true, will replace the tile and invalidate the old one. #2021 (1.9.4)
- ImageCache and TextureSystem now have
- Changes to string formatting: #2076 (2.0.1)
- New
Strutil::sprintf()
andustring::sprintf()
functions are for printf-style formatted errors and warnings. You are encouraged to change your existingformat()
calls tosprintf()
, since the originalformat
may in a later version (2.1?) switch to Python-style formatting commands, butsprintf
will continue to reliably use C printf style notation. - In ImageInput, ImageOutput, ImageBuf, and ErrorHandler, new
errorf()
andwarningf()
methods similarly provide printf-style formatted errors and warnings. The olderror()/warning()
calls will someday (maybe 2.1?) switch to Python-style formatting commands, buterrorf
will continue to reliably use C printf style notation.
- New
- ColorConfig changes: ColorConfig methods now return shared pointers to
ColorProcessor
rather than raw pointers. It is therefore no longer required to make an explicit delete call. Created ColorProcessor objects are now internally cached, so asking for the same color transformation multiple times is no longer expensive. The ColorProcessor interface is now incolor.h
and can be directly used to perform transformations on individual colors (previously it was just an opaque pointer and could only be used to pass into certain IBA functions). The color space names "rgb" and "default" are now understood to be synonyms for the default "linear" color space. #1788 (1.9.0) - Remove long-deprecated API calls:
- ImageBuf::get_pixels/get_pixel_channels varieties deprecated since 1.6.
- ImageBuf::set_deep_value_uint, deprecated since 1.7.
- ImageBuf::deep_alloc, deprecated since 1.7.
- ImageBufAlgo::colorconvert variety deprecated since 1.7.
- ImageCache::clear, deprecated since 1.7.
- ImageCache::add_tile variety deprecated since 1.6.
- ROI new methods: contains() #1874, #1878 (1.9.2)
ImageBufAlgo::pixeladdr()
now takes an additional optional parameter, the channel number. #1880 (1.9.2)- Global OIIO attribute "log_times" (which defaults to 0 but can be overridden
by setting the
OPENIMAGEIO_LOG_TIMES
environment variable), when nonzero, instruments ImageBufAlgo functions to record the number of times they are called and how much time they take to execute. A report of these times can be retrieved as a string as the "timing_report" attribute, or it will be printed to stdout automatically if the value of log_times is 2 or more at the time that the application exits. #1885 (1.9.2) - Moved the definition of
ROI
fromimagebuf.h
toimageio.h
and make most of the methodsconstexpr
. #1906 (1.9.2) - Rename/move of
array_view
tospan
. Deprecatedarray_view
and moved array_view.h contents to span.h. You should changearray_view<T>
tospan<T>
andarray_view<const T>
tocspan<T>
. #1956,2062 (1.9.4) - ustring: removed
operator int()
that allowed simple int casting such as:This was error-prone, neither std::string nor std::string_view had the equivalent, so we are removing it. The preferred idiom is:ustring u, v; if (u || !v) { ... }
if (!u.empty() || v.empty()) { ... }
Performance improvements:
- ImageBufAlgo::computePixelStats is now multithreaded and should improve by a large factor when running on a machine with many cores. This is particularly noticable for maketx. #1852 (1.9.2)
- Color conversions are sped up by 50% for 4 channel float images, about 30% for other combinations of channels or data formats. #1868 (1.9.2)
- ImageBuf::get_pixels() sped up by around 3x for the common case of the image being fully in memory (the slower path is now only used for ImageCache-based images). #1872 (1.9.2)
- ImageBufAlgo::copy() and crop() sped up for in-memory buffers, by about 35-45% when copying between buffers of the same type, 2-4x when copying between buffers of different data types. #1877 (1.9.2)
- ImageBufAlgo::over() when both buffers are in-memory, float, 4-channels, sped up by about 2x. #1879 (1.9.2).
- ImageBufAlgo::fill() of a constant color sped up by 1.5-2.5x (depending on the data type involved). #1886 (1.9.2)
Fixes and feature enhancements:
- oiiotool
--help
prints important usage tips that explain command parsing, syntax of optional modifiers, and the path to PDF docs. #1811 (1.9.2)--colormap
has new maps "inferno", "magma", "plasma", "viridis", which are perceptually uniform, monotonically increasing luminance, look good converted to greyscale, and usable by people with color blindness. #1820 (1.9.2)- oiiotool no longer enables autotile by default. #1856 (1.9.2)
--colorconvert
,--tocolorspace
, and all of the--ocio
commands now take an optional modifier:unpremult=1
which causes the color conversion to be internally bracketed by unpremult/premult steps (if the image has alpha and is not already marked as having unassociated alpha). You should therefore prefer--colorconvert:unpremult=1 from to
rather than the more complex--unpremult --colorconvert from to -premult
. #1864 (1.9.2)--autocc
will also cause unpremult/premult to bracket any color transformations it does automatically for read and write (if the image has alpha and does not appear to already be unassociated). #1864 (1.9.2)--help
prints the name of the OCIO color config file. #1869 (1.9.2)- Frame sequence wildcard improvements: fix handling of negative frame
numbers and ranges, also the
--frames
command line option is not enough to trigger a loop over those frame numbers, even if no other arguments appear to have wildcard structure. #1894 (1.8.10/1.9.2) --info -v
now prints metadata in sorted order, making it easier to spot the existance of particular metadata. #1982 (1.9.4)--no-autopremult
fixed, it wasn't working properly for cases that were read directly rather than backed by ImageCache. #1984 (1.9.4)- New
--contrast
allows for contrast remapping (linear or sigmoidal). #2043 (1.9.4) - Improved logic for propagating the pixel data format through multiple operations, especially for files with multiple subimages. #1769 (1.9.0/1.8.6)
- Outputs are now written to temporary files, then atomically moved
to the specified filename at the end. This makes it safe for oiiotool
to "overwrite" a file (i.e.
oiiotool in.tif ... -o out.tif
) without problematic situations where the file is truncated or overwritten before the reading is complete. #1797 (1.8.7/1.9.1) - Fixed problem with reading
half
files where very small (denormalized) half values could get squashed to float 0.0 instead of having their values preserved, if certain old versions of libopenjpeg were being used (because they set a CPU flag strangely upon library load and then never changed it back, this is a libopenjpeg bug that has since been fixed). #2048 (2.0) -d chan=type
logic fixed for certain cases of specifying the data types of individual channels. #2061 (2.0beta2)- Expression evaluation: metadata names can now be enclosed in single
or double quotes if they don't follow "C" identifier naming conventions.
For example,
{TOP.'foo/bar'}
retrieves metadata called "foo/bar" rather than trying to retrieve "foo" and divide by bar. #2068 (2.0beta2) - Expression evaluation: When retrieving metadata, timecode data will be expressed properly as a string ("00:00:00:00"). #2068 (2.0beta2)
- ImageBufAlgo:
color_map()
supports new maps "inferno", "magma", "plasma", "viridis". #1820 (1.9.2)- Across many functions, improve channel logic when combining an image with alpha with another image without alpha. #1827 (1.9.2)
mad()
now takes animg*color+img
variety. (Previously it supportedimg*img+img
andimg*color+color
.) #1866 (1.9.2)- New
fit()
is like resize but fits inside a specified window size, while preserving the aspect ratio of the image appearance. #1993. - New
contrast_remap()
allows flexible linear or sigmoidal contrast remapping. #2043 (1.9.4) channel_append()
is no longer limited to requiring the two input images to have the same pixel data type. #2022 (1.9.4)isConstantColor()
,isConstantChannel()
, andisMonochrome()
have added an optionalthreshold
parameter that allows you to compute whether the image is constant or monochrome within a non-zero tolerance (the default is still 0.0, meaning checking for an exact match). #2049 (2.0.0)IBA::ociodisplay()
has better behavior when its "fromspace" parameter is left blank -- instead of assuming "linear" (as a space name), it assumes it's whatever space in your OCIO color config has the "linear" role. #2083 (1.8.17/2.0.1)
- ImageBuf:
- Bug fixed in IB::copy() of rare types. #1829 (1.9.2)
- write() automatically tells the ImageCache to 'invalidate' the file being written, so cached images will not retain the prior version of the files. #1916 (1.9.2)
- Bug fix to ImageBuf::contains_roi() method -- it erroneously always
returned
true
. #1997 (1.8.14/1.9.4)
- ImageCache/TextureSystem/maketx:
- Improved stats on how long we wait for ImageInput mutexes. #1779 (1.9.0/1.8.6)
- Improved performance of IC/TS tile and file caches under heavy contention from many threads. #1780 (1.9.0)
- Increased the default
max_tile_channels
limit from 5 to 6. #1803 (1.9.1) - maketx: improved image hashing to avoid some (extremely rare) possible hash collisions. #1819 (1.9.2)
- IC/TS performance improvements by changing the underlying hash table implementation. #1823,1824,1825,1826,1830 (1.9.2)
- texture()/texture3d(): when requesting a nonexistant "subimage", return the fill color, like we do when requesting nonexistant channels (rather than nondeterministically simply not filling in the result). #1917 (1.9.2)
- Relying on some changes to the ImageInput API, there is now much less thread locking to protect the underlying ImageInputs, and this should improve texture and image cache performance when many threads need to read tiles from the same file. #1927 (1.9.2)
get_image_info()
/get_texture_info()
is now more flexible about retrieving arrays vs aggregates, in cases where the total number of elements is correct. #1968 (1.9.4)- Fix uninitialized read within the texture system (only affected statistics, never gave wrong texture results). #2000 (1.9.4)
- texture3d() transforms lookup points from world into local space if the file has a "worldtolocal" metadata giving a 4x4 matrix. #2009 (1.9.4)
- Fix minor texture filtering bug where widely disparate "sblur" and "tblur" values could in some circumstances lead to incorrect texture filter estimation. #2052 (2.0.0)
ImageCache::invalidate(filename)
did not properly invalidate the "fingerprint" is used to detect duplicate files. #2081 (1.8.17/2.0.1)
- iv:
- Fix (especially on OSX) for various ways it has been broken since the shift to Qt5. #1946 (1.8.12, 1.9.4)
- New optin
--no-autopremult
works like oiiotool, causes images with unassociated alpha to not be automatically premultiplied by alpha as they are read in. #1984 (1.9.4)
- All string->numeric parsing and numeric->string formatting is now locale-independent and always uses '.' as decimal marker. #1796 (1.9.0)
- Python Imagebuf.get_pixels and set_pixels bugs fixed, in the varieties that take an ROI to describe the region. #1802 (1.9.2)
- Python: Implement missing
ImageOutput.open()
call variety for declaring multiple subimages. #2074 (2.0.1) - More robust parsing of XMP metadata for unknown metadata names. #1816 (1.9.2/1.8.7)
- Fix ImageSpec constructor from an ROI, display/"full" window did not get the right default origin. #1997 (1.8.14/1.9.4)
- ImageSpec::erase_attribute() fix bug where it got case-sensitivity of the search backwards when built using std::regex rather than boost::regex. #2003 (1.8.14/1.9.4)
- DPX:
- Better catching of write errors, including filling the disk while in the process of writing a DPX file. #2072 (2.0.1)
- Field3d:
- Prevent crashes when open fails. #1848 (1.9.2/1.8.8)
- Fix potential mutex deadlock. #1972 (1.9.4)
- GIF:
- Fix crash when reading GIF with comment extension but no comment data. #2001 (1.8.14/1.9.4)
- JPEG:
- When writing, be robust to accidentally setting the "density" metadata to values larger than JPEG's 16 bit integer field will accommodate. #2002 (1.8.14/1.9.4)
- Better detection and reporting of error conditions while reading corrupt JPEG files. #2073 (2.0.1)
- OpenEXR:
- Gracefully detect and reject files with subsampled channels, which is a rarely-to-never-used OpenEXR feature that we don't support properly. #1849 (1.9.2/1.8.8)
- Improved handling of UTF-8 filenames on Windows. #1941 (1.9.3, 1.8.12, 1.7.19)
- PNG:
- Fix redundant png_write_end call. #1910 (1.9.2)
- PSD:
- Fix parse issue of layer mask data. #1777 (1.9.2)
- RAW:
- Add "raw:HighlightMode" configuration hint to control libraw's handling of highlight mode processing. #1851
- Important bug fix when dealing with rotated (and vertical) images, which were not being re-oriented properly and could get strangely scrambled. #1854 (1.9.2/1.8.9)
- Major rewrite of the way makernotes and camera-specific metadata are handled, resulting in much more (and more accurate) reporting of camera metadata. #1985 (1.9.4)
- The "oiio:ColorSpace" metadata is now set correctly when reading raw DSLR images. And we deprecate the old "raw:ColorSpace" metadata, which is useless. #2016 (1.9.4)
- Add "raw:aber" configuration hint to control libraw's adjustments for chromatic aberration. This data is of type "float[2]", the first value is the scale factor for red, the second for blue, and both should be very close to 1.0. #2030 (1.9.4)
- TIFF:
- Improve performance of TIFF scanline output. #1833 (1.9.2)
- Bug fix: read_tile() and read_tiles() input of un-premultiplied tiles botched the "shape" of the tile data array. #1907 (1.9.2/1.8.10)
- Improvement in speed of reading headers (by removing redundant call to TIFFSetDirectory). #1922 (1.9.2)
- When config option "oiio:UnassociatedAlpha" is nonzero (or not set -- which is the default), therefore enabling automatic premultiplication by alpha for any unassociated alpha files, it will set the metadata "tiff:UnassociatedAlpha" to indicate that the original file was unassociated. #1984 (1.9.4)
- Bug fixes for TIFF reads of images with unassociated alpha -- there were some edge cases where they pixels failed to automatically premultiply upon read. #2032 (1.9.4)
- zfile: more careful gzopen on Windows that could crash when given bogus filename. #1839,2070 (1.9.2/1.8.8/2.0.1)
- Windows fix: Safer thread pool destruction on. #2038 (1.9.4)
Build/test system improvements and platform ports:
- Fixes for Windows build. #1793, #1794 (1.9.0/1.8.6), #2025 (1.9.4)
- Fix build bug where if the makefile wrapper got
CODECOV=0
, it would force a "Debug" build (required for code coverage tests) even though code coverage is instructed to be off. (It would be fine if you didn't specifyCODECOV
at all.) #1792 (1.9.0/1.8.6) - Build: Fix broken build when Freetype was not found or disabled. #1800 (1.8.6/1.9.1)
- Build: Boost.Python is no longer a dependency, but
pybind11
is. If not found on the system, it will be automatically downloaded. #1801, #2031 (1.9.1) - Time for a multi-core build of OIIO is reduced by 40% by refactoring some extra big modules into more bite-sized pieces. #1806 (1.9.2)
- testtex:
- Make the "thread workout" cases all honor
--handle
. #1778 (1.9.0) - Only prints detailed stats if
-v
is used, and new option--invalidate
will invalidate the cache when starting each threadtimes trial. #1828 (1.9.2) - New
--anisoratio
lets you choose anisotropic shape for thread working tests, and make thread_workout samples twice as big to be more typical by interpolating mip levels. #1840 (1.9.2) - TextureSystem stats are printed as well as ImageCache. #1840 (1.9.2)
- Make the "thread workout" cases all honor
- iv no longer requires GLEW, using QOpenGLFunctions instead. #1840 (1.9.2)
- DICOM: Fix dcmtk build errors on some platforms. Also, the minimum dcmtk version we suport is 3.6.1. #1843 (1.9.2/1.8.8)
- Build fixes for Hurd OS. #1850 (1.9.2/1.8.8)
- Clean up leak sanitizer errors. #1855 (1.9.2)
- On Unix/Linux, add explicit DL library dependency to libOpenImageIO.so itself instead of only to the binaries and test utilities. #1860 (1.9.2/1.8.8)
- The build now bundles a sample OCIO config in testsuite/common so that we can do OCIO-based unit tests. #1870 (1.9.2)
- Properly find newer openjpeg 2.3. #1871 (1.9.2)
- Fix testsuite to be Python 2/3 agnostic. #1891 (1.9.2)
- Removed
USE_PYTHON3
build flag, which didn't do anything. #1891 (1.9.2) - The
PYTHON_VERSION
build variable is now better at selecting among several installed versions of Python, and all the tests should work fine with Python 3.x now. #2015 (1.9.4) - Remove some lingering support for MSVS < 2013 (which we haven't advertised as working anyway). #1887 (1.9.2)
- Windows/MSVC build fix: use the
/bigobj
option on some large modules that need it. #1900, #1902 (1.8.10/1.9.2) - Add up-to-date Nuke versions to FindNuke.cmake. #1920 (1.8.11, 1.9.2)
- Allow building against ffmpeg 4.0. #1926,#1936 (1.8.11, 1.9.2)
- Disable SSE for 32 bit Windows -- problematic build issues. #1933 (1.9.3, 1.8.12, 1.7.19)
- Fixes to the
EMBEDPLUGINS=0
build case, which had at some point stopped working properly. #1942 (1.9.3) - Improvements in finding the location of OpenJPEG with Macports. #1948 (1.8.12, 1.9.4)
- Improvement finding libraw properly on Windows. #1959 (1.9.4)
- Fix warnings to allow clean gcc8 builds. #1974 (1.9.4)
- Make sure we build properly for C++17. (1.9.4)
- Check properly for minimal FFMpeg version (2.6). #1981 (1.9.4)
- New build option GLIBCXX_USE_CXX11_ABI, when set to 0 will force the old gcc string ABI (even gcc 7+ where the new ABI is the default), and if set to 1 will force the new gcc string ABI (on gcc 5-6, where old ABI is the default). If not set at all, it will respect the default choice for that compiler. #1980 (1.9.4)
- TravisCI builds now use an abbreviated test matrix for most ordinary pushes of working branches, but the full test matrix for PRs or pushes to "master" or "RB" branches. #1983 (1.9.4)
- Support compilation by clang 7.0. #1995 (1.9.4)
- Support for building against OpenEXR 2.3. #2007 (1.9.4)
- Use OpenEXR pkgconfig if available. #2008 (1.9.4)
- Allow builds outside the source tree to pass testsuite. Defaults to
finding test image directories such as oiio-images, openexr-images, and
libtiffpic in the usual ".." from the main OIIO source directory, but now
it can be overridden with the CMake variable
OIIO_TESTSUITE_IMAGEDIR
. #2026 (1.9.4) - Remove stale python examples from
src/python
. They were untested, undocumented, and probably no longer worked against the current APIs. #2036 (1.9.4) - Fixes for Windows when making Unicode builds, and fix Plugin::dlopen on Windows to properly support UTF-8 filenames. #1454 (2.0.1)
- Support added for OpenCV 4.0. (2.0.1)
Developer goodies / internals:
- Formatting with clang-format: All submissions are expected to be
formatted using our standard clang-format rules. Please run
make clang-format
prior to submitting code. The TravisCI tests include one entry just to check that the formatting conforms, and will fail if it doesn't, printing the diffs that would bring it to proper formatting. (Note: for small changes, if you don't have clang-format locally, it's ok to submit, then use the diffs from the failures to fix it by hand and resubmit and update.) #2059,2064,2065,2067,2069. - argparse.h:
- Add pre- and post-option help printing callbacks. #1811 (1.9.2)
- Changed to PIMPL to hide implementation from the public headers. Also modernized internals, no raw new/delete. #1858 (1.9.2)
- array_view.h:
- Added begin(), end(), cbegin(), cend() methods, and new constructors from pointer pairs and from std::array. (1.9.0/1.8.6)
- Deprecated, moved contents to span.h. You should change
array_view<T>
tospan<T>
andarray_view<const T>
tocspan<T>
. #1956 (1.9.4)
- color.h: add guards to make this header safe for Cuda compilation. #1905 (1.9.2/1.8.10)
- filesystem.h:
- IOProxy classes that can abstract file operations for custom I/O substitutions. #1931 (1.9.3)
- Proper UTF-8 filenames for unique_path() and temp_directory(), and general UTF-8 cleanup/simplification. #1940 (1.9.3, 1.8.12, 1.7.19)
- fmath.h:
- Now defines preprocessor symbol
OIIO_FMATH_H
so other files can easily detect if it has been included. (1.9.0/1.8.6) - Modify to allow Cuda compilation/use of this header. #1888,#1896 (1.9.2/1.8.10)
- Improve numeric approximation of fast_atan() and fast_atan2(). #1943 (1.9.3)
- fast_cbrt() is a fast approximate cube root (maximum error 8e-14, about 3 times faster than pow computes cube roots). #1955 (1.9.4)
- Now defines preprocessor symbol
- function_view.h: Overhauled fixed with an alternate implementation borrowed from LLVM. (1.9.4)
- hash.h: add guards to make this header safe for Cuda compilation. #1905 (1.9.2/1.8.10)
- imageio.h:
convert_image()
andparallel_convert_image
have been simplified to remove optionalalpha_channel
andz_channel
parameters that were never actually used. The old versions are still present but are deprecated. #2088 (2.0.1) - parallel.h:
parallel_options
passed to many functions. #1807 (1.9.2)- More careful avoidance of threads not recursively using the thread pool (which could lead to deadlocks). #1807 (1.9.2)
- Internals refactor of task_set #1883 (1.9.2).
- Make the thread pool better behaved in times if pool congestion -- if there are already way too many items in the task queue, the caller may do the work itself rather than add to the end and have to wait too long to get results. #1884 (1.9.2)
- paramlist.h:
- ParamValue class has added get_int_indexed() and get_float_indexed() methods. #1773 (1.9.0/1.8.6)
- ParamValue restructured to allow additional common data types to store internally rather than requre an allocation. #1812 (1.9.2)
- New ParamList convenience methods: remove(), constains(), add_or_replace(). #1813 (1.9.2)
- platform.h:
- New OIIO_FALLTHROUGH and OIIO_NODISCARD macros, and renamed OIIO_UNUSED_OK to OIIO_MAYBE_UNUSED (to match C++17 naming). #2041
- simd.h:
- Fixed build break when AVX512VL is enabled. #1781 (1.9.0/1.8.6)
- Minor fixes especially for avx512. #1846 (1.9.2/1.8.8) #1873,#1893 (1.9.2)
- span.h:
- Used to be array_view. Now it's
span<>
andspan_strided
. Also,cspan<T>
is a handy alias forspan<const T>
. #1956 (1.9.4) - Added begin(), end(), cbegin(), cend() methods, and new constructors from pointer pairs and from std::array. (1.9.0/1.8.6)
- Added
==
and!=
to span and span_strided. #2037 (1.9.4)
- Used to be array_view. Now it's
- strutil.h:
- All string->numeric parsing and numeric->string formatting is now locale-independent and always uses '.' as decimal marker. #1796 (1.9.0)
- New
Strutil::stof()
,stoi()
,stoui()
,stod()
functions for easy parsing of strings to numbers. Also testsStrutil::string_is_int()
andstring_is_float()
. #1796 (1.9.0) - New
to_string<>
utility template. #1814 (1.9.2) - Fix to strtof, strtod for non-C locales. #1918 (1.8.11, 1.9.2)
- New
iless()
is case-insensitive locale-independent string_view ordering comparison. Also added StringIEqual, StringLess, StringILess functors. (1.9.4) join()
is now a template that can act on any iterable container of objects that allow stream output. #2033 (1.9.4)- New
splits()
/splitsv()
that direction returns a vector of std::string or string_view, respectively. #2033 (1.9.4) - A second version of
extract_from_list_string
that directly returns a std::vector (instead of being passed as a param). #2033 (1.9.4) parse_string
now accepts single quotes as well as double quotes to enclose a quoted string. #2066 (2.0beta2)- Fix Strutil::vsnprintf detection of encoding errors on Windows. #2082 (1.8.17/2.0.1)
- thread.h:
- Reimplementaiton of
spin_rw_mutex
has much better performance when many threads are accessing at once, especially if most of them are reader threads. #1787 (1.9.0) - task_set: add wait_for_task() method that waits for just one task in the set to finish (versus wait() that waits for all). #1847 (1.9.2)
- Fix rare crash in thread pool when lowering the number of threads. #2013 (1.9.4/1.8.15)
- Reimplementaiton of
- unittest.h:
- Made references to Strutil fully qualified in OIIO namespace, so that
unittest.h
can be more easily used outside of the OIIO codebase. #1791 (1.9.0) OIIO_CHECK_EQUAL_APPROX
- fix namespace ambiguity. #1998 (1.9.4)OIIO_CHECK_EQUAL
now can compare twostd::vector
s. #2033 (1.9.4)- Make unit test errors respect whether stdout is a terminal when deciding whether to print in color. #2045
- Made references to Strutil fully qualified in OIIO namespace, so that
- Extensive use of C++11
final
andoverride
decorators of virtual methods in our internals, especially ImageInput and ImageOutput. #1904 (1.9.2)
Notable documentation changes:
- A new LICENSE-THIRD-PARTY.md file reproduces the full open source licenses of all code that we distribute with OIIO, incorporate, or derive code from. They are have very similar license terms to the main OIIO license ("New BSD") -- MIT, Mozilla, Apache 2.0, or public domain. OIIO does not use any GPL or other "viral" licenesed code that would change license terms of any code that didn't come directly from those packages.
- The CHANGES.md file was getting truly enormous, so we have split the release notes from the 0.x and 1.x releases into separate files found in src/doc. So CHANGES.md only documents 2.0 and beyond.
For older release notes, see: