2010-09-24 12:52:58 +02:00
|
|
|
|
/*
|
2022-02-09 14:32:25 +01:00
|
|
|
|
* Copyright © 2007-2022 Dynare Team
|
2010-09-24 12:52:58 +02:00
|
|
|
|
*
|
|
|
|
|
* This file is part of Dynare.
|
|
|
|
|
*
|
|
|
|
|
* Dynare 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 3 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* Dynare 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
|
2021-06-09 17:33:48 +02:00
|
|
|
|
* along with Dynare. If not, see <https://www.gnu.org/licenses/>.
|
2010-09-24 12:52:58 +02:00
|
|
|
|
*/
|
|
|
|
|
|
2022-07-29 12:40:33 +02:00
|
|
|
|
#ifndef _ERROR_HANDLING_HH
|
|
|
|
|
#define _ERROR_HANDLING_HH
|
2010-09-24 12:52:58 +02:00
|
|
|
|
|
2021-02-09 15:55:36 +01:00
|
|
|
|
#include <string>
|
|
|
|
|
#include <sstream>
|
2021-02-01 12:28:50 +01:00
|
|
|
|
#include <cmath>
|
2021-02-09 15:55:36 +01:00
|
|
|
|
|
2010-09-24 12:52:58 +02:00
|
|
|
|
using namespace std;
|
|
|
|
|
|
2022-07-29 12:42:50 +02:00
|
|
|
|
struct GeneralException
|
2010-09-24 12:52:58 +02:00
|
|
|
|
{
|
2022-07-29 12:42:50 +02:00
|
|
|
|
const string message;
|
2010-09-24 12:52:58 +02:00
|
|
|
|
};
|
|
|
|
|
|
2022-07-29 12:42:50 +02:00
|
|
|
|
struct FloatingPointException : public GeneralException
|
2010-09-24 12:52:58 +02:00
|
|
|
|
{
|
2023-04-06 18:44:22 +02:00
|
|
|
|
const string location;
|
|
|
|
|
FloatingPointException(const string &details, string location_arg) :
|
|
|
|
|
GeneralException {"Floating point error: " + details},
|
|
|
|
|
location {move(location_arg)}
|
2011-02-04 16:53:12 +01:00
|
|
|
|
{
|
2021-02-03 18:10:01 +01:00
|
|
|
|
}
|
2010-09-24 12:52:58 +02:00
|
|
|
|
};
|
|
|
|
|
|
2023-04-07 17:28:07 +02:00
|
|
|
|
struct UnaryOpException : public FloatingPointException
|
2010-09-24 12:52:58 +02:00
|
|
|
|
{
|
2023-04-07 17:28:07 +02:00
|
|
|
|
UnaryOpException(const string &op, double value, string location_arg) :
|
2022-07-29 12:42:50 +02:00
|
|
|
|
FloatingPointException { [=]
|
|
|
|
|
{
|
|
|
|
|
// We don’t use std::to_string(), because it uses fixed formatting
|
|
|
|
|
ostringstream s;
|
2023-04-07 17:28:07 +02:00
|
|
|
|
s << op << "(X) with X=" << defaultfloat << value;
|
2022-07-29 12:42:50 +02:00
|
|
|
|
return s.str();
|
2023-04-06 18:44:22 +02:00
|
|
|
|
}(), move(location_arg) }
|
2011-02-04 16:53:12 +01:00
|
|
|
|
{
|
2021-02-03 18:10:01 +01:00
|
|
|
|
}
|
2010-09-24 12:52:58 +02:00
|
|
|
|
};
|
|
|
|
|
|
2022-07-29 12:42:50 +02:00
|
|
|
|
struct DivideException : public FloatingPointException
|
2010-09-24 12:52:58 +02:00
|
|
|
|
{
|
2023-04-06 18:44:22 +02:00
|
|
|
|
DivideException(double v1, double v2, string location_arg) :
|
2022-07-29 12:42:50 +02:00
|
|
|
|
FloatingPointException { [=]
|
|
|
|
|
{
|
|
|
|
|
// We don’t use std::to_string(), because it uses fixed formatting
|
|
|
|
|
ostringstream s;
|
2023-04-06 18:44:22 +02:00
|
|
|
|
s << "a/X with a=" << defaultfloat << v1 << " and X= " << v2;
|
2022-07-29 12:42:50 +02:00
|
|
|
|
return s.str();
|
2023-04-06 18:44:22 +02:00
|
|
|
|
}(), move(location_arg) }
|
2011-02-04 16:53:12 +01:00
|
|
|
|
{
|
2021-02-03 18:10:01 +01:00
|
|
|
|
}
|
2010-09-24 12:52:58 +02:00
|
|
|
|
};
|
|
|
|
|
|
2022-07-29 12:42:50 +02:00
|
|
|
|
struct PowException : public FloatingPointException
|
2010-09-24 12:52:58 +02:00
|
|
|
|
{
|
2023-04-06 18:44:22 +02:00
|
|
|
|
PowException(double base, double exponent, string location_arg) :
|
2022-07-29 12:42:50 +02:00
|
|
|
|
FloatingPointException { [=]
|
|
|
|
|
{
|
|
|
|
|
// We don’t use std::to_string(), because it uses fixed formatting
|
|
|
|
|
ostringstream s;
|
|
|
|
|
s << "X^a with X=" << defaultfloat << base;
|
|
|
|
|
if (fabs(base) <= 1e-10)
|
|
|
|
|
s << " and a=" << exponent;
|
|
|
|
|
return s.str();
|
2023-04-06 18:44:22 +02:00
|
|
|
|
}(), move(location_arg) }
|
2011-02-04 16:53:12 +01:00
|
|
|
|
{
|
2022-07-29 12:42:50 +02:00
|
|
|
|
}
|
2010-09-24 12:52:58 +02:00
|
|
|
|
};
|
|
|
|
|
|
2022-07-29 12:42:50 +02:00
|
|
|
|
struct UserException : public GeneralException
|
2013-03-22 15:44:34 +01:00
|
|
|
|
{
|
2022-07-29 12:42:50 +02:00
|
|
|
|
UserException() : GeneralException {"User break"}
|
2013-03-22 15:44:34 +01:00
|
|
|
|
{
|
2022-07-29 12:42:50 +02:00
|
|
|
|
}
|
2013-03-22 15:44:34 +01:00
|
|
|
|
};
|
|
|
|
|
|
2022-07-29 12:42:50 +02:00
|
|
|
|
struct FatalException : public GeneralException
|
2010-09-24 12:52:58 +02:00
|
|
|
|
{
|
2022-07-29 12:42:50 +02:00
|
|
|
|
FatalException(const string &details) :
|
|
|
|
|
GeneralException {"Fatal error: " + details}
|
2011-02-04 16:53:12 +01:00
|
|
|
|
{
|
2022-07-29 12:42:50 +02:00
|
|
|
|
}
|
2010-09-24 12:52:58 +02:00
|
|
|
|
};
|
2010-11-20 15:45:15 +01:00
|
|
|
|
|
2022-07-29 12:58:10 +02:00
|
|
|
|
inline void
|
|
|
|
|
test_mxMalloc(void *z, int line, const string &file, const string &func, int amount)
|
2013-03-22 15:44:34 +01:00
|
|
|
|
{
|
2022-07-29 12:58:10 +02:00
|
|
|
|
if (!z && amount > 0)
|
|
|
|
|
throw FatalException{"mxMalloc: out of memory " + to_string(amount) + " bytes required at line " + to_string(line) + " in function " + func + " (file " + file};
|
|
|
|
|
}
|
2013-03-22 15:44:34 +01:00
|
|
|
|
|
|
|
|
|
#ifdef MATLAB_MEX_FILE
|
|
|
|
|
extern "C" bool utIsInterruptPending();
|
|
|
|
|
#endif
|
|
|
|
|
|
2022-07-29 12:40:33 +02:00
|
|
|
|
#endif // _ERROR_HANDLING_HH
|