functiontemplate.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, Hoifung Poon, and Daniel Lowd.
00006  * 
00007  * Copyright [2004-07] Stanley Kok, Parag Singla, Matthew
00008  * Richardson, Pedro Domingos, Marc Sumner, Hoifung
00009  * Poon, and Daniel Lowd. 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, Hoifung
00032  * Poon, and Daniel Lowd 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 FUNCTIONTEMPLATE_JUN_22_2005
00067 #define FUNCTIONTEMPLATE_JUN_22_2005
00068 
00069 #include "predicatetemplate.h"
00070 
00071 class FunctionTemplate : public PredicateTemplate
00072 {
00073  public:
00074   static const char* EMPTY_FTEMPLATE_NAME; // name of empty template
00075  public:
00076   FunctionTemplate() : PredicateTemplate(), retTypeId_(-1),retTypeName_(NULL) {}
00077   virtual ~FunctionTemplate() { delete [] retTypeName_; }
00078 
00079 
00080     // Sets name and id of return type.
00081   void setRetTypeId(const int& id, const Domain* const & domain);
00082 
00083     // Sets name and id of return type.
00084     // Caller is responsible for deleteing name if required
00085   void setRetTypeName(const char* const & name, const Domain* const & domain);
00086 
00087   
00088   int getRetTypeId() const { return retTypeId_; }
00089   
00090     // Caller should not delete the returned const char*
00091   const char* getRetTypeName() const { return retTypeName_; }
00092 
00093     // returns funcName append with _typeNames
00094   static string createInternalFuncTypeName(const char* const & funcName,
00095                                                                                    const Array<string>& typeNames)
00096   {
00097     string ftName;
00098     ftName.append(funcName);
00099     for (int i = 0; i < typeNames.size(); i++)
00100     {
00101           ftName.append("_").append(typeNames[i]);
00102     }
00103     return ftName;
00104   }
00105   
00106   static bool isInternalFunctionTemplateName(const char* funcName)
00107   { 
00108         return (strncmp(funcName, SUCC_NAME, strlen(SUCC_NAME)) == 0 || 
00109                         strncmp(funcName, PLUS_NAME, strlen(PLUS_NAME)) == 0 ||
00110                         strncmp(funcName, MINUS_NAME, strlen(MINUS_NAME)) == 0 ||
00111                         strncmp(funcName, TIMES_NAME, strlen(TIMES_NAME)) == 0 ||
00112                         strncmp(funcName, DIVIDEDBY_NAME, strlen(DIVIDEDBY_NAME)) == 0 ||
00113                         strncmp(funcName, MOD_NAME, strlen(MOD_NAME)) == 0 ||
00114                         strncmp(funcName, CONCAT_NAME, strlen(CONCAT_NAME)) == 0);
00115   }
00116 
00117   static bool isInternalFunctionUnaryTemplateName(const char* funcName)
00118   { 
00119         return (strncmp(funcName, SUCC_NAME, strlen(SUCC_NAME)) == 0);
00120   }
00121 
00122 
00123   bool isInternalFunctionTemplate() const 
00124   { 
00125         return (strncmp(name_, SUCC_NAME, strlen(SUCC_NAME)) == 0 || 
00126                         strncmp(name_, PLUS_NAME, strlen(PLUS_NAME)) == 0 ||
00127                         strncmp(name_, MINUS_NAME, strlen(MINUS_NAME)) == 0 ||
00128                         strncmp(name_, TIMES_NAME, strlen(TIMES_NAME)) == 0 ||
00129                         strncmp(name_, DIVIDEDBY_NAME, strlen(DIVIDEDBY_NAME)) == 0 ||
00130                         strncmp(name_, MOD_NAME, strlen(MOD_NAME)) == 0 ||
00131                         strncmp(name_, CONCAT_NAME, strlen(CONCAT_NAME)) == 0);
00132   }
00133 
00134   ostream& print(ostream& out) const
00135   {
00136         out << retTypeName_ << " ";
00137     out << name_ << "(";
00138     for (int i = 0; i < termTypesAsStr_->size(); i++)
00139     {
00140       out << (*termTypesAsStr_)[i]; 
00141       out << ((i!=termTypesAsStr_->size()-1)?",":")");
00142     }
00143     return out;
00144   }
00145 
00146 
00147   ostream& printWithStrVar(ostream& out) const
00148   {
00149         out << retTypeName_ << " ";
00150     out << name_ << "(";
00151     for (int i = 0; i < termTypesAsStr_->size(); i++)
00152     {
00153       out << "a" << i+1; 
00154       out << ((i!=termTypesAsStr_->size()-1)?",":")");
00155     }
00156     return out;
00157   }
00158   
00159   
00160  private:
00161   int retTypeId_;
00162   char* retTypeName_;
00163 };
00164 
00165 #endif

Generated on Sun Jun 7 11:55:16 2009 for Alchemy by  doxygen 1.5.1