Back to Mame

0.9.8: type_vec.hpp Source File

3rdparty/glm/doc/api/a00127_source.html

latest29.4 KB
Original Source

| | 0.9.8 |

type_vec.hpp

Go to the documentation of this file.

1

4 #pragma once

5

6 #include "precision.hpp"

7 #include "type_int.hpp"

8

9 namespace glm{

10 namespace detail

11 {

12template<std::size_t N> struct aligned {};

13template<> GLM_ALIGNED_STRUCT(1) aligned<1>{};

14template<> GLM_ALIGNED_STRUCT(2) aligned<2>{};

15template<> GLM_ALIGNED_STRUCT(4) aligned<4>{};

16template<> GLM_ALIGNED_STRUCT(8) aligned<8>{};

17template<> GLM_ALIGNED_STRUCT(16) aligned<16>{};

18template<> GLM_ALIGNED_STRUCT(32) aligned<32>{};

19template<> GLM_ALIGNED_STRUCT(64) aligned<64>{};

20

21template <typename T, std::size_t size, bool aligned>

22struct storage

23 {

24typedef struct type {

25 uint8 data[size];

26 } type;

27 };

28

29template <typename T, std::size_t size>

30struct storage<T, size, true>

31 {

32struct type : aligned<size>

33 {

34 uint8 data[size];

35 };

36 };

37

38 # if GLM_ARCH & GLM_ARCH_SSE2_BIT

39template <>

40struct storage<float, 16, true>

41 {

42typedef glm_vec4 type;

43 };

44

45template <>

46struct storage<int, 16, true>

47 {

48typedef glm_ivec4 type;

49 };

50

51template <>

52struct storage<unsigned int, 16, true>

53 {

54typedef glm_uvec4 type;

55 };

56 /*

57 # else

58 typedef union __declspec(align(16)) glm_128

59 {

60 unsigned __int8 data[16];

61 } glm_128;

62

63 template <>

64 struct storage<float, 16, true>

65 {

66 typedef glm_128 type;

67 };

68

69 template <>

70 struct storage<int, 16, true>

71 {

72 typedef glm_128 type;

73 };

74

75 template <>

76 struct storage<unsigned int, 16, true>

77 {

78 typedef glm_128 type;

79 };

80 */

81 # endif

82

83 # if (GLM_ARCH & GLM_ARCH_AVX_BIT)

84template <>

85struct storage<double, 32, true>

86 {

87typedef glm_dvec4 type;

88 };

89 # endif

90

91 # if (GLM_ARCH & GLM_ARCH_AVX2_BIT)

92template <>

93struct storage<int64, 32, true>

94 {

95typedef glm_i64vec4 type;

96 };

97

98template <>

99struct storage<uint64, 32, true>

100 {

101typedef glm_u64vec4 type;

102 };

103 # endif

104 }//namespace detail

105

106template <typename T, precision P> struct tvec1;

107template <typename T, precision P> struct tvec2;

108template <typename T, precision P> struct tvec3;

109template <typename T, precision P> struct tvec4;

110

111typedef tvec1<float, highp> highp_vec1_t;

112typedef tvec1<float, mediump> mediump_vec1_t;

113typedef tvec1<float, lowp> lowp_vec1_t;

114typedef tvec1<double, highp> highp_dvec1_t;

115typedef tvec1<double, mediump> mediump_dvec1_t;

116typedef tvec1<double, lowp> lowp_dvec1_t;

117typedef tvec1<int, highp> highp_ivec1_t;

118typedef tvec1<int, mediump> mediump_ivec1_t;

119typedef tvec1<int, lowp> lowp_ivec1_t;

120typedef tvec1<uint, highp> highp_uvec1_t;

121typedef tvec1<uint, mediump> mediump_uvec1_t;

122typedef tvec1<uint, lowp> lowp_uvec1_t;

123typedef tvec1<bool, highp> highp_bvec1_t;

124typedef tvec1<bool, mediump> mediump_bvec1_t;

125typedef tvec1<bool, lowp> lowp_bvec1_t;

126

129

135typedef tvec2<float, highp> highp_vec2;

136

142typedef tvec2<float, mediump> mediump_vec2;

143

149typedef tvec2<float, lowp> lowp_vec2;

150

156typedef tvec2<double, highp> highp_dvec2;

157

163typedef tvec2<double, mediump> mediump_dvec2;

164

170typedef tvec2<double, lowp> lowp_dvec2;

171

177typedef tvec2<int, highp> highp_ivec2;

178

184typedef tvec2<int, mediump> mediump_ivec2;

185

191typedef tvec2<int, lowp> lowp_ivec2;

192

198typedef tvec2<uint, highp> highp_uvec2;

199

205typedef tvec2<uint, mediump> mediump_uvec2;

206

212typedef tvec2<uint, lowp> lowp_uvec2;

213

219typedef tvec2<bool, highp> highp_bvec2;

220

226typedef tvec2<bool, mediump> mediump_bvec2;

227

233typedef tvec2<bool, lowp> lowp_bvec2;

234

236

239

245typedef tvec3<float, highp> highp_vec3;

246

252typedef tvec3<float, mediump> mediump_vec3;

253

259typedef tvec3<float, lowp> lowp_vec3;

260

266typedef tvec3<double, highp> highp_dvec3;

267

273typedef tvec3<double, mediump> mediump_dvec3;

274

280typedef tvec3<double, lowp> lowp_dvec3;

281

287typedef tvec3<int, highp> highp_ivec3;

288

294typedef tvec3<int, mediump> mediump_ivec3;

295

301typedef tvec3<int, lowp> lowp_ivec3;

302

308typedef tvec3<uint, highp> highp_uvec3;

309

315typedef tvec3<uint, mediump> mediump_uvec3;

316

322typedef tvec3<uint, lowp> lowp_uvec3;

323

328typedef tvec3<bool, highp> highp_bvec3;

329

334typedef tvec3<bool, mediump> mediump_bvec3;

335

340typedef tvec3<bool, lowp> lowp_bvec3;

341

343

346

351typedef tvec4<float, highp> highp_vec4;

352

357typedef tvec4<float, mediump> mediump_vec4;

358

363typedef tvec4<float, lowp> lowp_vec4;

364

369typedef tvec4<double, highp> highp_dvec4;

370

375typedef tvec4<double, mediump> mediump_dvec4;

376

381typedef tvec4<double, lowp> lowp_dvec4;

382

387typedef tvec4<int, highp> highp_ivec4;

388

393typedef tvec4<int, mediump> mediump_ivec4;

394

399typedef tvec4<int, lowp> lowp_ivec4;

400

405typedef tvec4<uint, highp> highp_uvec4;

406

411typedef tvec4<uint, mediump> mediump_uvec4;

412

417typedef tvec4<uint, lowp> lowp_uvec4;

418

423typedef tvec4<bool, highp> highp_bvec4;

424

429typedef tvec4<bool, mediump> mediump_bvec4;

430

435typedef tvec4<bool, lowp> lowp_bvec4;

436

438

441

442// -- Default float definition --

443

444 #if(defined(GLM_PRECISION_LOWP_FLOAT))

445typedef lowp_vec2 vec2;

446typedef lowp_vec3 vec3;

447typedef lowp_vec4 vec4;

448 #elif(defined(GLM_PRECISION_MEDIUMP_FLOAT))

449typedef mediump_vec2 vec2;

450typedef mediump_vec3 vec3;

451typedef mediump_vec4 vec4;

452 #else //defined(GLM_PRECISION_HIGHP_FLOAT)

453typedef highp_vec2 vec2;

457

461typedef highp_vec3 vec3;

462

466typedef highp_vec4 vec4;

467 #endif//GLM_PRECISION

468

469// -- Default double definition --

470

471 #if(defined(GLM_PRECISION_LOWP_DOUBLE))

472typedef lowp_dvec2 dvec2;

473typedef lowp_dvec3 dvec3;

474typedef lowp_dvec4 dvec4;

475 #elif(defined(GLM_PRECISION_MEDIUMP_DOUBLE))

476typedef mediump_dvec2 dvec2;

477typedef mediump_dvec3 dvec3;

478typedef mediump_dvec4 dvec4;

479 #else //defined(GLM_PRECISION_HIGHP_DOUBLE)

480typedef highp_dvec2 dvec2;

484

488typedef highp_dvec3 dvec3;

489

493typedef highp_dvec4 dvec4;

494 #endif//GLM_PRECISION

495

496// -- Signed integer definition --

497

498 #if(defined(GLM_PRECISION_LOWP_INT))

499typedef lowp_ivec2 ivec2;

500typedef lowp_ivec3 ivec3;

501typedef lowp_ivec4 ivec4;

502 #elif(defined(GLM_PRECISION_MEDIUMP_INT))

503typedef mediump_ivec2 ivec2;

504typedef mediump_ivec3 ivec3;

505typedef mediump_ivec4 ivec4;

506 #else //defined(GLM_PRECISION_HIGHP_INT)

507typedef highp_ivec2 ivec2;

511

515typedef highp_ivec3 ivec3;

516

520typedef highp_ivec4 ivec4;

521 #endif//GLM_PRECISION

522

523// -- Unsigned integer definition --

524

525 #if(defined(GLM_PRECISION_LOWP_UINT))

526typedef lowp_uvec2 uvec2;

527typedef lowp_uvec3 uvec3;

528typedef lowp_uvec4 uvec4;

529 #elif(defined(GLM_PRECISION_MEDIUMP_UINT))

530typedef mediump_uvec2 uvec2;

531typedef mediump_uvec3 uvec3;

532typedef mediump_uvec4 uvec4;

533 #else //defined(GLM_PRECISION_HIGHP_UINT)

534typedef highp_uvec2 uvec2;

538

542typedef highp_uvec3 uvec3;

543

547typedef highp_uvec4 uvec4;

548 #endif//GLM_PRECISION

549

550// -- Boolean definition --

551

552 #if(defined(GLM_PRECISION_LOWP_BOOL))

553typedef lowp_bvec2 bvec2;

554typedef lowp_bvec3 bvec3;

555typedef lowp_bvec4 bvec4;

556 #elif(defined(GLM_PRECISION_MEDIUMP_BOOL))

557typedef mediump_bvec2 bvec2;

558typedef mediump_bvec3 bvec3;

559typedef mediump_bvec4 bvec4;

560 #else //defined(GLM_PRECISION_HIGHP_BOOL)

561typedef highp_bvec2 bvec2;

565

569typedef highp_bvec3 bvec3;

570

574typedef highp_bvec4 bvec4;

575 #endif//GLM_PRECISION

576

578 }//namespace glm

