00001 /*************************************************************************** 00002 * Copyright (C) 2007 by Pablo Diaz-Gutierrez * 00003 * pablo@ics.uci.edu * 00004 * * 00005 * This program is free software; you can redistribute it and/or modify * 00006 * it under the terms of the GNU Library General Public License as * 00007 * published by the Free Software Foundation; either version 2 of the * 00008 * License, or (at your option) any later version. * 00009 * * 00010 * This program is distributed in the hope that it will be useful, * 00011 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00013 * GNU General Public License for more details. * 00014 * * 00015 * You should have received a copy of the GNU Library General Public * 00016 * License along with this program; if not, write to the * 00017 * Free Software Foundation, Inc., * 00018 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * 00019 ***************************************************************************/ 00020 00021 #ifndef __UTIL_H__ 00022 #define __UTIL_H__ 00023 00024 #include <exception> 00025 #include <string> 00026 00031 namespace HE 00032 { 00036 class HE_exception : public std::exception 00037 { 00038 public: 00044 HE_exception(const char* msg) : _msg(msg) {} 00045 00052 HE_exception(const char* msg, const char* msg2) : _msg( (std::string(msg) + ": ") + msg2) {} 00053 00057 virtual ~HE_exception() throw() {} 00058 00063 virtual const char* what() const throw() { return _msg.c_str(); } 00064 00065 protected: 00066 std::string _msg; 00067 }; 00068 00076 double gaussianrand(double min, double max, long steps=10000); 00077 00086 double rangerand(double min, double max, long steps=10000); 00087 }; 00088 00089 #endif // __UTIL_H__