mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-02-25 18:55:30 -06:00
Merge duplicate functions
This commit is contained in:
parent
6ca5f167b2
commit
448af67ce6
@ -52,103 +52,7 @@ BILU0<block_size>::BILU0(ILUReorder opencl_ilu_reorder_, int verbosity_) :
|
|||||||
template <unsigned int block_size>
|
template <unsigned int block_size>
|
||||||
bool BILU0<block_size>::analyze_matrix(BlockedMatrix *mat)
|
bool BILU0<block_size>::analyze_matrix(BlockedMatrix *mat)
|
||||||
{
|
{
|
||||||
const unsigned int bs = block_size;
|
return analyze_matrix(mat, nullptr);
|
||||||
|
|
||||||
this->N = mat->Nb * block_size;
|
|
||||||
this->Nb = mat->Nb;
|
|
||||||
this->nnz = mat->nnzbs * block_size * block_size;
|
|
||||||
this->nnzb = mat->nnzbs;
|
|
||||||
|
|
||||||
std::vector<int> CSCRowIndices;
|
|
||||||
std::vector<int> CSCColPointers;
|
|
||||||
|
|
||||||
if (opencl_ilu_reorder == ILUReorder::NONE) {
|
|
||||||
LUmat = std::make_unique<BlockedMatrix>(*mat);
|
|
||||||
} else {
|
|
||||||
toOrder.resize(Nb);
|
|
||||||
fromOrder.resize(Nb);
|
|
||||||
CSCRowIndices.resize(nnzb);
|
|
||||||
CSCColPointers.resize(Nb + 1);
|
|
||||||
rmat = std::make_shared<BlockedMatrix>(mat->Nb, mat->nnzbs, block_size);
|
|
||||||
LUmat = std::make_unique<BlockedMatrix>(*rmat);
|
|
||||||
|
|
||||||
Timer t_convert;
|
|
||||||
csrPatternToCsc(mat->colIndices, mat->rowPointers, CSCRowIndices.data(), CSCColPointers.data(), mat->Nb);
|
|
||||||
if (verbosity >= 3) {
|
|
||||||
std::ostringstream out;
|
|
||||||
out << "BILU0 convert CSR to CSC: " << t_convert.stop() << " s";
|
|
||||||
OpmLog::info(out.str());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Timer t_analysis;
|
|
||||||
std::ostringstream out;
|
|
||||||
if (opencl_ilu_reorder == ILUReorder::LEVEL_SCHEDULING) {
|
|
||||||
out << "BILU0 reordering strategy: " << "level_scheduling\n";
|
|
||||||
findLevelScheduling(mat->colIndices, mat->rowPointers, CSCRowIndices.data(), CSCColPointers.data(), mat->Nb, &numColors, toOrder.data(), fromOrder.data(), rowsPerColor);
|
|
||||||
} else if (opencl_ilu_reorder == ILUReorder::GRAPH_COLORING) {
|
|
||||||
out << "BILU0 reordering strategy: " << "graph_coloring\n";
|
|
||||||
findGraphColoring<block_size>(mat->colIndices, mat->rowPointers, CSCRowIndices.data(), CSCColPointers.data(), mat->Nb, mat->Nb, mat->Nb, &numColors, toOrder.data(), fromOrder.data(), rowsPerColor);
|
|
||||||
} else if (opencl_ilu_reorder == ILUReorder::NONE) {
|
|
||||||
out << "BILU0 reordering strategy: none\n";
|
|
||||||
// numColors = 1;
|
|
||||||
// rowsPerColor.emplace_back(Nb);
|
|
||||||
numColors = Nb;
|
|
||||||
for (int i = 0; i < Nb; ++i) {
|
|
||||||
rowsPerColor.emplace_back(1);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
OPM_THROW(std::logic_error, "Error ilu reordering strategy not set correctly\n");
|
|
||||||
}
|
|
||||||
if (verbosity >= 1) {
|
|
||||||
out << "BILU0 analysis took: " << t_analysis.stop() << " s, " << numColors << " colors\n";
|
|
||||||
}
|
|
||||||
#if CHOW_PATEL
|
|
||||||
out << "BILU0 CHOW_PATEL: " << CHOW_PATEL << ", CHOW_PATEL_GPU: " << CHOW_PATEL_GPU;
|
|
||||||
#endif
|
|
||||||
OpmLog::info(out.str());
|
|
||||||
|
|
||||||
diagIndex.resize(mat->Nb);
|
|
||||||
invDiagVals.resize(mat->Nb * bs * bs);
|
|
||||||
|
|
||||||
#if CHOW_PATEL
|
|
||||||
Lmat = std::make_unique<BlockedMatrix>(mat->Nb, (mat->nnzbs - mat->Nb) / 2, bs);
|
|
||||||
Umat = std::make_unique<BlockedMatrix>(mat->Nb, (mat->nnzbs - mat->Nb) / 2, bs);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
s.invDiagVals = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(double) * bs * bs * mat->Nb);
|
|
||||||
s.rowsPerColor = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * (numColors + 1));
|
|
||||||
s.diagIndex = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * LUmat->Nb);
|
|
||||||
#if CHOW_PATEL
|
|
||||||
s.Lvals = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(double) * bs * bs * Lmat->nnzbs);
|
|
||||||
s.Lcols = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * Lmat->nnzbs);
|
|
||||||
s.Lrows = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * (Lmat->Nb + 1));
|
|
||||||
s.Uvals = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(double) * bs * bs * Lmat->nnzbs);
|
|
||||||
s.Ucols = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * Lmat->nnzbs);
|
|
||||||
s.Urows = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * (Lmat->Nb + 1));
|
|
||||||
#else
|
|
||||||
s.LUvals = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(double) * bs * bs * LUmat->nnzbs);
|
|
||||||
s.LUcols = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * LUmat->nnzbs);
|
|
||||||
s.LUrows = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * (LUmat->Nb + 1));
|
|
||||||
#endif
|
|
||||||
|
|
||||||
events.resize(2);
|
|
||||||
err = queue->enqueueWriteBuffer(s.invDiagVals, CL_FALSE, 0, mat->Nb * sizeof(double) * bs * bs, invDiagVals.data(), nullptr, &events[0]);
|
|
||||||
|
|
||||||
rowsPerColorPrefix.resize(numColors + 1); // resize initializes value 0.0
|
|
||||||
for (int i = 0; i < numColors; ++i) {
|
|
||||||
rowsPerColorPrefix[i + 1] = rowsPerColorPrefix[i] + rowsPerColor[i];
|
|
||||||
}
|
|
||||||
err |= queue->enqueueWriteBuffer(s.rowsPerColor, CL_FALSE, 0, (numColors + 1) * sizeof(int), rowsPerColorPrefix.data(), nullptr, &events[1]);
|
|
||||||
|
|
||||||
cl::WaitForEvents(events);
|
|
||||||
events.clear();
|
|
||||||
if (err != CL_SUCCESS) {
|
|
||||||
// enqueueWriteBuffer is C and does not throw exceptions like C++ OpenCL
|
|
||||||
OPM_THROW(std::logic_error, "BILU0 OpenCL enqueueWriteBuffer error");
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -162,25 +66,29 @@ bool BILU0<block_size>::analyze_matrix(BlockedMatrix *mat, BlockedMatrix *jacMat
|
|||||||
this->nnz = mat->nnzbs * block_size * block_size;
|
this->nnz = mat->nnzbs * block_size * block_size;
|
||||||
this->nnzb = mat->nnzbs;
|
this->nnzb = mat->nnzbs;
|
||||||
|
|
||||||
this->nnz_jm = jacMat->nnzbs * block_size * block_size;
|
|
||||||
this->nnzbs_jm = jacMat->nnzbs;
|
|
||||||
|
|
||||||
std::vector<int> CSCRowIndices;
|
std::vector<int> CSCRowIndices;
|
||||||
std::vector<int> CSCColPointers;
|
std::vector<int> CSCColPointers;
|
||||||
|
|
||||||
|
auto *matToDecompose = jacMat ? jacMat : mat; // decompose jacMat if valid, otherwise decompose mat
|
||||||
|
|
||||||
if (opencl_ilu_reorder == ILUReorder::NONE) {
|
if (opencl_ilu_reorder == ILUReorder::NONE) {
|
||||||
LUmat = std::make_unique<BlockedMatrix>(*mat);
|
LUmat = std::make_unique<BlockedMatrix>(*mat);
|
||||||
} else {
|
} else {
|
||||||
toOrder.resize(Nb);
|
toOrder.resize(Nb);
|
||||||
fromOrder.resize(Nb);
|
fromOrder.resize(Nb);
|
||||||
CSCRowIndices.resize(nnzbs_jm);
|
CSCRowIndices.resize(matToDecompose->nnzbs);
|
||||||
CSCColPointers.resize(Nb + 1);
|
CSCColPointers.resize(Nb + 1);
|
||||||
rmat = std::make_shared<BlockedMatrix>(mat->Nb, mat->nnzbs, block_size);
|
rmat = std::make_shared<BlockedMatrix>(mat->Nb, mat->nnzbs, block_size);
|
||||||
rJacMat = std::make_shared<BlockedMatrix>(jacMat->Nb, jacMat->nnzbs, block_size);
|
|
||||||
LUmat = std::make_unique<BlockedMatrix>(*rJacMat);
|
if (jacMat) {
|
||||||
|
rJacMat = std::make_shared<BlockedMatrix>(jacMat->Nb, jacMat->nnzbs, block_size);
|
||||||
|
LUmat = std::make_unique<BlockedMatrix>(*rJacMat);
|
||||||
|
} else {
|
||||||
|
LUmat = std::make_unique<BlockedMatrix>(*rmat);
|
||||||
|
}
|
||||||
|
|
||||||
Timer t_convert;
|
Timer t_convert;
|
||||||
csrPatternToCsc(jacMat->colIndices, jacMat->rowPointers, CSCRowIndices.data(), CSCColPointers.data(), jacMat->Nb);
|
csrPatternToCsc(matToDecompose->colIndices, matToDecompose->rowPointers, CSCRowIndices.data(), CSCColPointers.data(), Nb);
|
||||||
if(verbosity >= 3){
|
if(verbosity >= 3){
|
||||||
std::ostringstream out;
|
std::ostringstream out;
|
||||||
out << "BILU0 convert CSR to CSC: " << t_convert.stop() << " s";
|
out << "BILU0 convert CSR to CSC: " << t_convert.stop() << " s";
|
||||||
@ -192,10 +100,10 @@ bool BILU0<block_size>::analyze_matrix(BlockedMatrix *mat, BlockedMatrix *jacMat
|
|||||||
std::ostringstream out;
|
std::ostringstream out;
|
||||||
if (opencl_ilu_reorder == ILUReorder::LEVEL_SCHEDULING) {
|
if (opencl_ilu_reorder == ILUReorder::LEVEL_SCHEDULING) {
|
||||||
out << "BILU0 reordering strategy: " << "level_scheduling\n";
|
out << "BILU0 reordering strategy: " << "level_scheduling\n";
|
||||||
findLevelScheduling(jacMat->colIndices, jacMat->rowPointers, CSCRowIndices.data(), CSCColPointers.data(), jacMat->Nb, &numColors, toOrder.data(), fromOrder.data(), rowsPerColor);
|
findLevelScheduling(matToDecompose->colIndices, matToDecompose->rowPointers, CSCRowIndices.data(), CSCColPointers.data(), Nb, &numColors, toOrder.data(), fromOrder.data(), rowsPerColor);
|
||||||
} else if (opencl_ilu_reorder == ILUReorder::GRAPH_COLORING) {
|
} else if (opencl_ilu_reorder == ILUReorder::GRAPH_COLORING) {
|
||||||
out << "BILU0 reordering strategy: " << "graph_coloring\n";
|
out << "BILU0 reordering strategy: " << "graph_coloring\n";
|
||||||
findGraphColoring<block_size>(jacMat->colIndices, jacMat->rowPointers, CSCRowIndices.data(), CSCColPointers.data(), jacMat->Nb, jacMat->Nb, jacMat->Nb, &numColors, toOrder.data(), fromOrder.data(), rowsPerColor);
|
findGraphColoring<block_size>(matToDecompose->colIndices, matToDecompose->rowPointers, CSCRowIndices.data(), CSCColPointers.data(), Nb, Nb, Nb, &numColors, toOrder.data(), fromOrder.data(), rowsPerColor);
|
||||||
} else if (opencl_ilu_reorder == ILUReorder::NONE) {
|
} else if (opencl_ilu_reorder == ILUReorder::NONE) {
|
||||||
out << "BILU0 reordering strategy: none\n";
|
out << "BILU0 reordering strategy: none\n";
|
||||||
// numColors = 1;
|
// numColors = 1;
|
||||||
@ -224,8 +132,6 @@ bool BILU0<block_size>::analyze_matrix(BlockedMatrix *mat, BlockedMatrix *jacMat
|
|||||||
Umat = std::make_unique<BlockedMatrix<block_size> >(mat->Nb, (mat->nnzbs - mat->Nb) / 2);
|
Umat = std::make_unique<BlockedMatrix<block_size> >(mat->Nb, (mat->nnzbs - mat->Nb) / 2);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
LUmat->nnzValues = new double[jacMat->nnzbs * bs * bs];
|
|
||||||
|
|
||||||
s.invDiagVals = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(double) * bs * bs * mat->Nb);
|
s.invDiagVals = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(double) * bs * bs * mat->Nb);
|
||||||
s.rowsPerColor = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * (numColors + 1));
|
s.rowsPerColor = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * (numColors + 1));
|
||||||
s.diagIndex = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * LUmat->Nb);
|
s.diagIndex = cl::Buffer(*context, CL_MEM_READ_WRITE, sizeof(int) * LUmat->Nb);
|
||||||
@ -266,95 +172,8 @@ bool BILU0<block_size>::analyze_matrix(BlockedMatrix *mat, BlockedMatrix *jacMat
|
|||||||
template <unsigned int block_size>
|
template <unsigned int block_size>
|
||||||
bool BILU0<block_size>::create_preconditioner(BlockedMatrix *mat)
|
bool BILU0<block_size>::create_preconditioner(BlockedMatrix *mat)
|
||||||
{
|
{
|
||||||
const unsigned int bs = block_size;
|
return create_preconditioner(mat, nullptr);
|
||||||
auto *m = mat;
|
}
|
||||||
|
|
||||||
if (opencl_ilu_reorder != ILUReorder::NONE) {
|
|
||||||
m = rmat.get();
|
|
||||||
Timer t_reorder;
|
|
||||||
reorderBlockedMatrixByPattern(mat, toOrder.data(), fromOrder.data(), rmat.get());
|
|
||||||
|
|
||||||
if (verbosity >= 3) {
|
|
||||||
std::ostringstream out;
|
|
||||||
out << "BILU0 reorder matrix: " << t_reorder.stop() << " s";
|
|
||||||
OpmLog::info(out.str());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: remove this copy by replacing inplace ilu decomp by out-of-place ilu decomp
|
|
||||||
// this copy can have mat or rmat ->nnzValues as origin, depending on the reorder strategy
|
|
||||||
Timer t_copy;
|
|
||||||
memcpy(LUmat->nnzValues, m->nnzValues, sizeof(double) * bs * bs * m->nnzbs);
|
|
||||||
|
|
||||||
if (verbosity >= 3) {
|
|
||||||
std::ostringstream out;
|
|
||||||
out << "BILU0 memcpy: " << t_copy.stop() << " s";
|
|
||||||
OpmLog::info(out.str());
|
|
||||||
}
|
|
||||||
|
|
||||||
#if CHOW_PATEL
|
|
||||||
chowPatelIlu.decomposition(queue.get(), context.get(),
|
|
||||||
LUmat.get(), Lmat.get(), Umat.get(),
|
|
||||||
invDiagVals.data(), diagIndex,
|
|
||||||
s.diagIndex, s.invDiagVals,
|
|
||||||
s.Lvals, s.Lcols, s.Lrows,
|
|
||||||
s.Uvals, s.Ucols, s.Urows);
|
|
||||||
#else
|
|
||||||
Timer t_copyToGpu;
|
|
||||||
|
|
||||||
events.resize(1);
|
|
||||||
err = queue->enqueueWriteBuffer(s.LUvals, CL_FALSE, 0, LUmat->nnzbs * bs * bs * sizeof(double), LUmat->nnzValues, nullptr, &events[0]);
|
|
||||||
|
|
||||||
std::call_once(pattern_uploaded, [&]() {
|
|
||||||
// find the positions of each diagonal block
|
|
||||||
// must be done after reordering
|
|
||||||
for (int row = 0; row < Nb; ++row) {
|
|
||||||
int rowStart = LUmat->rowPointers[row];
|
|
||||||
int rowEnd = LUmat->rowPointers[row + 1];
|
|
||||||
|
|
||||||
auto candidate = std::find(LUmat->colIndices + rowStart, LUmat->colIndices + rowEnd, row);
|
|
||||||
assert(candidate != LUmat->colIndices + rowEnd);
|
|
||||||
diagIndex[row] = candidate - LUmat->colIndices;
|
|
||||||
}
|
|
||||||
events.resize(4);
|
|
||||||
err |= queue->enqueueWriteBuffer(s.diagIndex, CL_FALSE, 0, Nb * sizeof(int), diagIndex.data(), nullptr, &events[1]);
|
|
||||||
err |= queue->enqueueWriteBuffer(s.LUcols, CL_FALSE, 0, LUmat->nnzbs * sizeof(int), LUmat->colIndices, nullptr, &events[2]);
|
|
||||||
err |= queue->enqueueWriteBuffer(s.LUrows, CL_FALSE, 0, (LUmat->Nb + 1) * sizeof(int), LUmat->rowPointers, nullptr, &events[3]);
|
|
||||||
});
|
|
||||||
|
|
||||||
cl::WaitForEvents(events);
|
|
||||||
events.clear();
|
|
||||||
if (err != CL_SUCCESS) {
|
|
||||||
// enqueueWriteBuffer is C and does not throw exceptions like C++ OpenCL
|
|
||||||
OPM_THROW(std::logic_error, "BILU0 OpenCL enqueueWriteBuffer error");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (verbosity >= 3) {
|
|
||||||
std::ostringstream out;
|
|
||||||
out << "BILU0 copy to GPU: " << t_copyToGpu.stop() << " s";
|
|
||||||
OpmLog::info(out.str());
|
|
||||||
}
|
|
||||||
|
|
||||||
Timer t_decomposition;
|
|
||||||
std::ostringstream out;
|
|
||||||
cl::Event event;
|
|
||||||
for (int color = 0; color < numColors; ++color) {
|
|
||||||
const unsigned int firstRow = rowsPerColorPrefix[color];
|
|
||||||
const unsigned int lastRow = rowsPerColorPrefix[color + 1];
|
|
||||||
if (verbosity >= 4) {
|
|
||||||
out << "color " << color << ": " << firstRow << " - " << lastRow << " = " << lastRow - firstRow << "\n";
|
|
||||||
}
|
|
||||||
OpenclKernels::ILU_decomp(firstRow, lastRow, s.LUvals, s.LUcols, s.LUrows, s.diagIndex, s.invDiagVals, Nb, block_size);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (verbosity >= 3) {
|
|
||||||
out << "BILU0 decomposition: " << t_decomposition.stop() << " s";
|
|
||||||
OpmLog::info(out.str());
|
|
||||||
}
|
|
||||||
#endif // CHOW_PATEL
|
|
||||||
|
|
||||||
return true;
|
|
||||||
} // end create_preconditioner()
|
|
||||||
|
|
||||||
|
|
||||||
template <unsigned int block_size>
|
template <unsigned int block_size>
|
||||||
@ -362,13 +181,18 @@ bool BILU0<block_size>::create_preconditioner(BlockedMatrix *mat, BlockedMatrix
|
|||||||
{
|
{
|
||||||
const unsigned int bs = block_size;
|
const unsigned int bs = block_size;
|
||||||
|
|
||||||
auto *jm = jacMat;
|
auto *matToDecompose = jacMat;
|
||||||
|
|
||||||
if (opencl_ilu_reorder != ILUReorder::NONE) {
|
if (opencl_ilu_reorder != ILUReorder::NONE) {
|
||||||
jm = rJacMat.get();
|
|
||||||
Timer t_reorder;
|
Timer t_reorder;
|
||||||
reorderBlockedMatrixByPattern(mat, toOrder.data(), fromOrder.data(), rmat.get());
|
if (jacMat) {
|
||||||
reorderBlockedMatrixByPattern(jacMat, toOrder.data(), fromOrder.data(), rJacMat.get());
|
matToDecompose = rJacMat.get();
|
||||||
|
reorderBlockedMatrixByPattern(mat, toOrder.data(), fromOrder.data(), rmat.get());
|
||||||
|
reorderBlockedMatrixByPattern(jacMat, toOrder.data(), fromOrder.data(), rJacMat.get());
|
||||||
|
} else {
|
||||||
|
matToDecompose = rmat.get();
|
||||||
|
reorderBlockedMatrixByPattern(mat, toOrder.data(), fromOrder.data(), rmat.get());
|
||||||
|
}
|
||||||
|
|
||||||
if (verbosity >= 3){
|
if (verbosity >= 3){
|
||||||
std::ostringstream out;
|
std::ostringstream out;
|
||||||
@ -380,7 +204,7 @@ bool BILU0<block_size>::create_preconditioner(BlockedMatrix *mat, BlockedMatrix
|
|||||||
// TODO: remove this copy by replacing inplace ilu decomp by out-of-place ilu decomp
|
// TODO: remove this copy by replacing inplace ilu decomp by out-of-place ilu decomp
|
||||||
// this copy can have mat or rmat ->nnzValues as origin, depending on the reorder strategy
|
// this copy can have mat or rmat ->nnzValues as origin, depending on the reorder strategy
|
||||||
Timer t_copy;
|
Timer t_copy;
|
||||||
memcpy(LUmat->nnzValues, jm->nnzValues, sizeof(double) * bs * bs * jm->nnzbs);
|
memcpy(LUmat->nnzValues, matToDecompose->nnzValues, sizeof(double) * bs * bs * matToDecompose->nnzbs);
|
||||||
|
|
||||||
if (verbosity >= 3){
|
if (verbosity >= 3){
|
||||||
std::ostringstream out;
|
std::ostringstream out;
|
||||||
|
@ -53,8 +53,6 @@ class BILU0 : public Preconditioner<block_size>
|
|||||||
using Base::err;
|
using Base::err;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
int nnz_jm; // number of nonzeroes of the matrix (scalar)
|
|
||||||
int nnzbs_jm; // number of blocks of the matrix
|
|
||||||
std::unique_ptr<BlockedMatrix> LUmat = nullptr;
|
std::unique_ptr<BlockedMatrix> LUmat = nullptr;
|
||||||
std::shared_ptr<BlockedMatrix> rmat = nullptr; // only used with PAR_SIM
|
std::shared_ptr<BlockedMatrix> rmat = nullptr; // only used with PAR_SIM
|
||||||
std::shared_ptr<BlockedMatrix> rJacMat = nullptr;
|
std::shared_ptr<BlockedMatrix> rJacMat = nullptr;
|
||||||
@ -95,11 +93,11 @@ public:
|
|||||||
|
|
||||||
// analysis, find reordering if specified
|
// analysis, find reordering if specified
|
||||||
bool analyze_matrix(BlockedMatrix *mat) override;
|
bool analyze_matrix(BlockedMatrix *mat) override;
|
||||||
bool analyze_matrix(BlockedMatrix *mat, BlockedMatrix *jacMat);
|
bool analyze_matrix(BlockedMatrix *mat, BlockedMatrix *jacMat) override;
|
||||||
|
|
||||||
// ilu_decomposition
|
// ilu_decomposition
|
||||||
bool create_preconditioner(BlockedMatrix *mat) override;
|
bool create_preconditioner(BlockedMatrix *mat) override;
|
||||||
bool create_preconditioner(BlockedMatrix *mat, BlockedMatrix *jacMat);
|
bool create_preconditioner(BlockedMatrix *mat, BlockedMatrix *jacMat) override;
|
||||||
|
|
||||||
// apply preconditioner, x = prec(y)
|
// apply preconditioner, x = prec(y)
|
||||||
void apply(const cl::Buffer& y, cl::Buffer& x) override;
|
void apply(const cl::Buffer& y, cl::Buffer& x) override;
|
||||||
|
@ -125,8 +125,8 @@ public:
|
|||||||
CPR(int verbosity, ILUReorder opencl_ilu_reorder);
|
CPR(int verbosity, ILUReorder opencl_ilu_reorder);
|
||||||
|
|
||||||
bool analyze_matrix(BlockedMatrix *mat) override;
|
bool analyze_matrix(BlockedMatrix *mat) override;
|
||||||
|
|
||||||
bool analyze_matrix(BlockedMatrix *mat, BlockedMatrix *jacMat) override;
|
bool analyze_matrix(BlockedMatrix *mat, BlockedMatrix *jacMat) override;
|
||||||
|
|
||||||
// set own Opencl variables, but also that of the bilu0 preconditioner
|
// set own Opencl variables, but also that of the bilu0 preconditioner
|
||||||
void setOpencl(std::shared_ptr<cl::Context>& context, std::shared_ptr<cl::CommandQueue>& queue) override;
|
void setOpencl(std::shared_ptr<cl::Context>& context, std::shared_ptr<cl::CommandQueue>& queue) override;
|
||||||
|
|
||||||
@ -135,7 +135,6 @@ public:
|
|||||||
void apply(const cl::Buffer& y, cl::Buffer& x) override;
|
void apply(const cl::Buffer& y, cl::Buffer& x) override;
|
||||||
|
|
||||||
bool create_preconditioner(BlockedMatrix *mat) override;
|
bool create_preconditioner(BlockedMatrix *mat) override;
|
||||||
|
|
||||||
bool create_preconditioner(BlockedMatrix *mat, BlockedMatrix *jacMat) override;
|
bool create_preconditioner(BlockedMatrix *mat, BlockedMatrix *jacMat) override;
|
||||||
|
|
||||||
int* getToOrder() override
|
int* getToOrder() override
|
||||||
|
Loading…
Reference in New Issue
Block a user