FineKernelToolKit 4.2.13
読み取り中…
検索中…
一致する文字列を見つけられません
Quaternion.h
[詳解]
1#if !defined(__FK_QUATERNION_HEADER__)
2#define __FK_QUATERNION_HEADER__
3
4#include <FK/Vector.h>
5#include <FK/Angle.h>
6#include <FK/Matrix.h>
7
8namespace FK {
9
11
45 public:
46 double s;
48
50
55
57
71 fk_Quaternion(double s, double x, double y, double z);
72
74
86 fk_Quaternion(const double s, const fk_Vector &v);
87
90
93
95
110
112
129
131
150
152
155
157
168 bool operator ==(const fk_Quaternion &) const;
169
171
182 bool operator !=(const fk_Quaternion &) const;
183
185
188
191
193
209
211
222
224
235
237
248
250
261
263
266
268
271 void init(void);
272
274
289 void set(double s, double x, double y, double z);
290
292
306 void set(double s, const fk_Vector &v);
307
309
329 void setRotate(double theta, double x, double y, double z);
330
332
350 void setRotate(double theta, const fk_Vector &V);
351
353
362 void makeEuler(double h, double p, double b);
363
365
373 void makeEuler(const fk_Angle &angle);
374
376
384 fk_Angle & getEuler(void) const;
385
387
397 double norm(void) const;
398
400
410 double abs(void) const;
411
413
420 bool normalize(void);
421
423
435 void conj(void); // 共役化
436
438
458 bool inverse(void); // 逆元化
459
461
466 fk_Matrix & conv(void) const;
467
469
472
476 friend fk_Quaternion operator *(const fk_Quaternion &, double);
477 friend fk_Quaternion operator *(double, const fk_Quaternion &);
478 friend fk_Quaternion operator /(const fk_Quaternion &, double);
479 friend fk_Vector operator *(const fk_Quaternion &, const fk_Vector &);
480 friend double operator ^(const fk_Quaternion &, const fk_Quaternion &);
481
483 };
484
486
511
513
521
523
531
533
543
545
555
557
565
567
582
584
606 double operator ^(const fk_Quaternion &, const fk_Quaternion &);
607
608#if !defined(FK_OLD_NONSUPPORT) && !defined(FK_DOXYGEN_USER_PROCESS)
609 fk_Quaternion fk_Q_Inter_Linear(const fk_Quaternion &, const fk_Quaternion &, double);
610 fk_Quaternion fk_Q_Inter_Sphere(const fk_Quaternion &, const fk_Quaternion &, double);
611#endif
612
613}
614
615#endif // !__FK_QUATERNION_HEADER__
616
617/****************************************************************************
618 *
619 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
620 *
621 * Redistribution and use in source and binary forms,
622 * with or without modification, are permitted provided that the
623 * following conditions are met:
624 *
625 * - Redistributions of source code must retain the above
626 * copyright notice, this list of conditions and the
627 * following disclaimer.
628 *
629 * - Redistributions in binary form must reproduce the above
630 * copyright notice, this list of conditions and the
631 * following disclaimer in the documentation and/or
632 * other materials provided with the distribution.
633 *
634 * - Neither the name of the copyright holders nor the names
635 * of its contributors may be used to endorse or promote
636 * products derived from this software without specific
637 * prior written permission.
638 *
639 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
640 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
641 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
642 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
643 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
644 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
645 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
646 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
647 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
648 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
649 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
650 * POSSIBILITY OF SUCH DAMAGE.
651 *
652 ****************************************************************************/
653/****************************************************************************
654 *
655 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
656 *
657 * 本ソフトウェアおよびソースコードのライセンスは、基本的に
658 * 「修正 BSD ライセンス」に従います。以下にその詳細を記します。
659 *
660 * ソースコード形式かバイナリ形式か、変更するかしないかを問わず、
661 * 以下の条件を満たす場合に限り、再頒布および使用が許可されます。
662 *
663 * - ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、
664 * および下記免責条項を含めること。
665 *
666 * - バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の
667 * 資料に、上記の著作権表示、本条件一覧、および下記免責条項を
668 * 含めること。
669 *
670 * - 書面による特別の許可なしに、本ソフトウェアから派生した製品の
671 * 宣伝または販売促進に、本ソフトウェアの著作権者の名前または
672 * コントリビューターの名前を使用してはならない。
673 *
674 * 本ソフトウェアは、著作権者およびコントリビューターによって「現
675 * 状のまま」提供されており、明示黙示を問わず、商業的な使用可能性、
676 * および特定の目的に対する適合性に関す暗黙の保証も含め、またそれ
677 * に限定されない、いかなる保証もないものとします。著作権者もコン
678 * トリビューターも、事由のいかんを問わず、損害発生の原因いかんを
679 * 問わず、かつ責任の根拠が契約であるか厳格責任であるか(過失その
680 * 他の)不法行為であるかを問わず、仮にそのような損害が発生する可
681 * 能性を知らされていたとしても、本ソフトウェアの使用によって発生
682 * した(代替品または代用サービスの調達、使用の喪失、データの喪失、
683 * 利益の喪失、業務の中断も含め、またそれに限定されない)直接損害、
684 * 間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害に
685 * ついて、一切責任を負わないものとします。
686 *
687 ****************************************************************************/
オイラー角を表すクラス
Definition Angle.h:21
一般4元正方行列を管理するクラス
Definition Matrix.h:549
四元数(クォータニオン)を管理するクラス
Definition Quaternion.h:44
fk_Quaternion & operator=(const fk_Quaternion &)
単純代入演算子
double abs(void) const
絶対値取得関数
double s
スカラー部
Definition Quaternion.h:46
fk_Quaternion & operator-(void) const
単項マイナス演算子
bool operator==(const fk_Quaternion &) const
同値比較演算子
friend fk_Quaternion operator/(const fk_Quaternion &, double)
四元数スカラー商二項演算子
double norm(void) const
ノルム取得関数
void conj(void)
共役化関数
friend double operator^(const fk_Quaternion &, const fk_Quaternion &)
四元数内積二項演算子
void setRotate(double theta, double x, double y, double z)
回転変換設定関数1
fk_Quaternion(const fk_Quaternion &)
コピーコンストラクタ
friend fk_Quaternion operator+(const fk_Quaternion &, const fk_Quaternion &)
四元数和二項演算子
bool operator!=(const fk_Quaternion &) const
異値比較演算子
fk_Quaternion & operator!(void) const
単項逆元演算子
void makeEuler(double h, double p, double b)
オイラー角変換設定関数1
fk_Quaternion(double s, double x, double y, double z)
コンストラクタ2
fk_Angle & getEuler(void) const
オイラー角取得関数
fk_Quaternion & operator/=(double)
スカラー商代入演算子
fk_Quaternion & operator-=(const fk_Quaternion &)
単項差代入演算子
void makeEuler(const fk_Angle &angle)
オイラー角変換設定関数1
fk_Quaternion(void)
コンストラクタ1
fk_Matrix & conv(void) const
行列変換関数
void set(double s, double x, double y, double z)
成分設定関数1
fk_Quaternion(const double s, const fk_Vector &v)
コンストラクタ3
void init(void)
初期化関数
void set(double s, const fk_Vector &v)
成分設定関数2
void setRotate(double theta, const fk_Vector &V)
回転変換設定関数2
friend fk_Quaternion operator*(const fk_Quaternion &, const fk_Quaternion &)
四元数積二項演算子
fk_Quaternion & operator+=(const fk_Quaternion &)
単項和代入演算子
fk_Quaternion & operator~(void) const
単項共役演算子
fk_Quaternion & operator*=(const fk_Quaternion &)
積代入演算子
fk_Vector v
ベクトル部
Definition Quaternion.h:47
bool inverse(void)
逆元化関数
bool normalize(void)
正規化関数
3次元ベクトルを管理するクラス
Definition Vector.h:45
Fine Kernel Toolkit 名前空間
Definition Angle.h:6
fk_Color operator+(const fk_Color &, const fk_Color &)
色要素和二項演算子
fk_Color operator/(const fk_Color &, double)
実数商二項演算子
fk_Draw operator^(fk_Draw, fk_Draw)
描画モード用ビット XOR 演算子
fk_Color operator-(const fk_Color &, const fk_Color &)
色要素差二項演算子
fk_Color operator*(const fk_Color &, double)
実数倍二項演算子1