glm::ivec3

highp_ivec3 ivec3

3 components vector of signed integer numbers.

Definition: type_vec.hpp:515

glm::lowp_ivec4

tvec4< int, lowp > lowp_ivec4

4 components vector of low precision signed integer numbers.

Definition: type_vec.hpp:399

glm::bvec3

highp_bvec3 bvec3

3 components vector of boolean.

Definition: type_vec.hpp:569

glm::highp_ivec4

tvec4< int, highp > highp_ivec4

4 components vector of high precision signed integer numbers.

Definition: type_vec.hpp:387

glm::lowp_vec4

tvec4< float, lowp > lowp_vec4

4 components vector of low single-precision floating-point numbers.

Definition: type_vec.hpp:363

glm::lowp_vec2

tvec2< float, lowp > lowp_vec2

2 components vector of low single-precision floating-point numbers.

Definition: type_vec.hpp:149

glm::highp_vec3

tvec3< float, highp > highp_vec3

3 components vector of high single-precision floating-point numbers.

Definition: type_vec.hpp:245

glm::lowp_dvec3

tvec3< double, lowp > lowp_dvec3

3 components vector of low double-precision floating-point numbers.

Definition: type_vec.hpp:280

glm::bvec4

highp_bvec4 bvec4

4 components vector of boolean.

