ccgsl 2.7.2
C++wrappersforGnuScientificLibrary
gsl::fft::complex::workspace Class Reference

Workspace for complex fast fourier transforms. More...

#include <fft_complex.hpp>

Collaboration diagram for gsl::fft::complex::workspace:
Collaboration graph

Public Member Functions

 workspace ()
 The default constructor is only really useful for assigning to. More...
 
 workspace (size_t const n)
 The default constructor creates a new workspace of size n. More...
 
 workspace (gsl_fft_complex_workspace *v)
 Could construct from a gsl_fft_complex_workspace. More...
 
 workspace (workspace const &v)
 The copy constructor. More...
 
workspaceoperator= (workspace const &v)
 The assignment operator. More...
 
 ~workspace ()
 The destructor only deletes the pointers if count reaches zero. More...
 
 workspace (workspace &&v)
 Move constructor. More...
 
workspaceoperator= (workspace &&v)
 Move operator. More...
 
bool operator== (workspace const &v) const
 Two workspace are identically equal if their elements are identical. More...
 
bool operator!= (workspace const &v) const
 Two workspace are different equal if their elements are not identical. More...
 
bool operator< (workspace const &v) const
 A container needs to define an ordering for sorting. More...
 
bool operator> (workspace const &v) const
 A container needs to define an ordering for sorting. More...
 
bool operator<= (workspace const &v) const
 A container needs to define an ordering for sorting. More...
 
bool operator>= (workspace const &v) const
 A container needs to define an ordering for sorting. More...
 
bool empty () const
 Find if the workspace is empty. More...
 
void swap (workspace &v)
 Swap two workspace. More...
 
gsl_fft_complex_workspace * get () const
 Get the gsl_fft_complex_workspace. More...
 
bool unique () const
 Find if this is the only object sharing the gsl_fft_complex_workspace. More...
 
size_t use_count () const
 Find how many workspace objects share this pointer. More...
 
 operator bool () const
 Allow conversion to bool. More...
 

Private Attributes

gsl_fft_complex_workspace * ccgsl_pointer
 The shared pointer. More...
 
size_t * count
 The shared reference count. More...
 

Detailed Description

Workspace for complex fast fourier transforms.

Definition at line 642 of file fft_complex.hpp.

Constructor & Destructor Documentation

◆ workspace() [1/5]

gsl::fft::complex::workspace::workspace ( )
inline

The default constructor is only really useful for assigning to.

Definition at line 647 of file fft_complex.hpp.

References ccgsl_pointer, and count.

Referenced by operator=().

◆ workspace() [2/5]

gsl::fft::complex::workspace::workspace ( size_t const  n)
inlineexplicit

The default constructor creates a new workspace of size n.

Parameters
nThe size of the workspace.

Definition at line 657 of file fft_complex.hpp.

References ccgsl_pointer, count, and gsl::rstat::n().

◆ workspace() [3/5]

gsl::fft::complex::workspace::workspace ( gsl_fft_complex_workspace *  v)
inlineexplicit

Could construct from a gsl_fft_complex_workspace.

This is not usually a good idea. In this case you should not use gsl_fft_complex_workspace_free() to deallocate the memory.

Parameters
vThe workspace

Definition at line 673 of file fft_complex.hpp.

References ccgsl_pointer, and count.

◆ workspace() [4/5]

gsl::fft::complex::workspace::workspace ( workspace const &  v)
inline

The copy constructor.

This creates a new reference to the workspace.

Parameters
vThe workspace to copy.

Definition at line 684 of file fft_complex.hpp.

References ccgsl_pointer, and count.

◆ ~workspace()

gsl::fft::complex::workspace::~workspace ( )
inline

The destructor only deletes the pointers if count reaches zero.

Definition at line 703 of file fft_complex.hpp.

References ccgsl_pointer, and count.

◆ workspace() [5/5]

gsl::fft::complex::workspace::workspace ( workspace &&  v)
inline

Move constructor.

Parameters
vThe workspace to move.

Definition at line 715 of file fft_complex.hpp.

References count.

Member Function Documentation

◆ empty()

bool gsl::fft::complex::workspace::empty ( ) const
inline

Find if the workspace is empty.

Returns
true if has size zero; otherwise false

Definition at line 792 of file fft_complex.hpp.

References ccgsl_pointer.

◆ get()

gsl_fft_complex_workspace * gsl::fft::complex::workspace::get ( ) const
inline

Get the gsl_fft_complex_workspace.

Returns
the gsl_fft_complex_workspace

Definition at line 818 of file fft_complex.hpp.

References ccgsl_pointer.

