//============================================================================== // // Copyright (c) 2002- // Authors: // * Dave Parker (University of Oxford, formerly University of Birmingham) // //------------------------------------------------------------------------------ // // This file is part of PRISM. // // PRISM 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. // // PRISM 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 PRISM; if not, write to the Free Software Foundation, // Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // //============================================================================== #ifndef ODD_H #define ODD_H //------------------------------------------------------------------------------ #include #include #include // Flags for building Windows DLLs #ifdef __MINGW32__ #define EXPORT __declspec(dllexport) #else #define EXPORT #endif // odd definitions typedef struct ODDNode ODDNode; struct ODDNode { //int index; DdNode *dd; ODDNode *next; ODDNode *e; ODDNode *t; long eoff; long toff; }; // function prototypes EXPORT ODDNode *build_odd(DdManager *ddman, DdNode *dd, DdNode **vars, int num_vars); EXPORT void clear_odd(ODDNode *odd); EXPORT int get_index_of_first_from_bdd(DdManager *ddman, DdNode *dd, DdNode **vars, int num_vars, ODDNode *odd); EXPORT DdNode *single_index_to_bdd(DdManager *ddman, int i, DdNode **vars, int num_vars, ODDNode *odd); EXPORT int get_num_odd_nodes(); //------------------------------------------------------------------------------ #endif //------------------------------------------------------------------------------