Definition: type_vec.hpp:574

glm::lowp_ivec2

tvec2< int, lowp > lowp_ivec2

2 components vector of low precision signed integer numbers.

Definition: type_vec.hpp:191

glm::mediump_vec4

tvec4< float, mediump > mediump_vec4

4 components vector of medium single-precision floating-point numbers.

Definition: type_vec.hpp:357

glm::highp_uvec2

tvec2< uint, highp > highp_uvec2

2 components vector of high precision unsigned integer numbers.

Definition: type_vec.hpp:198

glm::vec4

highp_vec4 vec4

4 components vector of floating-point numbers.

Definition: type_vec.hpp:466

glm::highp_dvec3

tvec3< double, highp > highp_dvec3

3 components vector of high double-precision floating-point numbers.

Definition: type_vec.hpp:266

glm::ivec2

highp_ivec2 ivec2

2 components vector of signed integer numbers.

Definition: type_vec.hpp:510

glm::lowp_vec3

tvec3< float, lowp > lowp_vec3

3 components vector of low single-precision floating-point numbers.

Definition: type_vec.hpp:259

glm::mediump_ivec4

tvec4< int, mediump > mediump_ivec4

4 components vector of medium precision signed integer numbers.

Definition: type_vec.hpp:393

glm::mediump_ivec2

