如何复制 SoPlex 模型?
How to copy a SoPlex model?
我正在使用 SoPlex 设置 lp 并解决它。然后我尝试复制原始 lp 并修改它。我的代码如下所示:
int main()
{
using namespase soplex;
SoPlex spx;
// add columns
// add rows
auto status = spx.optimize();
SoPlex copy(spx);
// modify some columns
status = copy.optimize();
return 0;
}
当我在 valgrind 中 运行 我的代码时,我注意到 SoPlex
复制构造函数中的方法分配的内存没有被释放。
是内存泄漏SoPlex
还是我没有正确使用它?
您正确使用了复制功能。 SoPlex 确实存在内存泄漏,将在下一个版本中修复。
同时您可以尝试为 SoPlex-4.0.1 应用此补丁:
diff --git a/src/soplex/slufactor.cpp b/src/soplex/slufactor.cpp
index ae41604..a3314d8 100644
--- a/src/soplex/slufactor.cpp
+++ b/src/soplex/slufactor.cpp
@@ -1230,8 +1230,6 @@ SLUFactor::SLUFactor(const SLUFactor& old)
l.rperm = 0;
solveCount = 0;
- solveTime = TimerFactory::createTimer(timerType);
- factorTime = TimerFactory::createTimer(timerType);
try
{
@@ -1326,16 +1324,23 @@ void SLUFactor::freeAll()
if(l.rperm)
spx_free(l.rperm);
+
+ if(solveTime)
+ {
+ solveTime->~Timer();
+ spx_free(solveTime);
+ }
+
+ if(factorTime)
+ {
+ factorTime->~Timer();
+ spx_free(factorTime);
+ }
}
SLUFactor::~SLUFactor()
{
freeAll();
-
- solveTime->~Timer();
- factorTime->~Timer();
- spx_free(solveTime);
- spx_free(factorTime);
}
static Real betterThreshold(Real th)
diff --git a/src/soplex/spxbasis.cpp b/src/soplex/spxbasis.cpp
index 6370e89..40d201b 100644
--- a/src/soplex/spxbasis.cpp
+++ b/src/soplex/spxbasis.cpp
@@ -1363,6 +1363,7 @@ SPxBasis::~SPxBasis()
factor = 0;
}
+ theTime->~Timer();
spx_free(theTime);
}
我正在使用 SoPlex 设置 lp 并解决它。然后我尝试复制原始 lp 并修改它。我的代码如下所示:
int main()
{
using namespase soplex;
SoPlex spx;
// add columns
// add rows
auto status = spx.optimize();
SoPlex copy(spx);
// modify some columns
status = copy.optimize();
return 0;
}
当我在 valgrind 中 运行 我的代码时,我注意到 SoPlex
复制构造函数中的方法分配的内存没有被释放。
是内存泄漏SoPlex
还是我没有正确使用它?
您正确使用了复制功能。 SoPlex 确实存在内存泄漏,将在下一个版本中修复。
同时您可以尝试为 SoPlex-4.0.1 应用此补丁:
diff --git a/src/soplex/slufactor.cpp b/src/soplex/slufactor.cpp
index ae41604..a3314d8 100644
--- a/src/soplex/slufactor.cpp
+++ b/src/soplex/slufactor.cpp
@@ -1230,8 +1230,6 @@ SLUFactor::SLUFactor(const SLUFactor& old)
l.rperm = 0;
solveCount = 0;
- solveTime = TimerFactory::createTimer(timerType);
- factorTime = TimerFactory::createTimer(timerType);
try
{
@@ -1326,16 +1324,23 @@ void SLUFactor::freeAll()
if(l.rperm)
spx_free(l.rperm);
+
+ if(solveTime)
+ {
+ solveTime->~Timer();
+ spx_free(solveTime);
+ }
+
+ if(factorTime)
+ {
+ factorTime->~Timer();
+ spx_free(factorTime);
+ }
}
SLUFactor::~SLUFactor()
{
freeAll();
-
- solveTime->~Timer();
- factorTime->~Timer();
- spx_free(solveTime);
- spx_free(factorTime);
}
static Real betterThreshold(Real th)
diff --git a/src/soplex/spxbasis.cpp b/src/soplex/spxbasis.cpp
index 6370e89..40d201b 100644
--- a/src/soplex/spxbasis.cpp
+++ b/src/soplex/spxbasis.cpp
@@ -1363,6 +1363,7 @@ SPxBasis::~SPxBasis()
factor = 0;
}
+ theTime->~Timer();
spx_free(theTime);
}