Electricity Market Optimization 探索系列(一)

embedded/2025/2/2 6:29:40/


本文参考链接:Linear Programming Mini Example

先从一个线性规划的例子说起:

问题背景:
现在需要使用两台发电机满足用户的用电需求,发电机一的发电功率上限是 6MW,发电机二的发电功率上限是 4MW,发电机一的度电成本是0.015,发电机二的度电成本是0.03,用电需求是8 MW,求这两台发电机应该发多少电,满足需求的同时成本最小(我知道很简单,但是先听我说完)

min ⁡ ∑ i ∈ [ G ] c i p i s.t. ∑ i ∈ [ G ] p i = D 0 ≤ p i ≤ P ‾ i ∀ i ∈ [ G ] \begin{align} \min \quad & \sum_{i\in[G]}c_i p_i \\ \text{s.t.} \quad & \sum_{i\in[G]}p_i = D \\ & 0 \le p_i \le \overline{P}_i && \forall i \in [G] \end{align} mins.t.i[G]cipii[G]pi=D0piPii[G]
怎么用代码实现上面的模型呢?见如下代码:

import gurobipy as gp
from gurobipy import GRB
import numpy as npn_generators = 2 # G
p_lim = np.array([6,4]) # MW
cost = np.array([0.015,0.03]) # $/kWh
D = 8 # MW# 创建模型并隐去模型初始信息
m = gp.Model()
m.setParam("OutputFlag", 0)# 两个决策变量分别为发电机一和发电机二的发电功率,这两决策变量的下界都是0
p = m.addVars(n_generators, name="p")
m.update()
# 供需平衡约束
m.addConstr(gp.quicksum(p.values()) == D)# 两台发电机的最大发电功率约束
# 写法一:
# for i in range(n_generators):
#     m.addConstr(p[i] == [0, p_lim[i]])
# 写法二:
m.addConstrs(p[i] == [0, p_lim[i]] for i in range(n_generators))# 添加目标函数
# 写法一:
# m.setObjective(sum(p[i]*cost[i]*1000 for i in range(n_generators)), GRB.MINIMIZE)
# 写法二:
m.setObjective(gp.LinExpr(cost * 1000, list(p.values())), GRB.MINIMIZE)m.optimize()# 打印最优解
status = m.Status
if status == GRB.OPTIMAL:print("The model is optimal.")
elif status == GRB.INFEASIBLE:print("The model is infeasible.")
elif status == GRB.UNBOUNDED:print("The model is unbounded.")
else:print(f"Optimization ended with status {status}.")
print()# Objective value
objective = m.ObjVal
print(f"Objective value {objective:.1f}.\n")print("Variables values:")
# Print the values of all variables
for v in m.getVars():print(f"{v.VarName} = {v.X}")

至于 gurobi 的语法可以看看我的其他博客:
Gurobi之tupledict 和 tuplelist
Gurobi中quicksum的使用


http://www.ppmy.cn/embedded/158836.html

相关文章

网安加·百家讲坛 | 樊山:数据安全之威胁建模

作者简介:樊山,锦联世纪教育能源工业互联网数字安全CSM(新能源运维师)课程特聘培训讲师,哈尔滨工业大学(深圳)信飞合创数据合规联合实验室特聘专家,武汉赛博网络安全人才研究中心资深专家;近24年…

每日一道算法题

题目:单词接龙 II 给定两个单词(beginWord 和 endWord)和一个字典 wordList,找出所有从 beginWord 到 endWord 的最短转换序列。转换需遵循如下规则: 每次转换只能改变一个字母。转换过程中的中间单词必须是字典中的…

mysql中in和exists的区别?

大家好,我是锋哥。今天分享关于【mysql中in和exists的区别?】面试题。希望对大家有帮助; mysql中in和exists的区别? 在 MySQL 中,IN 和 EXISTS 都是用于子查询的操作符,但它们在执行原理和适用场景上有所不…

后端token校验流程

获取用户信息 前端中只有 await userStore.getInfo() 表示从后端获取数据 在页面中找到info对应的url地址,在IDEA中查找 这里是getInfo函数的声明,我们要找到这个函数的使用,所以点getInfo() Override public JSONObject getInfo() {JSO…

Qt调用FFmpeg库实时播放UDP组播视频流

基于以下参考链接,通过改进实现实时播放UDP组播视频流 https://blog.csdn.net/u012532263/article/details/102736700 源码在windows(qt-opensource-windows-x86-5.12.9.exe)、ubuntu20.04.6(x64)(qt-opensource-linux-x64-5.12.12.run)、以…

mybatis(78/134)

前天学了很多&#xff0c;关于java的反射机制&#xff0c;其实跳过了new对象&#xff0c;然后底层生成了字节码&#xff0c;创建了对应的编码。手搓了一遍源码&#xff0c;还是比较复杂的。 <?xml version"1.0" encoding"UTF-8" ?> <!DOCTYPE …

python爬虫入门(一) - requests库与re库,一个简单的爬虫程序

目录 web请求与requests库 1. web请求 1.1 客户端渲染与服务端渲染 1.2 抓包 1.3 HTTP状态代码 2. requests库 2.1 requests模块的下载 2.2 发送请求头与请求参数 2.3 GET请求与POST请求 GET请求的例子&#xff1a; POST请求的例子&#xff1a; 3. 案例&#xff1a;…

使用 Python 和 scikit-learn 实现 KNN 分类:以鸢尾花数据集为例

在机器学习的世界里&#xff0c;K-Nearest Neighbors&#xff08;KNN&#xff09;算法是一种简单而强大的分类方法。它基于一个直观的想法&#xff1a;相似的数据点往往属于同一类别。本文将通过 Python 的 scikit-learn 库实现 KNN 分类&#xff0c;以经典的鸢尾花数据集为例&…