123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- #ifndef CERES_INTERNAL_CUDA_BLOCK_STRUCTURE_H_
- #define CERES_INTERNAL_CUDA_BLOCK_STRUCTURE_H_
- #include "ceres/internal/config.h"
- #ifndef CERES_NO_CUDA
- #include "ceres/block_structure.h"
- #include "ceres/cuda_buffer.h"
- namespace ceres::internal {
- class CudaBlockStructureTest;
- class CERES_NO_EXPORT CudaBlockSparseStructure {
- public:
-
-
-
- CudaBlockSparseStructure(const CompressedRowBlockStructure& block_structure,
- ContextImpl* context);
-
-
- CudaBlockSparseStructure(const CompressedRowBlockStructure& block_structure,
- const int num_col_blocks_e,
- ContextImpl* context);
- int num_rows() const { return num_rows_; }
- int num_cols() const { return num_cols_; }
- int num_cells() const { return num_cells_; }
- int num_nonzeros() const { return num_nonzeros_; }
-
-
- int num_nonzeros_e() const { return num_nonzeros_e_; }
- int num_row_blocks() const { return num_row_blocks_; }
- int num_row_blocks_e() const { return num_row_blocks_e_; }
- int num_col_blocks() const { return num_col_blocks_; }
-
-
-
-
-
- bool IsCrsCompatible() const { return is_crs_compatible_; }
-
-
- const int* first_cell_in_row_block() const {
- return first_cell_in_row_block_.data();
- }
-
-
- const int* value_offset_row_block_f() const {
- return value_offset_row_block_f_.data();
- }
-
- const Cell* cells() const { return cells_.data(); }
-
- const Block* row_blocks() const { return row_blocks_.data(); }
-
- const Block* col_blocks() const { return col_blocks_.data(); }
- private:
- int num_rows_;
- int num_cols_;
- int num_cells_;
- int num_nonzeros_;
- int num_nonzeros_e_;
- int num_row_blocks_;
- int num_row_blocks_e_;
- int num_col_blocks_;
- bool is_crs_compatible_;
- CudaBuffer<int> first_cell_in_row_block_;
- CudaBuffer<int> value_offset_row_block_f_;
- CudaBuffer<Cell> cells_;
- CudaBuffer<Block> row_blocks_;
- CudaBuffer<Block> col_blocks_;
- friend class CudaBlockStructureTest;
- };
- }
- #endif
- #endif
|