COSC-4P82-Final-Project/lib/beagle-3.0.3/beagle/GP/src/And.cpp

103 lines
3.1 KiB
C++
Raw Normal View History

2024-04-01 00:01:49 -04:00
/*
* Open BEAGLE
* Copyright (C) 2001-2007 by Christian Gagne and Marc Parizeau
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Contact:
* Laboratoire de Vision et Systemes Numeriques
* Departement de genie electrique et de genie informatique
* Universite Laval, Quebec, Canada, G1K 7P4
* http://vision.gel.ulaval.ca
*
*/
/*!
* \file beagle/GP/src/And.cpp
* \brief Source code of class GP::And.
* \author Christian Gagne
* \author Marc Parizeau
* $Revision: 1.10.2.1 $
* $Date: 2007/05/09 01:51:06 $
*/
#include "beagle/GP.hpp"
#ifdef BEAGLE_HAVE_RTTI
#include <typeinfo>
#endif // BEAGLE_HAVE_RTTI
using namespace Beagle;
/*!
* \brief Construct a new boolean AND primitive.
* \param inName Name of the addition primitive.
*/
GP::And::And(Beagle::string inName) :
Beagle::GP::Primitive(2, inName)
{ }
#ifdef BEAGLE_HAVE_RTTI
/*!
* \brief Return the tag of the type of data needed as input for the primitive And.
* \param inN Index of the argument to get the type tag.
* \param ioContext Evolutionary context.
* \return Type_info (RTTI) tagging the data type needed.
* \throw AssertException If the index inN given is greater than 1.
*/
const std::type_info* GP::And::getArgType(unsigned int inN, GP::Context& ioContext) const
{
Beagle_StackTraceBeginM();
Beagle_AssertM(inN<2);
return &typeid(Bool);
Beagle_StackTraceEndM("const std::type_info* GP::And::getArgType(unsigned int inN, GP::Context& ioContext) const");
}
/*!
* \brief Return the tag of the type of data return by primitive And.
* \param ioContext Evolutionary context.
* \return Type_info (RTTI) tagging the data type returned.
*/
const std::type_info* GP::And::getReturnType(GP::Context& ioContext) const
{
Beagle_StackTraceBeginM();
return &typeid(Bool);
Beagle_StackTraceEndM("const std::type_info* GP::And::getReturnType(GP::Context& ioContext) const");
}
#endif // BEAGLE_HAVE_RTTI
/*!
* \brief Execute the characteristic operation of logical AND between two bools.
* \param outResult Result of the logical AND.
* \param ioContext Evolutionary context.
*/
void GP::And::execute(GP::Datum& outResult, GP::Context& ioContext)
{
Beagle_StackTraceBeginM();
Bool& lResult = castObjectT<Bool&>(outResult);
Bool lArg2;
get1stArgument(lResult, ioContext);
get2ndArgument(lArg2, ioContext);
lResult = lResult && lArg2;
Beagle_StackTraceEndM("void GP::And::execute(GP::Datum& outResult, GP::Context& ioContext)");
}