2009-10-02 2 views
1
import numpy 
from numpy import asarray 

Initial = numpy.asarray [2.0, 4.0, 5.0, 3.0, 5.0, 6.0]  # Initial values to start with 


bounds = [(1, 5000), (1, 6000), (2, 100000), (1, 50000), (1.0, 5000), (2, 1000000)] 

# actual passed bounds 

b1 = lambda x: numpy.asarray([1.4*x[0] - x[0]]) 
b2 = lambda x: numpy.asarray([1.4*x[1] - x[1]]) 
b3 = lambda x: numpy.asarray([x[2] - x[3]])  
constraints = numpy.asarray([b1, b2, b3]) 

opt= optimize.fmin_slsqp(func,Initial,ieqcons=constraints,bounds=bounds, full_output=True,iter=200,iprint=2, acc=0.01) 

Проблема: Я хочу передать в неравенство ограничений. Считают, что у меня есть 6 параметровИспользование лямбда для функции ограничения

[ a, b, c, d, e, f] 

в Initial ценности, и мои ограничения:

a<=e<=1.4*a ('e' varies from a to 1.4*a) 
b<=f<=1.4*b ('f' varies from b to 1.4*b) 
c>d   ('c' must always be greater than d) 

Но это не работает должным образом. Я не знаю, что это за ошибка. Есть ли лучший способ передать мои ограничения как функцию? Пожалуйста, помогите мне.

+0

Я не знаю NumPy, но а и Ь отрицательные? в противном случае я не вижу, как любые значения e и f могут удовлетворять 1.4 * a <= e <= a и 1.4 * b <= f <= b. – hughdbrown

+0

Это поможет, если вы четко укажете, что именно вы делаете, что вы хотите, и что на самом деле происходит, вместо простого вставки фрагмента кода. – MAK

+0

@pear, я попытался ответить на ваш вопрос, но, как сказал hughdbrown, ограничения в вашем коде выше не работают для положительных чисел. Может быть, знаки отступают на первых двух? –

ответ

1

Основываясь на комментарии Роберта Керна, я удалил свой предыдущий ответ. Вот ограничения как непрерывные функции:

b1 = lambda x: x[4]-x[0] if x[4]<1.2*x[0] else 1.4*x[0]-x[4] 
b2 = lambda x: x[5]-x[1] if x[5]<1.2*x[1] else 1.4*x[1]-x[5] 
b3 = lambda x: x[2]-x[3] 

Примечание: для этого синтаксиса требуется Python 2.5 или более.

Чтобы получить ограничение a<=e<=1.4*a, обратите внимание, что 1.2*a это точка на полпути между a и 1.4*a.

Под этим пунктом, то есть все e<1.2*a, мы используем непрерывную функцию e-a. Таким образом, общая функция ограничения отрицательна, когда e<a, обрабатывая условие нижнего запредельного состояния, ноль на нижней границе e==a, а затем положительно для e>a до половины.

Выше половины, то есть всего e>1.2*a, мы используем вместо этого непрерывную функцию 1.4*a-e. Это означает, что общая функция ограничения отрицательна, когда e>1.4*a, обрабатывая условие верхнего вне поля, ноль на верхней границе e==1.4*a, а затем положительно, когда e<1.4*a, вплоть до половины точки.

В середине пути, где e==1.2*a, обе функции имеют одинаковое значение. Это означает, что общая функция непрерывна.

Код: documentation for ieqcons.

- Здесь предварительно Python 2.5 Синтаксис: b1 = lambda x: (1.4*x[0]-x[4], x[4]-x[0])[x[4]<1.2*x[0]]

+0

Нет, это не сработает. Функции ограничения должны быть как можно более непрерывными,> 0, когда они выполняются, <0, если они не являются, и == 0, когда они точно находятся на границе. –

+0

system Пауза, как говорит Роберт, функция должна быть непрерывной. поэтому я сделал лямбда x: ([1.4 * x [0] - x [0]]), т. е. lambda x: (max-min). Но что я сделал, правильно или нет, я не знаю. –

+0

@pear, я не думаю, что это может быть правильно, поскольку он не использует * e * (aka 'x [4]') вообще в выражении. Это выражение эквивалентно '1.4 * a - a', которое всегда будет иметь значение' 0.4a'. –

 Смежные вопросы

  • Нет связанных вопросов^_^