mirror of
https://github.com/g-truc/glm.git
synced 2024-11-16 06:44:35 +00:00
56 lines
2.9 KiB
Plaintext
56 lines
2.9 KiB
Plaintext
/*!
|
|
@mainpage OpenGL Mathematics
|
|
|
|
OpenGL Mathematics (GLM) is a header only C++ mathematics library for graphics software based on the OpenGL Shading Language (GLSL) specification.
|
|
|
|
GLM provides classes and functions designed and implemented with the same naming conventions and functionalities than GLSL so that when a programmer knows GLSL, he knows GLM as well which makes it really easy to use.
|
|
|
|
This project isn't limited to GLSL features. An extension system, based on the GLSL extension conventions, provides extended capabilities: matrix transformations, quaternions, half-based types, random numbers, procedural noise functions, etc...
|
|
|
|
This library works perfectly with OpenGL but it also ensures interoperability with third party libraries and SDKs.
|
|
It is a good candidate for software rendering (Raytracing / Rasterisation), image processing, physic simulations and any context that requires a simple and convenient mathematics library.
|
|
|
|
GLM is written in C++98 but can take advantage of C++11 when supported by the compiler. It is a platform independent library with no dependence and officially supports the following compilers:
|
|
- Clang 2.6 and higher
|
|
- CUDA 3.0 and higher
|
|
- GCC 3.4 and higher
|
|
- Intel C++ Composer XE 2013 and higher
|
|
- LLVM 2.3 through GCC 4.2 front-end and higher
|
|
- Visual Studio 2005 and higher
|
|
- Any conform C++98 or C++11 compiler
|
|
|
|
@note The Doxygen-generated documentation will often state that a type or function
|
|
is defined in a namespace that is a child of the @link glm glm @endlink namespace.
|
|
Please ignore this; All publicly available types and functions can be accessed as a direct children
|
|
of the glm namespace.
|
|
|
|
The source code is licenced under the <a href="http://www.opensource.org/licenses/mit-license.php">MIT licence</a>.
|
|
|
|
These pages are the API reference only. For more information about how to use GLM, please have a look at <a href="http://glm.g-truc.net/glm.pdf">the manual</a>.
|
|
|
|
Thanks for contributing to the project by <a href="https://github.com/g-truc/glm/issues">submitting tickets for bug reports and feature requests</a>.
|
|
(SF.net account required). Any feedback is welcome at glm@g-truc.net.
|
|
**/
|
|
|
|
/*!
|
|
@page pg_differences Differences between GLSL and GLM core
|
|
|
|
GLM comes very close to replicating GLSL, but it is not exact. Here is a list of
|
|
differences between GLM and GLSL:
|
|
|
|
<ul>
|
|
<li>
|
|
Precision qualifiers. In GLSL numeric types can have qualifiers that define
|
|
the precision of that type. While OpenGL's GLSL ignores these qualifiers, OpenGL
|
|
ES's version of GLSL uses them.
|
|
|
|
C++ has no language equivalent to precision qualifiers. Instead, GLM provides
|
|
a set of typedefs for each kind of precision qualifier and type. These types can
|
|
be found in @ref core_precision "their own section".
|
|
|
|
Functions that take types tend to be templated on those types, so they can
|
|
take these qualified types just as well as the regular ones.
|
|
</li>
|
|
</ul>
|
|
**/
|