Edinburgh Speech Tools 2.4-release
 
Loading...
Searching...
No Matches
EST_DMatrix Class Reference

#include <include/EST_DMatrix.h>

Inheritance diagram for EST_DMatrix:
Collaboration diagram for EST_DMatrix:

Public Member Functions

 EST_DMatrix (int m, int n)
 size constructor
 
 EST_DMatrix (const EST_DMatrix &a)
 copy constructor
 
 EST_DMatrix (const EST_DMatrix &a, int b)
 CHECK - what does this do???
 
 EST_DMatrix ()
 default constructor
 
EST_write_status save (const EST_String &filename, const EST_String &type=EST_DMatrix::default_file_type)
 Save in file (ascii or binary)
 
EST_read_status load (const EST_String &filename)
 Load from file (ascii or binary as defined in file)
 
EST_write_status est_save (const EST_String &filename, const EST_String &type)
 Save in file in est format.
 
EST_read_status est_load (const EST_String &filename)
 Load from file in est format (binary/ascii defined in file itself)
 
void copyin (double **x, int rows, int cols)
 Copy 2-d array {\tt x} of size {\tt rows x cols} into matrix.
 
EST_DMatrixoperator+= (const EST_DMatrix &a)
 Add elements of 2 same sized matrices.
 
EST_DMatrixoperator-= (const EST_DMatrix &a)
 Subtract elements of 2 same sized matrices.
 
EST_DMatrixoperator*= (const double f)
 elementwise multiply by scalar
 
EST_DMatrixoperator/= (const double f)
 elementwise divide by scalar
 
- Public Member Functions inherited from EST_TSimpleMatrix< double >
 EST_TSimpleMatrix (void)
 default constructor
 
 EST_TSimpleMatrix (int m, int n)
 size constructor
 
 EST_TSimpleMatrix (const EST_TSimpleMatrix< double > &m)
 copy constructor
 
void copy (const EST_TSimpleMatrix< double > &a)
 copy one matrix into another
 
void resize (int rows, int cols, int set=1)
 resize matrix
 
EST_TSimpleMatrix< double > & operator= (const EST_TSimpleMatrix< double > &s)
 assignment operator
 
- Public Member Functions inherited from EST_TMatrix< T >
 EST_TMatrix ()
 default constructor
 
 EST_TMatrix (const EST_TMatrix< T > &m)
 copy constructor
 
 EST_TMatrix (int rows, int cols)
 "size" constructor
 
 EST_TMatrix (int rows, int cols, T *memory, int offset=0, int free_when_destroyed=0)
 construct from memory supplied by caller
 
 ~EST_TMatrix ()
 EST_TMatrix.
 
int num_rows () const
 return number of rows
 
int num_columns () const
 return number of columns
 
INLINE const Ta_no_check (int row, int col) const
 const access with no bounds check, care recommend
 
INLINE Ta_no_check (int row, int col)
 access with no bounds check, care recommend
 
INLINE const Ta_no_check_1 (int row, int col) const
 
INLINE Ta_no_check_1 (int row, int col)
 
const Ta_check (int row, int col) const
 const element access function
 
Ta_check (int row, int col)
 non-const element access function
 
const Ta (int row, int col) const
 
Ta (int row, int col)
 
const Toperator() (int row, int col) const
 const element access operator
 
Toperator() (int row, int col)
 non-const element access operator
 
bool have_rows_before (int n) const
 
bool have_columns_before (int n) const
 
void resize (int rows, int cols, int set=1)
 
void fill (const T &v)
 fill matrix with value v
 
void fill ()
 
EST_TMatrixoperator= (const EST_TMatrix &s)
 assignment operator
 
EST_TMatrixadd_rows (const EST_TMatrix &s)
 The two versions of what might have been operator +=.
 
EST_TMatrixadd_columns (const EST_TMatrix &s)
 
void row (EST_TVector< T > &rv, int r, int start_c=0, int len=-1)
 Make the vector {\tt rv} a window onto row {\tt r}.
 
