diff options
author | Jason Katz-Brown <jason@airbnb.com> | 2013-08-25 02:17:13 -0700 |
---|---|---|
committer | Jason Katz-Brown <jason@airbnb.com> | 2013-08-25 02:17:13 -0700 |
commit | 9306cb60c32082c5403931de0823a9fd5daa196c (patch) | |
tree | ca1b6eb695fdf3f0c2294e92416b272164bae642 /enumerator.h | |
parent | 8fb2c681cecc01b46b0f4ba02d5cc177c4747b1c (diff) |
Initial git commit.
Diffstat (limited to 'enumerator.h')
-rw-r--r-- | enumerator.h | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/enumerator.h b/enumerator.h new file mode 100644 index 0000000..03b5a6d --- /dev/null +++ b/enumerator.h @@ -0,0 +1,67 @@ +/* + * Quackle -- Crossword game artificial intelligence and analysis tool + * Copyright (C) 2005-2006 Jason Katz-Brown and John O'Laughlin. + * + * 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, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + * 02110-1301 USA + */ + +#ifndef QUACKLE_ENUMERATOR_H +#define QUACKLE_ENUMERATOR_H + +#include <vector> + +#include "bag.h" + +using namespace std; + +namespace Quackle +{ +class Bag; + +struct ProbableRack +{ + Rack rack; + double probability; + double possibility; +}; +typedef vector<ProbableRack> ProbableRackList; + +class Enumerator +{ +public: + Enumerator(Bag &B); + + // enumerates all rackSize racks and finds their probability + void enumerate(ProbableRackList *racks, unsigned int rackSize); + + // assumes rack size is as defined in QUACKLE_PARAMETERS + void enumerate(ProbableRackList *racks); + void enumeratePossible(ProbableRackList *racks, const Bag &bag); + + // makes all of the probabilities sum to 1 + static void normalizeProbabilities(ProbableRackList *racks); + +private: + void recurse(LetterString prefix, int i, Letter start, ProbableRackList *racks, unsigned int rackSize); + char m_bagcounts[QUACKLE_FIRST_LETTER + QUACKLE_MAXIMUM_ALPHABET_SIZE]; + Bag m_bag; + Bag m_possibleBag; +}; + + +} + +#endif |