Revision [1517]
This is an old revision of GraphicsHardwareRequirements made by MarioKleiner on 2009-03-22 17:11:01.
Graphics hardware requirements and recommendations
General recommendations:
The summary here is just for your reference, so you can get a feeling on what to expect with specific hardware. If you buy new systems, go for the latest generation hardware of NVidia or ATI. Currently, stuff that claims to support Direct3D-10, OpenGL-3 or ShaderModel 4, does support all functionality of Psychtoolbox in the most optimal way. All cards of the NVidia GeForce 8 series and later (e.g., 8600, 8800, 9600, 9800, GTX 280 etc.), as well as all cards of the ATI Radeon HD series and later (HD 2400, 2600, 3000 series, 4000 series etc.) and their corresponding counterparts from the NVidia Quadro series and ATI FireGL / FirePro line of cards are technically state of the art and Psychtoolbox can take full advantage of their useful new features. Expensive high-end models differ from cheap low-end models almost only in raw performace, ie., drawing speed, not in functionality, unless stated otherwise below.
Mobile graphics chips (in Laptops) are almost always slower than discrete graphics cards in desktop computers. This is a design tradeoff to accomodate the stricter requirements for cooling, space and power consumption in portable computers.
So called "integrated graphics chips" (aka "onboard graphics chips" or "chipset graphics" or IGPs) are usually cheaper and consume less power and space in a computer, which is why they are often found in Laptop computers and cheap desktops. Their disadvantage is usually much lower performance. The latest onboard parts from NVidia and ATI provide the same or almost the same features as dedicated graphics cards, so there isn't a limitation in functionality per se. The raw processing power is lower though, because these chips often don't have dedicated fast VRAM memory, but share slow RAM system memory with all other parts of your computer. They usually also have less processing units (so called shader processors or stream processors). All in all they may be sufficient for many not too demanding tasks. Very compute intense, image processing intense or memory intense tasks may not be feasible in practice because although they are doable in principle with the given feature set, the raw performance is just pathetically insufficient for research grade realtime behaviour. They are usually perfectly sufficient for designing and debugging your experiment scripts, where absolute realtime performance doesn't matter.
Tested graphics hardware + operating system configurations:
The following combinations of graphics hardware and operating systems are used by the developers for development of PTB-3's Screen function and therefore tested and known to work well within their respective feature set. This doesn't exclude other similar or more advanced system configurations which likely will work equally well or maybe even better. It just happens to be the equipment that is accessible to us for development and testing. As a rule of thumb, a specific feature of a specific piece of graphics hardware that works well on MS-Windows will likely work equally well on GNU/Linux and vice versa due to the unified drivers used for these operating systems (drivers for Windows and Linux by ATI and NVidia are derived from the same code base). This is not necessarily true for Win/Linux vs. Mac OS-X, because the OpenGL drivers for OS-X are developed by different development teams from a different code base - Apple imposes a much stricter control over their implementation of OpenGL, with different priorities wrt. feature set. This means that the same gfx hardware may expose different functionality, performance, limitations and bugs on OS-X vs. Win/Linux due to fundamental driver differences.
The following setups are used for development and testing of PTB, so they get tested for compatibility at least once for each beta release:
- ATI Radeon X1600 mobile chip in a Apple Intel MacBook-Pro, currently running OS-X 10.4.11. Dual display support tested. This is the current main development system for PTB, so it gets tested on a daily basis and for each beta release. The same system gets tested for each beta release under Linux Ubuntu 7.1.
- NVidia GeForce 8800 Ultra in a Apple Intel Mac Pro, currently running OS-X 10.5.6. This is one of the main testing and productive systems.
- NVidia GeforceFX-5200 desktop graphics in a single processor PowerMac-G5, under OS/X 10.4.11. This is one of the main testing systems.
- NVidia GeForce 7800 Ultra in a Dell PC running Windows XP SP-2/3. This is one of the main testing systems.
- NVidia Geforce2Go/GeforceMX mobile graphics chip: Regularly tested under Windows 2000 and GNU/Linux in a Dell Inspiron 8000 laptop. Dual display support tested under Windows.
These cards get tested infrequently, i.e., if significant changes inside Screen() indicate need for testing and if the systems are available for testing:
- NVidia GeForce 8800 Ultra under Windows XP.
- NVidia QuadroFX-5800 under Ubuntu Linux 8.1.
- Radeon HD 2400 under OS/X 10.4.11 in a Intel Mac.
- Intel GMA 950 of Apple MacBook. Tested once under OS/X 10.4.
- Nvidia Geforce 6800 mobile chip in a high end Dell Laptop under Windows XP and GNU/Linux tested once. Dual display support tested.
- Intel GMA 945 onboard GPU: Tested exactly once in single-display mode on a Dell PC under Windows XP, also tested once under GNU/Linux. A similar class would be the ATI Rage 128 / Pro in very old Apple Macintosh computers.
- NVidia Geforce4 desktop graphics chip tested once under GNU/Linux. Geforce3 series hardware should behave the same. Also tested once in a standard Intel PC under GNU/Linux and Windows XP. Dual display support also tested.
- ATI Radeon 9600 under Intel laptop with Windows-XP, tested once.
Rough lineup of different generations of graphics hardware with their respective features:
Basic OpenGL 1.2 compliant hardware:
These provide the minimum amount of functionality for use with Psychtoolbox:
- Frame accurate stimulus onset timing, animation timing and high precision stimulus onset timestamping generally works well, as long as you don't try to overtax the hardware.
- Some of these cards do provide full dual-display output support, e.g., for binocular stimulation.
- All basic 2D and 3D drawing functions work with useable performance for simple tasks.
- Limitations: Drawing of image textures works, but drawing speed may be rather low and use of texture memory inefficient (so you can use less textures or offscreen windows simultaneously). Drawing to and handling of offscreen windows is rather slow and inefficient. Precision for scrolling of textures (e.g., for drifting gratings) may be rather low. Image anti-aliasing is functionally limited to points and lines, slow and of low quality.
- Psychtoolbox imaging pipeline and support for procedural textures completely unsupported.
The limitations are due to lack of programmable shader support, lack of support for framebuffer objects and lack of support for rectangle textures. Typical examples of such hardware are: All ATI Rage 128 (Pro) and older, all Intel chips older than the GMA-950, all NVidia chips before GeForce-2.
Hardware with additional support for rectangle textures:
- Improvements: These support efficient storage and fast drawing of textures and offscreen windows, incremental speed and quality improvements in anti-aliasing and general performance.
- Remaining limitations: No support for imaging pipeline, no support for procedural textures, rather slow drawing into offscreen windows. Only point and line anti-aliasing.
Typical examples are all NVidia GeForce hardware from GeForce-2 series upto GeForce-4 series, all ATI Radeon hardware upto Radeon 9200.
Hardware with support for framebuffer objects and programmable shaders (Shader model 2.0):
Improvements:
- Fast, efficient support for offscreen windows: Efficient use of memory, fast drawing of and into offscreen windows and textures.
- Basic support for the imaging pipeline, e.g., geometric display undistortion, and almost all stereo display modes (dual display, very flexible and high quality anaglyph stereo, interlaced stereo).
- Support for simple procedural texture stimuli via GLSL shaders.
- High quality multisample anti-aliasing on all non-Intel graphics chips. Frame-Sequential stereo under OS/X on all graphics cards except Intel chips.
Typical examples are all NVidia GeForceFX cards (5200, 5800 etc.) and all Radeon 9600, 9700, 9800, X400, X600, X800 cards. Intel GMA 950 and X3000 series.
Hardware with support for Shader model 3.0 shaders and limited support for floating point textures and framebuffer objects:
Entry level systems
These provide basic functionality, e.g., efficient handling of textures and moderately efficient handling of Offscreen windows, fast drawing of basic 2D primitives and 3D graphics, basic anti-aliasing and smoothing of points, lines and full scenes.Low end systems
Provide additional support for fast Offscreen window support and basic image processing functions, e.g., flexible stereo display algorithms, geometric display undistortion, CLUT palette animation and image data conversion via simple mathematical functions or lookup tables. Basic GLSL Vertex and Pixel shader support (Shader model 2.0).- Intel X3100 of Apple MacBook. Not yet tested by developers, however given its specs, the card should work reliably assuming the drivers supplied by Apple are sufficiently mature and bug free. This card and its siblings are special in the sense that feature-wise they are DirectX10 cards with support for Shader model version 4 - they can do most of what the most recent state of the art cards of NVidia and ATI can do. However, they lack any support for frame-sequential stereo, anti-aliasing and high precision HDR framebuffers and due to lack of dedicated fast VRAM memory, they only have a low computational performance. So although theoretically "state of the art" cards, they are too restricted and weak for the typical applications of such state of the art cards.
Mid level systems
Provide additional support for complex image processing operations, e.g., 2D convolution, local and neighborhood operations on images, thresholding and classification. (Shader model 3.0). Advanced support for Vertex and Pixel shaders. Support for floating point framebuffers and floating point blending operations, e.g., high dynamic range rendering and processing, precise execution of iterative image processing algorithms, computer vision and scientific stream computing algorithms.Upper level systems
Similar to mid level systems, but with more generous resource constraints and significantly higher processing power. Do the same as on mid level systems, just much faster.- NVidia Geforce 7800 GT, tested under Windows XP and GNU/Linux. Our test platform for high performance image processing. Dual display support tested. Support for high dynamic range display devices tested. (Currently used in many experimental setups at MPI Tuebingen).
State of the art systems
- NVidia Geforce 8600 - 8800, 9xxx or ATI Radeon HD 2000/3000 systems: These provide a couple of new interesting features, especially if you need HDR rendering or high precision framebuffers for fine control over contrast and color. Buy one of these if you have the choice!
Graphics hardware requirements for specific PTB features:
OpenGL graphics hardware exposes its functionality via so called OpenGL extensions. Each extension defines a specific subset of functionality supported by the hardware. Specific advanced features of PTB-3 require your graphics hardware to support specific sets of OpenGL extensions. If you try to use an advanced PTB feature, PTB will probe your hardware for support of the required extension. If the extension is unsupported, PTB will either refuse use of an advanced feature or it will enable internal fallback implementations that do what you want, but at a much lower performance or precision and much higher resource requirements than if your hardware would support the extension. A list of all existing OpenGL extensions, including their full in-depth technical specification, can be found at the official OpenGL extension registry.
Different models of a specific generation of graphics hardware usually share support for a common set of extensions, but they differ in the precision, performance or efficiency with which features are supported as well as in the set of constraints that need to be fullfilled in order for the hardware efficiently to support a feature. The following websites list the specific set of extensions that are supported for specific models of graphics hardware for specific driver versions or operating system releases. They also list many interesting properties and limitations of these graphics cards. You will notice that there are separate websites for Windows/Linux and OS/X and that if you compare the resource limits, capabilities and feature sets of the same models of graphics hardware between Win/Lin and OS/X you'll sometimes find significant differences. Given that the hardware is the same, these differences are imposed by the different design and implementation of the graphics drivers and OpenGL subsystems of Windows/Linux versus OS/X.
- Delphi3D - Support on Microsoft Windows, sorted by vendor, model and driver release
- GLInfo - Support on MacOS-X, sorted by OS release, PowerPC vs. IntelMac and model
- Wikipedia has nicely written overview articles about different graphics cards and how they differ
- Tom's hardware has some overview about the best graphics cards for a given range of money you'd like to spend. (Caution: Check how recent the article is, could become outdated.)
- And an interface for quick comparison of prices. (Caution: Could be biased, use common sense!)
If you want to buy a graphics card which is an optimal tradeoff between required features for your project and cost, you'll have to match the listed requirements of PTB against the features in those databases. PTB's Screen command outputs a list of all OpenGL extensions supported by your hardware + operating system + driver at startup ("OpenGL extensions are: ...") unless you suppress it. The websites above also provide a tool called GLInfo which probes your hardware and outputs a full listing of all tested properties if you need reliable information about your hardware.
Standard Screen subfunctions and their requirements:
- Support for fast, efficient textures and moderately fast Offscreen windows: GL_ARB_texture_rectangle or GL_EXT_texture_rectangle or GL_NV_texture_rectangle.
- Everything on IntelMacs, everything on PowerMacs except ATI Rage, Rage 128 or Rage Pro. NVidia Geforce2 and later on Windows/Linux. Not Intel GMA 945.
- Support for fast drawing of 3D geometry in MOGL: GL_EXT_draw_range_elements.
- All OS/X hardware. Most PC hardware.
- Support for Screen('Flip', ..., clearmode) command with clearmode=1 (don't clear after Flip): At least one AUX buffer for mono displays, two AUX buffers for stereo displays.
- Well supported on OS/X on PowerPC, faulty on OS/X IntelMac, unsupported on most Windows and Linux systems, especially with ATI hardware. Alternatively if your hardware support the PTB imaging pipeline, you'll get this feature very efficiently for free.
- Support for different stereo display methods (stereomode flag in Screen('OpenWindow', ...):
- Frame sequential stereo for shutter glasses: Blue line syncing method supported on all OS/X hardware except ATI Rage and Intel chips. On Windows, only expensive professional line hardware is supported (ATI FireGL series and NVidia Quadro series). Linux can be extended in various ways to support commodity hardware in addition to the professional line hardware, and to support very special setups, e.g., high performance render clusters.
- Vertical split screen stereo (modes 2 and 3): Supported on OS/X PowerPC on all hardware. All other platforms need support for the PTB imaging pipeline for this to work.
- Dualview stereo for free fusion, cross fusion, haploscopes and dual display systems: Works on all hardware and OS, either via cheap display splitter hardware like the Matrox DualHead2Go or via dual display (dual head) graphics cards.
- Anaglyph stereo: Basic support (without automatic gain correction, desaturation or color to luminance conversion) works on all systems. Advanced anaglyph stereo with automatic color to luminance conversion, desaturation and gain correction is only supported on hardware that supports the PTB imaging pipeline.
- Other algorithms: Need basic support for PTB imaging pipeline.
- Support for full scene anti-aliasing (multisample parameter of Screen('OpenWindow', ...)): Needs GL_ARB_multisample with at least 1 multisample buffer (See constants Max Sample Buffers and Max Samples, bigger is better.
- Supported on most ATI and NVidia hardware, not supported on Intel onboard graphics, e.g., GMA 950 of MacMini, IntelMac or MacBook.
- Support for fast Offscreen windows: Needs support for basic imaging pipeline.
- Support for fast geometric display distortion correction, display hotspotting correction, color correction, clut animation: Needs support for basic imaging pipeline.
Psychtoolbox imaging pipeline:
The Psychtoolbox imaging pipeline is a built-in framework for fast image processing on the graphics hardware, currently in beta stage. It allows to perform common image processing operations on image stimuli (represented as Psychtoolbox textures), to customize and extend the behavior of specific Screen drawing commands and to provide a set of fully automatic post processing operations on your final visual stimuli which may be useful for some more advanced applications. The infrastructure is integrated into PTB, but the specific operations are implemented as shader plugins, written in the OpenGL shading language (GLSL) and executed on the graphics processor itself. The imaging pipeline requires recent hardware for basic operation and mid-level to high-end hardware for the more advanced features.
Basic imaging pipeline support:
Provides the following features:
- Fast efficient support for Offscreen windows. (Implemented)
- Fast support for "don't clear after Flip" mode (dontclear=1) for the Screen('Flip') command, allows for incremental drawing of stimuli. (Implemented)
- Automatic drawing of blue sync lines for frame sequential stereo on consumer hardware. (Implemented)
- Fast support for vertical split screen stereo modes (stereomode 2 and 3). (Implemented)
- Flexible high quality Anaglyph stereo modes with automatic conversion of color stimuli into grayscale images, online color gain correction, desaturation and alternate anaglyph implementations. (Implemented)
- New stereo modes, e.g., interlaced stereo and vertically interlaced stereo for free viewing setups with lenticular lens systems. (On your request)
- Fast remapping of pixel values via lookup tables, e.g., for palette animation. (Implemented)
- Correction of inhomogenities in display intensity via application of per pixel gain values. (On your request)
- Geometric undistortion and alignment for non-rectilinear displays. (Implemented)
Minimum requirement for 2D drawing is the support for the following OpenGL extensions: GL_EXT_framebuffer_object, GL_ARB_multitexture, GL_ARB_shading_language_100, GL_ARB_shader_objects, GL_ARB_vertex_shader, GL_ARB_fragment_shader.
The following cards and later models are known to fully support these extensions: ATI Radeon 9600, NVidia GeforceFX-5200, Intel GMA-950 onboard chip of Intel based MacMinis and MacBooks under OS/X.
For 3D graphics via MOGL or OpenGL one needs these additional extensions: GL_ARB_depth_texture for depth buffer support and GL_EXT_packed_depth_stencil for stencil buffer support on some systems. Stencil buffers are unsupported on all PowerPC hardware (an OS limitation not a hardware limitation), unless you use OS-X 10.5 "Leopard" and later.
High dynamic range support:
This allows for drawing, processing and representation of images with floating point precision. Color values can exceed the normal 0-255 integer range of standard 8bpc framebuffers and one can handle images and colors with negative color components. This is useful for efficient creation of specific stimuli, e.g., fields of overlapping gabor patches and special blending operations. The final stimulus image can get automatically converted into a format suitable for special high precision display hardware, e.g., CRS Bits++, video attenuators, high dynamic range display devices.
Required extensions: A subset of GL_ARB_float_pixels, GL_APPLE_float_pixels, GL_ATI_float_pixels, GL_NV_float_pixels, GL_ATI_texture_float, GL_ARB_texture_float, GL_NV_texture_float.
At least the following graphics cards should support this according to their specification: NVidia Geforce-6000 series and ATI Radeon X800 series.
The following cards have been successfully tested for support: ATI X1600 and NVidia Geforce 7800. All later cards will support this as well.
The NVidia GeforceFX 5200 should support it, but malfunctioned on OS/X PowerPC during tests. This may be different on OS-X 10.5 Leopard, but is untested so far.
The Intel chips do not support these functions.
Advanced support for imaging pipeline:
This allows for more complex shaders and therefore for additional functionality, especially in the area of general purpose image processing:
- Support for display devices with complex output processing requirements: E.g., BrightSide Technology High Dynamic Range display.
- Support for 2D convolution, 2D FFT and other standard image processing operations.
- Support for iterative algorithms and machine vision algorithms.
The graphics hardware needs to be Shader model 3.0 (aka DirectX 9.0c, aka Windows Vista Premium ready) compliant.
Known cards that should work well: (Follow the links for detailed infos about the different models)
- NVidia Geforce 6000 and 7000 series (e.g., Geforce 6800), NVidia Geforce 8000 series and later recommended, Quadro FX 4500. PTB is tested on Geforce 7800 GTX.
- ATI Radeon X1300 and later. PTB is tested on the Mobility Radeon X1600 of the Apple MacBook-Pro.
Good luck in choosing a suitable card.