void column (EST_TVector< T > &cv, int c, int start_r=0, int len=-1)
 Make the vector {\tt cv} a window onto column {\tt c}.
 
void sub_matrix (EST_TMatrix< T > &sm, int r=0, int numr=EST_ALL, int c=0, int numc=EST_ALL)
 Make the matrix {\tt sm} a window into this matrix.
 
void copy_row (int r, T *buf, int offset=0, int num=-1) const
 
void copy_row (int r, EST_TVector< T > &t, int offset=0, int num=-1) const
 
void copy_column (int c, T *buf, int offset=0, int num=-1) const
 
void copy_column (int c, EST_TVector< T > &t, int offset=0, int num=-1) const
 
void set_row (int n, const T *buf, int offset=0, int num=-1)
 
void set_row (int n, const EST_TVector< T > &t, int offset=0, int num=-1)
 
void set_row (int r, const EST_TMatrix< T > &from, int from_r, int from_offset=0, int offset=0, int num=-1)
 
void set_column (int n, const T *buf, int offset=0, int num=-1)
 
void set_column (int n, const EST_TVector< T > &t, int offset=0, int num=-1)
 
void set_column (int c, const EST_TMatrix< T > &from, int from_c, int from_offset=0, int offset=0, int num=-1)
 
void set_memory (T *buffer, int offset, int rows, int columns, int free_when_destroyed=0)
 
EST_read_status load (const class EST_String &filename)
 load Matrix from file - Not currently implemented.
 
EST_write_status save (const class EST_String &filename) const
 save Matrix to file {\tt filename}
 
- Public Member Functions inherited from EST_TVector< T >
INLINE unsigned int vcell_pos (unsigned int c, unsigned int cs) const
 The memory access rule, in one place for easy reference.
 
INLINE unsigned int vcell_pos (unsigned int c) const
 
INLINE unsigned int vcell_pos_1 (unsigned int c) const
 
INLINE const Tfast_a_v (int c) const
 quick method for returning (x[n])
 
INLINE Tfast_a_v (int c)
 
INLINE const Tfast_a_1 (int c) const
 
INLINE Tfast_a_1 (int c)
 
void set_values (const T *data, int step, int start_c, int num_c)
 Get and set values from array.
 
void get_values (T *data, int step, int start_c, int num_c) const
 
void copy (const EST_TVector< T > &a)
 private copy function, called from all other copying functions.
 
void copy_data (const EST_TVector< T > &a)
 just copy data, no resizing, no size check.
 
void just_resize (int new_cols, T **old_vals)
 resize the memory and reset the bounds, but don't set values.
 
void default_vals ()
 sets data and length to default values (0 in both cases).
 
 EST_TVector ()
 default constructor
 
 EST_TVector (const EST_TVector< T > &v)
 copy constructor
 
 EST_TVector (int n)
 "size" constructor - make vector of size n.
 
 EST_TVector (int, T *memory, int offset=0, int free_when_destroyed=0)
 construct from memory supplied by caller
 
 ~EST_TVector ()
 destructor.
 
void resize (int n, int set=1)
 
const Tmemory () const
 
Tmemory ()
 
const EST_DMatrixdef_val
 
EST_DMatrixerror_return
 
const EST_DVectordef_val
 
EST_DVectorerror_return
 
const EST_FMatrixdef_val
 
EST_FMatrixerror_return
 
INLINE int num_columns () const
 number of items in vector.
 
INLINE int length () const
 number of items in vector.
 
INLINE int n () const
 number of items in vector.
 
INLINE const Ta_no_check (int n) const
 read-only const access operator: without bounds checking
 
INLINE Ta_no_check (int n)
 read/write non-const access operator: without bounds checking
 
INLINE const Ta_no_check_1 (int n) const
 read-only const access operator: without bounds checking
 
INLINE Ta_no_check_1 (int n)
 read/write non-const access operator: without bounds checking
 
