Skip to main content

Power System Load Flow and Transient Stability Analysis Tool

Project description

GridGraphResearch

电力系统潮流计算与暂态稳定分析工具

简介

GridGraphResearch 是一个用于电力系统仿真分析的 Python 工具包,支持:

  • 解析电力系统配置文件(LF.L0-L9, ST.* 等格式)
  • 执行潮流计算和暂态稳定计算
  • 设置和分析各类故障(单相接地、两相短路、三相短路等)
  • 构建电网拓扑图并进行可视化

安装

pip install gridgraphresearch

或从源码安装:

git clone https://github.com/pronoobe/GridGraphResearch.git
cd GridGraphResearch
pip install -e .

快速开始

基本使用

from gridgraphresearch import GridLFSTAnalyzer

# 初始化分析器,指定配置文件目录
analyzer = GridLFSTAnalyzer(r"path/to/config/files")

# 执行潮流计算
analyzer.execute_LFcal()

# 执行暂态稳定计算
analyzer.execute_STcal()

# 获取计算结果
lf_data = analyzer.get_LFcal_data()
st_data = analyzer.get_STcal_data()

设置故障

# 设置发电机故障
analyzer.set_generator_fault(
    IDname='风电场1#虚拟发电机',
    fault_type='ABCG',  # 三相短路接地
    fault_begin_time=1,
    fault_during_time=10,
    fault_R=0.5,
    fault_X=0.01
)

支持的故障类型

故障代码 描述
AG A相接地
BG B相接地
CG C相接地
AB AB相间短路
AC AC相间短路
BC BC相间短路
ABG AB相间短路接地
ACG AC相间短路接地
BCG BC相间短路接地
ABCG 三相短路接地

构建电网图

# 初始化图工具
analyzer.graph_tools.make_graph()

# 可视化
analyzer.graph_tools.visualize_graph('network.png')

配置文件格式

支持的文件类型

文件名 描述 解析函数
LF.L0 系统控制信息 read_control_info_LFL0
LF.L1 母线数据 parse_bus_data_LFL1
LF.L2 交流线数据 parse_ac_line_data_LFL2
LF.L3 变压器数据 parse_transformer_data_LFL3
LF.L5 发电机数据 parse_generator_data_LFL5
LF.L6 负荷数据 parse_load_data_LFL6
LF.L7 区域功率交换数据 parse_area_power_data_LFL7
LF.L9 用户自定义模型数据 parse_ud_data_LFL9
LF.NL4 直流线数据 parse_dc_line_data_LFNL4
LF.CAL 潮流计算标识 parse_cal_data_LFCAL
LF.LP1 母线计算结果 parse_LFLP1_data
LF.LP2 交流线计算结果 parse_LFLP2_data
LF.LP3 变压器计算结果 parse_LFLP3_data
ST.CAL 暂态计算标识 parse_STCAL_data
ST.S11 故障设置 parse_fault_data_STS11
ST.B12 母线120电压 parse_STB12_data
ST.R12 线路120电流 parse_STR12_data
STANA.DAT 自动分析结果 parse_STANADAT_data
ST.SME 监视设置 parse_st_sme

API 参考

GridLFSTAnalyzer 类

主要分析器类,提供以下功能:

初始化

GridLFSTAnalyzer(file_path, cal_delay=7)
  • file_path: 配置文件目录路径
  • cal_delay: 计算等待时间(秒)

主要方法

  • execute_LFcal(): 执行潮流计算
  • execute_STcal(): 执行暂态稳定计算
  • LF_is_converge(): 检查潮流计算是否收敛
  • ST_is_converge(): 检查暂态计算是否收敛
  • get_LFcal_data(): 获取潮流计算结果
  • get_STcal_data(): 获取暂态稳定计算结果
  • set_generator_fault(): 设置发电机故障
  • find_by_IDName(): 根据名称查找元素
  • find_by_line_number(): 根据行号查找元素

GraphTools 类

电网拓扑图工具类:

  • make_graph(): 构建电网图
  • visualize_graph(name): 可视化并保存图片
  • get_U_inrange(v_range): 获取指定电压范围内的母线

依赖

  • Python >= 3.7
  • networkx
  • matplotlib

许可证

MIT License

作者

pronoobe

贡献

欢迎提交 Issue 和 Pull Request!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gridgraphresearch-0.1.0.tar.gz (18.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gridgraphresearch-0.1.0-py3-none-any.whl (15.7 kB view details)

Uploaded Python 3

File details

Details for the file gridgraphresearch-0.1.0.tar.gz.

File metadata

  • Download URL: gridgraphresearch-0.1.0.tar.gz
  • Upload date:
  • Size: 18.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.2

File hashes

Hashes for gridgraphresearch-0.1.0.tar.gz
Algorithm Hash digest
SHA256 ab9469a9de66a352ca75ea278e6df506b6de1c77ffc827e0fd61ffa021fcdf38
MD5 5ebab7bc60bd8c1663c4cce2fa5f2e9d
BLAKE2b-256 c7738cf5f4afbd5ba80924898950a6aed61213a4903166080d781be872ab3db9

See more details on using hashes here.

File details

Details for the file gridgraphresearch-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for gridgraphresearch-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7afba4f2488b4d7cbe48df940eaa4329f13b6a741e6b66c9a5679e8a09ec1699
MD5 b4fa69b35b7bb154f8ad537d1d8ec95b
BLAKE2b-256 51a58ebd663c860da5953c01ec3bc74cb79cc78832f31a7d19309aec7f30bea8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page