tvec2< int, mediump > mediump_ivec2

2 components vector of medium precision signed integer numbers.

Definition: type_vec.hpp:184

glm::lowp_ivec3

tvec3< int, lowp > lowp_ivec3

3 components vector of low precision signed integer numbers.

Definition: type_vec.hpp:301

glm

Definition: _noise.hpp:11

glm::highp_bvec4

tvec4< bool, highp > highp_bvec4

4 components vector of high precision bool numbers.

Definition: type_vec.hpp:423

glm::bvec2

highp_bvec2 bvec2

2 components vector of boolean.

Definition: type_vec.hpp:564

glm::highp_bvec3

tvec3< bool, highp > highp_bvec3

3 components vector of high precision bool numbers.

Definition: type_vec.hpp:328

glm::highp_vec4

tvec4< float, highp > highp_vec4

4 components vector of high single-precision floating-point numbers.

Definition: type_vec.hpp:351

glm::lowp_bvec2

tvec2< bool, lowp > lowp_bvec2

2 components vector of low precision bool numbers.

Definition: type_vec.hpp:233

glm::highp_dvec4

tvec4< double, highp > highp_dvec4

4 components vector of high double-precision floating-point numbers.

Definition: type_vec.hpp:369

glm::lowp_dvec2

tvec2< double, lowp > lowp_dvec2

2 components vector of low double-precision floating-point numbers.

Definition: type_vec.hpp:170

glm::uvec3

highp_uvec3 uvec3

3 components vector of unsigned integer numbers.

Definition: type_vec.hpp:542

glm::mediump_vec3

tvec3< float, mediump > mediump_vec3

3 components vector of medium single-precision floating-point numbers.

Definition: type_vec.hpp:252

glm::mediump_bvec4

tvec4< bool, mediump > mediump_bvec4

4 components vector of medium precision bool numbers.

Definition: type_vec.hpp:429

glm::lowp_bvec4

tvec4< bool, lowp > lowp_bvec4

4 components vector of low precision bool numbers.

Definition: type_vec.hpp:435

glm::mediump_uvec4

tvec4< uint, mediump > mediump_uvec4

4 components vector of medium precision unsigned integer numbers.

Definition: type_vec.hpp:411

glm::highp_uvec4

tvec4< uint, highp > highp_uvec4

4 components vector of high precision unsigned integer numbers.

Definition: type_vec.hpp:405

glm::highp_uvec3

tvec3< uint, highp > highp_uvec3

3 components vector of high precision unsigned integer numbers.

Definition: type_vec.hpp:308

glm::lowp_dvec4

tvec4< double, lowp > lowp_dvec4

4 components vector of low double-precision floating-point numbers.

Definition: type_vec.hpp:381

glm::highp_ivec3

tvec3< int, highp > highp_ivec3

