Frobby  0.9.5
BigTermRecorder.h
Go to the documentation of this file.
1 /* Frobby: Software for monomial ideal computations.
2  Copyright (C) 2007 Bjarke Hammersholt Roune (www.broune.com)
3 
4  This program is free software; you can redistribute it and/or modify
5  it under the terms of the GNU General Public License as published by
6  the Free Software Foundation; either version 2 of the License, or
7  (at your option) any later version.
8 
9  This program is distributed in the hope that it will be useful,
10  but WITHOUT ANY WARRANTY; without even the implied warranty of
11  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  GNU General Public License for more details.
13 
14  You should have received a copy of the GNU General Public License
15  along with this program. If not, see http://www.gnu.org/licenses/.
16 */
17 #ifndef BIG_TERM_RECORDER_GUARD
18 #define BIG_TERM_RECORDER_GUARD
19 
20 #include "BigTermConsumer.h"
21 #include "ElementDeleter.h"
22 
23 #include "VarNames.h"
24 
25 #include <list>
26 
27 class BigIdeal;
28 class TermTranslator;
29 
32 public:
34 
35  virtual void consumeRing(const VarNames& names);
36  virtual void beginConsuming();
37  virtual void consume(const Term& term, const TermTranslator& translator);
38  virtual void consume(const vector<mpz_class>& term);
39  virtual void doneConsuming();
40 
41  virtual void consume(auto_ptr<BigIdeal> ideal);
42 
43  // Returns true if this object currently stores no ideals.
44  bool empty() const;
45 
46  // Returns the least recently consumed ideal from this and returns it.
47  // It is a precondition that empty() is false.
48  auto_ptr<BigIdeal> releaseIdeal();
49 
50  // Returns the most recently consumed ring.
51  const VarNames& getRing();
52 
53 private:
55  size_t _idealCount;
56  list<BigIdeal*> _ideals; // zero entries are treated as if not there.
58 };
59 
60 #endif
BigTermRecorder records all the terms it consumes into an ideal.
ElementDeleter< list< BigIdeal * > > _idealsDeleter
bool empty() const
virtual void consumeRing(const VarNames &names)
Tell the consumer which ring is being used.
const VarNames & getRing()
list< BigIdeal * > _ideals
auto_ptr< BigIdeal > releaseIdeal()
virtual void doneConsuming()
Must be called once after each time beginConsuming has been called.
virtual void beginConsuming()
Tell the consumer to begin consuming an ideal.
virtual void consume(const Term &term, const TermTranslator &translator)
TermTranslator handles translation between terms whose exponents are infinite precision integers and ...
Term represents a product of variables which does not include a coefficient.
Definition: Term.h:49
Defines the variables of a polynomial ring and facilities IO involving them.
Definition: VarNames.h:40