82365c6d00e05604c2c66a3295bbd4bb02ba6a27
[blender.git] / source / blender / python / mathutils / mathutils_Vector.c
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * Contributor(s): Willian P. Germano, Joseph Gilbert, Ken Hughes, Alex Fraser, Campbell Barton
19  *
20  * ***** END GPL LICENSE BLOCK *****
21  */
22
23 /** \file blender/python/mathutils/mathutils_Vector.c
24  *  \ingroup pymathutils
25  */
26
27
28 #include <Python.h>
29
30 #include "mathutils.h"
31
32 #include "BLI_math.h"
33 #include "BLI_utildefines.h"
34
35 #ifndef MATH_STANDALONE
36 #  include "BLI_dynstr.h"
37 #endif
38
39 #define MAX_DIMENSIONS 4
40
41 /* Swizzle axes get packed into a single value that is used as a closure. Each
42  * axis uses SWIZZLE_BITS_PER_AXIS bits. The first bit (SWIZZLE_VALID_AXIS) is
43  * used as a sentinel: if it is unset, the axis is not valid. */
44 #define SWIZZLE_BITS_PER_AXIS 3
45 #define SWIZZLE_VALID_AXIS 0x4
46 #define SWIZZLE_AXIS       0x3
47
48 static PyObject *Vector_copy(VectorObject *self);
49 static PyObject *Vector_deepcopy(VectorObject *self, PyObject *args);
50 static PyObject *Vector_to_tuple_ext(VectorObject *self, int ndigits);
51 static int row_vector_multiplication(float rvec[MAX_DIMENSIONS], VectorObject *vec, MatrixObject *mat);
52
53 /* Supports 2D, 3D, and 4D vector objects both int and float values
54  * accepted. Mixed float and int values accepted. Ints are parsed to float
55  */
56 static PyObject *Vector_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
57 {
58         float *vec = NULL;
59         int size = 3; /* default to a 3D vector */
60
61         if (kwds && PyDict_Size(kwds)) {
62                 PyErr_SetString(PyExc_TypeError,
63                                 "Vector(): "
64                                 "takes no keyword args");
65                 return NULL;
66         }
67
68         switch (PyTuple_GET_SIZE(args)) {
69                 case 0:
70                         vec = PyMem_Malloc(size * sizeof(float));
71
72                         if (vec == NULL) {
73                                 PyErr_SetString(PyExc_MemoryError,
74                                                 "Vector(): "
75                                                 "problem allocating pointer space");
76                                 return NULL;
77                         }
78
79                         copy_vn_fl(vec, size, 0.0f);
80                         break;
81                 case 1:
82                         if ((size = mathutils_array_parse_alloc(&vec, 2, PyTuple_GET_ITEM(args, 0), "mathutils.Vector()")) == -1) {
83                                 return NULL;
84                         }
85                         break;
86                 default:
87                         PyErr_SetString(PyExc_TypeError,
88                                         "mathutils.Vector(): "
89                                         "more than a single arg given");
90                         return NULL;
91         }
92         return Vector_CreatePyObject_alloc(vec, size, type);
93 }
94
95 static PyObject *vec__apply_to_copy(PyNoArgsFunction vec_func, VectorObject *self)
96 {
97         PyObject *ret = Vector_copy(self);
98         PyObject *ret_dummy = vec_func(ret);
99         if (ret_dummy) {
100                 Py_DECREF(ret_dummy);
101                 return (PyObject *)ret;
102         }
103         else { /* error */
104                 Py_DECREF(ret);
105                 return NULL;
106         }
107 }
108
109 /*-----------------------CLASS-METHODS----------------------------*/
110 PyDoc_STRVAR(C_Vector_Fill_doc,
111 ".. classmethod:: Fill(size, fill=0.0)\n"
112 "\n"
113 "   Create a vector of length size with all values set to fill.\n"
114 "\n"
115 "   :arg size: The length of the vector to be created.\n"
116 "   :type size: int\n"
117 "   :arg fill: The value used to fill the vector.\n"
118 "   :type fill: float\n"
119 );
120 static PyObject *C_Vector_Fill(PyObject *cls, PyObject *args)
121 {
122         float *vec;
123         int size;
124         float fill = 0.0f;
125
126         if (!PyArg_ParseTuple(args, "i|f:Vector.Fill", &size, &fill)) {
127                 return NULL;
128         }
129
130         if (size < 2) {
131                 PyErr_SetString(PyExc_RuntimeError,
132                                 "Vector(): invalid size");
133                 return NULL;
134         }
135
136         vec = PyMem_Malloc(size * sizeof(float));
137
138         if (vec == NULL) {
139                 PyErr_SetString(PyExc_MemoryError,
140                                 "Vector.Fill(): "
141                                 "problem allocating pointer space");
142                 return NULL;
143         }
144
145         copy_vn_fl(vec, size, fill);
146
147         return Vector_CreatePyObject_alloc(vec, size, (PyTypeObject *)cls);
148 }
149
150 PyDoc_STRVAR(C_Vector_Range_doc,
151 ".. classmethod:: Range(start=0, stop, step=1)\n"
152 "\n"
153 "   Create a filled with a range of values.\n"
154 "\n"
155 "   :arg start: The start of the range used to fill the vector.\n"
156 "   :type start: int\n"
157 "   :arg stop: The end of the range used to fill the vector.\n"
158 "   :type stop: int\n"
159 "   :arg step: The step between successive values in the vector.\n"
160 "   :type step: int\n"
161 );
162 static PyObject *C_Vector_Range(PyObject *cls, PyObject *args)
163 {
164         float *vec;
165         int stop, size;
166         int start = 0;
167         int step = 1;
168
169         if (!PyArg_ParseTuple(args, "i|ii:Vector.Range", &start, &stop, &step)) {
170                 return NULL;
171         }
172
173         switch (PyTuple_GET_SIZE(args)) {
174                 case 1:
175                         size = start;
176                         start = 0;
177                         break;
178                 case 2:
179                         if (start >= stop) {
180                                 PyErr_SetString(PyExc_RuntimeError,
181                                                 "Start value is larger "
182                                                 "than the stop value");
183                                 return NULL;
184                         }
185
186                         size = stop - start;
187                         break;
188                 default:
189                         if (start >= stop) {
190                                 PyErr_SetString(PyExc_RuntimeError,
191                                                 "Start value is larger "
192                                                 "than the stop value");
193                                 return NULL;
194                         }
195
196                         size = (stop - start);
197
198                         if ((size % step) != 0)
199                                 size += step;
200
201                         size /= step;
202
203                         break;
204         }
205
206         if (size < 2) {
207                 PyErr_SetString(PyExc_RuntimeError,
208                                 "Vector(): invalid size");
209                 return NULL;
210         }
211
212         vec = PyMem_Malloc(size * sizeof(float));
213
214         if (vec == NULL) {
215                 PyErr_SetString(PyExc_MemoryError,
216                                 "Vector.Range(): "
217                                 "problem allocating pointer space");
218                 return NULL;
219         }
220
221         range_vn_fl(vec, size, (float)start, (float)step);
222
223         return Vector_CreatePyObject_alloc(vec, size, (PyTypeObject *)cls);
224 }
225
226 PyDoc_STRVAR(C_Vector_Linspace_doc,
227 ".. classmethod:: Linspace(start, stop, size)\n"
228 "\n"
229 "   Create a vector of the specified size which is filled with linearly spaced values between start and stop values.\n"
230 "\n"
231 "   :arg start: The start of the range used to fill the vector.\n"
232 "   :type start: int\n"
233 "   :arg stop: The end of the range used to fill the vector.\n"
234 "   :type stop: int\n"
235 "   :arg size: The size of the vector to be created.\n"
236 "   :type size: int\n"
237 );
238 static PyObject *C_Vector_Linspace(PyObject *cls, PyObject *args)
239 {
240         float *vec;
241         int size;
242         float start, end, step;
243
244         if (!PyArg_ParseTuple(args, "ffi:Vector.Linspace", &start, &end, &size)) {
245                 return NULL;
246         }
247
248         if (size < 2) {
249                 PyErr_SetString(PyExc_RuntimeError,
250                                 "Vector.Linspace(): invalid size");
251                 return NULL;
252         }
253
254         step = (end - start) / (float)(size - 1);
255
256         vec = PyMem_Malloc(size * sizeof(float));
257
258         if (vec == NULL) {
259                 PyErr_SetString(PyExc_MemoryError,
260                                 "Vector.Linspace(): "
261                                 "problem allocating pointer space");
262                 return NULL;
263         }
264
265         range_vn_fl(vec, size, start, step);
266
267         return Vector_CreatePyObject_alloc(vec, size, (PyTypeObject *)cls);
268 }
269
270 PyDoc_STRVAR(C_Vector_Repeat_doc,
271 ".. classmethod:: Repeat(vector, size)\n"
272 "\n"
273 "   Create a vector by repeating the values in vector until the required size is reached.\n"
274 "\n"
275 "   :arg tuple: The vector to draw values from.\n"
276 "   :type tuple: :class:`mathutils.Vector`\n"
277 "   :arg size: The size of the vector to be created.\n"
278 "   :type size: int\n"
279 );
280 static PyObject *C_Vector_Repeat(PyObject *cls, PyObject *args)
281 {
282         float *vec;
283         float *iter_vec = NULL;
284         int i, size, value_size;
285         PyObject *value;
286
287         if (!PyArg_ParseTuple(args, "Oi:Vector.Repeat", &value, &size)) {
288                 return NULL;
289         }
290
291         if (size < 2) {
292                 PyErr_SetString(PyExc_RuntimeError,
293                                 "Vector.Repeat(): invalid size");
294                 return NULL;
295         }
296
297         if ((value_size = mathutils_array_parse_alloc(&iter_vec, 2, value,
298                                                       "Vector.Repeat(vector, size), invalid 'vector' arg")) == -1)
299         {
300                 return NULL;
301         }
302
303         if (iter_vec == NULL) {
304                 PyErr_SetString(PyExc_MemoryError,
305                                 "Vector.Repeat(): "
306                                 "problem allocating pointer space");
307                 return NULL;
308         }
309
310         vec = PyMem_Malloc(size * sizeof(float));
311
312         if (vec == NULL) {
313                 PyMem_Free(iter_vec);
314                 PyErr_SetString(PyExc_MemoryError,
315                                 "Vector.Repeat(): "
316                                 "problem allocating pointer space");
317                 return NULL;
318         }
319
320         i = 0;
321         while (i < size) {
322                 vec[i] = iter_vec[i % value_size];
323                 i++;
324         }
325
326         PyMem_Free(iter_vec);
327
328         return Vector_CreatePyObject_alloc(vec, size, (PyTypeObject *)cls);
329 }
330
331 /*-----------------------------METHODS---------------------------- */
332 PyDoc_STRVAR(Vector_zero_doc,
333 ".. method:: zero()\n"
334 "\n"
335 "   Set all values to zero.\n"
336 );
337 static PyObject *Vector_zero(VectorObject *self)
338 {
339         if (BaseMath_Prepare_ForWrite(self) == -1)
340                 return NULL;
341
342         copy_vn_fl(self->vec, self->size, 0.0f);
343
344         if (BaseMath_WriteCallback(self) == -1)
345                 return NULL;
346
347         Py_RETURN_NONE;
348 }
349
350 PyDoc_STRVAR(Vector_normalize_doc,
351 ".. method:: normalize()\n"
352 "\n"
353 "   Normalize the vector, making the length of the vector always 1.0.\n"
354 "\n"
355 "   .. warning:: Normalizing a vector where all values are zero has no effect.\n"
356 "\n"
357 "   .. note:: Normalize works for vectors of all sizes,\n"
358 "      however 4D Vectors w axis is left untouched.\n"
359 );
360 static PyObject *Vector_normalize(VectorObject *self)
361 {
362         int size = (self->size == 4 ? 3 : self->size);
363         if (BaseMath_ReadCallback_ForWrite(self) == -1)
364                 return NULL;
365
366         normalize_vn(self->vec, size);
367
368         (void)BaseMath_WriteCallback(self);
369         Py_RETURN_NONE;
370 }
371 PyDoc_STRVAR(Vector_normalized_doc,
372 ".. method:: normalized()\n"
373 "\n"
374 "   Return a new, normalized vector.\n"
375 "\n"
376 "   :return: a normalized copy of the vector\n"
377 "   :rtype: :class:`Vector`\n"
378 );
379 static PyObject *Vector_normalized(VectorObject *self)
380 {
381         return vec__apply_to_copy((PyNoArgsFunction)Vector_normalize, self);
382 }
383
384 PyDoc_STRVAR(Vector_resize_doc,
385 ".. method:: resize(size=3)\n"
386 "\n"
387 "   Resize the vector to have size number of elements.\n"
388 );
389 static PyObject *Vector_resize(VectorObject *self, PyObject *value)
390 {
391         int size;
392
393         if (self->flag & BASE_MATH_FLAG_IS_WRAP) {
394                 PyErr_SetString(PyExc_TypeError,
395                                 "Vector.resize(): "
396                                 "cannot resize wrapped data - only python vectors");
397                 return NULL;
398         }
399         if (self->cb_user) {
400                 PyErr_SetString(PyExc_TypeError,
401                                 "Vector.resize(): "
402                                 "cannot resize a vector that has an owner");
403                 return NULL;
404         }
405
406         if ((size = PyLong_AsLong(value)) == -1) {
407                 PyErr_SetString(PyExc_TypeError,
408                                 "Vector.resize(size): "
409                                 "expected size argument to be an integer");
410                 return NULL;
411         }
412
413         if (size < 2) {
414                 PyErr_SetString(PyExc_RuntimeError,
415                                 "Vector.resize(): invalid size");
416                 return NULL;
417         }
418
419         self->vec = PyMem_Realloc(self->vec, (size * sizeof(float)));
420         if (self->vec == NULL) {
421                 PyErr_SetString(PyExc_MemoryError,
422                                 "Vector.resize(): "
423                                 "problem allocating pointer space");
424                 return NULL;
425         }
426
427         /* If the vector has increased in length, set all new elements to 0.0f */
428         if (size > self->size) {
429                 copy_vn_fl(self->vec + self->size, size - self->size, 0.0f);
430         }
431
432         self->size = size;
433         Py_RETURN_NONE;
434 }
435
436 PyDoc_STRVAR(Vector_resized_doc,
437 ".. method:: resized(size=3)\n"
438 "\n"
439 "   Return a resized copy of the vector with size number of elements.\n"
440 "\n"
441 "   :return: a new vector\n"
442 "   :rtype: :class:`Vector`\n"
443 );
444 static PyObject *Vector_resized(VectorObject *self, PyObject *value)
445 {
446         int size;
447         float *vec;
448
449         if ((size = PyLong_AsLong(value)) == -1) {
450                 return NULL;
451         }
452
453         if (size < 2) {
454                 PyErr_SetString(PyExc_RuntimeError,
455                                 "Vector.resized(): invalid size");
456                 return NULL;
457         }
458
459         vec = PyMem_Malloc(size * sizeof(float));
460
461         if (vec == NULL) {
462                 PyErr_SetString(PyExc_MemoryError,
463                                 "Vector.resized(): "
464                                 "problem allocating pointer space");
465                 return NULL;
466         }
467
468         copy_vn_fl(vec, size, 0.0f);
469         memcpy(vec, self->vec, self->size * sizeof(float));
470
471         return Vector_CreatePyObject_alloc(vec, size, NULL);
472 }
473
474 PyDoc_STRVAR(Vector_resize_2d_doc,
475 ".. method:: resize_2d()\n"
476 "\n"
477 "   Resize the vector to 2D  (x, y).\n"
478 );
479 static PyObject *Vector_resize_2d(VectorObject *self)
480 {
481         if (self->flag & BASE_MATH_FLAG_IS_WRAP) {
482                 PyErr_SetString(PyExc_TypeError,
483                                 "Vector.resize_2d(): "
484                                 "cannot resize wrapped data - only python vectors");
485                 return NULL;
486         }
487         if (self->cb_user) {
488                 PyErr_SetString(PyExc_TypeError,
489                                 "Vector.resize_2d(): "
490                                 "cannot resize a vector that has an owner");
491                 return NULL;
492         }
493
494         self->vec = PyMem_Realloc(self->vec, (sizeof(float) * 2));
495         if (self->vec == NULL) {
496                 PyErr_SetString(PyExc_MemoryError,
497                                 "Vector.resize_2d(): "
498                                 "problem allocating pointer space");
499                 return NULL;
500         }
501
502         self->size = 2;
503         Py_RETURN_NONE;
504 }
505
506 PyDoc_STRVAR(Vector_resize_3d_doc,
507 ".. method:: resize_3d()\n"
508 "\n"
509 "   Resize the vector to 3D  (x, y, z).\n"
510 );
511 static PyObject *Vector_resize_3d(VectorObject *self)
512 {
513         if (self->flag & BASE_MATH_FLAG_IS_WRAP) {
514                 PyErr_SetString(PyExc_TypeError,
515                                 "Vector.resize_3d(): "
516                                 "cannot resize wrapped data - only python vectors");
517                 return NULL;
518         }
519         if (self->cb_user) {
520                 PyErr_SetString(PyExc_TypeError,
521                                 "Vector.resize_3d(): "
522                                 "cannot resize a vector that has an owner");
523                 return NULL;
524         }
525
526         self->vec = PyMem_Realloc(self->vec, (sizeof(float) * 3));
527         if (self->vec == NULL) {
528                 PyErr_SetString(PyExc_MemoryError,
529                                 "Vector.resize_3d(): "
530                                 "problem allocating pointer space");
531                 return NULL;
532         }
533
534         if (self->size == 2)
535                 self->vec[2] = 0.0f;
536
537         self->size = 3;
538         Py_RETURN_NONE;
539 }
540
541 PyDoc_STRVAR(Vector_resize_4d_doc,
542 ".. method:: resize_4d()\n"
543 "\n"
544 "   Resize the vector to 4D (x, y, z, w).\n"
545 );
546 static PyObject *Vector_resize_4d(VectorObject *self)
547 {
548         if (self->flag & BASE_MATH_FLAG_IS_WRAP) {
549                 PyErr_SetString(PyExc_TypeError,
550                                 "Vector.resize_4d(): "
551                                 "cannot resize wrapped data - only python vectors");
552                 return NULL;
553         }
554         if (self->cb_user) {
555                 PyErr_SetString(PyExc_TypeError,
556                                 "Vector.resize_4d(): "
557                                 "cannot resize a vector that has an owner");
558                 return NULL;
559         }
560
561         self->vec = PyMem_Realloc(self->vec, (sizeof(float) * 4));
562         if (self->vec == NULL) {
563                 PyErr_SetString(PyExc_MemoryError,
564                                 "Vector.resize_4d(): "
565                                 "problem allocating pointer space");
566                 return NULL;
567         }
568
569         if (self->size == 2) {
570                 self->vec[2] = 0.0f;
571                 self->vec[3] = 1.0f;
572         }
573         else if (self->size == 3) {
574                 self->vec[3] = 1.0f;
575         }
576         self->size = 4;
577         Py_RETURN_NONE;
578 }
579 PyDoc_STRVAR(Vector_to_2d_doc,
580 ".. method:: to_2d()\n"
581 "\n"
582 "   Return a 2d copy of the vector.\n"
583 "\n"
584 "   :return: a new vector\n"
585 "   :rtype: :class:`Vector`\n"
586 );
587 static PyObject *Vector_to_2d(VectorObject *self)
588 {
589         if (BaseMath_ReadCallback(self) == -1)
590                 return NULL;
591
592         return Vector_CreatePyObject(self->vec, 2, Py_TYPE(self));
593 }
594 PyDoc_STRVAR(Vector_to_3d_doc,
595 ".. method:: to_3d()\n"
596 "\n"
597 "   Return a 3d copy of the vector.\n"
598 "\n"
599 "   :return: a new vector\n"
600 "   :rtype: :class:`Vector`\n"
601 );
602 static PyObject *Vector_to_3d(VectorObject *self)
603 {
604         float tvec[3] = {0.0f};
605
606         if (BaseMath_ReadCallback(self) == -1)
607                 return NULL;
608
609         memcpy(tvec, self->vec, sizeof(float) * MIN2(self->size, 3));
610         return Vector_CreatePyObject(tvec, 3, Py_TYPE(self));
611 }
612 PyDoc_STRVAR(Vector_to_4d_doc,
613 ".. method:: to_4d()\n"
614 "\n"
615 "   Return a 4d copy of the vector.\n"
616 "\n"
617 "   :return: a new vector\n"
618 "   :rtype: :class:`Vector`\n"
619 );
620 static PyObject *Vector_to_4d(VectorObject *self)
621 {
622         float tvec[4] = {0.0f, 0.0f, 0.0f, 1.0f};
623
624         if (BaseMath_ReadCallback(self) == -1)
625                 return NULL;
626
627         memcpy(tvec, self->vec, sizeof(float) * MIN2(self->size, 4));
628         return Vector_CreatePyObject(tvec, 4, Py_TYPE(self));
629 }
630
631 PyDoc_STRVAR(Vector_to_tuple_doc,
632 ".. method:: to_tuple(precision=-1)\n"
633 "\n"
634 "   Return this vector as a tuple with.\n"
635 "\n"
636 "   :arg precision: The number to round the value to in [-1, 21].\n"
637 "   :type precision: int\n"
638 "   :return: the values of the vector rounded by *precision*\n"
639 "   :rtype: tuple\n"
640 );
641 /* note: BaseMath_ReadCallback must be called beforehand */
642 static PyObject *Vector_to_tuple_ext(VectorObject *self, int ndigits)
643 {
644         PyObject *ret;
645         int i;
646
647         ret = PyTuple_New(self->size);
648
649         if (ndigits >= 0) {
650                 for (i = 0; i < self->size; i++) {
651                         PyTuple_SET_ITEM(ret, i, PyFloat_FromDouble(double_round((double)self->vec[i], ndigits)));
652                 }
653         }
654         else {
655                 for (i = 0; i < self->size; i++) {
656                         PyTuple_SET_ITEM(ret, i, PyFloat_FromDouble(self->vec[i]));
657                 }
658         }
659
660         return ret;
661 }
662
663 static PyObject *Vector_to_tuple(VectorObject *self, PyObject *args)
664 {
665         int ndigits = 0;
666
667         if (!PyArg_ParseTuple(args, "|i:to_tuple", &ndigits))
668                 return NULL;
669
670         if (ndigits > 22 || ndigits < 0) {
671                 PyErr_SetString(PyExc_ValueError,
672                                 "Vector.to_tuple(ndigits): "
673                                 "ndigits must be between 0 and 21");
674                 return NULL;
675         }
676
677         if (PyTuple_GET_SIZE(args) == 0)
678                 ndigits = -1;
679
680         if (BaseMath_ReadCallback(self) == -1)
681                 return NULL;
682
683         return Vector_to_tuple_ext(self, ndigits);
684 }
685
686 PyDoc_STRVAR(Vector_to_track_quat_doc,
687 ".. method:: to_track_quat(track, up)\n"
688 "\n"
689 "   Return a quaternion rotation from the vector and the track and up axis.\n"
690 "\n"
691 "   :arg track: Track axis in ['X', 'Y', 'Z', '-X', '-Y', '-Z'].\n"
692 "   :type track: string\n"
693 "   :arg up: Up axis in ['X', 'Y', 'Z'].\n"
694 "   :type up: string\n"
695 "   :return: rotation from the vector and the track and up axis.\n"
696 "   :rtype: :class:`Quaternion`\n"
697 );
698 static PyObject *Vector_to_track_quat(VectorObject *self, PyObject *args)
699 {
700         float vec[3], quat[4];
701         const char *strack, *sup;
702         short track = 2, up = 1;
703
704         if (!PyArg_ParseTuple(args, "|ss:to_track_quat", &strack, &sup))
705                 return NULL;
706
707         if (self->size != 3) {
708                 PyErr_SetString(PyExc_TypeError,
709                                 "Vector.to_track_quat(): "
710                                 "only for 3D vectors");
711                 return NULL;
712         }
713
714         if (BaseMath_ReadCallback(self) == -1)
715                 return NULL;
716
717         if (strack) {
718                 const char *axis_err_msg = "only X, -X, Y, -Y, Z or -Z for track axis";
719
720                 if (strlen(strack) == 2) {
721                         if (strack[0] == '-') {
722                                 switch (strack[1]) {
723                                         case 'X':
724                                                 track = 3;
725                                                 break;
726                                         case 'Y':
727                                                 track = 4;
728                                                 break;
729                                         case 'Z':
730                                                 track = 5;
731                                                 break;
732                                         default:
733                                                 PyErr_SetString(PyExc_ValueError, axis_err_msg);
734                                                 return NULL;
735                                 }
736                         }
737                         else {
738                                 PyErr_SetString(PyExc_ValueError, axis_err_msg);
739                                 return NULL;
740                         }
741                 }
742                 else if (strlen(strack) == 1) {
743                         switch (strack[0]) {
744                                 case '-':
745                                 case 'X':
746                                         track = 0;
747                                         break;
748                                 case 'Y':
749                                         track = 1;
750                                         break;
751                                 case 'Z':
752                                         track = 2;
753                                         break;
754                                 default:
755                                         PyErr_SetString(PyExc_ValueError, axis_err_msg);
756                                         return NULL;
757                         }
758                 }
759                 else {
760                         PyErr_SetString(PyExc_ValueError, axis_err_msg);
761                         return NULL;
762                 }
763         }
764
765         if (sup) {
766                 const char *axis_err_msg = "only X, Y or Z for up axis";
767                 if (strlen(sup) == 1) {
768                         switch (*sup) {
769                                 case 'X':
770                                         up = 0;
771                                         break;
772                                 case 'Y':
773                                         up = 1;
774                                         break;
775                                 case 'Z':
776                                         up = 2;
777                                         break;
778                                 default:
779                                         PyErr_SetString(PyExc_ValueError, axis_err_msg);
780                                         return NULL;
781                         }
782                 }
783                 else {
784                         PyErr_SetString(PyExc_ValueError, axis_err_msg);
785                         return NULL;
786                 }
787         }
788
789         if (track == up) {
790                 PyErr_SetString(PyExc_ValueError,
791                                 "Can't have the same axis for track and up");
792                 return NULL;
793         }
794
795         /*
796          * flip vector around, since vectoquat expect a vector from target to tracking object
797          * and the python function expects the inverse (a vector to the target).
798          */
799         negate_v3_v3(vec, self->vec);
800
801         vec_to_quat(quat, vec, track, up);
802
803         return Quaternion_CreatePyObject(quat, NULL);
804 }
805
806 PyDoc_STRVAR(Vector_orthogonal_doc,
807 ".. method:: orthogonal()\n"
808 "\n"
809 "   Return a perpendicular vector.\n"
810 "\n"
811 "   :return: a new vector 90 degrees from this vector.\n"
812 "   :rtype: :class:`Vector`\n"
813 "\n"
814 "   .. note:: the axis is undefined, only use when any orthogonal vector is acceptable.\n"
815 );
816 static PyObject *Vector_orthogonal(VectorObject *self)
817 {
818         float vec[3];
819
820         if (self->size > 3) {
821                 PyErr_SetString(PyExc_TypeError,
822                                 "Vector.orthogonal(): "
823                                 "Vector must be 3D or 2D");
824                 return NULL;
825         }
826
827         if (BaseMath_ReadCallback(self) == -1)
828                 return NULL;
829
830         if (self->size == 3)
831                 ortho_v3_v3(vec, self->vec);
832         else
833                 ortho_v2_v2(vec, self->vec);
834
835         return Vector_CreatePyObject(vec, self->size, Py_TYPE(self));
836 }
837
838
839 /*
840  * Vector.reflect(mirror): return a reflected vector on the mirror normal
841  *  vec - ((2 * DotVecs(vec, mirror)) * mirror)
842  */
843 PyDoc_STRVAR(Vector_reflect_doc,
844 ".. method:: reflect(mirror)\n"
845 "\n"
846 "   Return the reflection vector from the *mirror* argument.\n"
847 "\n"
848 "   :arg mirror: This vector could be a normal from the reflecting surface.\n"
849 "   :type mirror: :class:`Vector`\n"
850 "   :return: The reflected vector matching the size of this vector.\n"
851 "   :rtype: :class:`Vector`\n"
852 );
853 static PyObject *Vector_reflect(VectorObject *self, PyObject *value)
854 {
855         int value_size;
856         float mirror[3], vec[3];
857         float reflect[3] = {0.0f};
858         float tvec[MAX_DIMENSIONS];
859
860         if (BaseMath_ReadCallback(self) == -1)
861                 return NULL;
862
863         if ((value_size = mathutils_array_parse(tvec, 2, 4, value, "Vector.reflect(other), invalid 'other' arg")) == -1)
864                 return NULL;
865
866         if (self->size < 2 || self->size > 4) {
867                 PyErr_SetString(PyExc_ValueError,
868                                 "Vector must be 2D, 3D or 4D");
869                 return NULL;
870         }
871
872         mirror[0] = tvec[0];
873         mirror[1] = tvec[1];
874         mirror[2] = (value_size > 2) ? tvec[2] : 0.0f;
875
876         vec[0] = self->vec[0];
877         vec[1] = self->vec[1];
878         vec[2] = (value_size > 2) ? self->vec[2] : 0.0f;
879
880         normalize_v3(mirror);
881         reflect_v3_v3v3(reflect, vec, mirror);
882
883         return Vector_CreatePyObject(reflect, self->size, Py_TYPE(self));
884 }
885
886 PyDoc_STRVAR(Vector_cross_doc,
887 ".. method:: cross(other)\n"
888 "\n"
889 "   Return the cross product of this vector and another.\n"
890 "\n"
891 "   :arg other: The other vector to perform the cross product with.\n"
892 "   :type other: :class:`Vector`\n"
893 "   :return: The cross product.\n"
894 "   :rtype: :class:`Vector` or float when 2D vectors are used\n"
895 "\n"
896 "   .. note:: both vectors must be 2D or 3D\n"
897 );
898 static PyObject *Vector_cross(VectorObject *self, PyObject *value)
899 {
900         PyObject *ret;
901         float tvec[3];
902
903         if (BaseMath_ReadCallback(self) == -1)
904                 return NULL;
905
906         if (self->size > 3) {
907                 PyErr_SetString(PyExc_ValueError,
908                                 "Vector must be 2D or 3D");
909                 return NULL;
910         }
911
912         if (mathutils_array_parse(tvec, self->size, self->size, value, "Vector.cross(other), invalid 'other' arg") == -1)
913                 return NULL;
914
915         if (self->size == 3) {
916                 ret = Vector_CreatePyObject(NULL, 3, Py_TYPE(self));
917                 cross_v3_v3v3(((VectorObject *)ret)->vec, self->vec, tvec);
918         }
919         else {
920                 /* size == 2 */
921                 ret = PyFloat_FromDouble(cross_v2v2(self->vec, tvec));
922         }
923         return ret;
924 }
925
926 PyDoc_STRVAR(Vector_dot_doc,
927 ".. method:: dot(other)\n"
928 "\n"
929 "   Return the dot product of this vector and another.\n"
930 "\n"
931 "   :arg other: The other vector to perform the dot product with.\n"
932 "   :type other: :class:`Vector`\n"
933 "   :return: The dot product.\n"
934 "   :rtype: :class:`Vector`\n"
935 );
936 static PyObject *Vector_dot(VectorObject *self, PyObject *value)
937 {
938         float *tvec;
939         PyObject *ret;
940
941         if (BaseMath_ReadCallback(self) == -1)
942                 return NULL;
943
944         if (mathutils_array_parse_alloc(&tvec, self->size, value, "Vector.dot(other), invalid 'other' arg") == -1) {
945                 return NULL;
946         }
947
948         ret = PyFloat_FromDouble(dot_vn_vn(self->vec, tvec, self->size));
949         PyMem_Free(tvec);
950         return ret;
951 }
952
953 PyDoc_STRVAR(Vector_angle_doc,
954 ".. function:: angle(other, fallback=None)\n"
955 "\n"
956 "   Return the angle between two vectors.\n"
957 "\n"
958 "   :arg other: another vector to compare the angle with\n"
959 "   :type other: :class:`Vector`\n"
960 "   :arg fallback: return this when the angle can't be calculated (zero length vector),\n"
961 "      (instead of raising a :exc:`ValueError`).\n"
962 "   :type fallback: any\n"
963 "   :return: angle in radians or fallback when given\n"
964 "   :rtype: float\n"
965 );
966 static PyObject *Vector_angle(VectorObject *self, PyObject *args)
967 {
968         const int size = MIN2(self->size, 3); /* 4D angle makes no sense */
969         float tvec[MAX_DIMENSIONS];
970         PyObject *value;
971         double dot = 0.0f, dot_self = 0.0f, dot_other = 0.0f;
972         int x;
973         PyObject *fallback = NULL;
974
975         if (!PyArg_ParseTuple(args, "O|O:angle", &value, &fallback))
976                 return NULL;
977
978         if (BaseMath_ReadCallback(self) == -1)
979                 return NULL;
980
981         /* don't use clamped size, rule of thumb is vector sizes must match,
982          * even though n this case 'w' is ignored */
983         if (mathutils_array_parse(tvec, self->size, self->size, value, "Vector.angle(other), invalid 'other' arg") == -1)
984                 return NULL;
985
986         if (self->size > 4) {
987                 PyErr_SetString(PyExc_ValueError,
988                                 "Vector must be 2D, 3D or 4D");
989                 return NULL;
990         }
991
992         for (x = 0; x < size; x++) {
993                 dot_self  += (double)self->vec[x] * (double)self->vec[x];
994                 dot_other += (double)tvec[x]      * (double)tvec[x];
995                 dot       += (double)self->vec[x] * (double)tvec[x];
996         }
997
998         if (!dot_self || !dot_other) {
999                 /* avoid exception */
1000                 if (fallback) {
1001                         Py_INCREF(fallback);
1002                         return fallback;
1003                 }
1004                 else {
1005                         PyErr_SetString(PyExc_ValueError,
1006                                         "Vector.angle(other): "
1007                                         "zero length vectors have no valid angle");
1008                         return NULL;
1009                 }
1010         }
1011
1012         return PyFloat_FromDouble(saacos(dot / (sqrt(dot_self) * sqrt(dot_other))));
1013 }
1014
1015 PyDoc_STRVAR(Vector_angle_signed_doc,
1016 ".. function:: angle_signed(other, fallback)\n"
1017 "\n"
1018 "   Return the signed angle between two 2D vectors (clockwise is positive).\n"
1019 "\n"
1020 "   :arg other: another vector to compare the angle with\n"
1021 "   :type other: :class:`Vector`\n"
1022 "   :arg fallback: return this when the angle can't be calculated (zero length vector),\n"
1023 "      (instead of raising a :exc:`ValueError`).\n"
1024 "   :type fallback: any\n"
1025 "   :return: angle in radians or fallback when given\n"
1026 "   :rtype: float\n"
1027 );
1028 static PyObject *Vector_angle_signed(VectorObject *self, PyObject *args)
1029 {
1030         float tvec[2];
1031
1032         PyObject *value;
1033         PyObject *fallback = NULL;
1034
1035         if (!PyArg_ParseTuple(args, "O|O:angle_signed", &value, &fallback))
1036                 return NULL;
1037
1038         if (BaseMath_ReadCallback(self) == -1)
1039                 return NULL;
1040
1041         if (mathutils_array_parse(tvec, 2, 2, value, "Vector.angle_signed(other), invalid 'other' arg") == -1)
1042                 return NULL;
1043
1044         if (self->size != 2) {
1045                 PyErr_SetString(PyExc_ValueError,
1046                                 "Vector must be 2D");
1047                 return NULL;
1048         }
1049
1050         if (is_zero_v2(self->vec) || is_zero_v2(tvec)) {
1051                 /* avoid exception */
1052                 if (fallback) {
1053                         Py_INCREF(fallback);
1054                         return fallback;
1055                 }
1056                 else {
1057                         PyErr_SetString(PyExc_ValueError,
1058                                         "Vector.angle_signed(other): "
1059                                         "zero length vectors have no valid angle");
1060                         return NULL;
1061                 }
1062         }
1063
1064
1065         return PyFloat_FromDouble(angle_signed_v2v2(self->vec, tvec));
1066 }
1067
1068
1069 PyDoc_STRVAR(Vector_rotation_difference_doc,
1070 ".. function:: rotation_difference(other)\n"
1071 "\n"
1072 "   Returns a quaternion representing the rotational difference between this\n"
1073 "   vector and another.\n"
1074 "\n"
1075 "   :arg other: second vector.\n"
1076 "   :type other: :class:`Vector`\n"
1077 "   :return: the rotational difference between the two vectors.\n"
1078 "   :rtype: :class:`Quaternion`\n"
1079 "\n"
1080 "   .. note:: 2D vectors raise an :exc:`AttributeError`.\n"
1081 );
1082 static PyObject *Vector_rotation_difference(VectorObject *self, PyObject *value)
1083 {
1084         float quat[4], vec_a[3], vec_b[3];
1085
1086         if (self->size < 3 || self->size > 4) {
1087                 PyErr_SetString(PyExc_ValueError,
1088                                 "vec.difference(value): "
1089                                 "expects both vectors to be size 3 or 4");
1090                 return NULL;
1091         }
1092
1093         if (BaseMath_ReadCallback(self) == -1)
1094                 return NULL;
1095
1096         if (mathutils_array_parse(vec_b, 3, MAX_DIMENSIONS, value, "Vector.difference(other), invalid 'other' arg") == -1)
1097                 return NULL;
1098
1099         normalize_v3_v3(vec_a, self->vec);
1100         normalize_v3(vec_b);
1101
1102         rotation_between_vecs_to_quat(quat, vec_a, vec_b);
1103
1104         return Quaternion_CreatePyObject(quat, NULL);
1105 }
1106
1107 PyDoc_STRVAR(Vector_project_doc,
1108 ".. function:: project(other)\n"
1109 "\n"
1110 "   Return the projection of this vector onto the *other*.\n"
1111 "\n"
1112 "   :arg other: second vector.\n"
1113 "   :type other: :class:`Vector`\n"
1114 "   :return: the parallel projection vector\n"
1115 "   :rtype: :class:`Vector`\n"
1116 );
1117 static PyObject *Vector_project(VectorObject *self, PyObject *value)
1118 {
1119         const int size = self->size;
1120         float tvec[MAX_DIMENSIONS];
1121         float vec[MAX_DIMENSIONS];
1122         double dot = 0.0f, dot2 = 0.0f;
1123         int x;
1124
1125         if (mathutils_array_parse(tvec, size, size, value, "Vector.project(other), invalid 'other' arg") == -1)
1126                 return NULL;
1127
1128         if (self->size > 4) {
1129                 PyErr_SetString(PyExc_ValueError,
1130                                 "Vector must be 2D, 3D or 4D");
1131                 return NULL;
1132         }
1133
1134         if (BaseMath_ReadCallback(self) == -1)
1135                 return NULL;
1136
1137         /* get dot products */
1138         for (x = 0; x < size; x++) {
1139                 dot += (double)(self->vec[x] * tvec[x]);
1140                 dot2 += (double)(tvec[x] * tvec[x]);
1141         }
1142         /* projection */
1143         dot /= dot2;
1144         for (x = 0; x < size; x++) {
1145                 vec[x] = (float)dot * tvec[x];
1146         }
1147         return Vector_CreatePyObject(vec, size, Py_TYPE(self));
1148 }
1149
1150 PyDoc_STRVAR(Vector_lerp_doc,
1151 ".. function:: lerp(other, factor)\n"
1152 "\n"
1153 "   Returns the interpolation of two vectors.\n"
1154 "\n"
1155 "   :arg other: value to interpolate with.\n"
1156 "   :type other: :class:`Vector`\n"
1157 "   :arg factor: The interpolation value in [0.0, 1.0].\n"
1158 "   :type factor: float\n"
1159 "   :return: The interpolated vector.\n"
1160 "   :rtype: :class:`Vector`\n"
1161 );
1162 static PyObject *Vector_lerp(VectorObject *self, PyObject *args)
1163 {
1164         const int size = self->size;
1165         PyObject *value = NULL;
1166         float fac;
1167         float *tvec;
1168
1169         if (!PyArg_ParseTuple(args, "Of:lerp", &value, &fac))
1170                 return NULL;
1171
1172         if (BaseMath_ReadCallback(self) == -1) {
1173                 return NULL;
1174         }
1175
1176         if (mathutils_array_parse_alloc(&tvec, size, value, "Vector.lerp(other), invalid 'other' arg") == -1) {
1177                 return NULL;
1178         }
1179
1180         interp_vn_vn(tvec, self->vec, 1.0f - fac, size);
1181
1182         return Vector_CreatePyObject_alloc(tvec, size, Py_TYPE(self));
1183 }
1184
1185 PyDoc_STRVAR(Vector_slerp_doc,
1186 ".. function:: slerp(other, factor, fallback=None)\n"
1187 "\n"
1188 "   Returns the interpolation of two non-zero vectors (spherical coordinates).\n"
1189 "\n"
1190 "   :arg other: value to interpolate with.\n"
1191 "   :type other: :class:`Vector`\n"
1192 "   :arg factor: The interpolation value typically in [0.0, 1.0].\n"
1193 "   :type factor: float\n"
1194 "   :arg fallback: return this when the vector can't be calculated (zero length vector or direct opposites),\n"
1195 "      (instead of raising a :exc:`ValueError`).\n"
1196 "   :type fallback: any\n"
1197 "   :return: The interpolated vector.\n"
1198 "   :rtype: :class:`Vector`\n"
1199 );
1200 static PyObject *Vector_slerp(VectorObject *self, PyObject *args)
1201 {
1202         const int size = self->size;
1203         PyObject *value = NULL;
1204         float fac, cosom, w[2];
1205         float self_vec[3], other_vec[3], ret_vec[3];
1206         float self_len_sq, other_len_sq;
1207         int x;
1208         PyObject *fallback = NULL;
1209
1210         if (!PyArg_ParseTuple(args, "Of|O:slerp", &value, &fac, &fallback))
1211                 return NULL;
1212
1213         if (BaseMath_ReadCallback(self) == -1) {
1214                 return NULL;
1215         }
1216
1217         if (self->size > 3) {
1218                 PyErr_SetString(PyExc_ValueError,
1219                                 "Vector must be 2D or 3D");
1220                 return NULL;
1221         }
1222
1223         if (mathutils_array_parse(other_vec, size, size, value, "Vector.slerp(other), invalid 'other' arg") == -1) {
1224                 return NULL;
1225         }
1226
1227         self_len_sq  = normalize_vn_vn(self_vec, self->vec, size);
1228         other_len_sq = normalize_vn(other_vec,              size);
1229
1230         /* use fallbacks for zero length vectors */
1231         if (UNLIKELY((self_len_sq  < FLT_EPSILON) ||
1232                      (other_len_sq < FLT_EPSILON)))
1233         {
1234                 /* avoid exception */
1235                 if (fallback) {
1236                         Py_INCREF(fallback);
1237                         return fallback;
1238                 }
1239                 else {
1240                         PyErr_SetString(PyExc_ValueError,
1241                                         "Vector.slerp(): "
1242                                         "zero length vectors unsupported");
1243                         return NULL;
1244                 }
1245         }
1246
1247         /* We have sane state, execute slerp */
1248         cosom = (float)dot_vn_vn(self_vec, other_vec, size);
1249
1250         /* direct opposite, can't slerp */
1251         if (UNLIKELY(cosom < (-1.0f + FLT_EPSILON))) {
1252                 /* avoid exception */
1253                 if (fallback) {
1254                         Py_INCREF(fallback);
1255                         return fallback;
1256                 }
1257                 else {
1258                         PyErr_SetString(PyExc_ValueError,
1259                                         "Vector.slerp(): "
1260                                         "opposite vectors unsupported");
1261                         return NULL;
1262                 }
1263         }
1264
1265         interp_dot_slerp(fac, cosom, w);
1266
1267         for (x = 0; x < size; x++) {
1268                 ret_vec[x] = (w[0] * self_vec[x]) + (w[1] * other_vec[x]);
1269         }
1270
1271         return Vector_CreatePyObject(ret_vec, size, Py_TYPE(self));
1272 }
1273
1274 PyDoc_STRVAR(Vector_rotate_doc,
1275 ".. function:: rotate(other)\n"
1276 "\n"
1277 "   Rotate the vector by a rotation value.\n"
1278 "\n"
1279 "   :arg other: rotation component of mathutils value\n"
1280 "   :type other: :class:`Euler`, :class:`Quaternion` or :class:`Matrix`\n"
1281 );
1282 static PyObject *Vector_rotate(VectorObject *self, PyObject *value)
1283 {
1284         float other_rmat[3][3];
1285
1286         if (BaseMath_ReadCallback_ForWrite(self) == -1)
1287                 return NULL;
1288
1289         if (mathutils_any_to_rotmat(other_rmat, value, "Vector.rotate(value)") == -1)
1290                 return NULL;
1291
1292         if (self->size < 3 || self->size > 4) {
1293                 PyErr_SetString(PyExc_ValueError,
1294                                 "Vector must be 3D or 4D");
1295                 return NULL;
1296         }
1297
1298         mul_m3_v3(other_rmat, self->vec);
1299
1300         (void)BaseMath_WriteCallback(self);
1301         Py_RETURN_NONE;
1302 }
1303
1304 PyDoc_STRVAR(Vector_copy_doc,
1305 ".. function:: copy()\n"
1306 "\n"
1307 "   Returns a copy of this vector.\n"
1308 "\n"
1309 "   :return: A copy of the vector.\n"
1310 "   :rtype: :class:`Vector`\n"
1311 "\n"
1312 "   .. note:: use this to get a copy of a wrapped vector with\n"
1313 "      no reference to the original data.\n"
1314 );
1315 static PyObject *Vector_copy(VectorObject *self)
1316 {
1317         if (BaseMath_ReadCallback(self) == -1)
1318                 return NULL;
1319
1320         return Vector_CreatePyObject(self->vec, self->size, Py_TYPE(self));
1321 }
1322 static PyObject *Vector_deepcopy(VectorObject *self, PyObject *args)
1323 {
1324         if (!mathutils_deepcopy_args_check(args))
1325                 return NULL;
1326         return Vector_copy(self);
1327 }
1328
1329 static PyObject *Vector_repr(VectorObject *self)
1330 {
1331         PyObject *ret, *tuple;
1332
1333         if (BaseMath_ReadCallback(self) == -1)
1334                 return NULL;
1335
1336         tuple = Vector_to_tuple_ext(self, -1);
1337         ret = PyUnicode_FromFormat("Vector(%R)", tuple);
1338         Py_DECREF(tuple);
1339         return ret;
1340 }
1341
1342 #ifndef MATH_STANDALONE
1343 static PyObject *Vector_str(VectorObject *self)
1344 {
1345         int i;
1346
1347         DynStr *ds;
1348
1349         if (BaseMath_ReadCallback(self) == -1)
1350                 return NULL;
1351
1352         ds = BLI_dynstr_new();
1353
1354         BLI_dynstr_append(ds, "<Vector (");
1355
1356         for (i = 0; i < self->size; i++) {
1357                 BLI_dynstr_appendf(ds, i ? ", %.4f" : "%.4f", self->vec[i]);
1358         }
1359
1360         BLI_dynstr_append(ds, ")>");
1361
1362         return mathutils_dynstr_to_py(ds); /* frees ds */
1363 }
1364 #endif
1365
1366 /* Sequence Protocol */
1367 /* sequence length len(vector) */
1368 static int Vector_len(VectorObject *self)
1369 {
1370         return self->size;
1371 }
1372 /* sequence accessor (get): vector[index] */
1373 static PyObject *vector_item_internal(VectorObject *self, int i, const bool is_attr)
1374 {
1375         if (i < 0) i = self->size - i;
1376
1377         if (i < 0 || i >= self->size) {
1378                 if (is_attr) {
1379                         PyErr_Format(PyExc_AttributeError,
1380                                      "Vector.%c: unavailable on %dd vector",
1381                                      *(((char *)"xyzw") + i), self->size);
1382                 }
1383                 else {
1384                         PyErr_SetString(PyExc_IndexError,
1385                                         "vector[index]: out of range");
1386                 }
1387                 return NULL;
1388         }
1389
1390         if (BaseMath_ReadIndexCallback(self, i) == -1)
1391                 return NULL;
1392
1393         return PyFloat_FromDouble(self->vec[i]);
1394 }
1395
1396 static PyObject *Vector_item(VectorObject *self, int i)
1397 {
1398         return vector_item_internal(self, i, false);
1399 }
1400 /* sequence accessor (set): vector[index] = value */
1401 static int vector_ass_item_internal(VectorObject *self, int i, PyObject *value, const bool is_attr)
1402 {
1403         float scalar;
1404
1405         if (BaseMath_Prepare_ForWrite(self) == -1)
1406                 return -1;
1407
1408         if ((scalar = PyFloat_AsDouble(value)) == -1.0f && PyErr_Occurred()) { /* parsed item not a number */
1409                 PyErr_SetString(PyExc_TypeError,
1410                                 "vector[index] = x: "
1411                                 "assigned value not a number");
1412                 return -1;
1413         }
1414
1415         if (i < 0) i = self->size - i;
1416
1417         if (i < 0 || i >= self->size) {
1418                 if (is_attr) {
1419                         PyErr_Format(PyExc_AttributeError,
1420                                      "Vector.%c = x: unavailable on %dd vector",
1421                                      *(((char *)"xyzw") + i), self->size);
1422                 }
1423                 else {
1424                         PyErr_SetString(PyExc_IndexError,
1425                                         "vector[index] = x: "
1426                                         "assignment index out of range");
1427                 }
1428                 return -1;
1429         }
1430         self->vec[i] = scalar;
1431
1432         if (BaseMath_WriteIndexCallback(self, i) == -1)
1433                 return -1;
1434         return 0;
1435 }
1436
1437 static int Vector_ass_item(VectorObject *self, int i, PyObject *value)
1438 {
1439         return vector_ass_item_internal(self, i, value, false);
1440 }
1441
1442 /* sequence slice (get): vector[a:b] */
1443 static PyObject *Vector_slice(VectorObject *self, int begin, int end)
1444 {
1445         PyObject *tuple;
1446         int count;
1447
1448         if (BaseMath_ReadCallback(self) == -1)
1449                 return NULL;
1450
1451         CLAMP(begin, 0, self->size);
1452         if (end < 0) end = self->size + end + 1;
1453         CLAMP(end, 0, self->size);
1454         begin = MIN2(begin, end);
1455
1456         tuple = PyTuple_New(end - begin);
1457         for (count = begin; count < end; count++) {
1458                 PyTuple_SET_ITEM(tuple, count - begin, PyFloat_FromDouble(self->vec[count]));
1459         }
1460
1461         return tuple;
1462 }
1463 /* sequence slice (set): vector[a:b] = value */
1464 static int Vector_ass_slice(VectorObject *self, int begin, int end, PyObject *seq)
1465 {
1466         int size = 0;
1467         float *vec = NULL;
1468
1469         if (BaseMath_ReadCallback_ForWrite(self) == -1)
1470                 return -1;
1471
1472         CLAMP(begin, 0, self->size);
1473         CLAMP(end, 0, self->size);
1474         begin = MIN2(begin, end);
1475
1476         size = (end - begin);
1477         if (mathutils_array_parse_alloc(&vec, size, seq, "vector[begin:end] = [...]") == -1) {
1478                 return -1;
1479         }
1480
1481         if (vec == NULL) {
1482                 PyErr_SetString(PyExc_MemoryError,
1483                                 "vec[:] = seq: "
1484                                 "problem allocating pointer space");
1485                 return -1;
1486         }
1487
1488         /*parsed well - now set in vector*/
1489         memcpy(self->vec + begin, vec, size * sizeof(float));
1490
1491         PyMem_Free(vec);
1492
1493         if (BaseMath_WriteCallback(self) == -1)
1494                 return -1;
1495
1496         return 0;
1497 }
1498
1499 /* Numeric Protocols */
1500 /* addition: obj + obj */
1501 static PyObject *Vector_add(PyObject *v1, PyObject *v2)
1502 {
1503         VectorObject *vec1 = NULL, *vec2 = NULL;
1504         float *vec = NULL;
1505
1506         if (!VectorObject_Check(v1) || !VectorObject_Check(v2)) {
1507                 PyErr_Format(PyExc_AttributeError,
1508                              "Vector addition: (%s + %s) "
1509                              "invalid type for this operation",
1510                              Py_TYPE(v1)->tp_name, Py_TYPE(v2)->tp_name);
1511                 return NULL;
1512         }
1513         vec1 = (VectorObject *)v1;
1514         vec2 = (VectorObject *)v2;
1515
1516         if (BaseMath_ReadCallback(vec1) == -1 || BaseMath_ReadCallback(vec2) == -1)
1517                 return NULL;
1518
1519         /*VECTOR + VECTOR*/
1520         if (vec1->size != vec2->size) {
1521                 PyErr_SetString(PyExc_AttributeError,
1522                                 "Vector addition: "
1523                                 "vectors must have the same dimensions for this operation");
1524                 return NULL;
1525         }
1526
1527         vec = PyMem_Malloc(vec1->size * sizeof(float));
1528         if (vec == NULL) {
1529                 PyErr_SetString(PyExc_MemoryError,
1530                                 "Vector(): "
1531                                 "problem allocating pointer space");
1532                 return NULL;
1533         }
1534
1535         add_vn_vnvn(vec, vec1->vec, vec2->vec, vec1->size);
1536
1537         return Vector_CreatePyObject_alloc(vec, vec1->size, Py_TYPE(v1));
1538 }
1539
1540 /* addition in-place: obj += obj */
1541 static PyObject *Vector_iadd(PyObject *v1, PyObject *v2)
1542 {
1543         VectorObject *vec1 = NULL, *vec2 = NULL;
1544
1545         if (!VectorObject_Check(v1) || !VectorObject_Check(v2)) {
1546                 PyErr_Format(PyExc_AttributeError,
1547                              "Vector addition: (%s += %s) "
1548                              "invalid type for this operation",
1549                              Py_TYPE(v1)->tp_name, Py_TYPE(v2)->tp_name);
1550                 return NULL;
1551         }
1552         vec1 = (VectorObject *)v1;
1553         vec2 = (VectorObject *)v2;
1554
1555         if (vec1->size != vec2->size) {
1556                 PyErr_SetString(PyExc_AttributeError,
1557                                 "Vector addition: "
1558                                 "vectors must have the same dimensions for this operation");
1559                 return NULL;
1560         }
1561
1562         if (BaseMath_ReadCallback_ForWrite(vec1) == -1 || BaseMath_ReadCallback(vec2) == -1)
1563                 return NULL;
1564
1565         add_vn_vn(vec1->vec, vec2->vec, vec1->size);
1566
1567         (void)BaseMath_WriteCallback(vec1);
1568         Py_INCREF(v1);
1569         return v1;
1570 }
1571
1572 /* subtraction: obj - obj */
1573 static PyObject *Vector_sub(PyObject *v1, PyObject *v2)
1574 {
1575         VectorObject *vec1 = NULL, *vec2 = NULL;
1576         float *vec;
1577
1578         if (!VectorObject_Check(v1) || !VectorObject_Check(v2)) {
1579                 PyErr_Format(PyExc_AttributeError,
1580                              "Vector subtraction: (%s - %s) "
1581                              "invalid type for this operation",
1582                              Py_TYPE(v1)->tp_name, Py_TYPE(v2)->tp_name);
1583                 return NULL;
1584         }
1585         vec1 = (VectorObject *)v1;
1586         vec2 = (VectorObject *)v2;
1587
1588         if (BaseMath_ReadCallback(vec1) == -1 || BaseMath_ReadCallback(vec2) == -1)
1589                 return NULL;
1590
1591         if (vec1->size != vec2->size) {
1592                 PyErr_SetString(PyExc_AttributeError,
1593                                 "Vector subtraction: "
1594                                 "vectors must have the same dimensions for this operation");
1595                 return NULL;
1596         }
1597
1598         vec = PyMem_Malloc(vec1->size * sizeof(float));
1599         if (vec == NULL) {
1600                 PyErr_SetString(PyExc_MemoryError,
1601                                 "Vector(): "
1602                                 "problem allocating pointer space");
1603                 return NULL;
1604         }
1605
1606         sub_vn_vnvn(vec, vec1->vec, vec2->vec, vec1->size);
1607
1608         return Vector_CreatePyObject_alloc(vec, vec1->size, Py_TYPE(v1));
1609 }
1610
1611 /* subtraction in-place: obj -= obj */
1612 static PyObject *Vector_isub(PyObject *v1, PyObject *v2)
1613 {
1614         VectorObject *vec1 = NULL, *vec2 = NULL;
1615
1616         if (!VectorObject_Check(v1) || !VectorObject_Check(v2)) {
1617                 PyErr_Format(PyExc_AttributeError,
1618                              "Vector subtraction: (%s -= %s) "
1619                              "invalid type for this operation",
1620                              Py_TYPE(v1)->tp_name, Py_TYPE(v2)->tp_name);
1621                 return NULL;
1622         }
1623         vec1 = (VectorObject *)v1;
1624         vec2 = (VectorObject *)v2;
1625
1626         if (vec1->size != vec2->size) {
1627                 PyErr_SetString(PyExc_AttributeError,
1628                                 "Vector subtraction: "
1629                                 "vectors must have the same dimensions for this operation");
1630                 return NULL;
1631         }
1632
1633         if (BaseMath_ReadCallback_ForWrite(vec1) == -1 || BaseMath_ReadCallback(vec2) == -1)
1634                 return NULL;
1635
1636         sub_vn_vn(vec1->vec, vec2->vec, vec1->size);
1637
1638         (void)BaseMath_WriteCallback(vec1);
1639         Py_INCREF(v1);
1640         return v1;
1641 }
1642
1643 /*------------------------obj * obj------------------------------
1644  * multiplication */
1645
1646
1647 /* COLUMN VECTOR Multiplication (Matrix X Vector)
1648  * [1][4][7]   [a]
1649  * [2][5][8] * [b]
1650  * [3][6][9]   [c]
1651  *
1652  * note: vector/matrix multiplication IS NOT COMMUTATIVE!!!!
1653  * note: assume read callbacks have been done first.
1654  */
1655 int column_vector_multiplication(float r_vec[MAX_DIMENSIONS], VectorObject *vec, MatrixObject *mat)
1656 {
1657         float vec_cpy[MAX_DIMENSIONS];
1658         int row, col, z = 0;
1659
1660         if (mat->num_col != vec->size) {
1661                 if (mat->num_col == 4 && vec->size == 3) {
1662                         vec_cpy[3] = 1.0f;
1663                 }
1664                 else {
1665                         PyErr_SetString(PyExc_ValueError,
1666                                         "matrix * vector: "
1667                                         "len(matrix.col) and len(vector) must be the same, "
1668                                         "except for 4x4 matrix * 3D vector.");
1669                         return -1;
1670                 }
1671         }
1672
1673         memcpy(vec_cpy, vec->vec, vec->size * sizeof(float));
1674
1675         r_vec[3] = 1.0f;
1676
1677         for (row = 0; row < mat->num_row; row++) {
1678                 double dot = 0.0f;
1679                 for (col = 0; col < mat->num_col; col++) {
1680                         dot += (double)(MATRIX_ITEM(mat, row, col) * vec_cpy[col]);
1681                 }
1682                 r_vec[z++] = (float)dot;
1683         }
1684
1685         return 0;
1686 }
1687
1688 static PyObject *vector_mul_float(VectorObject *vec, const float scalar)
1689 {
1690         float *tvec = PyMem_Malloc(vec->size * sizeof(float));
1691         if (tvec == NULL) {
1692                 PyErr_SetString(PyExc_MemoryError,
1693                                 "vec * float: "
1694                                 "problem allocating pointer space");
1695                 return NULL;
1696         }
1697
1698         mul_vn_vn_fl(tvec, vec->vec, vec->size, scalar);
1699         return Vector_CreatePyObject_alloc(tvec, vec->size, Py_TYPE(vec));
1700 }
1701
1702 static PyObject *Vector_mul(PyObject *v1, PyObject *v2)
1703 {
1704         VectorObject *vec1 = NULL, *vec2 = NULL;
1705         float scalar;
1706         int vec_size;
1707
1708         if (VectorObject_Check(v1)) {
1709                 vec1 = (VectorObject *)v1;
1710                 if (BaseMath_ReadCallback(vec1) == -1)
1711                         return NULL;
1712         }
1713         if (VectorObject_Check(v2)) {
1714                 vec2 = (VectorObject *)v2;
1715                 if (BaseMath_ReadCallback(vec2) == -1)
1716                         return NULL;
1717         }
1718
1719
1720         /* make sure v1 is always the vector */
1721         if (vec1 && vec2) {
1722                 if (vec1->size != vec2->size) {
1723                         PyErr_SetString(PyExc_ValueError,
1724                                         "Vector multiplication: "
1725                                         "vectors must have the same dimensions for this operation");
1726                         return NULL;
1727                 }
1728
1729                 /*dot product*/
1730                 return PyFloat_FromDouble(dot_vn_vn(vec1->vec, vec2->vec, vec1->size));
1731         }
1732         else if (vec1) {
1733                 if (MatrixObject_Check(v2)) {
1734                         /* VEC * MATRIX */
1735                         float tvec[MAX_DIMENSIONS];
1736
1737                         if (BaseMath_ReadCallback((MatrixObject *)v2) == -1)
1738                                 return NULL;
1739                         if (row_vector_multiplication(tvec, vec1, (MatrixObject *)v2) == -1) {
1740                                 return NULL;
1741                         }
1742
1743                         if (((MatrixObject *)v2)->num_row == 4 && vec1->size == 3) {
1744                                 vec_size = 3;
1745                         }
1746                         else {
1747                                 vec_size = ((MatrixObject *)v2)->num_col;
1748                         }
1749
1750                         return Vector_CreatePyObject(tvec, vec_size, Py_TYPE(vec1));
1751                 }
1752                 else if (((scalar = PyFloat_AsDouble(v2)) == -1.0f && PyErr_Occurred()) == 0) { /* VEC * FLOAT */
1753                         return vector_mul_float(vec1, scalar);
1754                 }
1755         }
1756         else if (vec2) {
1757                 if (((scalar = PyFloat_AsDouble(v1)) == -1.0f && PyErr_Occurred()) == 0) { /* FLOAT * VEC */
1758                         return vector_mul_float(vec2, scalar);
1759                 }
1760         }
1761         else {
1762                 BLI_assert(!"internal error");
1763         }
1764
1765         PyErr_Format(PyExc_TypeError,
1766                      "Vector multiplication: "
1767                      "not supported between '%.200s' and '%.200s' types",
1768                      Py_TYPE(v1)->tp_name, Py_TYPE(v2)->tp_name);
1769         return NULL;
1770 }
1771
1772 /* multiplication in-place: obj *= obj */
1773 static PyObject *Vector_imul(PyObject *v1, PyObject *v2)
1774 {
1775         VectorObject *vec = (VectorObject *)v1;
1776         float scalar;
1777
1778         if (BaseMath_ReadCallback_ForWrite(vec) == -1)
1779                 return NULL;
1780
1781         /* only support vec*=float and vec*=mat
1782          *  vec*=vec result is a float so that wont work */
1783         if (((scalar = PyFloat_AsDouble(v2)) == -1.0f && PyErr_Occurred()) == 0) { /* VEC *= FLOAT */
1784                 mul_vn_fl(vec->vec, vec->size, scalar);
1785         }
1786         else {
1787                 PyErr_Format(PyExc_TypeError,
1788                              "Vector multiplication: (%s *= %s) "
1789                              "invalid type for this operation",
1790                              Py_TYPE(v1)->tp_name, Py_TYPE(v2)->tp_name);
1791                 return NULL;
1792         }
1793
1794         (void)BaseMath_WriteCallback(vec);
1795         Py_INCREF(v1);
1796         return v1;
1797 }
1798
1799 /* divid: obj / obj */
1800 static PyObject *Vector_div(PyObject *v1, PyObject *v2)
1801 {
1802         float *vec = NULL, scalar;
1803         VectorObject *vec1 = NULL;
1804
1805         if (!VectorObject_Check(v1)) { /* not a vector */
1806                 PyErr_SetString(PyExc_TypeError,
1807                                 "Vector division: "
1808                                 "Vector must be divided by a float");
1809                 return NULL;
1810         }
1811         vec1 = (VectorObject *)v1; /* vector */
1812
1813         if (BaseMath_ReadCallback(vec1) == -1)
1814                 return NULL;
1815
1816         if ((scalar = PyFloat_AsDouble(v2)) == -1.0f && PyErr_Occurred()) { /* parsed item not a number */
1817                 PyErr_SetString(PyExc_TypeError,
1818                                 "Vector division: "
1819                                 "Vector must be divided by a float");
1820                 return NULL;
1821         }
1822
1823         if (scalar == 0.0f) {
1824                 PyErr_SetString(PyExc_ZeroDivisionError,
1825                                 "Vector division: "
1826                                 "divide by zero error");
1827                 return NULL;
1828         }
1829
1830         vec = PyMem_Malloc(vec1->size * sizeof(float));
1831
1832         if (vec == NULL) {
1833                 PyErr_SetString(PyExc_MemoryError,
1834                                 "vec / value: "
1835                                 "problem allocating pointer space");
1836                 return NULL;
1837         }
1838
1839         mul_vn_vn_fl(vec, vec1->vec, vec1->size, 1.0f / scalar);
1840
1841         return Vector_CreatePyObject_alloc(vec, vec1->size, Py_TYPE(v1));
1842 }
1843
1844 /* divide in-place: obj /= obj */
1845 static PyObject *Vector_idiv(PyObject *v1, PyObject *v2)
1846 {
1847         float scalar;
1848         VectorObject *vec1 = (VectorObject *)v1;
1849
1850         if (BaseMath_ReadCallback_ForWrite(vec1) == -1)
1851                 return NULL;
1852
1853         if ((scalar = PyFloat_AsDouble(v2)) == -1.0f && PyErr_Occurred()) { /* parsed item not a number */
1854                 PyErr_SetString(PyExc_TypeError,
1855                                 "Vector division: "
1856                                 "Vector must be divided by a float");
1857                 return NULL;
1858         }
1859
1860         if (scalar == 0.0f) {
1861                 PyErr_SetString(PyExc_ZeroDivisionError,
1862                                 "Vector division: "
1863                                 "divide by zero error");
1864                 return NULL;
1865         }
1866
1867         mul_vn_fl(vec1->vec, vec1->size, 1.0f / scalar);
1868
1869         (void)BaseMath_WriteCallback(vec1);
1870
1871         Py_INCREF(v1);
1872         return v1;
1873 }
1874
1875 /* -obj
1876  * returns the negative of this object*/
1877 static PyObject *Vector_neg(VectorObject *self)
1878 {
1879         float *tvec;
1880
1881         if (BaseMath_ReadCallback(self) == -1)
1882                 return NULL;
1883
1884         tvec = PyMem_Malloc(self->size * sizeof(float));
1885         negate_vn_vn(tvec, self->vec, self->size);
1886         return Vector_CreatePyObject_alloc(tvec, self->size, Py_TYPE(self));
1887 }
1888
1889 /*------------------------tp_richcmpr
1890  * returns -1 exception, 0 false, 1 true */
1891 static PyObject *Vector_richcmpr(PyObject *objectA, PyObject *objectB, int comparison_type)
1892 {
1893         VectorObject *vecA = NULL, *vecB = NULL;
1894         int result = 0;
1895         double epsilon = 0.000001f;
1896         double lenA, lenB;
1897
1898         if (!VectorObject_Check(objectA) || !VectorObject_Check(objectB)) {
1899                 if (comparison_type == Py_NE) {
1900                         Py_RETURN_TRUE;
1901                 }
1902                 else {
1903                         Py_RETURN_FALSE;
1904                 }
1905         }
1906         vecA = (VectorObject *)objectA;
1907         vecB = (VectorObject *)objectB;
1908
1909         if (BaseMath_ReadCallback(vecA) == -1 || BaseMath_ReadCallback(vecB) == -1)
1910                 return NULL;
1911
1912         if (vecA->size != vecB->size) {
1913                 if (comparison_type == Py_NE) {
1914                         Py_RETURN_TRUE;
1915                 }
1916                 else {
1917                         Py_RETURN_FALSE;
1918                 }
1919         }
1920
1921         switch (comparison_type) {
1922                 case Py_LT:
1923                         lenA = len_squared_vn(vecA->vec, vecA->size);
1924                         lenB = len_squared_vn(vecB->vec, vecB->size);
1925                         if (lenA < lenB) {
1926                                 result = 1;
1927                         }
1928                         break;
1929                 case Py_LE:
1930                         lenA = len_squared_vn(vecA->vec, vecA->size);
1931                         lenB = len_squared_vn(vecB->vec, vecB->size);
1932                         if (lenA < lenB) {
1933                                 result = 1;
1934                         }
1935                         else {
1936                                 result = (((lenA + epsilon) > lenB) && ((lenA - epsilon) < lenB));
1937                         }
1938                         break;
1939                 case Py_EQ:
1940                         result = EXPP_VectorsAreEqual(vecA->vec, vecB->vec, vecA->size, 1);
1941                         break;
1942                 case Py_NE:
1943                         result = !EXPP_VectorsAreEqual(vecA->vec, vecB->vec, vecA->size, 1);
1944                         break;
1945                 case Py_GT:
1946                         lenA = len_squared_vn(vecA->vec, vecA->size);
1947                         lenB = len_squared_vn(vecB->vec, vecB->size);
1948                         if (lenA > lenB) {
1949                                 result = 1;
1950                         }
1951                         break;
1952                 case Py_GE:
1953                         lenA = len_squared_vn(vecA->vec, vecA->size);
1954                         lenB = len_squared_vn(vecB->vec, vecB->size);
1955                         if (lenA > lenB) {
1956                                 result = 1;
1957                         }
1958                         else {
1959                                 result = (((lenA + epsilon) > lenB) && ((lenA - epsilon) < lenB));
1960                         }
1961                         break;
1962                 default:
1963                         printf("The result of the comparison could not be evaluated");
1964                         break;
1965         }
1966         if (result == 1) {
1967                 Py_RETURN_TRUE;
1968         }
1969         else {
1970                 Py_RETURN_FALSE;
1971         }
1972 }
1973
1974 static Py_hash_t Vector_hash(VectorObject *self)
1975 {
1976         if (BaseMath_ReadCallback(self) == -1)
1977                 return -1;
1978
1979         if (BaseMathObject_Prepare_ForHash(self) == -1)
1980                 return -1;
1981
1982         return mathutils_array_hash(self->vec, self->size);
1983 }
1984
1985 /*-----------------PROTCOL DECLARATIONS--------------------------*/
1986 static PySequenceMethods Vector_SeqMethods = {
1987         (lenfunc) Vector_len,               /* sq_length */
1988         (binaryfunc) NULL,                  /* sq_concat */
1989         (ssizeargfunc) NULL,                /* sq_repeat */
1990         (ssizeargfunc) Vector_item,         /* sq_item */
1991         NULL,                               /* py3 deprecated slice func */
1992         (ssizeobjargproc) Vector_ass_item,  /* sq_ass_item */
1993         NULL,                               /* py3 deprecated slice assign func */
1994         (objobjproc) NULL,                  /* sq_contains */
1995         (binaryfunc) NULL,                  /* sq_inplace_concat */
1996         (ssizeargfunc) NULL,                /* sq_inplace_repeat */
1997 };
1998
1999 static PyObject *Vector_subscript(VectorObject *self, PyObject *item)
2000 {
2001         if (PyIndex_Check(item)) {
2002                 Py_ssize_t i;
2003                 i = PyNumber_AsSsize_t(item, PyExc_IndexError);
2004                 if (i == -1 && PyErr_Occurred())
2005                         return NULL;
2006                 if (i < 0)
2007                         i += self->size;
2008                 return Vector_item(self, i);
2009         }
2010         else if (PySlice_Check(item)) {
2011                 Py_ssize_t start, stop, step, slicelength;
2012
2013                 if (PySlice_GetIndicesEx(item, self->size, &start, &stop, &step, &slicelength) < 0)
2014                         return NULL;
2015
2016                 if (slicelength <= 0) {
2017                         return PyTuple_New(0);
2018                 }
2019                 else if (step == 1) {
2020                         return Vector_slice(self, start, stop);
2021                 }
2022                 else {
2023                         PyErr_SetString(PyExc_IndexError,
2024                                         "slice steps not supported with vectors");
2025                         return NULL;
2026                 }
2027         }
2028         else {
2029                 PyErr_Format(PyExc_TypeError,
2030                              "vector indices must be integers, not %.200s",
2031                              Py_TYPE(item)->tp_name);
2032                 return NULL;
2033         }
2034 }
2035
2036 static int Vector_ass_subscript(VectorObject *self, PyObject *item, PyObject *value)
2037 {
2038         if (PyIndex_Check(item)) {
2039                 Py_ssize_t i = PyNumber_AsSsize_t(item, PyExc_IndexError);
2040                 if (i == -1 && PyErr_Occurred())
2041                         return -1;
2042                 if (i < 0)
2043                         i += self->size;
2044                 return Vector_ass_item(self, i, value);
2045         }
2046         else if (PySlice_Check(item)) {
2047                 Py_ssize_t start, stop, step, slicelength;
2048
2049                 if (PySlice_GetIndicesEx(item, self->size, &start, &stop, &step, &slicelength) < 0)
2050                         return -1;
2051
2052                 if (step == 1)
2053                         return Vector_ass_slice(self, start, stop, value);
2054                 else {
2055                         PyErr_SetString(PyExc_IndexError,
2056                                         "slice steps not supported with vectors");
2057                         return -1;
2058                 }
2059         }
2060         else {
2061                 PyErr_Format(PyExc_TypeError,
2062                              "vector indices must be integers, not %.200s",
2063                              Py_TYPE(item)->tp_name);
2064                 return -1;
2065         }
2066 }
2067
2068 static PyMappingMethods Vector_AsMapping = {
2069         (lenfunc)Vector_len,
2070         (binaryfunc)Vector_subscript,
2071         (objobjargproc)Vector_ass_subscript
2072 };
2073
2074
2075 static PyNumberMethods Vector_NumMethods = {
2076         (binaryfunc)    Vector_add, /*nb_add*/
2077         (binaryfunc)    Vector_sub, /*nb_subtract*/
2078         (binaryfunc)    Vector_mul, /*nb_multiply*/
2079         NULL,                       /*nb_remainder*/
2080         NULL,                       /*nb_divmod*/
2081         NULL,                       /*nb_power*/
2082         (unaryfunc)     Vector_neg, /*nb_negative*/
2083         (unaryfunc)     Vector_copy,/*tp_positive*/
2084         (unaryfunc)     NULL,       /*tp_absolute*/
2085         (inquiry)   NULL,           /*tp_bool*/
2086         (unaryfunc) NULL,           /*nb_invert*/
2087         NULL,                       /*nb_lshift*/
2088         (binaryfunc)NULL,           /*nb_rshift*/
2089         NULL,                       /*nb_and*/
2090         NULL,                       /*nb_xor*/
2091         NULL,                       /*nb_or*/
2092         NULL,                       /*nb_int*/
2093         NULL,                       /*nb_reserved*/
2094         NULL,                       /*nb_float*/
2095         Vector_iadd,                /* nb_inplace_add */
2096         Vector_isub,                /* nb_inplace_subtract */
2097         Vector_imul,                /* nb_inplace_multiply */
2098         NULL,                       /* nb_inplace_remainder */
2099         NULL,                       /* nb_inplace_power */
2100         NULL,                       /* nb_inplace_lshift */
2101         NULL,                       /* nb_inplace_rshift */
2102         NULL,                       /* nb_inplace_and */
2103         NULL,                       /* nb_inplace_xor */
2104         NULL,                       /* nb_inplace_or */
2105         NULL,                       /* nb_floor_divide */
2106         Vector_div,                 /* nb_true_divide */
2107         NULL,                       /* nb_inplace_floor_divide */
2108         Vector_idiv,                /* nb_inplace_true_divide */
2109         NULL,                       /* nb_index */
2110 };
2111
2112 /*------------------PY_OBECT DEFINITION--------------------------*/
2113
2114 /* vector axis, vector.x/y/z/w */
2115
2116 PyDoc_STRVAR(Vector_axis_x_doc, "Vector X axis.\n\n:type: float");
2117 PyDoc_STRVAR(Vector_axis_y_doc, "Vector Y axis.\n\n:type: float");
2118 PyDoc_STRVAR(Vector_axis_z_doc, "Vector Z axis (3D Vectors only).\n\n:type: float");
2119 PyDoc_STRVAR(Vector_axis_w_doc, "Vector W axis (4D Vectors only).\n\n:type: float");
2120
2121 static PyObject *Vector_axis_get(VectorObject *self, void *type)
2122 {
2123         return vector_item_internal(self, GET_INT_FROM_POINTER(type), true);
2124 }
2125
2126 static int Vector_axis_set(VectorObject *self, PyObject *value, void *type)
2127 {
2128         return vector_ass_item_internal(self, GET_INT_FROM_POINTER(type), value, true);
2129 }
2130
2131 /* vector.length */
2132
2133 PyDoc_STRVAR(Vector_length_doc,
2134 "Vector Length.\n\n:type: float"
2135 );
2136 static PyObject *Vector_length_get(VectorObject *self, void *UNUSED(closure))
2137 {
2138         if (BaseMath_ReadCallback(self) == -1)
2139                 return NULL;
2140
2141         return PyFloat_FromDouble(sqrt(dot_vn_vn(self->vec, self->vec, self->size)));
2142 }
2143
2144 static int Vector_length_set(VectorObject *self, PyObject *value)
2145 {
2146         double dot = 0.0f, param;
2147
2148         if (BaseMath_ReadCallback_ForWrite(self) == -1)
2149                 return -1;
2150
2151         if ((param = PyFloat_AsDouble(value)) == -1.0 && PyErr_Occurred()) {
2152                 PyErr_SetString(PyExc_TypeError,
2153                                 "length must be set to a number");
2154                 return -1;
2155         }
2156
2157         if (param < 0.0) {
2158                 PyErr_SetString(PyExc_ValueError,
2159                                 "cannot set a vectors length to a negative value");
2160                 return -1;
2161         }
2162         if (param == 0.0) {
2163                 copy_vn_fl(self->vec, self->size, 0.0f);
2164                 return 0;
2165         }
2166
2167         dot = dot_vn_vn(self->vec, self->vec, self->size);
2168
2169         if (!dot) /* cant sqrt zero */
2170                 return 0;
2171
2172         dot = sqrt(dot);
2173
2174         if (dot == param)
2175                 return 0;
2176
2177         dot = dot / param;
2178
2179         mul_vn_fl(self->vec, self->size, 1.0 / dot);
2180
2181         (void)BaseMath_WriteCallback(self); /* checked already */
2182
2183         return 0;
2184 }
2185
2186 /* vector.length_squared */
2187 PyDoc_STRVAR(Vector_length_squared_doc,
2188 "Vector length squared (v.dot(v)).\n\n:type: float"
2189 );
2190 static PyObject *Vector_length_squared_get(VectorObject *self, void *UNUSED(closure))
2191 {
2192         if (BaseMath_ReadCallback(self) == -1)
2193                 return NULL;
2194
2195         return PyFloat_FromDouble(dot_vn_vn(self->vec, self->vec, self->size));
2196 }
2197
2198 /* Get a new Vector according to the provided swizzle. This function has little
2199  * error checking, as we are in control of the inputs: the closure is set by us
2200  * in Vector_createSwizzleGetSeter. */
2201 static PyObject *Vector_swizzle_get(VectorObject *self, void *closure)
2202 {
2203         size_t axis_to;
2204         size_t axis_from;
2205         float vec[MAX_DIMENSIONS];
2206         unsigned int swizzleClosure;
2207
2208         if (BaseMath_ReadCallback(self) == -1)
2209                 return NULL;
2210
2211         /* Unpack the axes from the closure into an array. */
2212         axis_to = 0;
2213         swizzleClosure = GET_INT_FROM_POINTER(closure);
2214         while (swizzleClosure & SWIZZLE_VALID_AXIS) {
2215                 axis_from = swizzleClosure & SWIZZLE_AXIS;
2216                 if (axis_from >= self->size) {
2217                         PyErr_SetString(PyExc_AttributeError,
2218                                         "Vector swizzle: "
2219                                         "specified axis not present");
2220                         return NULL;
2221                 }
2222
2223                 vec[axis_to] = self->vec[axis_from];
2224                 swizzleClosure = swizzleClosure >> SWIZZLE_BITS_PER_AXIS;
2225                 axis_to++;
2226         }
2227
2228         return Vector_CreatePyObject(vec, axis_to, Py_TYPE(self));
2229 }
2230
2231 /* Set the items of this vector using a swizzle.
2232  * - If value is a vector or list this operates like an array copy, except that
2233  *   the destination is effectively re-ordered as defined by the swizzle. At
2234  *   most min(len(source), len(dest)) values will be copied.
2235  * - If the value is scalar, it is copied to all axes listed in the swizzle.
2236  * - If an axis appears more than once in the swizzle, the final occurrence is
2237  *   the one that determines its value.
2238  *
2239  * Returns 0 on success and -1 on failure. On failure, the vector will be
2240  * unchanged. */
2241 static int Vector_swizzle_set(VectorObject *self, PyObject *value, void *closure)
2242 {
2243         size_t size_from;
2244         float scalarVal;
2245
2246         size_t axis_from;
2247         size_t axis_to;
2248
2249         unsigned int swizzleClosure;
2250
2251         float tvec[MAX_DIMENSIONS];
2252         float vec_assign[MAX_DIMENSIONS];
2253
2254         if (BaseMath_ReadCallback_ForWrite(self) == -1)
2255                 return -1;
2256
2257         /* Check that the closure can be used with this vector: even 2D vectors have
2258          * swizzles defined for axes z and w, but they would be invalid. */
2259         swizzleClosure = GET_INT_FROM_POINTER(closure);
2260         axis_from = 0;
2261
2262         while (swizzleClosure & SWIZZLE_VALID_AXIS) {
2263                 axis_to = swizzleClosure & SWIZZLE_AXIS;
2264                 if (axis_to >= self->size) {
2265                         PyErr_SetString(PyExc_AttributeError,
2266                                         "Vector swizzle: "
2267                                         "specified axis not present");
2268                         return -1;
2269                 }
2270                 swizzleClosure = swizzleClosure >> SWIZZLE_BITS_PER_AXIS;
2271                 axis_from++;
2272         }
2273
2274         if (((scalarVal = PyFloat_AsDouble(value)) == -1 && PyErr_Occurred()) == 0) {
2275                 int i;
2276
2277                 for (i = 0; i < MAX_DIMENSIONS; i++) {
2278                         vec_assign[i] = scalarVal;
2279                 }
2280
2281                 size_from = axis_from;
2282         }
2283         else if ((PyErr_Clear()), /* run but ignore the result */
2284                  (size_from = mathutils_array_parse(vec_assign, 2, 4, value,
2285                                                     "mathutils.Vector.**** = swizzle assignment")) == -1)
2286         {
2287                 return -1;
2288         }
2289
2290         if (axis_from != size_from) {
2291                 PyErr_SetString(PyExc_AttributeError,
2292                                 "Vector swizzle: size does not match swizzle");
2293                 return -1;
2294         }
2295
2296         /* Copy vector contents onto swizzled axes. */
2297         axis_from = 0;
2298         swizzleClosure = GET_INT_FROM_POINTER(closure);
2299
2300         /* We must first copy current vec into tvec, else some org values may be lost.
2301          * See [#31760].
2302          * Assuming self->size can't be higher than MAX_DIMENSIONS! */
2303         memcpy(tvec, self->vec, self->size * sizeof(float));
2304
2305         while (swizzleClosure & SWIZZLE_VALID_AXIS) {
2306                 axis_to = swizzleClosure & SWIZZLE_AXIS;
2307                 tvec[axis_to] = vec_assign[axis_from];
2308                 swizzleClosure = swizzleClosure >> SWIZZLE_BITS_PER_AXIS;
2309                 axis_from++;
2310         }
2311
2312         /* We must copy back the whole tvec into vec, else some changes may be lost (e.g. xz...).
2313          * See [#31760]. */
2314         memcpy(self->vec, tvec, self->size * sizeof(float));
2315         /* continue with BaseMathObject_WriteCallback at the end */
2316
2317         if (BaseMath_WriteCallback(self) == -1)
2318                 return -1;
2319         else
2320                 return 0;
2321 }
2322
2323 /*****************************************************************************/
2324 /* Python attributes get/set structure:                                      */
2325 /*****************************************************************************/
2326 static PyGetSetDef Vector_getseters[] = {
2327         {(char *)"x", (getter)Vector_axis_get, (setter)Vector_axis_set, Vector_axis_x_doc, (void *)0},
2328         {(char *)"y", (getter)Vector_axis_get, (setter)Vector_axis_set, Vector_axis_y_doc, (void *)1},
2329         {(char *)"z", (getter)Vector_axis_get, (setter)Vector_axis_set, Vector_axis_z_doc, (void *)2},
2330         {(char *)"w", (getter)Vector_axis_get, (setter)Vector_axis_set, Vector_axis_w_doc, (void *)3},
2331         {(char *)"length", (getter)Vector_length_get, (setter)Vector_length_set, Vector_length_doc, NULL},
2332         {(char *)"length_squared", (getter)Vector_length_squared_get, (setter)NULL, Vector_length_squared_doc, NULL},
2333         {(char *)"magnitude", (getter)Vector_length_get, (setter)Vector_length_set, Vector_length_doc, NULL},
2334         {(char *)"is_wrapped", (getter)BaseMathObject_is_wrapped_get, (setter)NULL, BaseMathObject_is_wrapped_doc, NULL},
2335         {(char *)"is_frozen",  (getter)BaseMathObject_is_frozen_get,  (setter)NULL, BaseMathObject_is_frozen_doc, NULL},
2336         {(char *)"owner", (getter)BaseMathObject_owner_get, (setter)NULL, BaseMathObject_owner_doc, NULL},
2337
2338         /* autogenerated swizzle attrs, see python script below */
2339         {(char *)"xx",   (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 36
2340         {(char *)"xxx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 292
2341         {(char *)"xxxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2340
2342         {(char *)"xxxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2852
2343         {(char *)"xxxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3364
2344         {(char *)"xxxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3876
2345         {(char *)"xxy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 356
2346         {(char *)"xxyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2404
2347         {(char *)"xxyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2916
2348         {(char *)"xxyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3428
2349         {(char *)"xxyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3940
2350         {(char *)"xxz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 420
2351         {(char *)"xxzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2468
2352         {(char *)"xxzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2980
2353         {(char *)"xxzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3492
2354         {(char *)"xxzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4004
2355         {(char *)"xxw",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 484
2356         {(char *)"xxwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2532
2357         {(char *)"xxwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3044
2358         {(char *)"xxwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3556
2359         {(char *)"xxww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4068
2360         {(char *)"xy",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 44
2361         {(char *)"xyx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 300
2362         {(char *)"xyxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2348
2363         {(char *)"xyxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2860
2364         {(char *)"xyxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3372
2365         {(char *)"xyxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3884
2366         {(char *)"xyy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 364
2367         {(char *)"xyyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2412
2368         {(char *)"xyyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2924
2369         {(char *)"xyyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3436
2370         {(char *)"xyyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3948
2371         {(char *)"xyz",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 428
2372         {(char *)"xyzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2476
2373         {(char *)"xyzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2988
2374         {(char *)"xyzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3500
2375         {(char *)"xyzw", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4012
2376         {(char *)"xyw",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 492
2377         {(char *)"xywx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2540
2378         {(char *)"xywy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3052
2379         {(char *)"xywz", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3564
2380         {(char *)"xyww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4076
2381         {(char *)"xz",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 52
2382         {(char *)"xzx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 308
2383         {(char *)"xzxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2356
2384         {(char *)"xzxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2868
2385         {(char *)"xzxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3380
2386         {(char *)"xzxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3892
2387         {(char *)"xzy",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 372
2388         {(char *)"xzyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2420
2389         {(char *)"xzyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2932
2390         {(char *)"xzyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3444
2391         {(char *)"xzyw", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3956
2392         {(char *)"xzz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 436
2393         {(char *)"xzzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2484
2394         {(char *)"xzzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2996
2395         {(char *)"xzzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3508
2396         {(char *)"xzzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4020
2397         {(char *)"xzw",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 500
2398         {(char *)"xzwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2548
2399         {(char *)"xzwy", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3060
2400         {(char *)"xzwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3572
2401         {(char *)"xzww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4084
2402         {(char *)"xw",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 60
2403         {(char *)"xwx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 316
2404         {(char *)"xwxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2364
2405         {(char *)"xwxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2876
2406         {(char *)"xwxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3388
2407         {(char *)"xwxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3900
2408         {(char *)"xwy",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 380
2409         {(char *)"xwyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2428
2410         {(char *)"xwyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2940
2411         {(char *)"xwyz", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3452
2412         {(char *)"xwyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3964
2413         {(char *)"xwz",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 444
2414         {(char *)"xwzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2492
2415         {(char *)"xwzy", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3004
2416         {(char *)"xwzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3516
2417         {(char *)"xwzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4028
2418         {(char *)"xww",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 508
2419         {(char *)"xwwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2556
2420         {(char *)"xwwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3068
2421         {(char *)"xwwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3580
2422         {(char *)"xwww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((0 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4092
2423         {(char *)"yx",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 37
2424         {(char *)"yxx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 293
2425         {(char *)"yxxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2341
2426         {(char *)"yxxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2853
2427         {(char *)"yxxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3365
2428         {(char *)"yxxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3877
2429         {(char *)"yxy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 357
2430         {(char *)"yxyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2405
2431         {(char *)"yxyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2917
2432         {(char *)"yxyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3429
2433         {(char *)"yxyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3941
2434         {(char *)"yxz",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 421
2435         {(char *)"yxzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2469
2436         {(char *)"yxzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2981
2437         {(char *)"yxzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3493
2438         {(char *)"yxzw", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4005
2439         {(char *)"yxw",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 485
2440         {(char *)"yxwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2533
2441         {(char *)"yxwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3045
2442         {(char *)"yxwz", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3557
2443         {(char *)"yxww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4069
2444         {(char *)"yy",   (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 45
2445         {(char *)"yyx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 301
2446         {(char *)"yyxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2349
2447         {(char *)"yyxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2861
2448         {(char *)"yyxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3373
2449         {(char *)"yyxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3885
2450         {(char *)"yyy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 365
2451         {(char *)"yyyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2413
2452         {(char *)"yyyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2925
2453         {(char *)"yyyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3437
2454         {(char *)"yyyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3949
2455         {(char *)"yyz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 429
2456         {(char *)"yyzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2477
2457         {(char *)"yyzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2989
2458         {(char *)"yyzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3501
2459         {(char *)"yyzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4013
2460         {(char *)"yyw",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 493
2461         {(char *)"yywx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2541
2462         {(char *)"yywy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3053
2463         {(char *)"yywz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3565
2464         {(char *)"yyww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4077
2465         {(char *)"yz",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 53
2466         {(char *)"yzx",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 309
2467         {(char *)"yzxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2357
2468         {(char *)"yzxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2869
2469         {(char *)"yzxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3381
2470         {(char *)"yzxw", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3893
2471         {(char *)"yzy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 373
2472         {(char *)"yzyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2421
2473         {(char *)"yzyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2933
2474         {(char *)"yzyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3445
2475         {(char *)"yzyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3957
2476         {(char *)"yzz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 437
2477         {(char *)"yzzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2485
2478         {(char *)"yzzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2997
2479         {(char *)"yzzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3509
2480         {(char *)"yzzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4021
2481         {(char *)"yzw",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 501
2482         {(char *)"yzwx", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2549
2483         {(char *)"yzwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3061
2484         {(char *)"yzwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3573
2485         {(char *)"yzww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4085
2486         {(char *)"yw",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 61
2487         {(char *)"ywx",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 317
2488         {(char *)"ywxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2365
2489         {(char *)"ywxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2877
2490         {(char *)"ywxz", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3389
2491         {(char *)"ywxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3901
2492         {(char *)"ywy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 381
2493         {(char *)"ywyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2429
2494         {(char *)"ywyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2941
2495         {(char *)"ywyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3453
2496         {(char *)"ywyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3965
2497         {(char *)"ywz",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 445
2498         {(char *)"ywzx", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2493
2499         {(char *)"ywzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3005
2500         {(char *)"ywzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3517
2501         {(char *)"ywzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4029
2502         {(char *)"yww",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 509
2503         {(char *)"ywwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2557
2504         {(char *)"ywwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3069
2505         {(char *)"ywwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3581
2506         {(char *)"ywww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((1 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4093
2507         {(char *)"zx",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 38
2508         {(char *)"zxx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 294
2509         {(char *)"zxxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2342
2510         {(char *)"zxxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2854
2511         {(char *)"zxxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3366
2512         {(char *)"zxxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3878
2513         {(char *)"zxy",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 358
2514         {(char *)"zxyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2406
2515         {(char *)"zxyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2918
2516         {(char *)"zxyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3430
2517         {(char *)"zxyw", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3942
2518         {(char *)"zxz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 422
2519         {(char *)"zxzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2470
2520         {(char *)"zxzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2982
2521         {(char *)"zxzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3494
2522         {(char *)"zxzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4006
2523         {(char *)"zxw",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 486
2524         {(char *)"zxwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2534
2525         {(char *)"zxwy", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3046
2526         {(char *)"zxwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3558
2527         {(char *)"zxww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4070
2528         {(char *)"zy",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 46
2529         {(char *)"zyx",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 302
2530         {(char *)"zyxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2350
2531         {(char *)"zyxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2862
2532         {(char *)"zyxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3374
2533         {(char *)"zyxw", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3886
2534         {(char *)"zyy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 366
2535         {(char *)"zyyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2414
2536         {(char *)"zyyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2926
2537         {(char *)"zyyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3438
2538         {(char *)"zyyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3950
2539         {(char *)"zyz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 430
2540         {(char *)"zyzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2478
2541         {(char *)"zyzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2990
2542         {(char *)"zyzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3502
2543         {(char *)"zyzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4014
2544         {(char *)"zyw",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 494
2545         {(char *)"zywx", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2542
2546         {(char *)"zywy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3054
2547         {(char *)"zywz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3566
2548         {(char *)"zyww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4078
2549         {(char *)"zz",   (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 54
2550         {(char *)"zzx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 310
2551         {(char *)"zzxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2358
2552         {(char *)"zzxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2870
2553         {(char *)"zzxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3382
2554         {(char *)"zzxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3894
2555         {(char *)"zzy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 374
2556         {(char *)"zzyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2422
2557         {(char *)"zzyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2934
2558         {(char *)"zzyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3446
2559         {(char *)"zzyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3958
2560         {(char *)"zzz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 438
2561         {(char *)"zzzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2486
2562         {(char *)"zzzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2998
2563         {(char *)"zzzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3510
2564         {(char *)"zzzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4022
2565         {(char *)"zzw",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 502
2566         {(char *)"zzwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2550
2567         {(char *)"zzwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3062
2568         {(char *)"zzwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3574
2569         {(char *)"zzww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4086
2570         {(char *)"zw",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 62
2571         {(char *)"zwx",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 318
2572         {(char *)"zwxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2366
2573         {(char *)"zwxy", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2878
2574         {(char *)"zwxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3390
2575         {(char *)"zwxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3902
2576         {(char *)"zwy",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 382
2577         {(char *)"zwyx", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2430
2578         {(char *)"zwyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2942
2579         {(char *)"zwyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3454
2580         {(char *)"zwyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3966
2581         {(char *)"zwz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 446
2582         {(char *)"zwzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2494
2583         {(char *)"zwzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3006
2584         {(char *)"zwzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3518
2585         {(char *)"zwzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4030
2586         {(char *)"zww",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 510
2587         {(char *)"zwwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2558
2588         {(char *)"zwwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3070
2589         {(char *)"zwwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3582
2590         {(char *)"zwww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((2 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4094
2591         {(char *)"wx",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 39
2592         {(char *)"wxx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 295
2593         {(char *)"wxxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2343
2594         {(char *)"wxxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2855
2595         {(char *)"wxxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3367
2596         {(char *)"wxxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3879
2597         {(char *)"wxy",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 359
2598         {(char *)"wxyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2407
2599         {(char *)"wxyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2919
2600         {(char *)"wxyz", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3431
2601         {(char *)"wxyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3943
2602         {(char *)"wxz",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 423
2603         {(char *)"wxzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2471
2604         {(char *)"wxzy", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2983
2605         {(char *)"wxzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3495
2606         {(char *)"wxzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4007
2607         {(char *)"wxw",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 487
2608         {(char *)"wxwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2535
2609         {(char *)"wxwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3047
2610         {(char *)"wxwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3559
2611         {(char *)"wxww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4071
2612         {(char *)"wy",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 47
2613         {(char *)"wyx",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 303
2614         {(char *)"wyxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2351
2615         {(char *)"wyxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2863
2616         {(char *)"wyxz", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3375
2617         {(char *)"wyxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3887
2618         {(char *)"wyy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 367
2619         {(char *)"wyyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2415
2620         {(char *)"wyyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2927
2621         {(char *)"wyyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3439
2622         {(char *)"wyyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3951
2623         {(char *)"wyz",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 431
2624         {(char *)"wyzx", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2479
2625         {(char *)"wyzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2991
2626         {(char *)"wyzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3503
2627         {(char *)"wyzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4015
2628         {(char *)"wyw",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 495
2629         {(char *)"wywx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2543
2630         {(char *)"wywy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3055
2631         {(char *)"wywz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3567
2632         {(char *)"wyww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4079
2633         {(char *)"wz",   (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 55
2634         {(char *)"wzx",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 311
2635         {(char *)"wzxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2359
2636         {(char *)"wzxy", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2871
2637         {(char *)"wzxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3383
2638         {(char *)"wzxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3895
2639         {(char *)"wzy",  (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 375
2640         {(char *)"wzyx", (getter)Vector_swizzle_get, (setter)Vector_swizzle_set, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2423
2641         {(char *)"wzyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2935
2642         {(char *)"wzyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3447
2643         {(char *)"wzyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3959
2644         {(char *)"wzz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 439
2645         {(char *)"wzzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2487
2646         {(char *)"wzzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2999
2647         {(char *)"wzzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3511
2648         {(char *)"wzzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4023
2649         {(char *)"wzw",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 503
2650         {(char *)"wzwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2551
2651         {(char *)"wzwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3063
2652         {(char *)"wzwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3575
2653         {(char *)"wzww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4087
2654         {(char *)"ww",   (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS)))}, // 63
2655         {(char *)"wwx",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 319
2656         {(char *)"wwxx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2367
2657         {(char *)"wwxy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2879
2658         {(char *)"wwxz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3391
2659         {(char *)"wwxw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3903
2660         {(char *)"wwy",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 383
2661         {(char *)"wwyx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2431
2662         {(char *)"wwyy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2943
2663         {(char *)"wwyz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3455
2664         {(char *)"wwyw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3967
2665         {(char *)"wwz",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 447
2666         {(char *)"wwzx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2495
2667         {(char *)"wwzy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3007
2668         {(char *)"wwzz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3519
2669         {(char *)"wwzw", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4031
2670         {(char *)"www",  (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2))))}, // 511
2671         {(char *)"wwwx", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((0 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 2559
2672         {(char *)"wwwy", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((1 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3071
2673         {(char *)"wwwz", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((2 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 3583
2674         {(char *)"wwww", (getter)Vector_swizzle_get, (setter)NULL, NULL, SET_INT_IN_POINTER(((3 | SWIZZLE_VALID_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << SWIZZLE_BITS_PER_AXIS) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((3 | SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 3)))  )}, // 4095
2675         {NULL, NULL, NULL, NULL, NULL}  /* Sentinel */
2676 };
2677
2678 /* Python script used to make swizzle array */
2679 /*
2680 SWIZZLE_BITS_PER_AXIS = 3
2681 SWIZZLE_VALID_AXIS = 0x4
2682
2683 axis_dict = {}
2684 axis_pos = {'x':0, 'y':1, 'z':2, 'w':3}
2685 axises = 'xyzw'
2686 while len(axises) >= 2:
2687
2688         for axis_0 in axises:
2689                 axis_0_pos = axis_pos[axis_0]
2690                 for axis_1 in axises:
2691                         axis_1_pos = axis_pos[axis_1]
2692                         axis_dict[axis_0 + axis_1] = '((%s|SWIZZLE_VALID_AXIS) | ((%s|SWIZZLE_VALID_AXIS)<<SWIZZLE_BITS_PER_AXIS))' % (axis_0_pos, axis_1_pos)
2693                         if len(axises)>2:
2694                                 for axis_2 in axises:
2695                                         axis_2_pos = axis_pos[axis_2]
2696                                         axis_dict[axis_0 + axis_1 + axis_2] = '((%s|SWIZZLE_VALID_AXIS) | ((%s|SWIZZLE_VALID_AXIS)<<SWIZZLE_BITS_PER_AXIS) | ((%s|SWIZZLE_VALID_AXIS)<<(SWIZZLE_BITS_PER_AXIS * 2)))' % (axis_0_pos, axis_1_pos, axis_2_pos)
2697                                         if len(axises)>3:
2698                                                 for axis_3 in axises:
2699                                                         axis_3_pos = axis_pos[axis_3]
2700                                                         axis_dict[axis_0 + axis_1 + axis_2 + axis_3] = '((%s|SWIZZLE_VALID_AXIS) | ((%s|SWIZZLE_VALID_AXIS)<<SWIZZLE_BITS_PER_AXIS) | ((%s|SWIZZLE_VALID_AXIS) << (SWIZZLE_BITS_PER_AXIS * 2)) | ((%s|SWIZZLE_VALID_AXIS)<<(SWIZZLE_BITS_PER_AXIS * 3)))  ' % (axis_0_pos, axis_1_pos, axis_2_pos, axis_3_pos)
2701
2702         axises = axises[:-1]
2703
2704
2705 items = axis_dict.items()
2706 items.sort(key = lambda a: a[0].replace('x', '0').replace('y', '1').replace('z', '2').replace('w', '3'))
2707
2708 unique = set()
2709 for key, val in items:
2710         num = eval(val)
2711         set_str = 'Vector_setSwizzle' if (len(set(key)) == len(key)) else 'NULL'
2712         print '\t{"%s", %s(getter)Vector_getSwizzle, (setter)%s, NULL, SET_INT_IN_POINTER(%s)}, // %s' % (key, (' '*(4 - len(key))), set_str, axis_dict[key], num)
2713         unique.add(num)
2714
2715 if len(unique) != len(items):
2716         print "ERROR"
2717 */
2718
2719 /* ROW VECTOR Multiplication - Vector X Matrix
2720  * [x][y][z] * [1][4][7]
2721  *             [2][5][8]
2722  *             [3][6][9]
2723  * vector/matrix multiplication IS NOT COMMUTATIVE!!!! */
2724 static int row_vector_multiplication(float r_vec[MAX_DIMENSIONS], VectorObject *vec, MatrixObject *mat)
2725 {
2726         float vec_cpy[MAX_DIMENSIONS];
2727         int row, col, z = 0, vec_size = vec->size;
2728
2729         if (mat->num_row != vec_size) {
2730                 if (mat->num_row == 4 && vec_size == 3) {
2731                         vec_cpy[3] = 1.0f;
2732                 }
2733                 else {
2734                         PyErr_SetString(PyExc_ValueError,
2735                                         "vector * matrix: matrix column size "
2736                                         "and the vector size must be the same");
2737                         return -1;
2738                 }
2739         }
2740
2741         if (BaseMath_ReadCallback(vec) == -1 || BaseMath_ReadCallback(mat) == -1)
2742                 return -1;
2743
2744         memcpy(vec_cpy, vec->vec, vec_size * sizeof(float));
2745
2746         r_vec[3] = 1.0f;
2747         /* muliplication */
2748         for (col = 0; col < mat->num_col; col++) {
2749                 double dot = 0.0;
2750                 for (row = 0; row < mat->num_row; row++) {
2751                         dot += (double)(MATRIX_ITEM(mat, row, col) * vec_cpy[row]);
2752                 }
2753                 r_vec[z++] = (float)dot;
2754         }
2755         return 0;
2756 }
2757
2758 /*----------------------------Vector.negate() -------------------- */
2759 PyDoc_STRVAR(Vector_negate_doc,
2760 ".. method:: negate()\n"
2761 "\n"
2762 "   Set all values to their negative.\n"
2763 );
2764 static PyObject *Vector_negate(VectorObject *self)
2765 {
2766         if (BaseMath_ReadCallback(self) == -1)
2767                 return NULL;
2768
2769         negate_vn(self->vec, self->size);
2770
2771         (void)BaseMath_WriteCallback(self);  /* already checked for error */
2772         Py_RETURN_NONE;
2773 }
2774
2775 static struct PyMethodDef Vector_methods[] = {
2776         /* Class Methods */
2777         {"Fill", (PyCFunction) C_Vector_Fill, METH_VARARGS | METH_CLASS, C_Vector_Fill_doc},
2778         {"Range", (PyCFunction) C_Vector_Range, METH_VARARGS | METH_CLASS, C_Vector_Range_doc},
2779         {"Linspace", (PyCFunction) C_Vector_Linspace, METH_VARARGS | METH_CLASS, C_Vector_Linspace_doc},
2780         {"Repeat", (PyCFunction) C_Vector_Repeat, METH_VARARGS | METH_CLASS, C_Vector_Repeat_doc},
2781
2782         /* in place only */
2783         {"zero", (PyCFunction) Vector_zero, METH_NOARGS, Vector_zero_doc},
2784         {"negate", (PyCFunction) Vector_negate, METH_NOARGS, Vector_negate_doc},
2785
2786         /* operate on original or copy */
2787         {"normalize", (PyCFunction) Vector_normalize, METH_NOARGS, Vector_normalize_doc},
2788         {"normalized", (PyCFunction) Vector_normalized, METH_NOARGS, Vector_normalized_doc},
2789
2790         {"resize", (PyCFunction) Vector_resize, METH_O, Vector_resize_doc},
2791         {"resized", (PyCFunction) Vector_resized, METH_O, Vector_resized_doc},
2792         {"to_2d", (PyCFunction) Vector_to_2d, METH_NOARGS, Vector_to_2d_doc},
2793         {"resize_2d", (PyCFunction) Vector_resize_2d, METH_NOARGS, Vector_resize_2d_doc},
2794         {"to_3d", (PyCFunction) Vector_to_3d, METH_NOARGS, Vector_to_3d_doc},
2795         {"resize_3d", (PyCFunction) Vector_resize_3d, METH_NOARGS, Vector_resize_3d_doc},
2796         {"to_4d", (PyCFunction) Vector_to_4d, METH_NOARGS, Vector_to_4d_doc},
2797         {"resize_4d", (PyCFunction) Vector_resize_4d, METH_NOARGS, Vector_resize_4d_doc},
2798         {"to_tuple", (PyCFunction) Vector_to_tuple, METH_VARARGS, Vector_to_tuple_doc},
2799         {"to_track_quat", (PyCFunction) Vector_to_track_quat, METH_VARARGS, Vector_to_track_quat_doc},
2800         {"orthogonal", (PyCFunction) Vector_orthogonal, METH_NOARGS, Vector_orthogonal_doc},
2801
2802         /* operation between 2 or more types  */
2803         {"reflect", (PyCFunction) Vector_reflect, METH_O, Vector_reflect_doc},
2804         {"cross", (PyCFunction) Vector_cross, METH_O, Vector_cross_doc},
2805         {"dot", (PyCFunction)