Correct comments & some explanation from last commit
[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         /* Intentionally don't support (Quaternion) here, uses reverse order instead. */
1721
1722         /* make sure v1 is always the vector */
1723         if (vec1 && vec2) {
1724                 if (vec1->size != vec2->size) {
1725                         PyErr_SetString(PyExc_ValueError,
1726                                         "Vector multiplication: "
1727                                         "vectors must have the same dimensions for this operation");
1728                         return NULL;
1729                 }
1730
1731                 /*dot product*/
1732                 return PyFloat_FromDouble(dot_vn_vn(vec1->vec, vec2->vec, vec1->size));
1733         }
1734         else if (vec1) {
1735                 if (MatrixObject_Check(v2)) {
1736                         /* VEC * MATRIX */
1737                         float tvec[MAX_DIMENSIONS];
1738
1739                         if (BaseMath_ReadCallback((MatrixObject *)v2) == -1)
1740                                 return NULL;
1741                         if (row_vector_multiplication(tvec, vec1, (MatrixObject *)v2) == -1) {
1742                                 return NULL;
1743                         }
1744
1745                         if (((MatrixObject *)v2)->num_row == 4 && vec1->size == 3) {
1746                                 vec_size = 3;
1747                         }
1748                         else {
1749                                 vec_size = ((MatrixObject *)v2)->num_col;
1750                         }
1751
1752                         return Vector_CreatePyObject(tvec, vec_size, Py_TYPE(vec1));
1753                 }
1754                 else if (((scalar = PyFloat_AsDouble(v2)) == -1.0f && PyErr_Occurred()) == 0) { /* VEC * FLOAT */
1755                         return vector_mul_float(vec1, scalar);
1756                 }
1757         }
1758         else if (vec2) {
1759                 if (((scalar = PyFloat_AsDouble(v1)) == -1.0f && PyErr_Occurred()) == 0) { /* FLOAT * VEC */
1760                         return vector_mul_float(vec2, scalar);
1761                 }
1762         }
1763         else {
1764                 BLI_assert(!"internal error");
1765         }
1766
1767         PyErr_Format(PyExc_TypeError,
1768                      "Vector multiplication: "
1769                      "not supported between '%.200s' and '%.200s' types",
1770                      Py_TYPE(v1)->tp_name, Py_TYPE(v2)->tp_name);
1771         return NULL;
1772 }
1773
1774 /* multiplication in-place: obj *= obj */
1775 static PyObject *Vector_imul(PyObject *v1, PyObject *v2)
1776 {
1777         VectorObject *vec = (VectorObject *)v1;
1778         float scalar;
1779
1780         if (BaseMath_ReadCallback_ForWrite(vec) == -1)
1781                 return NULL;
1782
1783         /* Intentionally don't support (Quaternion, Matrix) here, uses reverse order instead. */
1784
1785         /* only support 'vec *= float'
1786          *  vec*=vec result is a float so that wont work */
1787         if (((scalar = PyFloat_AsDouble(v2)) == -1.0f && PyErr_Occurred()) == 0) { /* VEC *= FLOAT */
1788                 mul_vn_fl(vec->vec, vec->size, scalar);
1789         }
1790         else {
1791                 PyErr_Format(PyExc_TypeError,
1792                              "Vector multiplication: (%s *= %s) "
1793                              "invalid type for this operation",
1794                              Py_TYPE(v1)->tp_name, Py_TYPE(v2)->tp_name);
1795                 return NULL;
1796         }
1797
1798         (void)BaseMath_WriteCallback(vec);
1799         Py_INCREF(v1);
1800         return v1;
1801 }
1802
1803 /* divid: obj / obj */
1804 static PyObject *Vector_div(PyObject *v1, PyObject *v2)
1805 {
1806         float *vec = NULL, scalar;
1807         VectorObject *vec1 = NULL;
1808
1809         if (!VectorObject_Check(v1)) { /* not a vector */
1810                 PyErr_SetString(PyExc_TypeError,
1811                                 "Vector division: "
1812                                 "Vector must be divided by a float");
1813                 return NULL;
1814         }
1815         vec1 = (VectorObject *)v1; /* vector */
1816
1817         if (BaseMath_ReadCallback(vec1) == -1)
1818                 return NULL;
1819
1820         if ((scalar = PyFloat_AsDouble(v2)) == -1.0f && PyErr_Occurred()) { /* parsed item not a number */
1821                 PyErr_SetString(PyExc_TypeError,
1822                                 "Vector division: "
1823                                 "Vector must be divided by a float");
1824                 return NULL;
1825         }
1826
1827         if (scalar == 0.0f) {
1828                 PyErr_SetString(PyExc_ZeroDivisionError,
1829                                 "Vector division: "
1830                                 "divide by zero error");
1831                 return NULL;
1832         }
1833
1834         vec = PyMem_Malloc(vec1->size * sizeof(float));
1835
1836         if (vec == NULL) {
1837                 PyErr_SetString(PyExc_MemoryError,
1838                                 "vec / value: "
1839                                 "problem allocating pointer space");
1840                 return NULL;
1841         }
1842
1843         mul_vn_vn_fl(vec, vec1->vec, vec1->size, 1.0f / scalar);
1844
1845         return Vector_CreatePyObject_alloc(vec, vec1->size, Py_TYPE(v1));
1846 }
1847
1848 /* divide in-place: obj /= obj */
1849 static PyObject *Vector_idiv(PyObject *v1, PyObject *v2)
1850 {
1851         float scalar;
1852         VectorObject *vec1 = (VectorObject *)v1;
1853
1854         if (BaseMath_ReadCallback_ForWrite(vec1) == -1)
1855                 return NULL;
1856
1857         if ((scalar = PyFloat_AsDouble(v2)) == -1.0f && PyErr_Occurred()) { /* parsed item not a number */
1858                 PyErr_SetString(PyExc_TypeError,
1859                                 "Vector division: "
1860                                 "Vector must be divided by a float");
1861                 return NULL;
1862         }
1863
1864         if (scalar == 0.0f) {
1865                 PyErr_SetString(PyExc_ZeroDivisionError,
1866                                 "Vector division: "
1867                                 "divide by zero error");
1868                 return NULL;
1869         }
1870
1871         mul_vn_fl(vec1->vec, vec1->size, 1.0f / scalar);
1872
1873         (void)BaseMath_WriteCallback(vec1);
1874
1875         Py_INCREF(v1);
1876         return v1;
1877 }
1878
1879 /* -obj
1880  * returns the negative of this object*/
1881 static PyObject *Vector_neg(VectorObject *self)
1882 {
1883         float *tvec;
1884
1885         if (BaseMath_ReadCallback(self) == -1)
1886                 return NULL;
1887
1888         tvec = PyMem_Malloc(self->size * sizeof(float));
1889         negate_vn_vn(tvec, self->vec, self->size);
1890         return Vector_CreatePyObject_alloc(tvec, self->size, Py_TYPE(self));
1891 }
1892
1893 /*------------------------tp_richcmpr
1894  * returns -1 exception, 0 false, 1 true */
1895 static PyObject *Vector_richcmpr(PyObject *objectA, PyObject *objectB, int comparison_type)
1896 {
1897         VectorObject *vecA = NULL, *vecB = NULL;
1898         int result = 0;
1899         double epsilon = 0.000001f;
1900         double lenA, lenB;
1901
1902         if (!VectorObject_Check(objectA) || !VectorObject_Check(objectB)) {
1903                 if (comparison_type == Py_NE) {
1904                         Py_RETURN_TRUE;
1905                 }
1906                 else {
1907                         Py_RETURN_FALSE;
1908                 }
1909         }
1910         vecA = (VectorObject *)objectA;
1911         vecB = (VectorObject *)objectB;
1912
1913         if (BaseMath_ReadCallback(vecA) == -1 || BaseMath_ReadCallback(vecB) == -1)
1914                 return NULL;
1915
1916         if (vecA->size != vecB->size) {
1917                 if (comparison_type == Py_NE) {
1918                         Py_RETURN_TRUE;
1919                 }
1920                 else {
1921                         Py_RETURN_FALSE;
1922                 }
1923         }
1924
1925         switch (comparison_type) {
1926                 case Py_LT:
1927                         lenA = len_squared_vn(vecA->vec, vecA->size);
1928                         lenB = len_squared_vn(vecB->vec, vecB->size);
1929                         if (lenA < lenB) {
1930                                 result = 1;
1931                         }
1932                         break;
1933                 case Py_LE:
1934                         lenA = len_squared_vn(vecA->vec, vecA->size);
1935                         lenB = len_squared_vn(vecB->vec, vecB->size);
1936                         if (lenA < lenB) {
1937                                 result = 1;
1938                         }
1939                         else {
1940                                 result = (((lenA + epsilon) > lenB) && ((lenA - epsilon) < lenB));
1941                         }
1942                         break;
1943                 case Py_EQ:
1944                         result = EXPP_VectorsAreEqual(vecA->vec, vecB->vec, vecA->size, 1);
1945                         break;
1946                 case Py_NE:
1947                         result = !EXPP_VectorsAreEqual(vecA->vec, vecB->vec, vecA->size, 1);
1948                         break;
1949                 case Py_GT:
1950                         lenA = len_squared_vn(vecA->vec, vecA->size);
1951                         lenB = len_squared_vn(vecB->vec, vecB->size);
1952                         if (lenA > lenB) {
1953                                 result = 1;
1954                         }
1955                         break;
1956                 case Py_GE:
1957                         lenA = len_squared_vn(vecA->vec, vecA->size);
1958                         lenB = len_squared_vn(vecB->vec, vecB->size);
1959                         if (lenA > lenB) {
1960                                 result = 1;
1961                         }
1962                         else {
1963                                 result = (((lenA + epsilon) > lenB) && ((lenA - epsilon) < lenB));
1964                         }
1965                         break;
1966                 default:
1967                         printf("The result of the comparison could not be evaluated");
1968                         break;
1969         }
1970         if (result == 1) {
1971                 Py_RETURN_TRUE;
1972         }
1973         else {
1974                 Py_RETURN_FALSE;
1975         }
1976 }
1977
1978 static Py_hash_t Vector_hash(VectorObject *self)
1979 {
1980         if (BaseMath_ReadCallback(self) == -1)
1981                 return -1;
1982
1983         if (BaseMathObject_Prepare_ForHash(self) == -1)
1984                 return -1;
1985
1986         return mathutils_array_hash(self->vec, self->size);
1987 }
1988
1989 /*-----------------PROTCOL DECLARATIONS--------------------------*/
1990 static PySequenceMethods Vector_SeqMethods = {
1991         (lenfunc) Vector_len,               /* sq_length */
1992         (binaryfunc) NULL,                  /* sq_concat */
1993         (ssizeargfunc) NULL,                /* sq_repeat */
1994         (ssizeargfunc) Vector_item,         /* sq_item */
1995         NULL,                               /* py3 deprecated slice func */
1996         (ssizeobjargproc) Vector_ass_item,  /* sq_ass_item */
1997         NULL,                               /* py3 deprecated slice assign func */
1998         (objobjproc) NULL,                  /* sq_contains */
1999         (binaryfunc) NULL,                  /* sq_inplace_concat */
2000         (ssizeargfunc) NULL,                /* sq_inplace_repeat */
2001 };
2002
2003 static PyObject *Vector_subscript(VectorObject *self, PyObject *item)
2004 {
2005         if (PyIndex_Check(item)) {
2006                 Py_ssize_t i;
2007                 i = PyNumber_AsSsize_t(item, PyExc_IndexError);
2008                 if (i == -1 && PyErr_Occurred())
2009                         return NULL;
2010                 if (i < 0)
2011                         i += self->size;
2012                 return Vector_item(self, i);
2013         }
2014         else if (PySlice_Check(item)) {
2015                 Py_ssize_t start, stop, step, slicelength;
2016
2017                 if (PySlice_GetIndicesEx(item, self->size, &start, &stop, &step, &slicelength) < 0)
2018                         return NULL;
2019
2020                 if (slicelength <= 0) {
2021                         return PyTuple_New(0);
2022                 }
2023                 else if (step == 1) {
2024                         return Vector_slice(self, start, stop);
2025                 }
2026                 else {
2027                         PyErr_SetString(PyExc_IndexError,
2028                                         "slice steps not supported with vectors");
2029                         return NULL;
2030                 }
2031         }
2032         else {
2033                 PyErr_Format(PyExc_TypeError,
2034                              "vector indices must be integers, not %.200s",
2035                              Py_TYPE(item)->tp_name);
2036                 return NULL;
2037         }
2038 }
2039
2040 static int Vector_ass_subscript(VectorObject *self, PyObject *item, PyObject *value)
2041 {
2042         if (PyIndex_Check(item)) {
2043                 Py_ssize_t i = PyNumber_AsSsize_t(item, PyExc_IndexError);
2044                 if (i == -1 && PyErr_Occurred())
2045                         return -1;
2046                 if (i < 0)
2047                         i += self->size;
2048                 return Vector_ass_item(self, i, value);
2049         }
2050         else if (PySlice_Check(item)) {
2051                 Py_ssize_t start, stop, step, slicelength;
2052
2053                 if (PySlice_GetIndicesEx(item, self->size, &start, &stop, &step, &slicelength) < 0)
2054                         return -1;
2055
2056                 if (step == 1)
2057                         return Vector_ass_slice(self, start, stop, value);
2058                 else {
2059                         PyErr_SetString(PyExc_IndexError,
2060                                         "slice steps not supported with vectors");
2061                         return -1;
2062                 }
2063         }
2064         else {
2065                 PyErr_Format(PyExc_TypeError,
2066                              "vector indices must be integers, not %.200s",
2067                              Py_TYPE(item)->tp_name);
2068                 return -1;
2069         }
2070 }
2071
2072 static PyMappingMethods Vector_AsMapping = {
2073         (lenfunc)Vector_len,
2074         (binaryfunc)Vector_subscript,
2075         (objobjargproc)Vector_ass_subscript
2076 };
2077
2078
2079 static PyNumberMethods Vector_NumMethods = {
2080         (binaryfunc)    Vector_add, /*nb_add*/
2081         (binaryfunc)    Vector_sub, /*nb_subtract*/
2082         (binaryfunc)    Vector_mul, /*nb_multiply*/
2083         NULL,                       /*nb_remainder*/
2084         NULL,                       /*nb_divmod*/
2085         NULL,                       /*nb_power*/
2086         (unaryfunc)     Vector_neg, /*nb_negative*/
2087         (unaryfunc)     Vector_copy,/*tp_positive*/
2088         (unaryfunc)     NULL,       /*tp_absolute*/
2089         (inquiry)   NULL,           /*tp_bool*/
2090         (unaryfunc) NULL,           /*nb_invert*/
2091         NULL,                       /*nb_lshift*/
2092         (binaryfunc)NULL,           /*nb_rshift*/
2093         NULL,                       /*nb_and*/
2094         NULL,                       /*nb_xor*/
2095         NULL,                       /*nb_or*/
2096         NULL,                       /*nb_int*/
2097         NULL,                       /*nb_reserved*/
2098         NULL,                       /*nb_float*/
2099         Vector_iadd,                /* nb_inplace_add */
2100         Vector_isub,                /* nb_inplace_subtract */
2101         Vector_imul,                /* nb_inplace_multiply */
2102         NULL,                       /* nb_inplace_remainder */
2103         NULL,                       /* nb_inplace_power */
2104         NULL,                       /* nb_inplace_lshift */
2105         NULL,                       /* nb_inplace_rshift */
2106         NULL,                       /* nb_inplace_and */
2107         NULL,                       /* nb_inplace_xor */
2108         NULL,                       /* nb_inplace_or */
2109         NULL,                       /* nb_floor_divide */
2110         Vector_div,                 /* nb_true_divide */
2111         NULL,                       /* nb_inplace_floor_divide */
2112         Vector_idiv,                /* nb_inplace_true_divide */
2113         NULL,                       /* nb_index */
2114 };
2115
2116 /*------------------PY_OBECT DEFINITION--------------------------*/
2117
2118 /* vector axis, vector.x/y/z/w */
2119
2120 PyDoc_STRVAR(Vector_axis_x_doc, "Vector X axis.\n\n:type: float");
2121 PyDoc_STRVAR(Vector_axis_y_doc, "Vector Y axis.\n\n:type: float");
2122 PyDoc_STRVAR(Vector_axis_z_doc, "Vector Z axis (3D Vectors only).\n\n:type: float");
2123 PyDoc_STRVAR(Vector_axis_w_doc, "Vector W axis (4D Vectors only).\n\n:type: float");
2124
2125 static PyObject *Vector_axis_get(VectorObject *self, void *type)
2126 {
2127         return vector_item_internal(self, GET_INT_FROM_POINTER(type), true);
2128 }
2129
2130 static int Vector_axis_set(VectorObject *self, PyObject *value, void *type)
2131 {
2132         return vector_ass_item_internal(self, GET_INT_FROM_POINTER(type), value, true);
2133 }
2134
2135 /* vector.length */
2136
2137 PyDoc_STRVAR(Vector_length_doc,
2138 "Vector Length.\n\n:type: float"
2139 );
2140 static PyObject *Vector_length_get(VectorObject *self, void *UNUSED(closure))
2141 {
2142         if (BaseMath_ReadCallback(self) == -1)
2143                 return NULL;
2144
2145         return PyFloat_FromDouble(sqrt(dot_vn_vn(self->vec, self->vec, self->size)));
2146 }
2147
2148 static int Vector_length_set(VectorObject *self, PyObject *value)
2149 {
2150         double dot = 0.0f, param;
2151
2152         if (BaseMath_ReadCallback_ForWrite(self) == -1)
2153                 return -1;
2154
2155         if ((param = PyFloat_AsDouble(value)) == -1.0 && PyErr_Occurred()) {
2156                 PyErr_SetString(PyExc_TypeError,
2157                                 "length must be set to a number");
2158                 return -1;
2159         }
2160
2161         if (param < 0.0) {
2162                 PyErr_SetString(PyExc_ValueError,
2163                                 "cannot set a vectors length to a negative value");
2164                 return -1;
2165         }
2166         if (param == 0.0) {
2167                 copy_vn_fl(self->vec, self->size, 0.0f);
2168                 return 0;
2169         }
2170
2171         dot = dot_vn_vn(self->vec, self->vec, self->size);
2172
2173         if (!dot) /* cant sqrt zero */
2174                 return 0;
2175
2176         dot = sqrt(dot);
2177
2178         if (dot == param)
2179                 return 0;
2180
2181         dot = dot / param;
2182
2183         mul_vn_fl(self->vec, self->size, 1.0 / dot);
2184
2185         (void)BaseMath_WriteCallback(self); /* checked already */
2186
2187         return 0;
2188 }
2189
2190 /* vector.length_squared */
2191 PyDoc_STRVAR(Vector_length_squared_doc,
2192 "Vector length squared (v.dot(v)).\n\n:type: float"
2193 );
2194 static PyObject *Vector_length_squared_get(VectorObject *self, void *UNUSED(closure))
2195 {
2196         if (BaseMath_ReadCallback(self) == -1)
2197                 return NULL;
2198
2199         return PyFloat_FromDouble(dot_vn_vn(self->vec, self->vec, self->size));
2200 }
2201
2202 /* Get a new Vector according to the provided swizzle. This function has little
2203  * error checking, as we are in control of the inputs: the closure is set by us
2204  * in Vector_createSwizzleGetSeter. */
2205 static PyObject *Vector_swizzle_get(VectorObject *self, void *closure)
2206 {
2207         size_t axis_to;
2208         size_t axis_from;
2209         float vec[MAX_DIMENSIONS];
2210         unsigned int swizzleClosure;
2211
2212         if (BaseMath_ReadCallback(self) == -1)
2213                 return NULL;
2214
2215         /* Unpack the axes from the closure into an array. */
2216         axis_to = 0;
2217         swizzleClosure = GET_INT_FROM_POINTER(closure);
2218         while (swizzleClosure & SWIZZLE_VALID_AXIS) {
2219                 axis_from = swizzleClosure & SWIZZLE_AXIS;
2220                 if (axis_from >= self->size) {
2221                         PyErr_SetString(PyExc_AttributeError,
2222                                         "Vector swizzle: "
2223                                         "specified axis not present");
2224                         return NULL;
2225                 }
2226
2227                 vec[axis_to] = self->vec[axis_from];
2228                 swizzleClosure = swizzleClosure >> SWIZZLE_BITS_PER_AXIS;
2229                 axis_to++;
2230         }
2231
2232         return Vector_CreatePyObject(vec, axis_to, Py_TYPE(self));
2233 }
2234
2235 /* Set the items of this vector using a swizzle.
2236  * - If value is a vector or list this operates like an array copy, except that
2237  *   the destination is effectively re-ordered as defined by the swizzle. At
2238  *   most min(len(source), len(dest)) values will be copied.
2239  * - If the value is scalar, it is copied to all axes listed in the swizzle.
2240  * - If an axis appears more than once in the swizzle, the final occurrence is
2241  *   the one that determines its value.
2242  *
2243  * Returns 0 on success and -1 on failure. On failure, the vector will be
2244  * unchanged. */
2245 static int Vector_swizzle_set(VectorObject *self, PyObject *value, void *closure)
2246 {
2247         size_t size_from;
2248         float scalarVal;
2249
2250         size_t axis_from;
2251         size_t axis_to;
2252
2253         unsigned int swizzleClosure;
2254
2255         float tvec[MAX_DIMENSIONS];
2256         float vec_assign[MAX_DIMENSIONS];
2257
2258         if (BaseMath_ReadCallback_ForWrite(self) == -1)
2259                 return -1;
2260
2261         /* Check that the closure can be used with this vector: even 2D vectors have
2262          * swizzles defined for axes z and w, but they would be invalid. */
2263         swizzleClosure = GET_INT_FROM_POINTER(closure);
2264         axis_from = 0;
2265
2266         while (swizzleClosure & SWIZZLE_VALID_AXIS) {
2267                 axis_to = swizzleClosure & SWIZZLE_AXIS;
2268                 if (axis_to >= self->size) {
2269                         PyErr_SetString(PyExc_AttributeError,
2270                                         "Vector swizzle: "
2271                                         "specified axis not present");
2272                         return -1;
2273                 }
2274                 swizzleClosure = swizzleClosure >> SWIZZLE_BITS_PER_AXIS;
2275                 axis_from++;
2276         }
2277
2278         if (((scalarVal = PyFloat_AsDouble(value)) == -1 && PyErr_Occurred()) == 0) {
2279                 int i;
2280
2281                 for (i = 0; i < MAX_DIMENSIONS; i++) {
2282                         vec_assign[i] = scalarVal;
2283                 }
2284
2285                 size_from = axis_from;
2286         }
2287         else if ((PyErr_Clear()), /* run but ignore the result */
2288                  (size_from = mathutils_array_parse(vec_assign, 2, 4, value,
2289                                                     "mathutils.Vector.**** = swizzle assignment")) == -1)
2290         {
2291                 return -1;
2292         }
2293
2294         if (axis_from != size_from) {
2295                 PyErr_SetString(PyExc_AttributeError,
2296                                 "Vector swizzle: size does not match swizzle");
2297                 return -1;
2298         }
2299
2300         /* Copy vector contents onto swizzled axes. */
2301         axis_from = 0;
2302         swizzleClosure = GET_INT_FROM_POINTER(closure);
2303
2304         /* We must first copy current vec into tvec, else some org values may be lost.
2305          * See [#31760].
2306          * Assuming self->size can't be higher than MAX_DIMENSIONS! */
2307         memcpy(tvec, self->vec, self->size * sizeof(float));
2308
2309         while (swizzleClosure & SWIZZLE_VALID_AXIS) {
2310                 axis_to = swizzleClosure & SWIZZLE_AXIS;
2311                 tvec[axis_to] = vec_assign[axis_from];
2312                 swizzleClosure = swizzleClosure >> SWIZZLE_BITS_PER_AXIS;
2313                 axis_from++;
2314         }
2315
2316         /* We must copy back the whole tvec into vec, else some changes may be lost (e.g. xz...).
2317          * See [#31760]. */
2318         memcpy(self->vec, tvec, self->size * sizeof(float));
2319         /* continue with BaseMathObject_WriteCallback at the end */
2320
2321         if (BaseMath_WriteCallback(self) == -1)
2322                 return -1;
2323         else
2324                 return 0;
2325 }
2326
2327 /*****************************************************************************/
2328 /* Python attributes get/set structure:                                      */
2329 /*****************************************************************************/
2330 static PyGetSetDef Vector_getseters[] = {
2331         {(char *)"x", (getter)Vector_axis_get, (setter)Vector_axis_set, Vector_axis_x_doc, (void *)0},
2332         {(char *)"y", (getter)Vector_axis_get, (setter)Vector_axis_set, Vector_axis_y_doc, (void *)1},
2333         {(char *)"z", (getter)Vector_axis_get, (setter)Vector_axis_set, Vector_axis_z_doc, (void *)2},
2334         {(char *)"w", (getter)Vector_axis_get, (setter)Vector_axis_set, Vector_axis_w_doc, (void *)3},
2335         {(char *)"length", (getter)Vector_length_get, (setter)Vector_length_set, Vector_length_doc, NULL},
2336         {(char *)"length_squared", (getter)Vector_length_squared_get, (setter)NULL, Vector_length_squared_doc, NULL},
2337         {(char *)"magnitude", (getter)Vector_length_get, (setter)Vector_length_set, Vector_length_doc, NULL},
2338         {(char *)"is_wrapped", (getter)BaseMathObject_is_wrapped_get, (setter)NULL, BaseMathObject_is_wrapped_doc, NULL},
2339         {(char *)"is_frozen",  (getter)BaseMathObject_is_frozen_get,  (setter)NULL, BaseMathObject_is_frozen_doc, NULL},
2340         {(char *)"owner", (getter)BaseMathObject_owner_get, (setter)NULL, BaseMathObject_owner_doc, NULL},
2341
2342         /* autogenerated swizzle attrs, see python script below */
2343         {(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
2344         {(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
2345         {(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
2346         {(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
2347         {(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
2348         {(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
2349         {(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
2350         {(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
2351         {(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
2352         {(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
2353         {(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
2354         {(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
2355         {(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
2356         {(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
2357         {(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
2358         {(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
2359         {(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
2360         {(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
2361         {(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
2362         {(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
2363         {(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
2364         {(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
2365         {(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
2366         {(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
2367         {(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
2368         {(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
2369         {(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
2370         {(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
2371         {(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
2372         {(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
2373         {(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
2374         {(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
2375         {(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
2376         {(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
2377         {(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
2378         {(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
2379         {(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
2380         {(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
2381         {(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
2382         {(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
2383         {(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
2384         {(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
2385         {(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
2386         {(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
2387         {(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
2388         {(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
2389         {(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
2390         {(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
2391         {(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
2392         {(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
2393         {(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
2394         {(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
2395         {(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
2396         {(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
2397         {(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
2398         {(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
2399         {(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
2400         {(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
2401         {(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
2402         {(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
2403         {(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
2404         {(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
2405         {(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
2406         {(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
2407         {(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
2408         {(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
2409         {(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
2410         {(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
2411         {(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
2412         {(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
2413         {(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
2414         {(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
2415         {(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
2416         {(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
2417         {(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
2418         {(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
2419         {(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
2420         {(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
2421         {(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
2422         {(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
2423         {(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
2424         {(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
2425         {(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
2426         {(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
2427         {(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
2428         {(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
2429         {(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
2430         {(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
2431         {(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
2432         {(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
2433         {(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
2434         {(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
2435         {(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
2436         {(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
2437         {(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
2438         {(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
2439         {(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
2440         {(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
2441         {(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
2442         {(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
2443         {(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
2444         {(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
2445         {(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
2446         {(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
2447         {(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
2448         {(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
2449         {(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
2450         {(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
2451         {(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
2452         {(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
2453         {(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
2454         {(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
2455         {(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
2456         {(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
2457         {(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
2458         {(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
2459         {(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
2460         {(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
2461         {(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
2462         {(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
2463         {(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
2464         {(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
2465         {(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
2466         {(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
2467         {(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
2468         {(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
2469         {(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
2470         {(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
2471         {(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
2472         {(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
2473         {(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
2474         {(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
2475         {(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
2476         {(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
2477         {(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
2478         {(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
2479         {(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
2480         {(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
2481         {(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
2482         {(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
2483         {(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
2484         {(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
2485         {(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
2486         {(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
2487         {(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
2488         {(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
2489         {(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
2490         {(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
2491         {(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
2492         {(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
2493         {(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
2494         {(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
2495         {(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
2496         {(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
2497         {(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
2498         {(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
2499         {(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
2500         {(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
2501         {(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
2502         {(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
2503         {(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
2504         {(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
2505         {(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
2506         {(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
2507         {(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
2508         {(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
2509         {(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
2510         {(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
2511         {(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
2512         {(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
2513         {(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
2514         {(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
2515         {(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
2516         {(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
2517         {(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
2518         {(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
2519         {(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
2520         {(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
2521         {(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
2522         {(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
2523         {(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
2524         {(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
2525         {(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
2526         {(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
2527         {(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
2528         {(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
2529         {(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
2530         {(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
2531         {(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
2532         {(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
2533         {(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
2534         {(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
2535         {(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
2536         {(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
2537         {(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
2538         {(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
2539         {(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
2540         {(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
2541         {(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
2542         {(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
2543         {(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
2544         {(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
2545         {(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
2546         {(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
2547         {(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
2548         {(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
2549         {(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
2550         {(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
2551         {(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
2552         {(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
2553         {(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
2554         {(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
2555         {(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
2556         {(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
2557         {(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
2558         {(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
2559         {(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
2560         {(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
2561         {(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
2562         {(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
2563         {(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
2564         {(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
2565         {(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
2566         {(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
2567         {(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
2568         {(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
2569         {(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
2570         {(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
2571         {(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
2572         {(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
2573         {(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
2574         {(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
2575         {(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
2576         {(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
2577         {(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
2578         {(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
2579         {(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
2580         {(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
2581         {(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
2582         {(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
2583         {(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
2584         {(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
2585         {(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
2586         {(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
2587         {(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
2588         {(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
2589         {(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
2590         {(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
2591         {(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
2592         {(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
2593         {(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
2594         {(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
2595         {(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
2596         {(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
2597         {(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
2598         {(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
2599         {(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
2600         {(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
2601         {(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
2602         {(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
2603         {(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
2604         {(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
2605         {(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
2606         {(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
2607         {(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
2608         {(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
2609         {(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
2610         {(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
2611         {(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
2612         {(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
2613         {(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
2614         {(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
2615         {(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
2616         {(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
2617         {(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
2618         {(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
2619         {(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
2620         {(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
2621         {(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
2622         {(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
2623         {(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
2624         {(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
2625         {(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
2626         {(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
2627         {(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
2628         {(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
2629         {(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
2630         {(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
2631         {(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
2632         {(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
2633         {(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
2634         {(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
2635         {(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
2636         {(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
2637         {(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
2638         {(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
2639         {(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
2640         {(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
2641         {(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
2642         {(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
2643         {(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
2644         {(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
2645         {(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
2646         {(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
2647         {(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
2648         {(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
2649         {(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
2650         {(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
2651         {(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
2652         {(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
2653         {(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
2654         {(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
2655         {(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
2656         {(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
2657         {(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
2658         {(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
2659         {(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
2660         {(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
2661         {(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
2662         {(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
2663         {(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
2664         {(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
2665         {(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
2666         {(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
2667         {(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
2668         {(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
2669         {(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
2670         {(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
2671         {(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
2672         {(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
2673         {(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
2674         {(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
2675         {(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
2676         {(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
2677         {(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
2678         {(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
2679         {NULL, NULL, NULL, NULL, NULL}  /* Sentinel */
2680 };
2681
2682 /* Python script used to make swizzle array */
2683 /*
2684 SWIZZLE_BITS_PER_AXIS = 3
2685 SWIZZLE_VALID_AXIS = 0x4
2686
2687 axis_dict = {}
2688 axis_pos = {'x':0, 'y':1, 'z':2, 'w':3}
2689 axises = 'xyzw'
2690 while len(axises) >= 2:
2691
2692         for axis_0 in axises:
2693                 axis_0_pos = axis_pos[axis_0]
2694                 for axis_1 in axises:
2695                         axis_1_pos = axis_pos[axis_1]
2696                         axis_dict[axis_0 + axis_1] = '((%s|SWIZZLE_VALID_AXIS) | ((%s|SWIZZLE_VALID_AXIS)<<SWIZZLE_BITS_PER_AXIS))' % (axis_0_pos, axis_1_pos)
2697                         if len(axises)>2:
2698                                 for axis_2 in axises:
2699                                         axis_2_pos = axis_pos[axis_2]
2700                                         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)
2701                                         if len(axises)>3:
2702                                                 for axis_3 in axises:
2703                                                         axis_3_pos = axis_pos[axis_3]
2704                                                         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)
2705
2706         axises = axises[:-1]
2707
2708
2709 items = axis_dict.items()
2710 items.sort(key = lambda a: a[0].replace('x', '0').replace('y', '1').replace('z', '2').replace('w', '3'))
2711
2712 unique = set()
2713 for key, val in items:
2714         num = eval(val)
2715         set_str = 'Vector_setSwizzle' if (len(set(key)) == len(key)) else 'NULL'
2716         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)
2717         unique.add(num)
2718
2719 if len(unique) != len(items):
2720         print "ERROR"
2721 */
2722
2723 /* ROW VECTOR Multiplication - Vector X Matrix
2724  * [x][y][z] * [1][4][7]
2725  *             [2][5][8]
2726  *             [3][6][9]
2727  * vector/matrix multiplication IS NOT COMMUTATIVE!!!! */
2728 static int row_vector_multiplication(float r_vec[MAX_DIMENSIONS], VectorObject *vec, MatrixObject *mat)
2729 {
2730         float vec_cpy[MAX_DIMENSIONS];
2731         int row, col, z = 0, vec_size = vec->size;
2732
2733         if (mat->num_row != vec_size) {
2734                 if (mat->num_row == 4 && vec_size == 3) {
2735                         vec_cpy[3] = 1.0f;
2736                 }
2737                 else {
2738                         PyErr_SetString(PyExc_ValueError,
2739                                         "vector * matrix: matrix column size "
2740                                         "and the vector size must be the same");
2741                         return -1;
2742                 }
2743         }
2744
2745         if (BaseMath_ReadCallback(vec) == -1 || BaseMath_ReadCallback(mat) == -1)
2746                 return -1;
2747
2748         memcpy(vec_cpy, vec->vec, vec_size * sizeof(float));
2749
2750         r_vec[3] = 1.0f;
2751         /* muliplication */
2752         for (col = 0; col < mat->num_col; col++) {
2753                 double dot = 0.0;
2754                 for (row = 0; row < mat->num_row; row++) {
2755                         dot += (double)(MATRIX_ITEM(mat, row, col) * vec_cpy[row]);
2756                 }
2757                 r_vec[z++] = (float)dot;
2758         }
2759         return 0;
2760 }
2761
2762 /*----------------------------Vector.negate() -------------------- */
2763 PyDoc_STRVAR(Vector_negate_doc,
2764 ".. method:: negate()\n"
2765 "\n"
2766 "   Set all values to their negative.\n"
2767 );
2768 static PyObject *Vector_negate(VectorObject *self)
2769 {
2770         if (BaseMath_ReadCallback(self) == -1)
2771                 return NULL;
2772
2773         negate_vn(self->vec, self->size);
2774
2775         (void)BaseMath_WriteCallback(self);  /* already checked for error */
2776         Py_RETURN_NONE;
2777 }
2778
2779 static struct PyMethodDef Vector_methods[] = {
2780         /* Class Methods */
2781         {"Fill", (PyCFunction) C_Vector_Fill, METH_VARARGS | METH_CLASS, C_Vector_Fill_doc},
2782         {"Range", (PyCFunction) C_Vector_Range, METH_VARARGS | METH_CLASS, C_Vector_Range_doc},
2783         {"Linspace", (PyCFunction) C_Vector_Linspace, METH_VARARGS | METH_CLASS, C_Vector_Linspace_doc},
2784         {"Repeat", (PyCFunction) C_Vector_Repeat, METH_VARARGS | METH_CLASS, C_Vector_Repeat_doc},
2785
2786         /* in place only */
2787         {"zero", (PyCFunction) Vector_zero, METH_NOARGS, Vector_zero_doc},
2788         {"negate", (PyCFunction) Vector_negate, METH_NOARGS, Vector_negate_doc},
2789
2790         /* operate on original or copy */
2791         {"normalize", (PyCFunction) Vector_normalize, METH_NOARGS, Vector_normalize_doc},
2792         {"normalized", (PyCFunction) Vector_normalized, METH_NOARGS, Vector_normalized_doc},
2793
2794         {"resize", (PyCFunction) Vector_resize, METH_O, Vector_resize_doc},
2795         {"resized", (PyCFunction) Vector_resized, METH_O, Vector_resized_doc},
2796         {"to_2d", (PyCFunction) Vector_to_2d, METH_NOARGS, Vector_to_2d_doc},
2797         {"resize_2d", (PyCFunction) Vector_resize_2d, METH_NOARGS, Vector_resize_2d_doc},
2798         {"to_3d", (PyCFunction) Vector_to_3d, METH_NOARGS, Vector_to_3d_doc},
2799         {"resize_3d", (PyCFunction) Vector_resize_3d, METH_NOARGS, Vector_resize_3d_doc},
2800         {"to_4d", (PyCFunction) Vector_to_4d, METH_NOARGS, Vector_to_4d_doc},
2801         {"resize_4d", (PyCFunction) Vector_resize_4d, METH_NOARGS, Vector_resize_4d_doc},
2802         {"to_tuple", (PyCFunction) Vector_to_tuple, METH_VARARGS, Vector_to_tuple_doc},
2803         {"to_track_quat", (PyCFunction) Vector_to_track_quat, METH_VARARGS, Vector_to_track_quat_doc},
2804         {"orthogonal", (PyCFunction) Vector_orthogonal, METH_NOARGS, Vector_orthogonal_doc},
2805
2806         /* operation between 2 or more types  */
2807         {"reflect", (PyCFunction) Vector_reflect, METH_O, Vector_reflect_doc},
2808         {"cross", (PyCFunction) Vector_cross, METH_O, Vector_cross_doc},
2809         {"dot", (PyCFunction) Vector_dot,&