遗传算法微网优化。 考虑风光柴油机等设备,程序注释详细,适合初学者学习
凌晨三点的实验室键盘声格外清脆,我盯着屏幕上跳动的曲线突然来了精神——那个折腾了半个月的微网优化模型终于收敛了!记得刚开始接触风光柴储系统时,总被各种设备的耦合关系绕得头晕,直到把遗传算法这个"魔方"玩明白了才发现,原来复杂的优化问题可以这么有趣。
先来看个真实场景:某海岛微网需要配置200kW风机、150kW光伏,搭配柴油发电机和储能电池。我们的目标是在满足负载需求的前提下,让系统日均成本最低。这就涉及到一个经典的多变量优化问题,传统方法很容易陷入局部最优,这时候就该遗传算法登场了。
class Chromosome: def __init__(self): self.wind_cutin = random.uniform(3, 5) # 风机切入风速(m/s) self.pv_tilt = random.randint(15, 45) # 光伏板倾角(度) self.diesel_ratio = random.uniform(0.3, 0.7) # 柴油机出力比例 self.bat_capacity = random.randint(500, 2000) # 电池容量(kWh) self.fitness = 0 # 适应度值(成本越低越好) def calculate_cost(self): # 风机发电量计算 wind_power = self.wind_model(self.wind_cutin) # 光伏发电量计算 pv_power = self.pv_model(self.pv_tilt) # 柴油机燃料成本 diesel_cost = diesel_consumption * self.diesel_ratio # 电池循环损耗 battery_loss = bat_cycle_cost * self.bat_capacity return wind_power + pv_power + diesel_cost + battery_loss这段代码藏着三个玄机:首先,用面向对象的方式封装染色体,比纯数组更直观;其次,参数范围设定要符合工程实际,比如光伏倾角不可能设成90度;最后,成本计算需要整合各个设备的数学模型,比如风机功率与风速的关系:
def wind_model(cutin_speed): # 韦伯分布风速概率模型 rated_speed = 12 # 额定风速 k = 2 # 形状参数 lambda_ = 8 # 尺度参数 prob = (k/lambda_) * (cutin_speed/lambda_)**(k-1) * np.exp(-(cutin_speed/lambda_)**k) return 200 * prob * 24 # 200kW风机日发电量估算遗传算法的精髓在于选择、交叉、变异这三个操作。这里有个小技巧——自适应变异率,能让算法后期收敛更稳定:
def mutate(chromosome, generation): # 随代数增加降低变异概率 mutation_rate = 0.1 * (1 - generation/100) if random.random() < mutation_rate: # 对柴油机参数做高斯扰动 chromo.diesel_ratio += random.gauss(0, 0.05) chromo.diesel_ratio = np.clip(chromo.diesel_ratio, 0.3, 0.7)跑完500代后,最优解显示把风机切入风速设在4.2m/s,光伏板33度倾角,柴油机出力控制在45%,电池配到1200kWh时,日均成本降低23%。有意思的是,算法自动发现了"光伏午间多发时适当降低柴油机出力"的调度策略,这比人工经验更精细。
不过遗传算法也不是万能的,有次我把种群规模设到500,结果程序跑了整晚——后来才明白设备模型的调用次数是种群规模×迭代次数,算力撑不住。现在改用精英保留策略,只评估前20%的新个体,速度直接快了三倍。
看着优化前后的成本对比曲线,突然想起导师那句话:"好的算法不是替代人工,而是帮我们发现那些反直觉的优化路径。"或许这就是智能算法的魅力,在看似混沌的搜索中,藏着我们尚未察觉的系统最优解。