Project Icon

PySCIPOpt

Python与SCIP优化套件的桥梁

PySCIPOpt是一个Python接口库,用于访问SCIP优化套件。它能通过Python构建和求解数学优化模型,支持开发自定义插件如定价器和启发式算法。PySCIPOpt安装简便,易于使用,功能全面,适用于多种优化问题。项目定期更新,文档完善,为Python编程和高性能优化求解提供了有效连接。

PySCIPOpt

本项目提供了一个从Python连接到SCIP优化套件的接口。从v8.0.3版本开始,SCIP采用了Apache2.0许可证。如果您计划使用早期版本的SCIP,请查看SCIP的许可证限制

文档

请查阅在线文档,或直接在Python中使用help()函数,或在IPython/Jupyter中使用?

有关新增、移除或修复的功能,请参见CHANGELOG.md

安装

使用Conda

请勿使用Conda基础环境安装PYSCIPOPT。

Conda将自动安装SCIP,因此可以通过一条命令完成所有安装:

conda install --channel conda-forge pyscipopt

使用PyPI和从源代码安装

请参阅INSTALL.md获取安装说明。 请注意,最新版本的PySCIPOpt通常仅与SCIP优化套件的最新主要版本兼容。 下表总结了不同SCIP版本所需的PySCIPOpt版本:

SCIPPySCIPOpt
9.15.1+
9.05.0.x
8.04.x
7.03.x
6.02.x
5.01.4, 1.3
4.01.2, 1.1
3.21.0

关于特定SCIP版本所需的PySCIPOpt版本信息也可以在INSTALL.md中找到。

构建和求解模型

有几个示例教程。这些展示了接口的一些功能,可以作为编写更复杂代码的入门点。一些常见用例也可以在recipes子包中找到。 您可能还想看看这篇关于PySCIPOpt的文章: https://opus4.kobv.de/opus4-zib/frontdoor/index/index/docId/6045。 使用接口时始终需要以下步骤:

  1. 需要在代码中导入python-scip。这可以通过包含以下行来实现:
from pyscipopt import Model
  1. 创建一个求解器实例。
model = Model("Example")  # 模型名称是可选的
  1. 使用求解器/模型实例model访问scip.pxi文件中的方法,例如:
x = model.addVar("x")
y = model.addVar("y", vtype="INTEGER")
model.setObjective(x + y)
model.addCons(2*x - y*y >= 0)
model.optimize()
sol = model.getBestSol()
print("x: {}".format(sol[x]))
print("y: {}".format(sol[y]))

编写新插件

Python接口可用于定义自定义插件来扩展SCIP的功能。您可以使用纯Python代码编写定价器、启发式算法甚至约束处理器,SCIP可以使用回调系统调用它们的方法。每个可用的插件都有一个基类,您需要扩展该基类,重写预定义但为空的回调。请参阅test_pricer.pytest_heur.py两个简单示例。

请注意,在大多数情况下,需要使用字典来指定SCIP所需的返回值。

扩展接口

PySCIPOpt已经涵盖了SCIP可调用库方法中的许多方法。您也可以扩展它以增加此接口的功能。以下将提供一些关于如何实现这一点的指导:

PySCIPOpt中最重要的两个文件是scip.pxdscip.pxi。这两个文件指定了可以从Python代码访问的SCIP公共函数。

要让PySCIPOpt知道您想要访问的公共函数,必须将它们添加到scip.pxd中。为了正确添加这些函数,必须做两件事:

  1. 确保scip.pxd中包含任何enumstruct或SCIP变量类型
  2. 将您希望访问的公共函数的原型添加到scip.pxd

完成上述两个步骤后,就可以在Python中创建引用scip.pxd中包含的SCIP公共函数的函数。这是通过修改scip.pxi文件来添加您需要的功能来实现的。

我们随时欢迎包含补丁或扩展的拉取请求!

请查看我们的贡献指南

注意事项

范围约束

虽然支持形式为

lhs <= expression <= rhs

的范围约束,但Python语法中的链式比较无法通过运算符重载来劫持。相反,必须使用括号,例如,

lhs <= (expression <= rhs)

或者,您可以在创建单边约束后调用model.chgRhs(cons, newrhs)model.chgLhs(cons, newlhs)

变量对象

您不能将Variable对象用作set的元素或dict的键。它们不可哈希和比较。问题在于诸如x == y之类的比较将被解释为线性约束,因为Variable也是Expr对象。

对偶值

虽然PySCIPOpt支持访问解的对偶值,但存在一些限制:

  • 只能在禁用预求解和传播时使用,以确保LP求解器(提供对偶信息的求解器)实际上求解未修改的问题。
  • 也应该禁用启发式算法,以避免在调用LP求解器之前问题就被解决。
  • 不应该有约束条件,即只有一个变量的约束。这可能会导致不正确的值,如#136中所解释的那样。

因此,在尝试使用对偶信息时,应使用以下设置:

model.setPresolve(pyscipopt.SCIP_PARAMSETTING.OFF)
model.setHeuristics(pyscipopt.SCIP_PARAMSETTING.OFF)
model.disablePropagation()

引用PySCIPOpt

请引用此论文

@incollection{MaherMiltenbergerPedrosoRehfeldtSchwarzSerrano2016,
  author = {Stephen Maher and Matthias Miltenberger and Jo{\~{a}}o Pedro Pedroso and Daniel Rehfeldt and Robert Schwarz and Felipe Serrano},
  title = {{PySCIPOpt}: Mathematical Programming in Python with the {SCIP} Optimization Suite},
  booktitle = {Mathematical Software {\textendash} {ICMS} 2016},
  publisher = {Springer International Publishing},
  pages = {301--307},
  year = {2016},
  doi = {10.1007/978-3-319-42432-3_37},
}

以及相应的SCIP优化套件报告,当您将此工具用于出版物或其他科学工作时。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号