/usr/include/polymake/polytope/gale_tools.h is in polymake 3.0r1-4.
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 | /* Copyright (c) 1997-2015
Ewgenij Gawrilow, Michael Joswig (Technische Universitaet Berlin, Germany)
http://www.polymake.org
This program is free software; you can redistribute it and/or modify it
under the terms of the GNU General Public License as published by the
Free Software Foundation; either version 2, or (at your option) any
later version: http://www.gnu.org/licenses/gpl.txt.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
--------------------------------------------------------------------------------
*/
#ifndef __POLYMAKE_GALE_TOOLS_H
#define __POLYMAKE_GALE_TOOLS_H
namespace polymake { namespace polytope {
template <typename MatrixTop, typename E>
Matrix<E> balance(const GenericMatrix<MatrixTop, E>& _G)
{
// Given a matrix of vectors in R^d (actually, R^{n-d}), we want to
// scale d of them by positive coefficients so that the entire set
// of vectors has the origin as barycenter. To do this, we
// exhaustively check all d-tuples of vectors for feasibility.
Matrix<E> G (_G);
const int n = G.rows(), d = G.cols();
Vector<E> coeffs;
bool success (false);
for (Entire<Subsets_of_k<const sequence&> >::const_iterator r(entire(all_subsets_of_k(sequence(0,n),d))); !r.at_end() && !success; ++r) {
Set<int> comp (sequence(0,n)), rset(*r);
comp -= rset;
const Vector<E> mbarycenter = - ones_vector<E>(comp.size()) * G.minor(comp,All);
try {
coeffs = lin_solve(T(G.minor(rset,All)), mbarycenter);
} catch (const linalg_error& e) {
continue;
}
success = accumulate(coeffs, operations::min()) > 0;
if (success) {
Entire<Set<int> >::const_iterator sit = entire(rset);
typename Entire<Vector<E> >::const_iterator vit = entire(coeffs);
for (; !sit.at_end() && !vit.at_end(); ++sit, ++vit)
G.row(*sit) *= *vit;
}
}
if (!success)
throw std::runtime_error("Could not balance the Gale diagram. This shouldn't have happened.");
return G;
}
} } // namespaces
#endif // __POLYMAKE_GALE_TOOLS_H
// Local Variables:
// mode:C++
// c-basic-offset:3
// indent-tabs-mode:nil
// End:
|