You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
43 lines
1.1 KiB
Python
43 lines
1.1 KiB
Python
6 years ago
|
"""Regression tests for optimize.
|
||
|
|
||
|
"""
|
||
|
from __future__ import division, print_function, absolute_import
|
||
|
|
||
|
import numpy as np
|
||
|
from numpy.testing import assert_almost_equal
|
||
|
from pytest import raises as assert_raises
|
||
|
|
||
|
import scipy.optimize
|
||
|
|
||
|
|
||
|
class TestRegression(object):
|
||
|
|
||
|
def test_newton_x0_is_0(self):
|
||
|
# Regression test for gh-1601
|
||
|
tgt = 1
|
||
|
res = scipy.optimize.newton(lambda x: x - 1, 0)
|
||
|
assert_almost_equal(res, tgt)
|
||
|
|
||
|
def test_newton_integers(self):
|
||
|
# Regression test for gh-1741
|
||
|
root = scipy.optimize.newton(lambda x: x**2 - 1, x0=2,
|
||
|
fprime=lambda x: 2*x)
|
||
|
assert_almost_equal(root, 1.0)
|
||
|
|
||
|
def test_lmdif_errmsg(self):
|
||
|
# This shouldn't cause a crash on Python 3
|
||
|
class SomeError(Exception):
|
||
|
pass
|
||
|
counter = [0]
|
||
|
|
||
|
def func(x):
|
||
|
counter[0] += 1
|
||
|
if counter[0] < 3:
|
||
|
return x**2 - np.array([9, 10, 11])
|
||
|
else:
|
||
|
raise SomeError()
|
||
|
assert_raises(SomeError,
|
||
|
scipy.optimize.leastsq,
|
||
|
func, [1, 2, 3])
|
||
|
|