Я использую Pyomo, и я хотел бы сделать серию оптимизаций, где некоторые результаты предыдущей оптимизации используются для следующего.Интерфейс IPyomoTask уже определен
AgOpt.py
import pyomo
import pyomo.opt
from pyomo.environ import *
import numpy as np
AvailLand = 330
AvailWat = 945
AlfWat = 4
AlmWat = 1.5
CornWat = 2.5
AlfMaxY = 7
AlmMaxY = 6.5
CornMaxY = 7
AlfPrice = 132
AlmPrice = 610
CornPrice = 300
AlfCostAcre = 681
AlmCostAcre = 3478
CornCostAcre = 610
N=[1,2,3]
model = ConcreteModel()
model.x = Var(N, within=NonNegativeReals)
model.Obj = Objective(expr=model.x[1]*(AlfMaxY*AlfPrice-AlfCostAcre)+\
model.x[2]*(AlmMaxY*AlmPrice-AlmCostAcre)+\
model.x[3]*(CornMaxY*CornPrice-CornCostAcre), sense=maximize)
model.con1=Constraint(expr=model.x[1]<=100.1)
model.con2=Constraint(expr=model.x[2]<=30.03)
model.con3=Constraint(expr=model.x[3]<=200.2)
model.con4=Constraint(expr=model.x[1]+model.x[2]+model.x[3]<=330)
model.dual=Suffix(direction=Suffix.IMPORT_EXPORT)
opt = SolverFactory("glpk")
results = opt.solve(model)
model.solutions.load_from(results)
results.write()
model.Obj.display()
model.x.display()
model.dual.display()
Проблема заключается в том, что, когда я решаю код (с помощью Spyder) один раз, второй раз поднимает эту ошибку:
«Интерфейс IPyomoTask уже определен»
И мне нужно выйти из Spyder и снова войти.
Любое предложение?
Python и анаконды версии:
Python 3.5.2 | Anaconda 4.2.0 (64-разрядная версия) | (По умолчанию, 5 июля 2016, 11:41:13) [MSC v.1900 64 бит (AMD64)]
Traceback (most recent call last):
File "<ipython-input-2-f27cc52b2eaf>", line 1, in <module>
runfile('//fresno/users/escriva/Documents/Python Scripts/AgOpt.py', wdir='//fresno/users/escriva/Documents/Python Scripts')
File "C:\Users\escriva\AppData\Local\Continuum\Anaconda2\envs\py35\lib\site-packages\spyder\utils\site\sitecustomize.py", line 866, in runfile
execfile(filename, namespace)
File "C:\Users\escriva\AppData\Local\Continuum\Anaconda2\envs\py35\lib\site-packages\spyder\utils\site\sitecustomize.py", line 102, in execfile
exec(compile(f.read(), filename, 'exec'), namespace)
File "//fresno/users/escriva/Documents/Python Scripts/AgOpt.py", line 9, in <module>
import pyomo.opt
File "c:\users\escriva\appdata\local\continuum\anaconda2\envs\py35\lib\site-packages\pyomo-4.2.10784-py3.5.egg\pyomo\opt\__init__.py", line 10, in <module>
from pyomo.util.plugin import PluginGlobals
File "c:\users\escriva\appdata\local\continuum\anaconda2\envs\py35\lib\site-packages\pyomo-4.2.10784-py3.5.egg\pyomo\util\__init__.py", line 10, in <module>
from pyomo.util._task import pyomo_api, PyomoAPIData, PyomoAPIFactory
File "c:\users\escriva\appdata\local\continuum\anaconda2\envs\py35\lib\site-packages\pyomo-4.2.10784-py3.5.egg\pyomo\util\_task.py", line 102, in <module>
class IPyomoTask(plugin.Interface):
File "C:\Users\escriva\AppData\Local\Continuum\Anaconda2\envs\py35\lib\site-packages\PyUtilib-5.2.3601-py3.5.egg\pyutilib\component\core\core.py", line 600, in __new__
raise PluginError("Interface %s has already been defined" % name)
PluginError: Interface IPyomoTask has already been defined
Можете ли вы опубликовать полную трассировку стека за ошибку, которую вы получаете? Кроме того, можете ли вы опубликовать драйвер, который вы используете в spyder? Ошибка исходит от системы плагинов, но я не могу ее дублировать с помощью простых моделей/драйверов. – jsiirola
Я отредактировал вопрос, спасибо за ваш ответ. Позвольте мне знать, если вам нужно что-нибудь еще. –
До сих пор я не смог воспроизвести это поведение с помощью простого примера (я запускаю Python 3.5.2 со spyder, но не в anaconda, и попытался использовать Pyomo 4.2.10784, 4.4.1 и trunk). Можете ли вы поделиться своим скриптом 'AgOpt.py'? Это может дать некоторые подсказки. – jsiirola