/usr/include/polybori/groebner/HasTRepOrExtendedProductCriterion.h is in libpolybori-groebner-dev 0.8.3-5build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | // -*- c++ -*-
//*****************************************************************************
/** @file HasTRepOrExtendedProductCriterion.h
*
* @author Michael Brickenstein
* @date 2011-06-30
*
* This file includes the definition of the class @c HasTRepOrExtendedProductCriterion.
*
* @par Copyright:
* (c) 2006-2010 by The PolyBoRi Team
*
**/
//*****************************************************************************
#ifndef polybori_groebner_HasTRepOrExtendedProductCriterion_h_
#define polybori_groebner_HasTRepOrExtendedProductCriterion_h_
// include basic definitions
#include "groebner_defs.h"
#include "GroebnerStrategy.h"
BEGIN_NAMESPACE_PBORIGB
inline bool
extended_product_criterion(const PolyEntry& m, const PolyEntry& m2){
//BooleMonomial m;
///@todo need GCDdeg
bool res=(m.lead.GCD(m2.lead).deg()==common_literal_factors_deg(m.literal_factors, m2.literal_factors));
//if (res)
// cout<<"EXTENDED PRODUCT_CRIT";
return res;
}
/** @class HasTRepOrExtendedProductCriterion
* @brief This class defines HasTRepOrExtendedProductCriterion.
*
**/
class HasTRepOrExtendedProductCriterion{
public:
GroebnerStrategy* strat;
int j;
HasTRepOrExtendedProductCriterion(GroebnerStrategy& strat, int j){
this->strat=&strat;
this->j=j;
}
bool operator() (const Monomial &m){
int i = strat->generators.index(m);
if (strat->pairs.status.hasTRep(i,j))
return true;
if (extended_product_criterion(const_cast<const GroebnerStrategy*>(strat)->generators[i],const_cast<const GroebnerStrategy*>(strat)->generators[j])){
strat->pairs.status.setToHasTRep(i,j);
strat->extendedProductCriterions++;
return true;
}
return false;
}
bool operator() (const Exponent &m){
int i;
i=strat->generators.index(m);
if (strat->pairs.status.hasTRep(i,j))
return true;
if (extended_product_criterion(const_cast<const GroebnerStrategy*>(strat)->generators[i],const_cast<const GroebnerStrategy*>(strat)->generators[j])){
strat->pairs.status.setToHasTRep(i,j);
strat->extendedProductCriterions++;
return true;
}
return false;
}
};
END_NAMESPACE_PBORIGB
#endif /* polybori_HasTRepOrExtendedProductCriterion_h_ */
|