我要评分
获取效率
正确性
完整性
易理解

KmlIssCgInit?I

Initialize the data structure and associate the coefficient matrix provided by the user to the solution system.

Interface Definition

C interface:

int KmlIssCgInitSI(KmlSolverTask **handle, int n, const float *a, const int *ja, const int *ia);

int KmlIssCgInitDI(KmlSolverTask **handle, int n, const double *a, const int *ja, const int *ia);

Parameters

Parameter

Type

Description

Input/Output

handle

KmlSolverTask **

Solver handle. The handle cannot be a null pointer.

Input/Output

n

int

Dimension of matrix A

Input

a

  • float * in KmlIssCgInitSI
  • double * in KmlIssCgInitDI

Array whose dimension is the quantity of non-zero elements. a[i] is the value of the ith non-zero element. The lifecycle of this array is the same as that of the handle.

Input

ja

int *

Array whose dimension is the quantity of non-zero elements. ja[i] is the column number of the ith non-zero element. The lifecycle of this array is the same as that of the handle.

Input

ia

int *

(n+1)-dimensional array. ia[i] is the index of the first non-zero element in the ith row in all non-zero elements. The lifecycle of this array is the same as that of the handle.

Input

Return Values

Return Value

Type

Description

NO_ERROR

int

The execution is successful.

KML_SOLVER_INVALID_ARGUMENT

int

Invalid parameter.

Dependencies

#include "kml_iss.h"

Examples

C interface:
    KmlSolverTask *handle
    int n = 8;   
    double a[17] = { 1.0,1.0,2.0,9.0,2.0,1.0,-3.0,3.0,2.0,9.0,-5.0,6.0,1.0,4.0,1.0,7.0,2.0 };
    int ja[17] = { 0,3,4,1,2,3,5,2,7,3,6,4,5,5,7,6,7 };
    int ia[9] = {0, 3, 7, 9, 11, 13, 15, 16, 17};
    int ierr;
    ierr = KmlIssCgInitDI(&handle, n, a, ja, ia);