3 components vector of high precision signed integer numbers.

Definition: type_vec.hpp:287

glm::mediump_vec2

tvec2< float, mediump > mediump_vec2

2 components vector of medium single-precision floating-point numbers.

Definition: type_vec.hpp:142

glm::uvec4

highp_uvec4 uvec4

4 components vector of unsigned integer numbers.

Definition: type_vec.hpp:547

glm::mediump_dvec2

tvec2< double, mediump > mediump_dvec2

2 components vector of medium double-precision floating-point numbers.

Definition: type_vec.hpp:163

glm::highp_vec2

tvec2< float, highp > highp_vec2

2 components vector of high single-precision floating-point numbers.

Definition: type_vec.hpp:135

glm::mediump_bvec2

tvec2< bool, mediump > mediump_bvec2

2 components vector of medium precision bool numbers.

Definition: type_vec.hpp:226

glm::mediump_bvec3

tvec3< bool, mediump > mediump_bvec3

3 components vector of medium precision bool numbers.

Definition: type_vec.hpp:334

type_int.hpp

GLM Core

glm::highp_bvec2

tvec2< bool, highp > highp_bvec2

2 components vector of high precision bool numbers.

Definition: type_vec.hpp:219

glm::dvec3

highp_dvec3 dvec3

3 components vector of double-precision floating-point numbers.

Definition: type_vec.hpp:488

glm::mediump_uvec2

tvec2< uint, mediump > mediump_uvec2

2 components vector of medium precision unsigned integer numbers.

Definition: type_vec.hpp:205

glm::uvec2

highp_uvec2 uvec2

2 components vector of unsigned integer numbers.

Definition: type_vec.hpp:537

glm::dvec4

highp_dvec4 dvec4

4 components vector of double-precision floating-point numbers.

Definition: type_vec.hpp:493

glm::mediump_dvec4

tvec4< double, mediump > mediump_dvec4

4 components vector of medium double-precision floating-point numbers.

Definition: type_vec.hpp:375

glm::lowp_uvec3

tvec3< uint, lowp > lowp_uvec3

3 components vector of low precision unsigned integer numbers.

Definition: type_vec.hpp:322

glm::mediump_dvec3

tvec3< double, mediump > mediump_dvec3

3 components vector of medium double-precision floating-point numbers.

Definition: type_vec.hpp:273

glm::lowp_uvec2

tvec2< uint, lowp > lowp_uvec2

2 components vector of low precision unsigned integer numbers.

Definition: type_vec.hpp:212

glm::highp_ivec2

tvec2< int, highp > highp_ivec2

2 components vector of high precision signed integer numbers.

Definition: type_vec.hpp:177

glm::lowp_bvec3

tvec3< bool, lowp > lowp_bvec3

3 components vector of low precision bool numbers.

Definition: type_vec.hpp:340

glm::mediump_ivec3

tvec3< int, mediump > mediump_ivec3

3 components vector of medium precision signed integer numbers.

Definition: type_vec.hpp:294

glm::vec3

highp_vec3 vec3

3 components vector of floating-point numbers.

Definition: type_vec.hpp:461

glm::dvec2

highp_dvec2 dvec2

2 components vector of double-precision floating-point numbers.

Definition: type_vec.hpp:483

glm::highp_dvec2

tvec2< double, highp > highp_dvec2

2 components vector of high double-precision floating-point numbers.

Definition: type_vec.hpp:156

glm::vec2

highp_vec2 vec2

2 components vector of floating-point numbers.

Definition: type_vec.hpp:456

glm::mediump_uvec3

tvec3< uint, mediump > mediump_uvec3

3 components vector of medium precision unsigned integer numbers.

Definition: type_vec.hpp:315

glm::lowp_uvec4

tvec4< uint, lowp > lowp_uvec4

4 components vector of low precision unsigned integer numbers.

Definition: type_vec.hpp:417

precision.hpp

GLM Core

glm::ivec4

highp_ivec4 ivec4

4 components vector of signed integer numbers.

Definition: type_vec.hpp:520


Generated by 1.8.10