-
Notifications
You must be signed in to change notification settings - Fork 63
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add diagnostic function #537
base: develop
Are you sure you want to change the base?
Conversation
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## develop #537 +/- ##
===========================================
- Coverage 86.02% 83.70% -2.32%
===========================================
Files 90 91 +1
Lines 6497 6180 -317
===========================================
- Hits 5589 5173 -416
- Misses 908 1007 +99 ☔ View full report in Codecov by Sentry. |
# Conflicts: # src/pandapipes/diagnostic.py
logger.info(f"If sinks and sources were scaled with a factor of to " | ||
f"{check_scaling_factor}, the pipeflow would converge.") | ||
else: | ||
logger.warning(f"If sinks and sources were scaled with a factor of to " |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See comment above.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You mean iterations as a function argument?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I mean the pipeflow exception that must be caught. The else-part will never be reached.
f"highest value in the net is {net.pipe.k_mm.max()}. Up to " | ||
f"0.2 mm is a common value for old steel pipes." | ||
f"\nRough pipes: {net.pipe.loc[net.pipe.k_mm > 0.5]}.") | ||
net4 = net.deepcopy() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is net.deepcopy() the same as copy.deepcopy(net)?
branch_component = ["pipe", "valve", "compressor", "pump", "heat_exchanger", "circulation_pump"] | ||
for bc in branch_component: | ||
if hasattr(net, bc): | ||
missing_f = np.setdiff1d(net[bc].from_junction, net.junction.index) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would prefer the following:
- Add some code above that checks all tables in net and makes sure that the respective model is part of the component list (an important source of errors).
- Iterate over all branch components and use the "from_to_junction" identifiers to check the columns
@@ -615,3 +615,40 @@ def get_internal_tables_pandas(net, convert_types=True): | |||
tbl[col] = tbl[col].astype(np.bool_) | |||
|
|||
return node_table, branch_table | |||
|
|||
|
|||
def print_pf_summary(net): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We would need some kwargs here (e.g. for heating grids)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We could also just choose between different modes here. But for a start, we can also just add a hint that this function returns some unuseful stuff for heating grids.
I just had an interesting network that converged with alpha = 0.3 (nonlinear = "automatic") but not with alpha = 0.2 or alpha = 0.4. |
Add diagnostic functions to run some common checks. The function is intended to be applied if a pipeflow calculation does not converge.
Please feel free to modify and extend the function!
Also, a Doc-chapter for pipeflow-troubleshooting would be helpful.
It should mention: