spLib
|
double型を扱うためのベクトル型です. [詳解]
#include <sp/vector.h>
フィールド | |
long | length |
double * | data |
double * | imag |
関連関数 | |
(これらはメソッドではありません) | |
#define | dvnums(x, length, value) dvinit(x, (double)(value), 0.0, (double)(length)) |
#define | dvzeros(x, length) dvnums(x, length, 0.0) |
#define | dvones(x, length) dvnums(x, length, 1.0) |
#define | dvinums(x, length, value) dviinit(x, (double)(value), 0.0, (double)(length)) |
#define | dvizeros(x, length) dvinums(x, length, 0.0) |
#define | dviones(x, length) dvinums(x, length, 1.0) |
#define | dvrinums(x, length, value) dvriinit(x, (double)(value), 0.0, (double)(length)) |
#define | dvrizeros(x, length) dvrinums(x, length, 0.0) |
#define | dvriones(x, length) dvrinums(x, length, 1.0) |
#define | xdvnums(length, value) xdvinit((double)(value), 0.0, (double)(length)) |
#define | xdvnumsul(plugin, length, value, unlock_flag) xdvinitul(plugin, (double)(value), 0.0, (double)(length), unlock_flag) |
#define | xdvzeros(length) xdvnums(length, 0.0) |
#define | xdvzerosul(plugin, length, unlock_flag) xdvnumsul(plugin, length, 0.0, unlock_flag) |
#define | xdvones(length) xdvnums(length, 1.0) |
#define | xdvonesul(plugin, length, unlock_flag) xdvnumsul(plugin, length, 1.0, unlock_flag) |
#define | xdvnull() xdvalloc(0) |
#define | xdvnullul(plugin, unlock_flag) xdvallocul(plugin, 0, unlock_flag) |
#define | xdvrinums(length, value) xdvriinit((double)(value), 0.0, (double)(length)) |
#define | xdvrinumsul(plugin, length, value, unlock_flag) xdvriinitul(plugin, (double)(value), 0.0, (double)(length), unlock_flag) |
#define | xdvrizeros(length) xdvrinums(length, 0.0) |
#define | xdvrizerosul(plugin, length, unlock_flag) xdvrinumsul(plugin, length, 0.0, unlock_flag) |
#define | xdvriones(length) xdvrinums(length, 1.0) |
#define | xdvrionesul(plugin, length, unlock_flag) xdvrinumsul(plugin, length, 1.0, unlock_flag) |
#define | dvunset(x) dvset(x, NULL, 0) |
#define | dviunset(x) dviset(x, NULL, 0) |
ベクトル型用ファイル入出力 (<sp/fileio.h>) | |
spDVector | xdvreaddsignal (const char *filename, long headlen, int swap) |
spDVector | xdvreadssignal (const char *filename, long headlen, int swap) |
spDVector | xdvreadlsignal (const char *filename, long headlen, int swap) |
spDVector | xdvreadfsignal (const char *filename, long headlen, int swap) |
spBool | dvwritedsignal (const char *filename, spDVector vector, int swap) |
spBool | dvwritessignal (const char *filename, spDVector vector, int swap) |
spBool | dvwritelsignal (const char *filename, spDVector vector, int swap) |
spBool | dvwritefsignal (const char *filename, spDVector vector, int swap) |
#define | xdvreaddvector(filename, swap) xdvreaddsignal((filename), 0, (swap)) |
#define | xdvreadsvector(filename, swap) xdvreadssignal((filename), 0, (swap)) |
#define | xdvreadlvector(filename, swap) xdvreadlsignal((filename), 0, (swap)) |
#define | xdvreadfvector(filename, swap) xdvreadfsignal((filename), 0, (swap)) |
#define | dvwritedvector(filename, vector, swap) dvwritedsignal(filename, vector, swap) |
#define | dvwritesvector(filename, vector, swap) dvwritessignal(filename, vector, swap) |
#define | dvwritelvector(filename, vector, swap) dvwritelsignal(filename, vector, swap) |
#define | dvwritefvector(filename, vector, swap) dvwritefsignal(filename, vector, swap) |
double型を扱うためのベクトル型です.
実際には,クラスではなく, typedef struct _spDVector *spDVector;
により typedef された型です. メモリを確保するには, xdvalloc() , xdvinit() などの xdv で始まる関数を呼び出す必要があります. また,メモリを解放するには, xdvfree() を呼ぶ必要があります.
spDVector のメモリを確保し,ロック・アンロック状態を設定します.
spDVector のメモリを確保し,入力ベクトルの状態に基づいてロック・アンロック状態を設定します.
spDVector の実部と虚部のメモリを確保し,ロック・アンロック状態を設定します.
ベクトルの要素数を変更し,長くなった部分の要素を0に初期化します.
x
のアドレスが返り,失敗時には SP_NODATA が返ります. void dvreal | ( | spDVector | x | ) |
x
に対し,虚部が存在すれば虚部のメモリを解放し,実部のみのデータにします.
void dvimag | ( | spDVector | x | ) |
x
の虚部のみのデータにします.元々の虚部は実部となります.
void dvconj | ( | spDVector | x | ) |
x
の複素共役を計算します.
void dvriswap | ( | spDVector | x | ) |
x
の実部と虚部を入れ替えます.
x
のデータを y
にコピーします.x
の虚部は, y->imag != NULL
が成り立つ場合にのみコピーされます.
long dvcopyfromarray | ( | spDVector | y, |
long | y_offset, | ||
double * | data, | ||
long | length ) |
配列 data
のデータをベクトル y
の位置 y_offset
へコピーします.
long dvcopyfromriarray | ( | spDVector | y, |
long | y_offset, | ||
double * | data, | ||
double * | imag, | ||
long | length ) |
実部が data
,虚部が imag
である複素数配列のデータをベクトル y
の位置 y_offset
へコピーします.
long dvcopytoarray | ( | spDVector | x, |
long | x_offset, | ||
double * | data, | ||
long | length ) |
ベクトル x
の位置 x_offset
から取り出したデータを,配列 data
へコピーします.
long dvcopytoriarray | ( | spDVector | x, |
long | x_offset, | ||
double * | data, | ||
double * | imag, | ||
long | length ) |
ベクトル x
の位置 x_offset
から取り出したデータを,実部 data
,虚部 imag
の複素数配列へコピーします.
ベクトル x
を,要素の値の範囲が m
から n
で増分が incr
になるように初期化します.
spDVector xdvinit | ( | double | m, |
double | incr, | ||
double | n ) |
要素の値の範囲が m
から n
で増分が incr
であるようなベクトルを新規に作成します.
要素の値の範囲が m
から n
で増分が incr
であるようなプラグインベースのベクトルを新規に作成します.
ベクトル x
の虚部を,要素の値の範囲が m
から n
で増分が incr
になるように初期化します.
ベクトル x
の実部と虚部を,要素の値の範囲が m
から n
で増分が incr
になるように初期化します.
spDVector xdvriinit | ( | double | m, |
double | incr, | ||
double | n ) |
実部と虚部において,要素の値の範囲が m
から n
で増分が incr
であるようなベクトルを新規に作成します.
実部と虚部において,要素の値の範囲が m
から n
で増分が incr
であるようなプラグインベースのベクトルを新規に作成します.
ベクトル x
の offset
から要素数 length
分のデータを取り出します.
ベクトル x
を要素数 x_length
で切り出し,それをベクトル y
の位置 y_offset
へペーストします. 引数 overlap
は,ペーストする際に重畳加算するかどうかを決定するフラグです.
long dvadd | ( | spDVector | y, |
long | y_offset, | ||
spDVector | x, | ||
long | x_offset, | ||
long | x_length, | ||
spBool | overlap ) |
ベクトル x
を位置 x_offset
から要素数 x_length
で切り出し,それをベクトル y
の位置 y_offset
へペーストします. 引数 overlap
が SP_TRUE の場合には,ペーストする際に重畳加算します.
ベクトル x
の位置 offset
から要素数 length
分のデータを0に設定します. 引数 inv
が SP_TRUE の場合には,位置 offset
から要素数 length
分のデータのみを残し,それ以外の区間を0に設定します.
void dvset | ( | spDVector | x, |
double * | data, | ||
long | length ) |
data
のアドレスを x->data
に設定します.
void dviset | ( | spDVector | x, |
double * | imag, | ||
long | length ) |
imag
のアドレスを x->imag
に設定します.
data
のアドレスをプラグインベースの新規ベクトルの data
に設定します.
spDVector xdvset | ( | double * | data, |
long | length ) |
data
のアドレスを新規ベクトルの data
に設定します.
spDVector xdvsetnew | ( | double * | data, |
long | length ) |
実部が data
と同じ内容を持つ新規ベクトルを作成します.
ベクトル x
の要素を,要素数 length
の範囲内で値が value
になるよう初期化します.
ベクトル x
の要素を,要素数 length
の範囲内で値が0になるよう初期化します.
ベクトル x
の要素を,要素数 length
の範囲内で値が1になるよう初期化します.
ベクトル x
の虚部の要素を,要素数 length
の範囲内で値が value
になるよう初期化します.
ベクトル x
の虚部の要素を,要素数 length
の範囲内で値が0になるよう初期化します.
ベクトル x
の虚部の要素を,要素数 length
の範囲内で値が1になるよう初期化します.
ベクトル x
の実部と虚部の両方の要素を,要素数 length
の範囲内で値が value
になるよう初期化します.
ベクトル x
の実部と虚部の両方の要素を,要素数 length
の範囲内で値が0になるよう初期化します.
ベクトル x
の実部と虚部の両方の要素を,要素数 length
の範囲内で値が1になるよう初期化します.
要素の値が要素数 length
の範囲内で value
であるようなベクトルを新規に作成します.
|
related |
要素の値が要素数 length
の範囲内で value
であるようなプラグインベースのベクトルを新規に作成します.
|
related |
要素の値が要素数 length
の範囲内で0であるようなプラグインベースのベクトルを新規に作成します.
|
related |
要素の値が要素数 length
の範囲内で1であるようなプラグインベースのベクトルを新規に作成します.
|
related |
要素数0であるベクトルを新規に作成します.
|
related |
要素数0であるプラグインベースのベクトルを新規に作成します.
実部と虚部の両方の要素の値が要素数 length
の範囲内で value
であるようなベクトルを新規に作成します.
|
related |
実部と虚部の両方の要素の値が要素数 length
の範囲内で value
であるようなプラグインベースのベクトルを新規に作成します.
実部と虚部の両方の要素の値が要素数 length
の範囲内で0であるようなベクトルを新規に作成します.
|
related |
実部と虚部の両方の要素の値が要素数 length
の範囲内で0であるようなプラグインベースのベクトルを新規に作成します.
実部と虚部の両方の要素の値が要素数 length
の範囲内で1であるようなベクトルを新規に作成します.
|
related |
実部と虚部の両方の要素の値が要素数 length
の範囲内で1であるようなプラグインベースのベクトルを新規に作成します.
|
related |
x->data
を NULL に設定します.
|
related |
x->imag
を NULL に設定します.
long length |
ベクトルの要素数を保持します.メモリ確保された spDVector 型 x
があった場合,その要素数は x->length
で取得できます.
double* data |
実部のデータを保持します.メモリ確保された spDVector 型 x
があった場合,0番目の要素は x->data
[0] で取得できます.