首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何做并行Python Gekko?

如何做并行Python Gekko?
EN

Stack Overflow用户
提问于 2019-11-16 13:19:36
回答 1查看 368关注 0票数 2

有时,一个求解器比另一个求解器能更好地解决我的Python Gekko应用程序。很难预测哪个求解器会表现得最好。因为Python Gekko支持使用m.GEKKO(server='http://{address}')在不同服务器上进行本地或远程求解,所以是否可以创建一个并行Gekko应用程序,该应用程序将在任意数量的计算机(包括本地计算机)上同时尝试所有求解器,然后在第一个进程成功返回时终止其他进程?我一直在研究Python的多线程和并行程序包。有没有能和Gekko一起很好地进行并行求解的工具?这是一个连续的原型:

代码语言:javascript
复制
from gekko import GEKKO
m = GEKKO()
x = m.Var(); y = m.Var()
m.Equation(x**2+y**2==1)
m.Maximize(x+y)
# try all solvers
for i in range(1,4):
    m.options.SOLVER = i
    m.solve()
    if m.options.APPSTATUS==1:
        print('Success: ' + str(i))
EN

回答 1

Stack Overflow用户

发布于 2019-11-17 22:34:20

您可以使用多线程应用程序同时在任意数量的服务器上进行求解。下面是使用queue的串行应用程序的并行版本,尽管它不会在第一个线程完成时停止其他线程。即使其他线程没有停止,您也可以包含一个MAX_TIME value,以便强制这些线程在指定的秒数内完成。这种方法确实允许您继续主程序,同时让其他线程在它们完成或达到最大时间限制时终止。

代码语言:javascript
复制
from gekko import GEKKO
import queue, threading

def solve(rq, solver, server):
    #print('Solver ' + str(solver) + ' Server: ' + str(server) + '\n')
    if server=='localhost':
        m = GEKKO(remote=False)
    else:
        m = GEKKO(server=server)
    x = m.Var(); y = m.Var()
    m.Equation(x**2+y**2==1)
    m.Maximize(x+y)
    m.options.SOLVER = solver
    m.options.MAX_TIME = 2
    m.solve(disp=False)
    m.cleanup()
    rq.put(('solver',solver,'server',server))

# Select servers and solvers (1=APOPT, 2=BPOPT, 3=IPOPT, etc)
APOPT = 1; BPOPT = 2; IPOPT = 3
jobs = {'https://byu.apmonitor.com':APOPT,\
        'localhost':APOPT,\
        'https://byu.apmonitor.com':IPOPT,\
        'https://apmonitor.com':IPOPT}

# Run jobs, get only first result
q = queue.Queue()
threads = [threading.Thread(target=solve, args=(q, solver, server)) \
           for server, solver in jobs.items()]
for th in threads:
    th.daemon = True
    th.start()
first = q.get(); print(first)

如果您还想获得第二个或更多结果,那么您可以添加另一行,其中包含更多的q.get()调用。

代码语言:javascript
复制
second = q.get(); print(second)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58887835

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档