This file is indexed.

/usr/include/frobby.h is in libfrobby-dev 0.9.0-5.

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
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
/* Frobby: Software for monomial ideal computations.
   Copyright (C) 2007 Bjarke Hammersholt Roune (www.broune.com)

   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 of the License, or
   (at your option) any later version.

   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.

   You should have received a copy of the GNU General Public License
   along with this program.  If not, see http://www.gnu.org/licenses/.
*/
#ifndef FROBBY_INCLUSION_GUARD
#define FROBBY_INCLUSION_GUARD

// This file contains the public library interface of Frobby.

#include "gmp.h"

/** The namespace FrobbyImpl is for internal use inside Frobby only.
 It is not part of the public interface of Frobby.
*/
namespace FrobbyImpl {
  class FrobbyIdealHelper;
}

/** The namespace Frobby contains the public interface of Frobby. */
namespace Frobby {
  class Ideal {
  public:
    // Construct an ideal with variableCount variables.
    Ideal(size_t variableCount);
    Ideal(const Ideal& ideal);
    ~Ideal();

    Ideal& operator=(const Ideal& ideal);

    /** Call addExponent once for each variable to add a term one
     exponent at a time. This object keeps track of how many times you
     called addExponent to know which variable is to be raised to the
     passed-in exponent. Frobby does not alter the passed-in exponent
     and retains no reference to it. The exponent must be
     non-negative. It is allowed to mix the different overloads even
     within the same term.

     If the number of variables is zero, then a call to addExponent
     adds the element 1 as a generator. In that case it makes no
     difference what the value of exponent is.
    */
    void addExponent(const mpz_t exponent);
    void addExponent(int exponent);
    void addExponent(unsigned int exponent);

  private:
    friend class FrobbyImpl::FrobbyIdealHelper;
    FrobbyImpl::FrobbyIdealHelper* _data;
  };

  /** This class provides a way to get monomial ideals as output from
   Frobby one generator at a time. Many computations performed by
   Frobby can produce output continously instead of having to wait for
   the computation to be done to be able to produce any output. Often
   the output can be processed, such as writing it to disk, as it is
   produced, and in these cases there is no reason to store all of the
   output before processing any of it. Often just storing the output
   can consume many times the amount of memory Frobby otherwise needs
   to carry out the computation.
  */
  class IdealConsumer {
  public:
    /** The provided implementation does nothing. */
    virtual ~IdealConsumer();

    /** Called before output of a monomial ideal. varCount is the
     number of variables of the ring within which the output ideal
     lies. The provided implementation does nothing.
    */
    virtual void idealBegin(size_t varCount);

    /** For output of a generator of the ideal. exponentVector is an
     array containing the exponents of the generator.

     The parameter exponentVector and its entries must not be altered
     or deallocated, and no reference to them can be retained after
     the consume method has returned. If the output must be stored,
     then a copy must be made.
    */
    virtual void consume(mpz_ptr* exponentVector) = 0;

    /** Called after output of a monomial ideal. The provided
     implementation does nothing.
    */
    virtual void idealEnd();
  };

  /** This class provides a way to get polynomials as output from
   Frobby one term at a time. Many computations performed by Frobby
   can produce output continously instead of having to wait for the
   computation to be done to be able to produce any output. Often the
   output can be processed, such as writing it to disk, as it is
   produced, and in these cases there is no reason to store all of the
   output before processing any of it. Often just storing the output
   can consume many times the amount of memory Frobby otherwise needs
   to carry out the computation.
  */
  class PolynomialConsumer {
  public:
    /** The provided implementation does nothing. */
    virtual ~PolynomialConsumer();

    /** Called before output of a polynomial. varCount is the number
     of variables in the ring within which the output polynomial
     lies. The provided implementation does nothing.
    */
    virtual void polynomialBegin(size_t varCount);

    /** For output of a term of the polynomial. coefficient contains
     the coefficient of the term, and exponentVector is an array
     containing the exponents of the term.

     The parameters coefficient, exponentVector and its entries must
     not be altered or deallocated, and no reference to them can be
     retained after the consume method has returned. If the output
     must be stored, then a copy must be made.
    */
    virtual void consume(const mpz_t coefficient, mpz_ptr* exponentVector) = 0;

    /** Called after output of a polynomial. The provided
     implementation does nothing.
    */
    virtual void polynomialEnd();
  };

  /** Compute the Alexander dual of ideal using the point
   reflectionMonomial. The minimal generators of the dual are provided
   to the consumer in some arbitrary order. If reflectionMonomial is
   null (i.e. equal to 0), then the lcm of the minimal generators of
   ideal are used. Note that this lcm does not include any non-minimal
   generators that may have been added to ideal. If reflectionMonomial
   is not null, then it must be divisible by this lcm. This function
   returns true if and only if reflectionMonomial is valid.

   The parameter reflectionMonomial must be either null or an array of
   size at least the number of variables of ideal. Frobby does not
   alter or retain a reference to the passed-in reflectionMonomial or
   its elements.  This is also true when the consumer gets called, so
   it is allowed for the consumer to change or delete
   reflectionMonomial. The overload taking an Ideal for
   reflectionMonomial simply uses the generator of that ideal, and it
   is required that there be exactly one generator.

   @todo don't use exceptions to propagate false internally.
  */
  bool alexanderDual(const Ideal& ideal,
                     const mpz_t* reflectionMonomial,
                     IdealConsumer& consumer);

  /** @todo doc. and test */
  bool alexanderDual(const Ideal& ideal,
                     const Ideal& reflectionMonomial,
                     IdealConsumer& consumer);

