VFu_rsqrt | VDu_rsqrt | VEu_rsqrt |
|
Funktion | Kehrwert der Quadratwurzel |
|
Syntax C/C++ | #include <VFmath.h>
int VF_rsqrt( fVector Y, fVector X, ui size );
int VFx_rsqrt( fVector Y, fVector X, ui size, float A, float B, float C ); |
C++ VecObj | #include <OptiVec.h>
int vector<T>::rsqrt( const vector<T>& X );
int vector<T>::x_rsqrt( const vector<T>& X, const T& A, const T& B, const T& C ); |
Pascal/Delphi | uses VFmath;
function VF_rsqrt( Y, X:fVector; size:UIntSize ): IntBool;
function VFx_rsqrt( Y, X:fVector; size:UIntSize; A, B, C:Single ): IntBool; |
|
CUDA-Funktion C/C++ | #include <cudaVFmath.h>
int cudaVF_rsqrt( fVector d_Y, fVector d_X, ui size );
int cudaVFx_rsqrt( fVector d_Y, fVector d_X, ui size, float A, float B, float C );
int cusdVFx_rsqrt( fVector d_Y, fVector d_X, ui size, float *d_A, float *d_B, float *d_C );
int VFcu_rsqrt( fVector h_Y, fVector h_X, ui size );
int VFxcu_rsqrt( fVector h_Y, fVector h_X, ui size, float A, float B, float C );
|
CUDA-Funktion Pascal/Delphi | uses VFmath;
function cudaVF_rsqrt( d_Y, d_X:fVector; size:UIntSize ): IntBool;
function cudaVFx_rsqrt( d_Y, d_X:fVector; size:UIntSize; A, B, C:Single ): IntBool;
function cusdVFx_rsqrt( d_Y, d_X:fVector; size:UIntSize; d_A, d_B, d_C:PSingle ): IntBool;
function VFcu_rsqrt( h_Y, h_X:fVector; size:UIntSize ): IntBool;
function VFxcu_rsqrt( h_Y, h_X:fVector; size:UIntSize; A, B, C:Single ): IntBool;
|
|
Beschreibung | einfache Versionen: Yi = 1 / sqrt( Xi )
erweiterte Versionen: Yi = C / sqrt( A*Xi+B )
"ungeschützte" Versionen (Präfix VFu_, VFux_, etc.):
Diese Funktionen führen keinerlei Fehlerbehandlung durch und sind hierdurch deutlich schneller, stürzen aber unkontrolliert ab, falls ein negativer oder zu kleiner Eingabewert angetroffen wird. |
|
Fehlerbehandlung | Normale Versionen (VF_, VFx_ etc.): DOMAIN-Fehler entstehen in den reellen Versionen für negative Argumente und führen zum Ergebnis NAN ("not-a-number", IEEE-Nicht-Zahl). Argumente nahe oder gleich 0 führen zum Überlauf mit dem Ergebnis HUGE_VAL.
Ungeschützte Versionen (VFu_, VFux_ etc.): keine Fehlerbehandlung |
|
Rückgabewert | FALSE (0), wenn fehlerfrei, andernfalls TRUE (≠ 0) |
|
|