const Ta_check (int n) const
 read-only const access operator: with bounds checking
 
Ta_check (int n)
 read/write non-const access operator: with bounds checking
 
const Ta (int n) const
 
Ta (int n)
 
const Toperator() (int n) const
 read-only const access operator: return reference to nth member
 
Toperator[] (int n)
 read/write non const access operator: return reference to nth member
 
void set_memory (T *buffer, int offset, int columns, int free_when_destroyed=0)
 
EST_TVectoroperator= (const EST_TVector &s)
 assignment operator
 
void fill (const T &v)
 Fill entire array will value <parameter>v</parameter>.
 
void empty ()
 Fill vector with default value.
 
int operator== (const EST_TVector &v) const
 is true if vectors are equal size and all elements are equal.
 
int operator!= (const EST_TVector &v) const
 is true if vectors are not equal size or a single elements isn't equal.
 
void copy_section (T *dest, int offset=0, int num=-1) const
 Copy data in and out. Subclassed by SimpleVector for speed.
 
void set_section (const T *src, int offset=0, int num=-1)
 
void sub_vector (EST_TVector< T > &sv, int start_c=0, int len=-1)
 Create a sub vector.
 
void integrity () const
 

Static Public Attributes

static EST_String default_file_type = "est_ascii"
 
- Static Public Attributes inherited from EST_TVector< T >
static const Tdef_val = &def_val_item_ptr
 default value, used for filling matrix after resizing
 
static Terror_return = &error_return_item_ptr
 

Friends

EST_DMatrix operator* (const EST_DMatrix &a, const double x)
 Multiply all elements of matrix by {\tt x}.
 
EST_DVector operator* (const EST_DMatrix &a, const EST_DVector &v)
 Multiply matrix by vector.
 
EST_DVector operator* (const EST_DVector &v, const EST_DMatrix &a)
 Multiply vector by matrix.
 
EST_DMatrix operator* (const EST_DMatrix &a, const EST_DMatrix &b)
 Multiply matrix by matrix.
 

Additional Inherited Members

- Public Attributes inherited from EST_TVector< T >
Tp_memory
 
unsigned int p_num_columns
 Visible shape.
 
unsigned int p_offset
 How to access the memory.
 
unsigned int p_column_step
 
bool p_sub_matrix
 
- Protected Member Functions inherited from EST_TSimpleMatrix< double >
void copy_data (const EST_TSimpleMatrix< double > &a)
 
- Protected Member Functions inherited from EST_TMatrix< T >
INLINE unsigned int mcell_pos (int r, int c, int rs, int cs) const
 
INLINE unsigned int mcell_pos (int r, int c) const
 
INLINE unsigned int mcell_pos_1 (int r, int c) const
 
INLINE const Tfast_a_m (int r, int c) const
 quick method for returning {\tt x[m][n]}
 
INLINE Tfast_a_m (int r, int c)
 
INLINE const Tfast_a_1 (int r, int c) const
 
INLINE Tfast_a_1 (int r, int c)
 
void set_values (const T *data, int r_step, int c_step, int start_r, int num_r, int start_c, int num_c)
 Get and set values from array.
 
void get_values (T *data, int r_step, int c_step, int start_r, int num_r, int start_c, int num_c) const
 
void copy (const EST_TMatrix< T > &a)
 private resize and copy function.
 
void copy_data (const EST_TMatrix< T > &a)
 just copy data, no resizing, no size check.
 
void just_resize (int new_rows, int new_cols, T **old_vals)
 resize the memory and reset the bounds, but don't set values.
 
void default_vals ()
 sets data and length to default values (0 in both cases).
 
- Protected Attributes inherited from EST_TMatrix< T >
unsigned int p_num_rows
 Visible shape.
 
unsigned int p_row_step
 How to access the memory.
 

Detailed Description

A matrix class for double precision floating point numbers. EST_DMatrix x should be used instead of double **x wherever possible.