  /** Compute the multigraded Hilbert-Poincare series of ideal. More
   precisely, compute the numerator polynomial of the series expressed
   as a rational function with (1-x1)...(1-xn) in the denominator
   where x1,...,xn are the variables in the polynomial ring. The
   multigraded Hilbert-Poincare series of a monomial ideal is the
   possibly infinite sum of all monomials not in that ideal.
  */
  void multigradedHilbertPoincareSeries(const Ideal& ideal,
                                        PolynomialConsumer& consumer);

  /** Compute the univariate Hilbert-Poincare series of ideal. The
   univariate series can be obtained from the multigraded one by
   substituting the same variable for each other variable. The
   univariate series thus lives in a ring with one variable only.
  */
  void univariateHilbertPoincareSeries(const Ideal& ideal,
                                       PolynomialConsumer& consumer);

  /** Compute the irreducible decomposition of ideal. Every monomial
   ideal can be written uniquely as the irredundant intersection of
   irreducible monomial ideals, and each intersectand in this
   intersection is called an irreducible component. A monomial ideal
   is irreducible if and only if each minimal generator is a pure
   power, i.e. has the form x^e for a variable x and an integer
   exponent e.

   The output is each of the irreducible components. These are
   provided to the consumer in some arbitrary order. The ideal
   generated by the identity has no irreducible components, since the
   intersection of no ideals is the entire ring, i.e. the ideal
   generated by the identity. The output for the zero ideal is a
   single ideal which is the zero ideal itself, which is also an
   irreducible ideal since it is generated by the empty set, which is
   trivially a set of pure powers.
  */
  void irreducibleDecompositionAsIdeals(const Ideal& ideal,
                                        IdealConsumer& consumer);

  /** Compute the irreducible decomposition of ideal, and encode each
   irreducible component as a monomial. This is done by multiplyng the
   minimal generators of the irreducible ideal, which defines a
   bijection between irreducible monomial ideals and monomials.

   Note that the ideal generated by the identity has no irreducible
   components, so the output is the zero ideal, since that ideal has
   no generators.

   The zero ideal as input presents a problem, since no monomial
   corresponds to the zero ideal, which would be the correct
   output. If ideal is the zero ideal, then there is no output
   (i.e. idealBegin does not get called on the consumer), and the
   return value is false. Otherwise the return value is true.

   @todo This can be improved to have no special cases, since the zero
   ideal does correpond to the identity, since the product of the
   zero ideal's generators is the empty product, which is the
   identity. At the same time we don't need the identity otherwise,
   since the whole ring is always redundant as an intersectand.
  */
  bool irreducibleDecompositionAsMonomials(const Ideal& ideal,
                                           IdealConsumer& consumer);

  /** Compute the maximal standard monomials of ideal. A standard
   monomial of an ideal is a monomial that does not lie in that
   ideal. A maximal standard monomial is a standard monomial m such
   that mx is not standard for each variable x in the polynomial ring
   within which the ideal resides.

   Note that many ideals have no maximal standard
   monomials. E.g. every monomial is a standard monomial of the zero
   ideal, so none of them are maximal. In contrast, the ideal
   generated by the identity has no standard monomials, maximal or
   otherwise.

   The maximal standard monomials are output to the consumer as the
   generators of a single ideal. If ideal has no maximal standard
   monomials, then the output is the zero ideal.
  */
  void maximalStandardMonomials(const Ideal& ideal,
                                IdealConsumer& consumer);

  /** Solve the optimization program

      maximize l*d subject to d being the exponent vector of a maximal
      standard monomial of ideal

   If ideal has any maximal standard monomials, then the return value
   is true, and an ideal with a single generator representing an
   optimal solution to the optimization program is written to the
   consumer. If ideal has no maximal standard monomials, then the
   return value is false, and nothing is written to the consumer.

   l must be an array of at least ideal.getVarCount() entries.

   The algorithm used is significantly faster than computing all the
   maximal standard monomials and seeing which exponent vector yields
   a maximum value.
  */
  bool solveStandardMonomialProgram(const Ideal& ideal,
                                    const mpz_t* l,
                                    IdealConsumer& consumer);

  /** Compute the codimension of a monomial ideal.

      We define the codimension by the property that the sum of the
      Krull dimension and codimension is the number of variables in
      the ambient polynomial ring of the ideal. Thus the codimension
      of the ideal that is generated by the identity is the number of
      variables plus one.

      The codimension of a monomial ideal is the minimal size of
      support among the irreducible components of that ideal.

      @param codim This mpz_t must be initialized before calling this
      function. It will be set to the codimension.
   */
  void codimension(const Ideal& ideal, mpz_t codim);

  /** Compute the Krull dimension of a monomial ideal.

      Note that by convention the ideal generated by the identity has
      dimension -1. The sum of the dimension and codimension is the
      number of variables in the ambient polynomial ring of the ideal.

      @param codim This mpz_t must be initialized before calling this
      function. It will be set to the dimension.
   */
  void dimension(const Ideal& ideal, mpz_t dim);

  /** Compute the canonical primary decomposition of a monomial ideal.

   This is defined as the primary decomposition where each primary
   component is the intersection of the irreducible components with
   that same support. I.e. the set of irreducible components of the
   canonical primary components are precisely the irreducible
   components of the ideal itself. So each canonical primary component
   has as few irreducible components as possible. This is not true of
   just any primary decomposition.

   Each canonical primary component is provided to the consumer as a
   separate ideal in an arbitrary order.
  */
  void primaryDecomposition(const Ideal& ideal, IdealConsumer& consumer);

  /** Compute the associated primes of the ideal.

   The prime ideals are passed to the consumer in arbitrary order. */
  void associatedPrimes(const Ideal& ideal, IdealConsumer& consumer);
}

#endif