diff --git a/Geo/ChainComplex.cpp b/Geo/ChainComplex.cpp index 7b8375bbaad3d24e41bc33f3353d187f0641c14d..ff44be42f9ec8971d9deb72aef7914da7a44f22f 100644 --- a/Geo/ChainComplex.cpp +++ b/Geo/ChainComplex.cpp @@ -48,12 +48,10 @@ ChainComplex::ChainComplex(CellComplex* cellComplex, int domain) lastCols = cols; if(cols == 0){ // no dim-cells, no map - //_HMatrix[dim] = create_gmp_matrix_zero(rows, 1); _HMatrix[dim] = NULL; } else if(rows == 0){ // no dim-1-cells, maps everything to zero _HMatrix[dim] = create_gmp_matrix_zero(1, cols); - //_HMatrix[dim] = NULL; } else{ mpz_t elem; @@ -315,16 +313,13 @@ void ChainComplex::computeHomology(bool dual) lowDim = getDim()+1-i; highDim = getDim()+1-(i+1); setDim = highDim; - //KerCod(lowDim); } else{ lowDim = i; highDim = i+1; setDim = lowDim; - //KerCod(highDim); } - KerCod(highDim); // 1) no edges, but zero cells @@ -342,7 +337,7 @@ void ChainComplex::computeHomology(bool dual) } // 2) this dimension is empty - else if(getHMatrix(lowDim) == NULL && getHMatrix(highDim) == NULL){ + else if(getHMatrix(lowDim) == NULL){ setHbasis(setDim, NULL); } // 3) No higher dimension cells -> none of the cycles are boundaries @@ -387,13 +382,9 @@ void ChainComplex::computeHomology(bool dual) } } - //destroy_gmp_matrix(getKerHMatrix(lowDim)); - //destroy_gmp_matrix(getCodHMatrix(lowDim)); destroy_gmp_matrix(getJMatrix(lowDim)); destroy_gmp_matrix(getQMatrix(lowDim)); - //setKerHMatrix(lowDim, NULL); - //setCodHMatrix(lowDim, NULL); setJMatrix(lowDim, NULL); setQMatrix(lowDim, NULL); } @@ -465,8 +456,6 @@ void ChainComplex::getBasisChain(std::map<Cell*, int, Less_Cell>& chain, if(basisMatrix == NULL || (int)gmp_matrix_cols(basisMatrix) < num) return; - //int rows = gmp_matrix_rows(basisMatrix); - int elemi; long int elemli; mpz_t elem; @@ -508,7 +497,8 @@ int ChainComplex::getBasisSize(int dim, int basis) else if(basis == 3) basisMatrix = getBasis(dim, 3); else return 0; - if(basisMatrix != NULL) return gmp_matrix_cols(basisMatrix); + if(basisMatrix != NULL && gmp_matrix_rows(basisMatrix) != 0) + return gmp_matrix_cols(basisMatrix); else return 0; } @@ -645,7 +635,7 @@ bool ChainComplex::deformChain(std::map<Cell*, int, Less_Cell>& cells, void ChainComplex::smoothenChain(std::map<Cell*, int, Less_Cell>& cells) { - if(!_cellComplex->simplicial() || cells.empty()) return; + if(!_cellComplex->simplicial() || cells.size() < 2) return; int dim = cells.begin()->first->getDim(); int start = cells.size(); @@ -653,10 +643,8 @@ void ChainComplex::smoothenChain(std::map<Cell*, int, Less_Cell>& cells) for(int i = 0; i < 20; i++){ int size = cells.size(); for(citer cit = cells.begin(); cit != cells.end(); cit++){ - //if(!deformChain(*cit, false) && getDim() == 2) deformChain(*cit, true); if(dim == 2) deformChain(cells, *cit, true); deformChain(cells, *cit, false); - } deImmuneCells(cells);