27 #ifndef CASADI_SPARSITY_INTERNAL_HPP
28 #define CASADI_SPARSITY_INTERNAL_HPP
30 #include "sparsity.hpp"
31 #include "shared_object_internal.hpp"
36 class CASADI_EXPORT SparsityInternal :
public SharedObjectInternal {
47 std::vector<casadi_int> sp_;
54 std::vector<casadi_int> rowperm, colperm;
55 std::vector<casadi_int> rowblock, colblock;
56 std::vector<casadi_int> coarse_rowblock, coarse_colblock;
68 SparsityInternal(casadi_int nrow, casadi_int ncol,
69 const casadi_int* colind,
const casadi_int* row);
72 ~SparsityInternal()
override;
77 inline const std::vector<casadi_int>& sp()
const {
return sp_;}
82 inline casadi_int size1()
const {
return sp_[0];}
87 inline casadi_int size2()
const {
return sp_[1];}
92 inline const casadi_int* colind()
const {
return &sp_.front()+2;}
97 inline const casadi_int* row()
const {
return colind()+size2()+1;}
100 inline casadi_int nnz()
const {
return colind()[size2()];}
107 Sparsity get_diag(std::vector<casadi_int>& mapping)
const;
110 bool has_diag()
const;
113 Sparsity drop_diag()
const;
122 casadi_int dfs(casadi_int j, casadi_int top, std::vector<casadi_int>& xi,
123 std::vector<casadi_int>& pstack,
124 const std::vector<casadi_int>& pinv, std::vector<bool>& marked)
const;
133 casadi_int scc(std::vector<casadi_int>& p, std::vector<casadi_int>& r)
const;
142 std::vector<casadi_int> amd()
const;
154 static void etree(
const casadi_int* sp, casadi_int* parent, casadi_int *w, casadi_int ata);
164 static casadi_int postorder_dfs(casadi_int j, casadi_int k, casadi_int* head,
165 const casadi_int* next, casadi_int* post, casadi_int* stack);
177 static void postorder(
const casadi_int* parent, casadi_int n, casadi_int* post, casadi_int* w);
187 static casadi_int leaf(casadi_int i, casadi_int j,
const casadi_int* first,
188 casadi_int* maxfirst,
189 casadi_int* prevleaf, casadi_int* ancestor, casadi_int* jleaf);
201 static casadi_int qr_counts(
const casadi_int* tr_sp,
const casadi_int* parent,
202 const casadi_int* post, casadi_int* counts, casadi_int* w);
215 static casadi_int qr_nnz(
const casadi_int* sp, casadi_int* pinv, casadi_int* leftmost,
216 const casadi_int* parent, casadi_int* nrow_ext, casadi_int* w);
226 static void qr_init(
const casadi_int* sp,
const casadi_int* sp_tr,
227 casadi_int* leftmost, casadi_int* parent, casadi_int* pinv,
228 casadi_int* nrow_ext, casadi_int* v_nnz, casadi_int* r_nnz, casadi_int* w);
246 static void qr_sparsities(
247 const casadi_int* sp_a, casadi_int nrow_ext, casadi_int* sp_v, casadi_int* sp_r,
248 const casadi_int* leftmost,
const casadi_int* parent,
const casadi_int* pinv,
263 static void ldl_colind(
const casadi_int* sp, casadi_int* parent,
264 casadi_int* l_colind, casadi_int* w);
276 static void ldl_row(
const casadi_int* sp,
const casadi_int* parent,
277 casadi_int* l_colind, casadi_int* l_row, casadi_int *w);
287 Sparsity transpose(std::vector<casadi_int>& mapping,
bool invert_mapping=
false)
const;
290 bool is_transpose(
const SparsityInternal& y)
const;
293 bool is_reshape(
const SparsityInternal& y)
const;
302 void bfs(casadi_int n, std::vector<casadi_int>& wi, std::vector<casadi_int>& wj,
303 std::vector<casadi_int>& queue,
const std::vector<casadi_int>& imatch,
304 const std::vector<casadi_int>& jmatch, casadi_int mark)
const;
314 casadi_int n,
const std::vector<casadi_int>& wj,
const std::vector<casadi_int>& imatch,
315 std::vector<casadi_int>& p, std::vector<casadi_int>& q, std::vector<casadi_int>& cc,
316 std::vector<casadi_int>& rr, casadi_int set, casadi_int mark);
325 static void unmatched(casadi_int m,
const std::vector<casadi_int>& wi,
326 std::vector<casadi_int>& p, std::vector<casadi_int>& rr, casadi_int set);
335 static casadi_int rprune(casadi_int i, casadi_int j,
double aij,
void *other);
344 static casadi_int drop(casadi_int (*fkeep)(casadi_int, casadi_int,
double,
void *),
void *other,
345 casadi_int nrow, casadi_int ncol,
346 std::vector<casadi_int>& colind, std::vector<casadi_int>& row);
349 casadi_int btf(std::vector<casadi_int>& rowperm, std::vector<casadi_int>& colperm,
350 std::vector<casadi_int>& rowblock, std::vector<casadi_int>& colblock,
351 std::vector<casadi_int>& coarse_rowblock,
352 std::vector<casadi_int>& coarse_colblock)
const {
353 T()->dmperm(colperm, rowperm, colblock, rowblock,
354 coarse_colblock, coarse_rowblock);
355 return rowblock.size()-1;
359 const Btf& btf()
const;
368 void dmperm(std::vector<casadi_int>& rowperm, std::vector<casadi_int>& colperm,
369 std::vector<casadi_int>& rowblock, std::vector<casadi_int>& colblock,
370 std::vector<casadi_int>& coarse_rowblock,
371 std::vector<casadi_int>& coarse_colblock)
const;
380 void maxtrans(std::vector<casadi_int>& imatch,
381 std::vector<casadi_int>& jmatch, Sparsity& trans, casadi_int seed)
const;
390 void augment(casadi_int k, std::vector<casadi_int>& jmatch,
391 casadi_int *cheap, std::vector<casadi_int>& w, casadi_int *js,
392 casadi_int *is, casadi_int *ps)
const;
403 static std::vector<casadi_int> randperm(casadi_int n, casadi_int seed);
408 static std::vector<casadi_int> invertPermutation(
const std::vector<casadi_int>& p);
411 Sparsity permute(
const std::vector<casadi_int>& pinv,
412 const std::vector<casadi_int>& q, casadi_int values)
const;
421 void permute(
const std::vector<casadi_int>& pinv,
422 const std::vector<casadi_int>& q, casadi_int values,
423 std::vector<casadi_int>& colind_C,
424 std::vector<casadi_int>& row_C)
const;
433 static casadi_int wclear(casadi_int mark, casadi_int lemax, casadi_int *w, casadi_int n);
442 static casadi_int diag(casadi_int i, casadi_int j,
double aij,
void *other);
451 Sparsity multiply(
const Sparsity& B)
const;
460 casadi_int scatter(casadi_int j, std::vector<casadi_int>& w, casadi_int mark,
461 casadi_int* Ci, casadi_int nz)
const;
464 std::vector<casadi_int> get_row()
const;
467 std::vector<casadi_int> get_colind()
const;
470 std::vector<casadi_int> get_col()
const;
473 Sparsity _resize(casadi_int nrow, casadi_int ncol)
const;
476 Sparsity _reshape(casadi_int nrow, casadi_int ncol)
const;
479 casadi_int numel()
const;
482 casadi_int nnz_lower(
bool strictly=
false)
const;
485 casadi_int nnz_upper(
bool strictly=
false)
const;
488 casadi_int nnz_diag()
const;
493 casadi_int bw_upper()
const;
498 casadi_int bw_lower()
const;
501 std::pair<casadi_int, casadi_int> size()
const;
504 bool is_scalar(
bool scalar_and_dense)
const;
512 bool is_empty(
bool both=
false)
const;
515 bool is_dense()
const;
525 bool is_column()
const;
530 bool is_vector()
const;
533 bool is_diag()
const;
536 bool is_square()
const;
541 bool is_permutation()
const;
546 bool is_selection(
bool allow_empty=
false)
const;
551 bool is_orthonormal(
bool allow_empty=
false)
const;
556 bool is_orthonormal_rows(
bool allow_empty=
false)
const;
561 bool is_orthonormal_columns(
bool allow_empty=
false)
const;
564 bool is_symmetric()
const;
567 bool is_tril(
bool strictly)
const;
570 bool is_triu(
bool strictly)
const;
573 Sparsity _triu(
bool includeDiagonal)
const;
576 Sparsity _tril(
bool includeDiagonal)
const;
579 std::vector<casadi_int> get_lower()
const;
582 std::vector<casadi_int> get_upper()
const;
585 std::string dim(
bool with_nz=
false)
const;
588 std::string repr_el(casadi_int k)
const;
591 Sparsity _mtimes(
const Sparsity& y)
const;
595 Sparsity combine(
const Sparsity& y,
bool f0x_is_zero,
bool function0_is_zero,
596 std::vector<unsigned char>& mapping)
const;
597 Sparsity combine(
const Sparsity& y,
bool f0x_is_zero,
bool function0_is_zero)
const;
599 template<
bool with_mapping>
600 Sparsity combineGen1(
const Sparsity& y,
bool f0x_is_zero,
bool function0_is_zero,
601 std::vector<unsigned char>& mapping)
const;
603 template<
bool with_mapping,
bool f0x_is_zero,
bool function0_is_zero>
604 Sparsity combineGen(
const Sparsity& y, std::vector<unsigned char>& mapping)
const;
608 bool is_subset(
const Sparsity& rhs)
const;
611 Sparsity pattern_inverse()
const;
614 bool is_equal(
const Sparsity& y)
const;
617 bool is_equal(casadi_int y_nrow, casadi_int y_ncol,
const std::vector<casadi_int>& y_colind,
618 const std::vector<casadi_int>& y_row)
const;
621 bool is_equal(casadi_int y_nrow, casadi_int y_ncol,
622 const casadi_int* y_colind,
const casadi_int* y_row)
const;
625 bool is_stacked(
const Sparsity& y, casadi_int n)
const;
628 Sparsity _enlargeRows(casadi_int nrow,
const std::vector<casadi_int>& rr,
bool ind1)
const;
631 Sparsity _enlargeColumns(casadi_int ncol,
const std::vector<casadi_int>& cc,
bool ind1)
const;
634 Sparsity makeDense(std::vector<casadi_int>& mapping)
const;
637 Sparsity _erase(
const std::vector<casadi_int>& rr,
const std::vector<casadi_int>& cc,
638 bool ind1, std::vector<casadi_int>& mapping)
const;
641 Sparsity _erase(
const std::vector<casadi_int>& rr,
bool ind1,
642 std::vector<casadi_int>& mapping)
const;
645 Sparsity _appendVector(
const SparsityInternal& sp)
const;
648 Sparsity _appendColumns(
const SparsityInternal& sp)
const;
656 Sparsity sub(
const std::vector<casadi_int>& rr,
const std::vector<casadi_int>& cc,
657 std::vector<casadi_int>& mapping,
bool ind1)
const;
665 Sparsity sub(
const std::vector<casadi_int>& rr,
const SparsityInternal& sp,
666 std::vector<casadi_int>& mapping,
bool ind1)
const;
669 casadi_int get_nz(casadi_int rr, casadi_int cc)
const;
672 std::vector<casadi_int> get_nz(
const std::vector<casadi_int>& rr,
673 const std::vector<casadi_int>& cc)
const;
676 void get_nz(std::vector<casadi_int>& indices)
const;
679 bool rowsSequential(
bool strictly)
const;
687 Sparsity _removeDuplicates(std::vector<casadi_int>& mapping)
const;
690 void find(std::vector<casadi_int>& loc,
bool ind1)
const;
693 std::size_t hash()
const;
696 std::string class_name()
const override {
return "SparsityInternal";}
699 void disp(std::ostream& stream,
bool more)
const override;
707 Sparsity uni_coloring(
const Sparsity& AT, casadi_int cutoff)
const;
714 Sparsity star_coloring(casadi_int ordering, casadi_int cutoff)
const;
721 Sparsity star_coloring2(casadi_int ordering, casadi_int cutoff)
const;
724 std::vector<casadi_int> largest_first()
const;
727 Sparsity pmult(
const std::vector<casadi_int>& p,
bool permute_rows=
true,
bool permute_cols=
true,
728 bool invert_permutation=
false)
const;
733 void spy(std::ostream &stream)
const;
736 void spy_matlab(
const std::string& mfile)
const;
741 void export_code(
const std::string& lang, std::ostream &stream,
742 const Dict& options)
const;
745 void spsolve(bvec_t* X, bvec_t* B,
bool tr)
const;
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.