dualmap.h

00001 /*
00002  * All of the documentation and software included in the
00003  * Alchemy Software is copyrighted by Stanley Kok, Parag
00004  * Singla, Matthew Richardson, Pedro Domingos, Marc
00005  * Sumner and Hoifung Poon.
00006  * 
00007  * Copyright [2004-07] Stanley Kok, Parag Singla, Matthew
00008  * Richardson, Pedro Domingos, Marc Sumner and Hoifung
00009  * Poon. All rights reserved.
00010  * 
00011  * Contact: Pedro Domingos, University of Washington
00012  * (pedrod@cs.washington.edu).
00013  * 
00014  * Redistribution and use in source and binary forms, with
00015  * or without modification, are permitted provided that
00016  * the following conditions are met:
00017  * 
00018  * 1. Redistributions of source code must retain the above
00019  * copyright notice, this list of conditions and the
00020  * following disclaimer.
00021  * 
00022  * 2. Redistributions in binary form must reproduce the
00023  * above copyright notice, this list of conditions and the
00024  * following disclaimer in the documentation and/or other
00025  * materials provided with the distribution.
00026  * 
00027  * 3. All advertising materials mentioning features or use
00028  * of this software must display the following
00029  * acknowledgment: "This product includes software
00030  * developed by Stanley Kok, Parag Singla, Matthew
00031  * Richardson, Pedro Domingos, Marc Sumner and Hoifung
00032  * Poon in the Department of Computer Science and
00033  * Engineering at the University of Washington".
00034  * 
00035  * 4. Your publications acknowledge the use or
00036  * contribution made by the Software to your research
00037  * using the following citation(s): 
00038  * Stanley Kok, Parag Singla, Matthew Richardson and
00039  * Pedro Domingos (2005). "The Alchemy System for
00040  * Statistical Relational AI", Technical Report,
00041  * Department of Computer Science and Engineering,
00042  * University of Washington, Seattle, WA.
00043  * http://www.cs.washington.edu/ai/alchemy.
00044  * 
00045  * 5. Neither the name of the University of Washington nor
00046  * the names of its contributors may be used to endorse or
00047  * promote products derived from this software without
00048  * specific prior written permission.
00049  * 
00050  * THIS SOFTWARE IS PROVIDED BY THE UNIVERSITY OF WASHINGTON
00051  * AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED
00052  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00053  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
00054  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY
00055  * OF WASHINGTON OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
00056  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00057  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00058  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
00059  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
00060  * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00061  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00062  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
00063  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00064  * 
00065  */
00066 #ifndef DUALMAP_H_JUN_21_2005
00067 #define DUALMAP_H_JUN_21_2005
00068   
00069   
00070 #include <limits>
00071 #include <ext/hash_map>
00072 using namespace __gnu_cxx;
00073 #include "array.h"
00074 #include "equalstr.h"
00075 
00076 
00077 typedef hash_map<const char*, int, hash<const char*>, EqualStr> StrToIntMap;
00078 
00079 
00080   // Maps int to const char* and vice versa.
00081 class DualMap
00082 { 
00083  public:
00084   DualMap() : intToStrArr_(new Array<const char*>), 
00085               strToIntMap_(new StrToIntMap) {}
00086 
00087   
00088   DualMap(const DualMap& dm)
00089   { 
00090     intToStrArr_ = new Array<const char*>; 
00091     strToIntMap_ = new StrToIntMap;
00092     for (int i = 0; i < dm.intToStrArr_->size(); i++)
00093       insert((*(dm.intToStrArr_))[i]);
00094     compress();
00095   }
00096   
00097 
00098   ~DualMap() 
00099   {
00100     for (int i = 0; i < intToStrArr_->size(); i++)
00101       delete [] (*intToStrArr_)[i];
00102     delete intToStrArr_;
00103     delete strToIntMap_;
00104   }
00105 
00106 
00107     // Returns const char* corresponding to i or NULL if there is no such char*.
00108     // The returned const char* should not be deleted.
00109   const char* getStr(const int& i) const
00110   { 
00111     if (0<= i && i < intToStrArr_->size())
00112       return (*intToStrArr_)[i];
00113     return NULL;
00114   }
00115 
00116 
00117     // Returns int corresponding to str or -1 if there is no such str.
00118     // Caller should delete str if required.
00119     // Making this function const causes the compiler to complain.
00120   int getInt(const char* const & str) const
00121   {
00122     StrToIntMap::iterator it;
00123     if ((it=strToIntMap_->find(str)) == strToIntMap_->end())
00124       return -1;
00125     return (*it).second;
00126   }
00127 
00128 
00129     // Returns corresponding int (which increases by one each time addType() is 
00130     // called), or -1 is str has been added before.
00131     // Caller should delete str if required.
00132   int insert(const char* const & str)
00133   {
00134     StrToIntMap::iterator it;
00135     if ((it=strToIntMap_->find(str)) != strToIntMap_->end())
00136     {
00137       cout << "Warning: In DualMap::insert(), tried to insert duplicate " 
00138            << str << ", prev id " << (*it).second << endl;
00139       return -1;
00140     }
00141     
00142     if (((int)intToStrArr_->size()) >= numeric_limits<int>::max()) 
00143     {
00144       cout << "Error: In DualMap::insert(), reach int max limit when inserting "
00145            << str << endl;
00146       exit(-1);
00147     }
00148 
00149     char* s = new char[strlen(str)+1];
00150     strcpy(s,str);
00151     intToStrArr_->append(s);
00152     int i = intToStrArr_->size()-1;
00153     (*strToIntMap_)[s] = i;
00154     return i;
00155   }
00156 
00157   
00158   int getNumInt() const  { return intToStrArr_->size(); }
00159 
00160     // Caller should not delete the returned Array<const char*>*.
00161   const Array<const char*>* getIntToStrArr() const  { return intToStrArr_; }
00162   
00163   void compress() { intToStrArr_->compress(); }
00164 
00165 
00166  private:
00167   Array<const char*>* intToStrArr_;
00168   StrToIntMap* strToIntMap_;
00169 };
00170 
00171 #endif

Generated on Tue Jan 16 05:30:05 2007 for Alchemy by  doxygen 1.5.1