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>
 | 
						|
**/
 |