FineKernelToolKit  2.9.0
 全て クラス ネームスペース ファイル 関数 変数 型定義 列挙型 列挙型の値 フレンド マクロ定義 ページ
GenVector.h
説明を見る。
1 /****************************************************************************
2  *
3  * Copyright (c) 1999-2014, Fine Kernel Project, All rights reserved.
4  *
5  * Redistribution and use in source and binary forms,
6  * with or without modification, are permitted provided that the
7  * following conditions are met:
8  *
9  * - Redistributions of source code must retain the above
10  * copyright notice, this list of conditions and the
11  * following disclaimer.
12  *
13  * - Redistributions in binary form must reproduce the above
14  * copyright notice, this list of conditions and the
15  * following disclaimer in the documentation and/or
16  * other materials provided with the distribution.
17  *
18  * - Neither the name of the copyright holders nor the names
19  * of its contributors may be used to endorse or promote
20  * products derived from this software without specific
21  * prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
26  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
27  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
28  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
29  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
30  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
32  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
33  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34  * POSSIBILITY OF SUCH DAMAGE.
35  *
36  ****************************************************************************/
37 /****************************************************************************
38  *
39  * Copyright (c) 1999-2014, Fine Kernel Project, All rights reserved.
40  *
41  * 本ソフトウェアおよびソースコードのライセンスは、基本的に
42  * 「修正 BSD ライセンス」に従います。以下にその詳細を記します。
43  *
44  * ソースコード形式かバイナリ形式か、変更するかしないかを問わず、
45  * 以下の条件を満たす場合に限り、再頒布および使用が許可されます。
46  *
47  * - ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、
48  * および下記免責条項を含めること。
49  *
50  * - バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の
51  * 資料に、上記の著作権表示、本条件一覧、および下記免責条項を
52  * 含めること。
53  *
54  * - 書面による特別の許可なしに、本ソフトウェアから派生した製品の
55  * 宣伝または販売促進に、本ソフトウェアの著作権者の名前または
56  * コントリビューターの名前を使用してはならない。
57  *
58  * 本ソフトウェアは、著作権者およびコントリビューターによって「現
59  * 状のまま」提供されており、明示黙示を問わず、商業的な使用可能性、
60  * および特定の目的に対する適合性に関す暗黙の保証も含め、またそれ
61  * に限定されない、いかなる保証もないものとします。著作権者もコン
62  * トリビューターも、事由のいかんを問わず、損害発生の原因いかんを
63  * 問わず、かつ責任の根拠が契約であるか厳格責任であるか(過失その
64  * 他の)不法行為であるかを問わず、仮にそのような損害が発生する可
65  * 能性を知らされていたとしても、本ソフトウェアの使用によって発生
66  * した(代替品または代用サービスの調達、使用の喪失、データの喪失、
67  * 利益の喪失、業務の中断も含め、またそれに限定されない)直接損害、
68  * 間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害に
69  * ついて、一切責任を負わないものとします。
70  *
71  ****************************************************************************/
72 #ifndef __FK_GEN_VECTOR_HEADER__
73 #define __FK_GEN_VECTOR_HEADER__
74 
75 #include <FK/Vector.h>
76 
77 class fk_GenMatrix;
78 
80 
90 class fk_GenVector {
91 
92  friend class fk_GenMatrix;
93 
94  private:
95 
96  std::vector<double> v;
97 
98  public:
99 
101 
108  fk_GenVector(int deg = 0);
109 
111 
116  fk_GenVector(std::vector<double> &array);
117 
119 
125  fk_GenVector(int deg, double *array);
126 
128  fk_GenVector(const fk_GenVector &);
129 
131  fk_GenVector(const fk_Vector &);
132 
134  fk_GenVector(const fk_HVector &);
135 
137 
138 
140 
147  fk_GenVector & operator -(void) const;
148 
150 
152 
153 
155 
167  bool operator ==(const fk_GenVector &) const;
168 
170 
182  bool operator !=(const fk_GenVector &) const;
183 
185 
187 
188 
191 
193  fk_GenVector & operator =(const fk_Vector &);
194 
197 
199 
209  fk_GenVector & operator *=(double d);
210 
212 
224  fk_GenVector & operator /=(double);
225 
227 
240 
242 
255 
257 
270 
272 
274 
275 
277 
282  void resize(int deg);
283 
284  // 成分値設定関数
293  bool set(int ID, double value);
294 
296 
300  int size(void) const;
301 
303 
309  double get(int ID) const; // 値取得
310 
312 
323  double norm(void) const;
324 
326 
337  double norm2(void) const;
338 
340 
354  bool normalize(void);
355 
357 
362  void init(bool degFlg = false);
363 
365 
370  bool isZero(void) const;
371 
373 
395  bool replace(int s, fk_GenVector &Q);
396 
398 
420  bool replace(int s, fk_Vector &Q);
421 
423 
445  bool replace(int s, fk_HVector &Q);
446 
448 
470  bool add(int s, fk_GenVector &Q);
471 
473 
495  bool add(int s, fk_Vector &Q);
496 
498 
520  bool add(int s, fk_HVector &Q);
521 
523 
545  bool sub(int s, fk_GenVector &Q);
546 
548 
570  bool sub(int s, fk_Vector &Q);
571 
573 
595  bool sub(int s, fk_HVector &Q);
596 
598 
607  fk_GenVector div(int s, int e);
608 
609 #ifndef FK_DOXYGEN_USER_PROCESS
610 
611  void Print(void) const;
612  void Print(std::string) const;
613 
614 #endif
615 
617 
618  friend double operator *(const fk_GenVector &, const fk_GenVector &);
619  friend fk_GenVector operator +(const fk_GenVector &, const fk_GenVector &);
620  friend fk_GenVector operator -(const fk_GenVector &, const fk_GenVector &);
621  friend fk_GenVector operator *(const fk_GenVector &, double);
622  friend fk_GenVector operator *(double, const fk_GenVector &);
623  friend fk_GenVector operator /(const fk_GenVector &, double);
624  friend fk_GenVector operator ^(const fk_GenVector &, const fk_GenVector &);
626 };
627 
629 
631 
647 double operator *(const fk_GenVector &P, const fk_GenVector &Q);
648 
650 
660 
662 
672 
674 
682 fk_GenVector operator *(const fk_GenVector &V, double d);
683 
685 
693 fk_GenVector operator *(double d, const fk_GenVector &V);
694 
696 
702 fk_GenVector operator /(const fk_GenVector &V, double d);
703 
704 
706 
726 
727 #endif // !__FK_GEN_VECTOR_HEADER__
bool replace(int s, fk_GenVector &Q)
部分置換関数1
friend fk_GenVector operator^(const fk_GenVector &, const fk_GenVector &)
外積二項演算子
void init(bool degFlg=false)
初期化関数
fk_GenVector operator^(const fk_GenVector &P, const fk_GenVector &Q)
外積二項演算子
friend fk_GenVector operator/(const fk_GenVector &, double)
実数商二項演算子
fk_GenMatrix operator-(const fk_GenMatrix &, const fk_GenMatrix &)
行列差二項演算子
fk_GenVector & operator=(const fk_GenVector &)
単純代入演算子
3次元ベクトルを管理するクラス
Definition: Vector.h:110
double norm2(void) const
ノルム平方値取得関数
fk_GenVector operator*(const fk_GenMatrix &, const fk_GenVector &)
ベクトル変換二項演算子
任意次元正方行列を管理するクラス
Definition: GenMatrix.h:88
4次元ベクトルを管理するクラス
Definition: Vector.h:542
bool normalize(void)
正規化関数
bool add(int s, fk_GenVector &Q)
部分加算関数1
friend double operator*(const fk_GenVector &, const fk_GenVector &)
内積二項演算子
bool operator!=(const fk_GenVector &) const
異値比較演算子
bool sub(int s, fk_GenVector &Q)
部分減算関数1
void resize(int deg)
次元数設定関数
friend fk_GenVector operator+(const fk_GenVector &, const fk_GenVector &)
ベクトル和二項演算子
fk_GenVector & operator*=(double d)
実数積演算子
double norm(void) const
ノルム取得関数
fk_GenVector & operator-=(const fk_GenVector &)
単項差代入演算子
fk_GenVector & operator-(void) const
単項マイナス演算子
fk_GenVector & operator+=(const fk_GenVector &)
単項和代入演算子
fk_GenVector operator/(const fk_GenVector &V, double d)
実数商二項演算子
fk_GenMatrix operator+(const fk_GenMatrix &, const fk_GenMatrix &)
行列和二項演算子
fk_GenVector div(int s, int e)
部分抽出関数
bool set(int ID, double value)
fk_GenVector(int deg=0)
コンストラクタ1
bool operator==(const fk_GenVector &) const
同値比較演算子
任意次元ベクトルを管理するクラス
Definition: GenVector.h:90
fk_GenVector & operator/=(double)
実数商代入演算子
bool isZero(void) const
零ベクトル判定関数
int size(void) const
次元数取得関数