- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在一个简单的 Windows 命令提示应用程序中使用 QuantLib,但无法使 Garch 函数正常工作。
我不确定我是否了解如何使用 Garch11 对象,这可能是我的程序无法运行的结果。我也找不到任何有关如何使用它的示例。文档也(IMO)含糊不清。我感谢任何有关如何使用它的帮助或线索。
我想做的是通过一个方法传递一个价格 vector (最小 4,因为这是 garch 模型对象的最小值)并将该系列的波动率作为 vector 或 double 值返回,不要介意。
有两种构建我的对象的方法,一种是通过希腊人,另一种是通过 self 优化。这两种方法都将在我的应用程序中进行测试。
目前,当我运行代码时,每次运行代码时都会得到不同的输出,例如:
D:\Users\ypx7647\Documents\Visual Studio 2017\Projects\GarchTest\Release>GarchTest.exe
iQuotes size = 4
ts size = 4
GarchByGreeks iTs size = 4
_alpha = 0.000000 _beta = 0.000000 _omega = 0.000000
oTs size = 4
tsOut size = 4
oGarch[0] = 121.182504
oGarch[1] = 121.182504
oGarch[2] = 121.182504
oGarch[3] = 121.182504
oGarch size = 4
og size = 4
D:\Users\ypx7647\Documents\Visual Studio 2017\Projects\GarchTest\Release>GarchTest.exe
iQuotes size = 4
ts size = 4
GarchByGreeks iTs size = 4
_alpha = 0.000000 _beta = 0.000000 _omega = 0.000000
oTs size = 4
tsOut size = 4
oGarch[0] = 11003897096.575457
oGarch[1] = 11000266346.069284
oGarch[2] = 10995727907.936573
oGarch[3] = 10998450970.816200
oGarch size = 4
og size = 4
调试我的代码后,我发现使用 Greeks 传递的 Garch11 构造函数没有注册传递的相同值。这一个问题。
接下来返回的对象返回与输入对象相同数量的值。我不想要这个,只需要返回波动率。这是第二个问题。
我遇到的另一个问题是我无法将 EndCriteria 参数的 size_t 参数作为变量传递,这只会导致应用程序崩溃。据我所知,所有参数都配置为 size_t 参数,因此没有转换或转换。
我需要更改什么才能使我的代码正常工作(我不是 C++ 专家)?
这是我的代码(包括调试行):
GarchTest.cpp
#include "stdafx.h"
#include "CGarch.h"
int main()
{
// CGarch* Garch = new CGarch(Method::SelfOptimisation);
CGarch* Garch = new CGarch();
std::vector<double> p, og;
p.push_back(121.230000);
p.push_back(121.190000);
p.push_back(121.140000);
p.push_back(121.170000);
Garch->GarchOnArray(p,og);
std::cout << "og size = " << std::to_string(og.size()) << std::endl;
delete Garch;
return 0;
}
`CGarch.h
#include <ql/quantlib.hpp>
#define _MD
enum Method {
Greeks,
SelfOptimisation
};
enum OptimizationMethodType {
simplex,
levenbergMarquardt,
levenbergMarquardt2,
conjugateGradient,
conjugateGradient_goldstein,
steepestDescent,
steepestDescent_goldstein,
bfgs,
bfgs_goldstein
};
enum Model {
LevenbergMarquardt,
Simplex
};
enum Mode {
MomentMatchingGuess, /*!< The initial guess is a moment
matching estimates for
mean(r2), acf(0), and acf(1). */
GammaGuess, /*!< The initial guess is an
estimate of gamma based on the
property:
acf(i+1) = gamma*acf(i) for i > 1. */
BestOfTwo, /*!< The best of the two above modes */
DoubleOptimization /*!< Double optimization */
};
class CGarch
{
private:
int GarchByGreeks(const QuantLib::TimeSeries<QuantLib::Volatility> &iTs, QuantLib::TimeSeries<QuantLib::Volatility> &oTs);
int GarchByOptimisation(const QuantLib::TimeSeries<QuantLib::Volatility> &iTs, QuantLib::TimeSeries<QuantLib::Volatility> &oTs);
protected:
int _method;
int _model;
int _mode;
std::size_t _maxIterations;
std::size_t _maxStationaryStateInterations;
double _rootEpsilon;
double _functionEpsilon;
double _gradientEpsilon;
double _omega;
double _beta;
double _alpha;
public:
CGarch();
CGarch(Method pMethod);
CGarch(double pOmega, double pBeta, double pAlpha);
CGarch(Model pModel, Mode pMode, std::size_t pMaxIterations, std::size_t pMaxStationaryStateIterations, double pRootEpsilon, double pFunctionEpsilon, double pGradientNormEpsilon);
~CGarch();
int GarchOnArray(const std::vector<double> &iPrices, std::vector<double> &oGarch);
};
CGarch.cpp
#include "stdafx.h"
#include "CGarch.h"
#include <vector>
#include <ql/auto_link.hpp>
#include <ql/models/volatility/garch.hpp>
//#include <ql/math/optimization/simplex.hpp>
#include <ql/math/optimization/levenbergmarquardt.hpp>
using namespace QuantLib;
CGarch::CGarch()
{
_method = Method::Greeks;
CGarch::CGarch(0.0, 0.1, 0.3);
}
CGarch::CGarch(Method pMethod)
{
_method = pMethod;
switch (pMethod) {
case Method::Greeks: CGarch::CGarch(); break;
case Method::SelfOptimisation: CGarch::CGarch(Model::LevenbergMarquardt, Mode::BestOfTwo, 20, 3, 0.0, 0.0, 0.0); break;
}
}
CGarch::CGarch(double pOmega, double pBeta, double pAlpha)
{
_method = Method::Greeks;
_model = 0;
_mode = 0;
_maxIterations = 0;
_maxStationaryStateInterations = 0;
_rootEpsilon = 0.0;
_functionEpsilon = 0.0;
_gradientEpsilon = 0.0;
_omega = pOmega;
_beta = pBeta;
_alpha = pAlpha;
}
CGarch::CGarch(Model pModel, Mode pMode, std::size_t pMaxIterations, std::size_t pMaxStationaryStateIterations, double pRootEpsilon, double pFunctionEpsilon, double pGradientNormEpsilon)
{
_method = Method::SelfOptimisation;
_model = pModel;
_mode = pMode;;
_maxIterations = pMaxIterations;
_maxStationaryStateInterations = pMaxStationaryStateIterations;
_rootEpsilon = pRootEpsilon;
_functionEpsilon = pFunctionEpsilon;
_gradientEpsilon = pGradientNormEpsilon;
_omega = 0.0;
_beta = 0.0;
_alpha = 0.0;
std::cout << "SelfOptimisation _maxIterations = " << std::to_string((unsigned int)_maxIterations) << " _maxStationaryStateInterations = " << std::to_string((unsigned int)_maxStationaryStateInterations) << " _rootEpsilon = " << std::to_string(_rootEpsilon) << " _functionEpsilon = " << std::to_string(_functionEpsilon) << " _gradientEpsilon = " << std::to_string(_gradientEpsilon) << std::endl;
}
CGarch::~CGarch()
{
}
int CGarch::GarchByGreeks(const TimeSeries<Volatility> &iTs, TimeSeries<Volatility> &oTs)
{
std::cout << "GarchByGreeks iTs size = " << std::to_string(iTs.size()) << std::endl;
if (iTs.empty()) {
// QL_FAIL("ERROR: input array (iTs) is empty");
return -1;
}
std::cout << "_alpha = " << std::to_string(_alpha) << " _beta = " << std::to_string(_beta) << " _omega = " << std::to_string(_omega) << std::endl;
Garch11* g11 = new Garch11(_alpha, _beta, _omega);
// Garch11 g11(_alpha, _beta, _omega);
/*
if (g11 == NULL) {
QL_FAIL("FATAL; Unable to instantiate Garch11 object");
return -1;
}
*/
g11->calibrate(iTs);
oTs = g11->calculate(iTs);
std::cout << "oTs size = " << std::to_string(oTs.size()) << std::endl;
delete g11;
return 0;
}
int CGarch::GarchByOptimisation(const TimeSeries<Volatility> &iTs, TimeSeries<Volatility> &oTs)
{
std::cout << "GarchByOptimisation iTs size = " << std::to_string(iTs.size()) << std::endl;
if (iTs.empty()) {
return -1;
}
std::cout << "GarchByOptimisation _maxIterations = " << std::to_string(_maxIterations) << " _maxStationaryStateInterations = " << std::to_string(_maxStationaryStateInterations) << " _rootEpsilon = " << std::to_string(_rootEpsilon) << " _functionEpsilon = " << std::to_string(_functionEpsilon) << " _gradientEpsilon = " << std::to_string(_gradientEpsilon) << std::endl;
Garch11* g11 = new Garch11(iTs, Garch11::MomentMatchingGuess);
if (g11 == nullptr) {
std::cout << "FATAL: Failed to create g11 object " << std::endl;
return -2;
}
std::cout << "Here 1" << std::endl;
QuantLib::LevenbergMarquardt om;
std::cout << "Here 2" << std::endl;
g11->calibrate(iTs, om, EndCriteria(200, 3, _rootEpsilon, _functionEpsilon, _gradientEpsilon));
std::cout << "Here 3" << std::endl;
g11->calibrate(iTs);
std::cout << "Here 4" << std::endl;
oTs = g11->calculate(iTs);
std::cout << "Here 5" << std::endl;
std::cout << "alpha = " << std::to_string(g11->alpha()) << " beta = " << std::to_string(g11->beta()) << " omega = " << std::to_string(g11->omega()) << std::endl;
std::cout << "oTs size = " << std::to_string(oTs.size()) << std::endl;
delete g11;
return 0;
}
int CGarch::GarchOnArray(const std::vector<double> &iQuotes, std::vector<double> &oGarch)
{
oGarch.clear();
std::cout << "iQuotes size = " << std::to_string(iQuotes.size()) << std::endl;
if (iQuotes.empty()) {
// QL_FAIL("ERROR: input array (ts) is empty");
return -1;
}
if (iQuotes.size() < 4) {
// QL_FAIL("ERROR: minimum (3) individual prices not present in ts array");
return -2;
}
Date ds(7, July, 1962);
TimeSeries<Volatility> ts(ds, iQuotes.begin(), iQuotes.end()), tsOut;
std::cout << "ts size = " << std::to_string(ts.size()) << std::endl;
if (_method == Method::SelfOptimisation)
{
if (GarchByOptimisation(ts, tsOut) < 0)
return -3;
}
else {
if (GarchByGreeks(ts, tsOut) < 0)
return -4;
}
// QL_ASSERT(false, "tsOut size = " + std::to_string(tsOut.size()));
std::cout << "tsOut size = " << std::to_string(tsOut.size()) << std::endl;
// tsOut.find(ds + ts.size());
oGarch = tsOut.values();
for (int i = 0; i < oGarch.size(); i++)
std::cout << "oGarch[" << std::to_string(i) << "] = " << std::to_string(oGarch.at(i)) << std::endl;
std::cout << "oGarch size = " << std::to_string(oGarch.size()) << std::endl;
// QL_ASSERT(false, "oGarch size = " + std::to_string(oGarch.size()));
return 0;
}
提前致谢。
最佳答案
代码如
CGarch::CGarch()
{
_method = Method::Greeks;
CGarch::CGarch(0.0, 0.1, 0.3);
}
无效。如果你想委托(delegate)给另一个构造函数,在 C++11 和更高版本中你可以这样写
CGarch::CGarch() : CGarch(0.0, 0.1, 0.3)
{
_method = Method::Greeks;
}
我不知道你的版本是做什么的(这取决于你的编译器决定它的意思)但我怀疑它只是创建一个单独的临时文件并且你的数据成员没有被初始化。
关于c++ - QuantLib:需要 Garch 帮助,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45424916/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!