FineKernelToolKit 4.2.13
読み取り中…
検索中…
一致する文字列を見つけられません
GenVector_CLI.h
[詳解]
1#pragma once
2
3#include <FK/GenVector.h>
4#include "Matrix_CLI.h"
5
6namespace FK_CLI {
7 using namespace System;
8 using namespace System::Collections::Generic;
9
11
20 public ref class fk_GenVector {
21 internal:
22 ::FK::fk_GenVector *pGVec;
23
24 public:
25
26#if !defined(FK_DOXYGEN_USER_PROCESS)
27 fk_GenVector(::FK::fk_GenVector *argV);
28#endif
30
34
36
42 fk_GenVector(int deg);
43
45
51 fk_GenVector(IEnumerable<double>^ array);
52
55
58
61
64
67
69
71
81
83
92 virtual bool Equals(Object^ O) override;
93
95
97
105
107
123 static double operator*(fk_GenVector^ P, fk_GenVector^ Q);
124
125
127
137
139
149
151
159 static fk_GenVector^ operator*(fk_GenVector^ V1, double d);
160
162
170 static fk_GenVector^ operator*(double d, fk_GenVector^ V1);
171
173
179 static fk_GenVector^ operator/(fk_GenVector^ V1, double d);
180
182
202
203 //代入演算子
204
206
216 static void operator *=(fk_GenVector^ V, double d);
217
219
231 static void operator /=(fk_GenVector^ V, double d);
232
234
246 static void operator +=(fk_GenVector^ V1, fk_GenVector^ V2);
247
249
261 static void operator -=(fk_GenVector^ V1, fk_GenVector^ V2);
262
264
270 property double default[int] {
271 double get(int argID);
272 void set(int argID, double argD);
273 }
274
276
282 property int Size {
283 void set(int);
284 int get();
285 }
286
288
300 property double Norm {
301 double get();
302 }
303
305
317 property double Norm2 {
318 double get();
319 }
320
322
327 String^ ToString() override;
328
330
345 bool Normalize(void);
346
348
355 void Init(bool degFlg);
356
358
362 void Init(void);
363
365
372 bool IsZero(void);
373
375
398 bool Replace(int s, fk_GenVector^ Q);
399
401
424 bool Replace(int s, fk_Vector^ Q);
425
427
450 bool Replace(int s, fk_HVector^ Q);
451
453
476 bool Add(int s, fk_GenVector^ Q);
477
479
502 bool Add(int s, fk_Vector^ Q);
503
505
528 bool Add(int s, fk_HVector^ Q);
529
531
554 bool Sub(int s, fk_GenVector^ Q);
555
557
579 bool Sub(int s, fk_Vector^ Q);
580
582
605 bool Sub(int s, fk_HVector^ Q);
606
608
620 fk_GenVector^ Div(int s, int e);
621 };
622}
623
624/****************************************************************************
625 *
626 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
627 *
628 * Redistribution and use in source and binary forms,
629 * with or without modification, are permitted provided that the
630 * following conditions are met:
631 *
632 * - Redistributions of source code must retain the above
633 * copyright notice, this list of conditions and the
634 * following disclaimer.
635 *
636 * - Redistributions in binary form must reproduce the above
637 * copyright notice, this list of conditions and the
638 * following disclaimer in the documentation and/or
639 * other materials provided with the distribution.
640 *
641 * - Neither the name of the copyright holders nor the names
642 * of its contributors may be used to endorse or promote
643 * products derived from this software without specific
644 * prior written permission.
645 *
646 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
647 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
648 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
649 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
650 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
651 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
652 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
653 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
654 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
655 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
656 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
657 * POSSIBILITY OF SUCH DAMAGE.
658 *
659 ****************************************************************************/
660/****************************************************************************
661 *
662 * Copyright (c) 1999-2024, Fine Kernel Project, All rights reserved.
663 *
664 * 本ソフトウェアおよびソースコードのライセンスは、基本的に
665 * 「修正 BSD ライセンス」に従います。以下にその詳細を記します。
666 *
667 * ソースコード形式かバイナリ形式か、変更するかしないかを問わず、
668 * 以下の条件を満たす場合に限り、再頒布および使用が許可されます。
669 *
670 * - ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、
671 * および下記免責条項を含めること。
672 *
673 * - バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の
674 * 資料に、上記の著作権表示、本条件一覧、および下記免責条項を
675 * 含めること。
676 *
677 * - 書面による特別の許可なしに、本ソフトウェアから派生した製品の
678 * 宣伝または販売促進に、本ソフトウェアの著作権者の名前または
679 * コントリビューターの名前を使用してはならない。
680 *
681 * 本ソフトウェアは、著作権者およびコントリビューターによって「現
682 * 状のまま」提供されており、明示黙示を問わず、商業的な使用可能性、
683 * および特定の目的に対する適合性に関す暗黙の保証も含め、またそれ
684 * に限定されない、いかなる保証もないものとします。著作権者もコン
685 * トリビューターも、事由のいかんを問わず、損害発生の原因いかんを
686 * 問わず、かつ責任の根拠が契約であるか厳格責任であるか(過失その
687 * 他の)不法行為であるかを問わず、仮にそのような損害が発生する可
688 * 能性を知らされていたとしても、本ソフトウェアの使用によって発生
689 * した(代替品または代用サービスの調達、使用の喪失、データの喪失、
690 * 利益の喪失、業務の中断も含め、またそれに限定されない)直接損害、
691 * 間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害に
692 * ついて、一切責任を負わないものとします。
693 *
694 ****************************************************************************/
任意次元ベクトルを管理するクラス
Definition GenVector_CLI.h:20
bool Sub(int s, fk_GenVector^ Q)
部分減算メソッド1
static fk_GenVector ^ operator-(fk_GenVector^ P, fk_GenVector^ Q)
ベクトル差二項演算子
void Init(bool degFlg)
初期化メソッド1
fk_GenVector(fk_GenVector^ GV)
コピーコンストラクタ
static fk_GenVector ^ operator-(fk_GenVector^ argV)
単項マイナス演算子
double Norm2
ノルム2乗プロパティ
Definition GenVector_CLI.h:317
bool Replace(int s, fk_GenVector^ Q)
部分置換メソッド1
fk_GenVector()
コンストラクタ1
static double operator*(fk_GenVector^ P, fk_GenVector^ Q)
内積二項演算子
fk_GenVector(fk_Vector^ V)
fk_Vector からのコピーコンストラクタ
fk_GenVector(IEnumerable< double >^ array)
コンストラクタ3
static fk_GenVector ^ operator^(fk_GenVector^ P, fk_GenVector^ Q)
外積二項演算子
void Init(void)
初期化メソッド2
static fk_GenVector ^ operator/(fk_GenVector^ V1, double d)
実数商二項演算子
bool Add(int s, fk_GenVector^ Q)
部分加算メソッド1
virtual bool Equals(Object^ O) override
同値比較メソッド2
bool Add(int s, fk_Vector^ Q)
部分加算メソッド2
bool Normalize(void)
正規化メソッド
bool Add(int s, fk_HVector^ Q)
部分加算メソッド3
bool Replace(int s, fk_Vector^ Q)
部分置換メソッド2
fk_GenVector(fk_HVector^ H)
fk_HVector からのコピーコンストラクタ
fk_GenVector ^ Div(int s, int e)
部分抽出メソッド
double Norm
ノルムプロパティ
Definition GenVector_CLI.h:300
static void operator*=(fk_GenVector^ V, double d)
実数積演算子
bool Sub(int s, fk_HVector^ Q)
部分減算メソッド3
~fk_GenVector()
デストラクタ
static void operator-=(fk_GenVector^ V1, fk_GenVector^ V2)
単項差代入演算子
bool IsZero(void)
零ベクトル判定メソッド
static void operator/=(fk_GenVector^ V, double d)
実数商代入演算子
static void operator+=(fk_GenVector^ V1, fk_GenVector^ V2)
単項和代入演算子
bool Equals(fk_GenVector^ V)
同値比較メソッド1
static fk_GenVector ^ operator*(double d, fk_GenVector^ V1)
実数倍二項演算子2
bool Sub(int s, fk_Vector^ Q)
部分減算メソッド2
int Size
次元数プロパティ
Definition GenVector_CLI.h:282
bool Replace(int s, fk_HVector^ Q)
部分置換メソッド3
static fk_GenVector ^ operator+(fk_GenVector^ P, fk_GenVector^ Q)
ベクトル和二項演算子
static fk_GenVector ^ operator*(fk_GenVector^ V1, double d)
実数倍二項演算子1
fk_GenVector(int deg)
コンストラクタ2
String ^ ToString() override
文字列出力メソッド
4次元ベクトルを管理するクラス
Definition Vector_CLI.h:465
3次元ベクトルを管理するクラス
Definition Vector_CLI.h:35
Definition AppWindow_CLI.h:11