Referenced by gsl::fft::complex::backward(), gsl::fft::complex::forward(), gsl::fft::complex::inverse(), and gsl::fft::complex::transform().

◆ operator bool()

gsl::fft::complex::workspace::operator bool ( ) const
inlineexplicit

Allow conversion to bool.

Returns
true or false according as this contains a pointer to a gsl_fft_complex_workspace

Definition at line 838 of file fft_complex.hpp.

References ccgsl_pointer.

◆ operator!=()

bool gsl::fft::complex::workspace::operator!= ( workspace const &  v) const
inline

Two workspace are different equal if their elements are not identical.

Parameters
vThe workspace to be compared with this
Returns
false or true according as this and v have identical elements or not

Definition at line 745 of file fft_complex.hpp.

References operator==().

◆ operator<()

bool gsl::fft::complex::workspace::operator< ( workspace const &  v) const
inline

A container needs to define an ordering for sorting.

This uses standard lexicographical ordering and so is not useful, for eaxmple, for checking, that a workspace is nonnegative.

Parameters
vThe workspace to be compared with this
Returns
false or true according as this is less than v lexicographically

Definition at line 757 of file fft_complex.hpp.

References ccgsl_pointer.

◆ operator<=()

bool gsl::fft::complex::workspace::operator<= ( workspace const &  v) const
inline

A container needs to define an ordering for sorting.

This uses standard lexicographical ordering and so is not useful, for eaxmple, for checking, that a workspace is nonnegative.

Parameters
vThe workspace to be compared with this
Returns
false or true according as this is less than or equal to v lexicographically

Definition at line 777 of file fft_complex.hpp.

References ccgsl_pointer.

◆ operator=() [1/2]

workspace & gsl::fft::complex::workspace::operator= ( workspace &&  v)
inline

Move operator.

Parameters
vThe workspace to move.
Returns
A reference to this.

Definition at line 724 of file fft_complex.hpp.

References workspace().

◆ operator=() [2/2]

workspace & gsl::fft::complex::workspace::operator= ( workspace const &  v)
inline

The assignment operator.

This copies elementwise.

Parameters
vThe workspace to copy

Definition at line 691 of file fft_complex.hpp.

References ccgsl_pointer, and count.

◆ operator==()

bool gsl::fft::complex::workspace::operator== ( workspace const &  v) const
inline

Two workspace are identically equal if their elements are identical.

Parameters
vThe workspace to be compared with this
Returns
true or false according as this and v have identical elements or not

Definition at line 737 of file fft_complex.hpp.

References ccgsl_pointer.

Referenced by operator!=().

◆ operator>()

bool gsl::fft::complex::workspace::operator> ( workspace const &  v) const
inline

A container needs to define an ordering for sorting.

This uses standard lexicographical ordering and so is not useful, for eaxmple, for checking, that a workspace is nonnegative.

Parameters
vThe workspace to be compared with this
Returns
false or true according as this is greater than v lexicographically

Definition at line 767 of file fft_complex.hpp.

References ccgsl_pointer.

◆ operator>=()

bool gsl::fft::complex::workspace::operator>= ( workspace const &  v) const
inline

A container needs to define an ordering for sorting.

This uses standard lexicographical ordering and so is not useful, for eaxmple, for checking, that a workspace is nonnegative.

Parameters
vThe workspace to be compared with this
Returns
false or true according as this is no less than v lexicographically

Definition at line 787 of file fft_complex.hpp.

References ccgsl_pointer.

◆ swap()

void gsl::fft::complex::workspace::swap ( workspace v)
inline

Swap two workspace.

This works even if the workspace have different sizes because it swaps pointers.

Parameters
vThe workspace to swap with this.

Definition at line 799 of file fft_complex.hpp.

References ccgsl_pointer, and count.

◆ unique()

bool gsl::fft::complex::workspace::unique ( ) const
inline

Find if this is the only object sharing the gsl_fft_complex_workspace.

Returns
true or falses according as this is the only workspace object sharing the gsl_fft_complex_workspace

Definition at line 824 of file fft_complex.hpp.

References count.

◆ use_count()

size_t gsl::fft::complex::workspace::use_count ( ) const
inline

Find how many workspace objects share this pointer.

Returns
the number of workspace objects that share this pointer

Definition at line 829 of file fft_complex.hpp.

References count.

Member Data Documentation

◆ ccgsl_pointer

gsl_fft_complex_workspace* gsl::fft::complex::workspace::ccgsl_pointer
private

◆ count

size_t* gsl::fft::complex::workspace::count
private

The shared reference count.

Definition at line 811 of file fft_complex.hpp.

Referenced by operator=(), swap(), unique(), use_count(), workspace(), and ~workspace().


The documentation for this class was generated from the following file: