Introduction

The VFX Reference Platform is a set of tool and library versions to be used as a common target platform for building software for the VFX industry. Its purpose is to minimise incompatibilities between different software packages, ease the support burden for Linux-based pipelines and encourage further adoption of Linux by software vendors. The Reference Platform is updated annually by a group of software vendors in collaboration with the Visual Effects Society Technology Committee.

Current Status

The Calendar Year 2017 (CY2017) Reference Platform is the target for all major software releases in 2017. The CY2018 Draft has been published for comment in advance of the Final version being published in July.

28th August 2017 - Added a note for gcc 5 and updated the Qt note to include a link to the qtdeclarative modifications.

3rd August 2017 - The CY2018 Platform was ratified as Final at the annual SIGGRAPH VFX Reference Platform Birds of a Feather with no further changes.

2nd July 2017 - Minor updates to CY2018 Draft for Qt and ACES.

29th April 2017 - CY2018 Draft published with significant upgrades to gcc and glibc. This also comes with notice of our intention to move to Python 3 for CY2019 in advance of Python 2 support ending in 2020. We are currently soliciting feedback on this Draft so please either send to feedback@vfxplatform.com or share on vfx-platform-discuss. We expect to publish CY2018 Final around SIGGRAPH in July.

1st August 2016 - CY2017 Final now published with OpenSubdiv and OpenVDB being updated in addition to Boost, Ptex, Alembic and TBB as result of feedback to the Draft.

28th June 2016 - The VFX Reference Platform Qt modifications to the Qt 5.6.1 release are now available from these forks of qtbase and qtx11extras.

20th June 2016 - CY2017 Draft published for comment from the community. The theme for CY2017 is to minmize code changes in the year following the transition to Qt 5.

27th October 2015 - A late change has been proposed to CY2016 to move from Qt 5.5.x to Qt 5.6.x due to that version now being targetted as a Long Term Support release. Please see here for further details.

Reference Platform

Each annual reference platform is designated by the calendar year in which major product releases should be targeting that particular reference.

All versions should be considered exact required versions, except for those components where indicates that:

  CY2018 CY2017 CY2016 CY2015 CY2014
gcc 5.3.1 (see notes) 4.8.2 with bugfix or 4.8.3 4.8.2 with bugfix or 4.8.3 4.8.2 4.1.2
glibc 2.17 2.12 2.12 2.12  
python
(built with ucs4)
2.7.5 - 2.7.latest
Python 3 planned for CY2019
2.7.5 - 2.7.latest 2.7.5 - 2.7.latest 2.7.x 2.7.3
Qt 5.6.1 - 5.6.latest (modified) 5.6.1 (modified) 5.6.1 (modified) 4.8.x 4.8.5
PyQt 5.6 5.6 5.6    
PySide 2.0.x 2.0.x 2.0 1.2.x 1.2
NumPy 1.12.1 1.9.2 1.9.2    
OpenEXR 2.2.x 2.2.x 2.2.x 2.2.x 2.0.1
Ptex 2.1.28 2.1.28 2.0.42    
OpenSubdiv 3.3.x 3.1.x 3.0.x 2.5.x 2.3.3
OpenVDB 5.x 4.x 3.x 3.0.x  
Alembic 1.7.x 1.6.x 1.5.8 1.5.x 1.5.x
FBX 2018.x latest latest latest 2015
OpenColorIO 1.0.9 1.0.9 1.0.9 1.0.9 1.0.7
ACES 1.0.3 - 1.0.latest 1.0.x 1.0    
Boost 1.61 1.61 1.55 1.55 1.53
Intel TBB 2017 Update 6 4.4 4.3 4.2 4.1
Intel MKL 2017 Update 2 11.3 11.3    
C++ API/SDK C++14 C++11 C++11    
Note - gcc 5

Redhat/CentOS systems can obtain gcc 5.3.1 by installing Redhat DTS 4.1. Ubuntu 16.04 LTS ships with gcc 5.3.1 as standard.

Since gcc 5.1, libstdc++ introduced a new library ABI that includes new implementations of std::string and std::list. In order to maintain backwards compatibility the old implementations are still supported in parallel with the new ones. The choice of implementation is made using the _GLIBCXX_USE_CXX11_ABI macro, and the VFX Reference Platform is still using the older option so the compiler setting should be _GLIBCXX_USE_CXX11_ABI=0. The Platform will move to the newer implementations in a future year once the major Linux distributions have made the transition. RHEL/CentOS 7 and Redhat DTS still use the original implementations by default.

Note - gcc 4

The vanilla gcc 4.8.2 has a serious bug that was fixed in 4.8.3 and some Linux distribution vendors actually ship a patched version as 4.8.2. The reason the Platform gave 4.8.2 as an option for CY2016 is that this gcc version is what ships with Redhat Developer Toolset 2.1 that some software vendors werw committed to using through 2016.

The following are the known distributions that ship with a fixed 4.8.2:- Redhat DTS 2.1, RHEL/CentOS 6.

Note - Qt modifications

The major change for CY2016 was a move to Qt 5 which required a port of PySide and modifications to vanilla Qt. In November 2015 CY2016 version of Qt was upped from 5.5.x to 5.6.x with agreement from the community that it was preferable to align with a Long Term Support release. In May 2016 it was updated again to 5.6.1 to incorporate some critical bug fixes.

These modifications are required to avoid the introduction of functional UI regressions impacting DCC tools and consist only of backported bug fixes and critical changes that have not yet been accepted into the mainline Qt distribution. The need for these modifications is not new, currently some software vendors ship their own differently modified Qt so CY2016 represents a significant step forward with the goal of all software vendors sharing an identically modified Qt. We are working with the Qt Company to eliminate the need for these modifications entirely in future releases.

These Qt modifications are available on Github from these forks of qtbase, qtx11extras and qtdeclarative. These modifications to Qt 5.6.1 should be used by anyone who wishes to build Qt applications against the Platforms from CY2016 or later.

 

Any reference made in the VFX Reference Platform to any company or any other entity, or to their services or products, is not an endorsement or recommendation nor should it imply any such endorsement or recommendation of the quality or fitness of purpose of that company or entity, or its services or products. In no event shall the Visual Effects Society be responsible or liable, directly or indirectly, for any damage or loss caused or alleged to be caused by or in connection with the use of or reliance on any such content, goods, or services identified in the VFX Reference Platform or the Visual Effects Society website.