Definition at line 54 of file EST_DMatrix.h.

Constructor & Destructor Documentation

◆ EST_DMatrix() [1/4]

EST_DMatrix::EST_DMatrix ( int  m,
int  n 
)
inline

size constructor

Definition at line 58 of file EST_DMatrix.h.

◆ EST_DMatrix() [2/4]

EST_DMatrix::EST_DMatrix ( const EST_DMatrix a)
inline

copy constructor

Definition at line 60 of file EST_DMatrix.h.

◆ EST_DMatrix() [3/4]

EST_DMatrix::EST_DMatrix ( const EST_DMatrix a,
int  b 
)

CHECK - what does this do???

Definition at line 57 of file EST_DMatrix.cc.

◆ EST_DMatrix() [4/4]

EST_DMatrix::EST_DMatrix ( )
inline

default constructor

Definition at line 66 of file EST_DMatrix.h.

Member Function Documentation

◆ save()

EST_write_status EST_DMatrix::save ( const EST_String filename,
const EST_String type = EST_DMatrix::default_file_type 
)

Save in file (ascii or binary)

Definition at line 320 of file EST_DMatrix.cc.

◆ load()

EST_read_status EST_DMatrix::load ( const EST_String filename)

Load from file (ascii or binary as defined in file)

Definition at line 494 of file EST_DMatrix.cc.

◆ est_save()

EST_write_status EST_DMatrix::est_save ( const EST_String filename,
const EST_String type 
)

Save in file in est format.

Definition at line 357 of file EST_DMatrix.cc.

◆ est_load()

EST_read_status EST_DMatrix::est_load ( const EST_String filename)

Load from file in est format (binary/ascii defined in file itself)

Definition at line 418 of file EST_DMatrix.cc.

◆ copyin()

void EST_DMatrix::copyin ( double **  x,
int  rows,
int  cols 
)

Copy 2-d array {\tt x} of size {\tt rows x cols} into matrix.

Definition at line 308 of file EST_DMatrix.cc.

◆ operator+=()

EST_DMatrix & EST_DMatrix::operator+= ( const EST_DMatrix a)

Add elements of 2 same sized matrices.

Definition at line 67 of file EST_DMatrix.cc.

◆ operator-=()

EST_DMatrix & EST_DMatrix::operator-= ( const EST_DMatrix a)

Subtract elements of 2 same sized matrices.

Definition at line 87 of file EST_DMatrix.cc.

◆ operator*=()

EST_DMatrix & EST_DMatrix::operator*= ( const double  f)

elementwise multiply by scalar

Definition at line 107 of file EST_DMatrix.cc.

◆ operator/=()

EST_DMatrix & EST_DMatrix::operator/= ( const double  f)

elementwise divide by scalar

Definition at line 118 of file EST_DMatrix.cc.

Friends And Related Symbol Documentation

◆ operator* [1/4]

EST_DMatrix operator* ( const EST_DMatrix a,
const double  x 
)
friend

Multiply all elements of matrix by {\tt x}.

Definition at line 175 of file EST_DMatrix.cc.

◆ operator* [2/4]

EST_DVector operator* ( const EST_DMatrix a,
const EST_DVector v 
)
friend

Multiply matrix by vector.

Definition at line 187 of file EST_DMatrix.cc.

◆ operator* [3/4]

EST_DVector operator* ( const EST_DVector v,
const EST_DMatrix a 
)
friend

Multiply vector by matrix.

Definition at line 246 of file EST_DMatrix.cc.

◆ operator* [4/4]

EST_DMatrix operator* ( const EST_DMatrix a,
const EST_DMatrix b 
)
friend

Multiply matrix by matrix.

Definition at line 278 of file EST_DMatrix.cc.

Member Data Documentation

◆ default_file_type

EST_String EST_DMatrix::default_file_type = "est_ascii"
static

Definition at line 62 of file EST_DMatrix.h.


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