CS计算机代考程序代写 ///////////////////////////////////////////////////////////////////////////////////

///////////////////////////////////////////////////////////////////////////////////
/// OpenGL Mathematics (glm.g-truc.net)
///
/// Copyright (c) 2005 – 2015 G-Truc Creation (www.g-truc.net)
/// Permission is hereby granted, free of charge, to any person obtaining a copy
/// of this software and associated documentation files (the “Software”), to deal
/// in the Software without restriction, including without limitation the rights
/// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
/// copies of the Software, and to permit persons to whom the Software is
/// furnished to do so, subject to the following conditions:
///
/// The above copyright notice and this permission notice shall be included in
/// all copies or substantial portions of the Software.
///
/// Restrictions:
/// By making use of the Software for military purposes, you choose to make
/// a Bunny unhappy.
///
/// THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
/// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
/// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
/// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
/// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
/// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
/// THE SOFTWARE.
///
/// @ref core
/// @file glm/detail/type_mat2x3.hpp
/// @date 2006-10-01 / 2011-06-15
/// @author Christophe Riccio
///////////////////////////////////////////////////////////////////////////////////

#pragma once

#include “../fwd.hpp”
#include “type_vec2.hpp”
#include “type_vec3.hpp”
#include “type_mat.hpp”
#include #include

namespace glm
{
template
struct tmat2x3
{
typedef tvec3 col_type;
typedef tvec2 row_type;
typedef tmat2x3 type;
typedef tmat3x2 transpose_type;
typedef T value_type;

private:
/// @cond DETAIL
col_type value[2];
/// @endcond

public:
// Constructors
GLM_FUNC_DECL tmat2x3();
GLM_FUNC_DECL tmat2x3(tmat2x3 const & m);
template GLM_FUNC_DECL tmat2x3(tmat2x3 const & m);

GLM_FUNC_DECL explicit tmat2x3(ctor);
GLM_FUNC_DECL explicit tmat2x3(T const & s);
GLM_FUNC_DECL tmat2x3(
T const & x0, T const & y0, T const & z0,
T const & x1, T const & y1, T const & z1);
GLM_FUNC_DECL tmat2x3(
col_type const & v0,
col_type const & v1);

//////////////////////////////////////
// Conversions

template
GLM_FUNC_DECL tmat2x3(
X1 const & x1, Y1 const & y1, Z1 const & z1,
X2 const & x2, Y2 const & y2, Z2 const & z2);

template
GLM_FUNC_DECL tmat2x3(
tvec3 const & v1,
tvec3 const & v2);

//////////////////////////////////////
// Matrix conversion

# ifdef GLM_FORCE_EXPLICIT_CTOR
template
GLM_FUNC_DECL explicit tmat2x3(tmat2x3 const & m);
# else
template
GLM_FUNC_DECL tmat2x3(tmat2x3 const & m);
# endif

GLM_FUNC_DECL explicit tmat2x3(tmat2x2 const & x);
GLM_FUNC_DECL explicit tmat2x3(tmat3x3 const & x);
GLM_FUNC_DECL explicit tmat2x3(tmat4x4 const & x);
GLM_FUNC_DECL explicit tmat2x3(tmat2x4 const & x);
GLM_FUNC_DECL explicit tmat2x3(tmat3x2 const & x);
GLM_FUNC_DECL explicit tmat2x3(tmat3x4 const & x);
GLM_FUNC_DECL explicit tmat2x3(tmat4x2 const & x);
GLM_FUNC_DECL explicit tmat2x3(tmat4x3 const & x);

//////////////////////////////////////
// Accesses

# ifdef GLM_FORCE_SIZE_FUNC
typedef size_t size_type;
GLM_FUNC_DECL GLM_CONSTEXPR size_t size() const;

GLM_FUNC_DECL col_type & operator[](size_type i);
GLM_FUNC_DECL col_type const & operator[](size_type i) const;
# else
typedef length_t length_type;
GLM_FUNC_DECL GLM_CONSTEXPR length_type length() const;

GLM_FUNC_DECL col_type & operator[](length_type i);
GLM_FUNC_DECL col_type const & operator[](length_type i) const;
# endif//GLM_FORCE_SIZE_FUNC

//////////////////////////////////////
// Unary arithmetic operators

GLM_FUNC_DECL tmat2x3 & operator=(tmat2x3 const & m);

template
GLM_FUNC_DECL tmat2x3 & operator=(tmat2x3 const & m);
template
GLM_FUNC_DECL tmat2x3 & operator+=(U s);
template
GLM_FUNC_DECL tmat2x3 & operator+=(tmat2x3 const & m);
template
GLM_FUNC_DECL tmat2x3 & operator-=(U s);
template
GLM_FUNC_DECL tmat2x3 & operator-=(tmat2x3 const & m);
template
GLM_FUNC_DECL tmat2x3 & operator*=(U s);
template
GLM_FUNC_DECL tmat2x3 & operator/=(U s);

//////////////////////////////////////
// Increment and decrement operators

GLM_FUNC_DECL tmat2x3 & operator++ ();
GLM_FUNC_DECL tmat2x3 & operator– ();
GLM_FUNC_DECL tmat2x3 operator++(int);
GLM_FUNC_DECL tmat2x3 operator–(int);
};

// Binary operators

template
GLM_FUNC_DECL tmat2x3 operator+(tmat2x3 const & m, T const & s);

template
GLM_FUNC_DECL tmat2x3 operator+(tmat2x3 const & m1, tmat2x3 const & m2);

template
GLM_FUNC_DECL tmat2x3 operator-(tmat2x3 const & m, T const & s);

template
GLM_FUNC_DECL tmat2x3 operator-(tmat2x3 const & m1, tmat2x3 const & m2);

template
GLM_FUNC_DECL tmat2x3 operator*(tmat2x3 const & m, T const & s);

template
GLM_FUNC_DECL tmat2x3 operator*(T const & s, tmat2x3 const & m);

template
GLM_FUNC_DECL typename tmat2x3::col_type operator*(tmat2x3 const & m, typename tmat2x3::row_type const & v);

template
GLM_FUNC_DECL typename tmat2x3::row_type operator*(typename tmat2x3::col_type const & v, tmat2x3 const & m);

template
GLM_FUNC_DECL tmat2x3 operator*(tmat2x3 const & m1, tmat2x2 const & m2);

template
GLM_FUNC_DECL tmat3x3 operator*(tmat2x3 const & m1, tmat3x2 const & m2);

template
GLM_FUNC_DECL tmat4x3 operator*(tmat2x3 const & m1, tmat4x2 const & m2);

template
GLM_FUNC_DECL tmat2x3 operator/(tmat2x3 const & m, T const & s);

template
GLM_FUNC_DECL tmat2x3 operator/(T const & s, tmat2x3 const & m);

// Unary constant operators
template
GLM_FUNC_DECL tmat2x3 const operator-(tmat2x3 const & m);
}//namespace glm

#ifndef GLM_EXTERNAL_TEMPLATE
#include “type_mat2x3.inl”
#endif