a9249c5ebb
- Add python-sherpa-python3.8.patch: Fix building with python3.8; taken from upstream commit [gh#sherpa/sherpa#696]. - Disbale bytecode generation when running tests. - Remove hashbangs from non executable files. OBS-URL: https://build.opensuse.org/request/show/784357 OBS-URL: https://build.opensuse.org/package/show/devel:languages:python:numeric/python-sherpa?expand=0&rev=5
1283 lines
53 KiB
Diff
1283 lines
53 KiB
Diff
From afe571af5ac6f9682ad5e986d095c43a84891643 Mon Sep 17 00:00:00 2001
|
|
From: Douglas Burke <dburke.gw@gmail.com>
|
|
Date: Sun, 20 Oct 2019 10:39:02 -0400
|
|
Subject: [PATCH 1/6] Bump "quick" test to python 3.8 on Travis
|
|
|
|
---
|
|
From 7322ce142b50294b6cd4c9a4f3a7efac9864c430 Mon Sep 17 00:00:00 2001
|
|
From: Douglas Burke <dburke.gw@gmail.com>
|
|
Date: Fri, 17 Jan 2020 10:25:27 -0500
|
|
Subject: [PATCH 2/6] Fix SyntaxWarning in Python 3.8
|
|
|
|
Change 'a is "string"' to 'a == "string"'
|
|
---
|
|
sherpa/astro/data.py | 14 +++++++-------
|
|
sherpa/ui/utils.py | 6 +++---
|
|
2 files changed, 10 insertions(+), 10 deletions(-)
|
|
|
|
diff --git a/sherpa/astro/data.py b/sherpa/astro/data.py
|
|
index 1d77b38de..bb8dcd15f 100644
|
|
--- a/sherpa/astro/data.py
|
|
+++ b/sherpa/astro/data.py
|
|
@@ -1,5 +1,5 @@
|
|
#
|
|
-# Copyright (C) 2008, 2015, 2016, 2017, 2018, 2019
|
|
+# Copyright (C) 2008, 2015, 2016, 2017, 2018, 2019, 2020
|
|
# Smithsonian Astrophysical Observatory
|
|
#
|
|
#
|
|
@@ -2597,7 +2597,7 @@ def _world_to_physical(self, x0=None, x1=None):
|
|
def get_logical(self):
|
|
coord = self.coord
|
|
x0, x1 = self.get_indep()
|
|
- if coord is not 'logical':
|
|
+ if coord != 'logical':
|
|
x0 = x0.copy()
|
|
x1 = x1.copy()
|
|
x0, x1 = getattr(self, '_' + coord + '_to_logical')(x0, x1)
|
|
@@ -2606,7 +2606,7 @@ def get_logical(self):
|
|
def get_physical(self):
|
|
coord = self.coord
|
|
x0, x1 = self.get_indep()
|
|
- if coord is not 'physical':
|
|
+ if coord != 'physical':
|
|
x0 = x0.copy()
|
|
x1 = x1.copy()
|
|
x0, x1 = getattr(self, '_' + coord + '_to_physical')(x0, x1)
|
|
@@ -2615,7 +2615,7 @@ def get_physical(self):
|
|
def get_world(self):
|
|
coord = self.coord
|
|
x0, x1 = self.get_indep()
|
|
- if coord is not 'world':
|
|
+ if coord != 'world':
|
|
x0 = x0.copy()
|
|
x1 = x1.copy()
|
|
x0, x1 = getattr(self, '_' + coord + '_to_world')(x0, x1)
|
|
@@ -2808,7 +2808,7 @@ def _init_data_space(self, filter, *data):
|
|
def get_logical(self):
|
|
coord = self.coord
|
|
x0lo, x1lo, x0hi, x1hi = self.get_indep()
|
|
- if coord is not 'logical':
|
|
+ if coord != 'logical':
|
|
x0lo = x0lo.copy()
|
|
x1lo = x1lo.copy()
|
|
convert = getattr(self, '_' + coord + '_to_logical')
|
|
@@ -2823,7 +2823,7 @@ def get_logical(self):
|
|
def get_physical(self):
|
|
coord = self.coord
|
|
x0lo, x1lo, x0hi, x1hi = self.get_indep()
|
|
- if coord is not 'physical':
|
|
+ if coord != 'physical':
|
|
x0lo = x0lo.copy()
|
|
x1lo = x1lo.copy()
|
|
convert = getattr(self, '_' + coord + '_to_physical')
|
|
@@ -2838,7 +2838,7 @@ def get_physical(self):
|
|
def get_world(self):
|
|
coord = self.coord
|
|
x0lo, x1lo, x0hi, x1hi = self.get_indep()
|
|
- if coord is not 'world':
|
|
+ if coord != 'world':
|
|
x0lo = x0lo.copy()
|
|
x1lo = x1lo.copy()
|
|
convert = getattr(self, '_' + coord + '_to_world')
|
|
diff --git a/sherpa/ui/utils.py b/sherpa/ui/utils.py
|
|
index 46d9ccb85..9485aeeb6 100644
|
|
--- a/sherpa/ui/utils.py
|
|
+++ b/sherpa/ui/utils.py
|
|
@@ -1,6 +1,6 @@
|
|
from __future__ import print_function
|
|
#
|
|
-# Copyright (C) 2010, 2015, 2016, 2017, 2018, 2019
|
|
+# Copyright (C) 2010, 2015, 2016, 2017, 2018, 2019, 2020
|
|
# Smithsonian Astrophysical Observatory
|
|
#
|
|
#
|
|
@@ -255,8 +255,8 @@ def _export_names(self, gdict):
|
|
|
|
for name in dir(self):
|
|
if ((not name.startswith('_')) or
|
|
- (name is '_sherpa_version') or
|
|
- (name is '_sherpa_version_string')):
|
|
+ (name == '_sherpa_version') or
|
|
+ (name == '_sherpa_version_string')):
|
|
gdict[name] = export_method(getattr(self, name),
|
|
modname=gdict.get('__name__'))
|
|
allnames.append(name)
|
|
|
|
From 8c183a392e05c51e0937f1fba50bfdcc776865a8 Mon Sep 17 00:00:00 2001
|
|
From: Douglas Burke <dburke.gw@gmail.com>
|
|
Date: Fri, 17 Jan 2020 10:51:52 -0500
|
|
Subject: [PATCH 3/6] Fix PY_SSIZE_T_CLEAN deprecation warning in Python 3.8
|
|
|
|
The PY_SSIZE_T_CLEAN symbol was added in Python 2.5 so this should be
|
|
backwards compatible for the versions of Python that Sherpa supports.
|
|
---
|
|
sherpa/optmethods/tests/_tstoptfct.cc | 9 +++++++--
|
|
1 file changed, 7 insertions(+), 2 deletions(-)
|
|
|
|
diff --git a/sherpa/optmethods/tests/_tstoptfct.cc b/sherpa/optmethods/tests/_tstoptfct.cc
|
|
index 3b271973e..32722aee4 100644
|
|
--- a/sherpa/optmethods/tests/_tstoptfct.cc
|
|
+++ b/sherpa/optmethods/tests/_tstoptfct.cc
|
|
@@ -1,5 +1,5 @@
|
|
//
|
|
-// Copyright (C) 2007 Smithsonian Astrophysical Observatory
|
|
+// Copyright (C) 2007, 2020 Smithsonian Astrophysical Observatory
|
|
//
|
|
//
|
|
// This program is free software; you can redistribute it and/or modify
|
|
@@ -17,6 +17,10 @@
|
|
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
//
|
|
|
|
+// This define is needed for "#i" argument to PyArg_ParseTuple in init_optfcn
|
|
+// and must be made before including Python.h
|
|
+#define PY_SSIZE_T_CLEAN
|
|
+
|
|
#include <Python.h>
|
|
|
|
#include <sherpa/extension.hh>
|
|
@@ -1344,7 +1348,8 @@ static PyObject *wood( PyObject *self, PyObject *args ) {
|
|
|
|
static PyObject *init_optfcn( PyObject *self, PyObject *args ) {
|
|
|
|
- int name_length, npar;
|
|
+ int npar;
|
|
+ Py_ssize_t name_length;
|
|
char* name;
|
|
|
|
if ( !PyArg_ParseTuple( args,
|
|
|
|
From 12dd8dbb8fc6527f02327ee301da82c090601f6e Mon Sep 17 00:00:00 2001
|
|
From: Douglas Burke <dburke.gw@gmail.com>
|
|
Date: Fri, 17 Jan 2020 11:26:32 -0500
|
|
Subject: [PATCH 4/6] BUGFIX: Python 3.8 TypeError about integer scalar arrays
|
|
|
|
The error message was:
|
|
|
|
TypeError: only integer scalar arrays can be converted to a scalar index
|
|
|
|
It looks like Python 3.8.1 / NumPy 1.18.1 doesn't want to automatically convert
|
|
a NumPy int64 array (with one element) to a Python integer type.
|
|
It's not clear to me whether this is an issue with one, both, or a combo
|
|
of these two versions.
|
|
|
|
The approach taken is to explicitly convert the integer value to a
|
|
Python one: this conversion works if brightPixel is a scalar or a one-element
|
|
NumPy array, which holds here.
|
|
---
|
|
sherpa/instrument.py | 13 ++++++++++---
|
|
1 file changed, 10 insertions(+), 3 deletions(-)
|
|
|
|
diff --git a/sherpa/instrument.py b/sherpa/instrument.py
|
|
index 58a4ea670..304195ea2 100644
|
|
--- a/sherpa/instrument.py
|
|
+++ b/sherpa/instrument.py
|
|
@@ -1,6 +1,7 @@
|
|
from __future__ import division
|
|
#
|
|
-# Copyright (C) 2008, 2016, 2018, 2019 Smithsonian Astrophysical Observatory
|
|
+# Copyright (C) 2008, 2016, 2018, 2019, 2020
|
|
+# Smithsonian Astrophysical Observatory
|
|
#
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
@@ -296,14 +297,20 @@ def init_kernel(self, kernel):
|
|
# be centered on brightest pixel.
|
|
brightPixel = list(numpy.where(kernel == kernel.max())).pop()
|
|
|
|
- origin = None
|
|
# if more than one pixel qualifies as brightest, such as const2D
|
|
# use the middle of subkernel -- assumes the user provided center at
|
|
# time of kernel extraction, so that should be middle of subkernel.
|
|
+ origin = None
|
|
if (not numpy.isscalar(brightPixel)) and len(brightPixel) != 1:
|
|
origin = set_origin(kshape)
|
|
else:
|
|
- origin = set_origin(kshape, brightPixel)
|
|
+ # brightPixel is a NumPy index (int64) which - as of NumPy 1.18
|
|
+ # and Python 3.8 - causes a TypeError with the message
|
|
+ # "only integer scalar arrays can be converted to a scalar index"
|
|
+ # to be thrown here if sent directly to set_origin. So
|
|
+ # we convert to a Python integer type.
|
|
+ #
|
|
+ origin = set_origin(kshape, int(brightPixel))
|
|
|
|
if self.origin is None:
|
|
self.origin = origin
|
|
|
|
From a7174f00d8111cf3a955b7a0ffa333def12baabe Mon Sep 17 00:00:00 2001
|
|
From: Douglas Burke <dburke.gw@gmail.com>
|
|
Date: Fri, 17 Jan 2020 14:49:06 -0500
|
|
Subject: [PATCH 5/6] Docs: note limited testing with Python 3.8
|
|
|
|
I have not added 3.8 to the supported badges on the README.
|
|
---
|
|
README.md | 4 ++++
|
|
docs/index.rst | 2 ++
|
|
docs/install.rst | 3 ++-
|
|
3 files changed, 8 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/README.md b/README.md
|
|
index d01cb34c3..3e0ae34f3 100644
|
|
--- a/README.md
|
|
+++ b/README.md
|
|
@@ -70,6 +70,10 @@ documentation, and should be read if the following is not sufficient.
|
|
It is strongly recommended that some form of *virtual environment* is
|
|
used with Sherpa.
|
|
|
|
+Sherpa is tested against Python versions 3.5, 3.6, and 3.7. It is
|
|
+expected that it will work with Python 3.8 but testing has been
|
|
+limited.
|
|
+
|
|
The last version of Sherpa which supported Python 2.7 is
|
|
[Sherpa 4.11.1](https://doi.org/10.5281/zenodo.3358134).
|
|
|
|
diff --git a/docs/index.rst b/docs/index.rst
|
|
index deab01a04..2566c8456 100644
|
|
--- a/docs/index.rst
|
|
+++ b/docs/index.rst
|
|
@@ -30,6 +30,8 @@ Sherpa is released under the
|
|
`GNU General Public License v3.0
|
|
<https://github.com/sherpa/sherpa/blob/master/LICENSE>`_,
|
|
and is compatible with Python versions 3.5, 3.6, and 3.7.
|
|
+It is expected that it will work with Python 3.8 but testing has been
|
|
+limited.
|
|
Information on recent releases and citation information for
|
|
Sherpa is available using the Digital Object Identifier (DOI)
|
|
`10.5281/zenodo.593753 <https://doi.org/10.5281/zenodo.593753>`_.
|
|
diff --git a/docs/install.rst b/docs/install.rst
|
|
index 3d7e127b9..19360e6e3 100644
|
|
--- a/docs/install.rst
|
|
+++ b/docs/install.rst
|
|
@@ -27,7 +27,8 @@ Requirements
|
|
|
|
Sherpa has the following requirements:
|
|
|
|
-* Python 3.5, 3.6, or 3.7
|
|
+* Python 3.5, 3.6, or 3.7 (there has been limited testing with
|
|
+ Python 3.8)
|
|
* NumPy (the exact lower limit has not been determined,
|
|
but it is likely to be 1.7.0 or later)
|
|
* Linux or OS-X (patches to add Windows support are welcome)
|
|
|
|
From 9a488e146af0674e8ddcd08cd1de37719779d13c Mon Sep 17 00:00:00 2001
|
|
From: Douglas Burke <dburke.gw@gmail.com>
|
|
Date: Sat, 25 Jan 2020 11:15:56 -0500
|
|
Subject: [PATCH 6/6] Replace PyErr_Format with PyErr_SetString where
|
|
appropriate
|
|
|
|
This is slightly-clearer in intent, but doesn't change anything
|
|
functionally.
|
|
|
|
Suggested by @serhiy-storchaka
|
|
---
|
|
sherpa/optmethods/tests/_tstoptfct.cc | 308 +++++++++-----------------
|
|
1 file changed, 103 insertions(+), 205 deletions(-)
|
|
|
|
diff --git a/sherpa/optmethods/tests/_tstoptfct.cc b/sherpa/optmethods/tests/_tstoptfct.cc
|
|
index 32722aee4..9f56a0b18 100644
|
|
--- a/sherpa/optmethods/tests/_tstoptfct.cc
|
|
+++ b/sherpa/optmethods/tests/_tstoptfct.cc
|
|
@@ -37,8 +37,7 @@ static PyObject *bard( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 15 * npar / 3;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -48,16 +47,14 @@ static PyObject *bard( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Bard<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for bard function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for bard function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Bard<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Bard Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Bard Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -77,8 +74,7 @@ static PyObject *beale( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 3 * npar / 2;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -88,16 +84,14 @@ static PyObject *beale( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Beale<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for beale function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for beale function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Beale<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Beale Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Beale Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -116,8 +110,7 @@ static PyObject *biggs( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 6;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -127,16 +120,14 @@ static PyObject *biggs( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Biggs<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for biggs function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for biggs function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Biggs<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Biggs Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Biggs Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -156,8 +147,7 @@ static PyObject *box3d( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 6;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -167,16 +157,14 @@ static PyObject *box3d( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Box3d<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for box3d function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for box3d function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Box3d<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Box3d Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Box3d Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -195,8 +183,7 @@ static PyObject *broyden_banded( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -206,16 +193,14 @@ static PyObject *broyden_banded( PyObject *self, PyObject *args ) {
|
|
tstoptfct::BroydenBanded<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for broyden_banded function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for broyden_banded function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::BroydenBanded<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for BroydenBanded Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for BroydenBanded Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -235,8 +220,7 @@ static PyObject *broyden_tridiagonal( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -246,8 +230,7 @@ static PyObject *broyden_tridiagonal( PyObject *self, PyObject *args ) {
|
|
tstoptfct::BroydenTridiagonal<double,void*>( mfct, npar, &xpar[0],
|
|
&fvec[0], ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for broyden_tridiagonal function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for broyden_tridiagonal function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -255,8 +238,7 @@ static PyObject *broyden_tridiagonal( PyObject *self, PyObject *args ) {
|
|
tstoptfct::BroydenTridiagonal<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for BroydenTridiagonal Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for BroydenTridiagonal Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -275,8 +257,7 @@ static PyObject *brown_almost_linear( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -286,8 +267,7 @@ static PyObject *brown_almost_linear( PyObject *self, PyObject *args ) {
|
|
tstoptfct::BrownAlmostLinear<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for brown_almost_linear function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for brown_almost_linear function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -295,8 +275,7 @@ static PyObject *brown_almost_linear( PyObject *self, PyObject *args ) {
|
|
tstoptfct::BrownAlmostLinear<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for BrownAlmostLinear Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for BrownAlmostLinear Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -316,8 +295,7 @@ static PyObject *brown_badly_scaled( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar + npar / 2;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -327,8 +305,7 @@ static PyObject *brown_badly_scaled( PyObject *self, PyObject *args ) {
|
|
tstoptfct::BrownBadlyScaled<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for brown_badly_scaled function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for brown_badly_scaled function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -336,8 +313,7 @@ static PyObject *brown_badly_scaled( PyObject *self, PyObject *args ) {
|
|
tstoptfct::BrownBadlyScaled<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Brownbadlyscaled Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Brownbadlyscaled Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -356,8 +332,7 @@ static PyObject *brown_dennis( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 20;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -367,16 +342,14 @@ static PyObject *brown_dennis( PyObject *self, PyObject *args ) {
|
|
tstoptfct::BrownDennis<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for brown_dennis function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for brown_dennis function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::BrownDennis<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for brown_dennis Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for brown_dennis Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -396,8 +369,7 @@ static PyObject *chebyquad( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -407,16 +379,14 @@ static PyObject *chebyquad( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Chebyquad<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for chebyquad function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for chebyquad function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Chebyquad<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for chebyquad Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for chebyquad Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -436,8 +406,7 @@ static PyObject *discrete_boundary( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -446,8 +415,7 @@ static PyObject *discrete_boundary( PyObject *self, PyObject *args ) {
|
|
{
|
|
tstoptfct::DiscreteBoundary<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for discrete_boundary function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for discrete_boundary function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -455,8 +423,7 @@ static PyObject *discrete_boundary( PyObject *self, PyObject *args ) {
|
|
tstoptfct::DiscreteBoundary<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for discrete_boundary_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for discrete_boundary_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -476,8 +443,7 @@ static PyObject *discrete_integral( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -487,8 +453,7 @@ static PyObject *discrete_integral( PyObject *self, PyObject *args ) {
|
|
tstoptfct::DiscreteIntegral<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for discrete_integral function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for discrete_integral function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -496,8 +461,7 @@ static PyObject *discrete_integral( PyObject *self, PyObject *args ) {
|
|
tstoptfct::DiscreteIntegral<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for discrete_integral_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for discrete_integral_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -517,8 +481,7 @@ static PyObject *freudenstein_roth( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -527,16 +490,14 @@ static PyObject *freudenstein_roth( PyObject *self, PyObject *args ) {
|
|
{
|
|
tstoptfct::FreudensteinRoth<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for freudenstein_roth function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for freudenstein_roth function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::FreudensteinRoth<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for freudenstein_roth_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for freudenstein_roth_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -556,8 +517,7 @@ static PyObject *gaussian( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 15;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -567,16 +527,14 @@ static PyObject *gaussian( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Gaussian<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for gaussian function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for gaussian function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Gaussian<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Gaussian Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Gaussian Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -596,8 +554,7 @@ static PyObject *gulf_research_development( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -607,8 +564,7 @@ static PyObject *gulf_research_development( PyObject *self, PyObject *args ) {
|
|
tstoptfct::GulfResearchDevelopment<double,void*>( mfct, npar, &xpar[0],
|
|
&fvec[0], ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for gulf_research_development function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for gulf_research_development function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -616,8 +572,7 @@ static PyObject *gulf_research_development( PyObject *self, PyObject *args ) {
|
|
tstoptfct::GulfResearchDevelopment<double,void*>( npar, &xpar[0], fval,
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Gulf_Research_Development Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Gulf_Research_Development Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -636,8 +591,7 @@ static PyObject *helical_valley( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -647,16 +601,14 @@ static PyObject *helical_valley( PyObject *self, PyObject *args ) {
|
|
tstoptfct::HelicalValley<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for helical_valley function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for helical_valley function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::HelicalValley<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for helical_valley_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for helical_valley_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -676,8 +628,7 @@ static PyObject *jennrich_sampson( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 10 * npar / 2;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -687,8 +638,7 @@ static PyObject *jennrich_sampson( PyObject *self, PyObject *args ) {
|
|
tstoptfct::JennrichSampson<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for jennrich_sampson function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for jennrich_sampson function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -696,8 +646,7 @@ static PyObject *jennrich_sampson( PyObject *self, PyObject *args ) {
|
|
tstoptfct::JennrichSampson<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for jennrich_sampson_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for jennrich_sampson_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -717,8 +666,7 @@ static PyObject *kowalik_osborne( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 11;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -728,8 +676,7 @@ static PyObject *kowalik_osborne( PyObject *self, PyObject *args ) {
|
|
tstoptfct::KowalikOsborne<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for kowalikosborne function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for kowalikosborne function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -737,8 +684,7 @@ static PyObject *kowalik_osborne( PyObject *self, PyObject *args ) {
|
|
tstoptfct::KowalikOsborne<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for kowalikosborne_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for kowalikosborne_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -758,8 +704,7 @@ static PyObject *linear_fullrank( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -769,8 +714,7 @@ static PyObject *linear_fullrank( PyObject *self, PyObject *args ) {
|
|
tstoptfct::LinearFullRank<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for linear_fullrank function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for linear_fullrank function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -778,8 +722,7 @@ static PyObject *linear_fullrank( PyObject *self, PyObject *args ) {
|
|
tstoptfct::LinearFullRank<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for linear_fullrank1_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for linear_fullrank1_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -799,8 +742,7 @@ static PyObject *linear_fullrank1( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -810,8 +752,7 @@ static PyObject *linear_fullrank1( PyObject *self, PyObject *args ) {
|
|
tstoptfct::LinearFullRank1<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for linear_fullrank1 function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for linear_fullrank1 function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -819,8 +760,7 @@ static PyObject *linear_fullrank1( PyObject *self, PyObject *args ) {
|
|
tstoptfct::LinearFullRank1<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for linear_fullrank_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for linear_fullrank_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -840,8 +780,7 @@ static PyObject *linear_fullrank0col0rows( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -850,8 +789,7 @@ static PyObject *linear_fullrank0col0rows( PyObject *self, PyObject *args ) {
|
|
{
|
|
tstoptfct::LinearFullRank0cols0rows<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for linear_fullrank0col0rows function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for linear_fullrank0col0rows function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -859,8 +797,7 @@ static PyObject *linear_fullrank0col0rows( PyObject *self, PyObject *args ) {
|
|
tstoptfct::LinearFullRank0cols0rows<double,void*>( npar, &xpar[0], fval,
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for linear_fullrank0col0rows_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for linear_fullrank0col0rows_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -880,8 +817,7 @@ static PyObject *meyer( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 16 * npar / 3;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -890,16 +826,14 @@ static PyObject *meyer( PyObject *self, PyObject *args ) {
|
|
{
|
|
tstoptfct::Meyer<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for meyer function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for meyer function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Meyer<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for meyer_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for meyer_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -918,8 +852,7 @@ static PyObject *osborne1( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 33;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -928,16 +861,14 @@ static PyObject *osborne1( PyObject *self, PyObject *args ) {
|
|
{
|
|
tstoptfct::Osborne1<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for osborne1 function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for osborne1 function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Osborne1<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for osborne1_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for osborne1_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -957,8 +888,7 @@ static PyObject *osborne2( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 65;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -968,16 +898,14 @@ static PyObject *osborne2( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Osborne2<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for osborne2 function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for osborne2 function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Osborne2<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for osborne2_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for osborne2_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -997,8 +925,7 @@ static PyObject *osborne2( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar + 1;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -1008,16 +935,14 @@ static PyObject *osborne2( PyObject *self, PyObject *args ) {
|
|
tstoptfct::PenaltyI<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for penaltyI function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for penaltyI function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::PenaltyI<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for penaltyI_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for penaltyI_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1037,8 +962,7 @@ static PyObject *penaltyII( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 65;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -1048,16 +972,14 @@ static PyObject *penaltyII( PyObject *self, PyObject *args ) {
|
|
tstoptfct::PenaltyII<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for penaltyII function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for penaltyII function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::PenaltyII<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for penaltyII_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for penaltyII_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1077,8 +999,7 @@ static PyObject *powell_badly_scaled( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 2 * npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -1088,8 +1009,7 @@ static PyObject *powell_badly_scaled( PyObject *self, PyObject *args ) {
|
|
tstoptfct::PowellBadlyScaled<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for powell_badly_scaled function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for powell_badly_scaled function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1097,8 +1017,7 @@ static PyObject *powell_badly_scaled( PyObject *self, PyObject *args ) {
|
|
tstoptfct::PowellBadlyScaled<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for powell_badly_scaled_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for powell_badly_scaled_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1118,8 +1037,7 @@ static PyObject *powell_singular( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -1129,8 +1047,7 @@ static PyObject *powell_singular( PyObject *self, PyObject *args ) {
|
|
tstoptfct::PowellSingular<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for powell_singular function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for powell_singular function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1138,8 +1055,7 @@ static PyObject *powell_singular( PyObject *self, PyObject *args ) {
|
|
tstoptfct::PowellSingular<double,void*>( npar, &xpar[0], fval, ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for powell_singular_fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for powell_singular_fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1159,8 +1075,7 @@ static PyObject *rosenbrock( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -1170,16 +1085,14 @@ static PyObject *rosenbrock( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Rosenbrock<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for rosenbrock function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for rosenbrock function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Rosenbrock<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Rosenbrock Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Rosenbrock Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1199,8 +1112,7 @@ static PyObject *trigonometric( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -1210,16 +1122,14 @@ static PyObject *trigonometric( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Trigonometric<double,void*>( mfct, npar, &xpar[0], &fvec[0],
|
|
ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for trigonmetric function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for trigonmetric function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Trigonometric<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Trigonmetric Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Trigonmetric Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1238,8 +1148,7 @@ static PyObject *variably_dimensioned( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = npar + 2;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -1249,16 +1158,14 @@ static PyObject *variably_dimensioned( PyObject *self, PyObject *args ) {
|
|
tstoptfct::VariablyDimensioned<double,void*>( mfct, npar, &xpar[0],
|
|
&fvec[0], ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for varibly_dimensioned function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for varibly_dimensioned function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::VariablyDimensioned<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for variably dimensioned Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for variably dimensioned Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1278,8 +1185,7 @@ static PyObject *watson( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 31;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -1288,16 +1194,14 @@ static PyObject *watson( PyObject *self, PyObject *args ) {
|
|
{
|
|
tstoptfct::Watson<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for watson function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for watson function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Watson<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for watson Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for watson Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1317,8 +1221,7 @@ static PyObject *wood( PyObject *self, PyObject *args ) {
|
|
npy_intp npar = xpar.get_size( );
|
|
npy_intp mfct = 6;
|
|
if ( EXIT_SUCCESS != fvec.create( 1, &mfct ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'fvec'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'fvec'" );
|
|
return NULL;
|
|
}
|
|
double fval;
|
|
@@ -1328,16 +1231,14 @@ static PyObject *wood( PyObject *self, PyObject *args ) {
|
|
tstoptfct::Wood<double,void*>( mfct, npar, &xpar[0], &fvec[0], ierr,
|
|
NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for wood function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for wood function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
{
|
|
tstoptfct::Wood<double,void*>( npar, &xpar[0], fval, ierr, NULL );
|
|
if ( EXIT_SUCCESS != ierr ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "error returned for Wood Fct function" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "error returned for Wood Fct function" );
|
|
return NULL;
|
|
}
|
|
}
|
|
@@ -1362,18 +1263,15 @@ static PyObject *init_optfcn( PyObject *self, PyObject *args ) {
|
|
DoubleArray xpar, lo, hi;
|
|
npy_intp my_npar = npar;
|
|
if ( EXIT_SUCCESS != xpar.create( 1, &my_npar ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'xpar'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'xpar'" );
|
|
return NULL;
|
|
}
|
|
if ( EXIT_SUCCESS != lo.create( 1, &my_npar ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'lo'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'lo'" );
|
|
return NULL;
|
|
}
|
|
if ( EXIT_SUCCESS != hi.create( 1, &my_npar ) ) {
|
|
- PyErr_Format( PyExc_ValueError,
|
|
- static_cast<const char*>( "Unable to create 'hi'" ) );
|
|
+ PyErr_SetString( PyExc_ValueError, "Unable to create 'hi'" );
|
|
return NULL;
|
|
}
|
|
|
|
@@ -1480,7 +1378,7 @@ static PyObject *init_optfcn( PyObject *self, PyObject *args ) {
|
|
if ( xpar.get_size() != lo.get_size() ||
|
|
xpar.get_size() != hi.get_size() ) {
|
|
PyErr_Format( PyExc_ValueError,
|
|
- "init_optfcn: Incompatible array sizes "
|
|
+ "init_optfcn: Incompatible array sizes "
|
|
"xpar=%d, lo=%d, hi=%d\n",
|
|
(int) xpar.get_size(), (int) lo.get_size(),
|
|
(int) hi.get_size() );
|