DOKK / manpages / debian 12 / libsc-doc / sc_SCMatrixLTriSubBlock.3.en
sc::SCMatrixLTriSubBlock(3) MPQC sc::SCMatrixLTriSubBlock(3)

sc::SCMatrixLTriSubBlock - The SCMatrixLTriSubBlock describes a triangular subblock of a matrix.

#include <block.h>

Inherits sc::SCMatrixBlock.


SCMatrixLTriSubBlock (int is, int ie, int js, int je, double *data)
SCMatrixLTriSubBlock (StateIn &)
void save_data_state (StateOut &)
Save the base classes (with save_data_state) and the members in the same order that the StateIn CTOR initializes them. void process (SCElementOp *)
void process (SCElementOp2 *, SCMatrixBlock *)
void process (SCElementOp3 *, SCMatrixBlock *, SCMatrixBlock *)


int istart
int iend
int jstart
int jend
double * data

The SCMatrixLTriSubBlock describes a triangular subblock of a matrix.

The following bit of code illustrates the data layout: fill(double **matrix, SCMatrixLTriSubBlock &b) { int offset=(b.istart*(b.istart+1)>>1) + b.jstart; for (int i=b.start; i<b.end; i++) { for (int j=b.start; j<=i && j<b.jend; j++,offset++) { matrix[i][j] = b.data[offset]; } if (j>i) offset += b.istart; else offset += i + b.jstart - b.jend; } }

void sc::SCMatrixLTriSubBlock::process (SCElementOp *) [virtual]

Implements sc::SCMatrixBlock.

void sc::SCMatrixLTriSubBlock::process (SCElementOp2 *, SCMatrixBlock *) [virtual]

Implements sc::SCMatrixBlock.

void sc::SCMatrixLTriSubBlock::process (SCElementOp3 *, SCMatrixBlock *, SCMatrixBlock *) [virtual]

Implements sc::SCMatrixBlock.

Save the base classes (with save_data_state) and the members in the same order that the StateIn CTOR initializes them. This must be implemented by the derived class if the class has data.

Reimplemented from sc::SCMatrixBlock.

Generated automatically by Doxygen for MPQC from the source code.

Fri Dec 2 2022 Version 2.3.1