Skip to content
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

Introduce parameter "expected" for Flows #814

Draft
wants to merge 10 commits into
base: dev
Choose a base branch
from
Draft

Conversation

p-snft
Copy link
Member

@p-snft p-snft commented Dec 17, 2021

This value can be used as a hint to the optimiser to speed up
minimisation. The fature is actually a reintroduction:
Up to oemof v0.3, it was possible to have a time series "actual_value"
plus a boolean parameter "fixed". When fixed was false, it was just
taken as the initial value for optimisation of the energy system.
When compared to this previous implemenataion, having either fix=(series)
or expected=(series) might be easier to understand.

  • Test speed-up for complex model
  • (More) documentation
  • Unit tests

Implements #759

This value can be used as a hint to the optimiser to speed up
minimisation. The fature is actually a reintroduction:
Up to oemof v0.3, it was possible to have a time series "actual_value"
plus a boolean parameter "fixed". When fixed was false, it was just
taken as the initial value for optimisation of the energy system.
When compared to this previous implemenataion, having either fix=(series)
or expected=(series) might be easier to understand.
@p-snft
Copy link
Member Author

p-snft commented Dec 17, 2021

For testing the speedup, I consider the following:

  • Source with high nominal value and random costs. (Binary/ NonConvex so that performance is needed.)
  • GenericStorage with very high capacity and random series for loss_rate.
  • Sink with random (fix) demand

With a sufficiently high number of time steps, this should be rather hard to optimised. So:

  1. Optimise without giving starting values.
  2. Redo 1. to make sure there is no effect due to caching, branch prediction and stuff like that.
  3. Optimise using solution of 1. as starting values.
  4. Redo 1 once again, same reasoning as in 2, should again be slower.

# Conflicts:
#	src/oemof/solph/flows/_flow.py
#	tests/test_processing.py
In example there are no performance gains by adding expected values.
@pep8speaks
Copy link

pep8speaks commented Feb 7, 2022

Hello @p-snft! Thanks for updating this PR. We checked the lines you've touched for PEP 8 issues, and found:

Line 23:18: E261 at least two spaces before inline comment

Comment last updated at 2024-12-11 21:12:11 UTC

@p-snft
Copy link
Member Author

p-snft commented Feb 7, 2022

It looks like my implementation does not improve performance in my benchmark/ example case:

Time to solve run (no hints): 292.25 s
Time to solve run (no hints): 281.17 s
Time to solve run (with hints): 286.85 s
Time to solve run (no hints): 375.14 s

Problem is maybe caused by #818.

Update: It's not.

Comment on lines 368 to 371
self.flow[o, i, t].value = (
self.flows[o, i].value[t]
* self.flows[o, i].nominal_value
)
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This statement does not seem to have any effect. Also, I did not see any hint in the documentation that assignment is possible. (However, it seems to work for the fixed entries.)

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I found examples that show the value being set that way in the documentation (https://pyomo.readthedocs.io/en/stable/working_models.html#changing-the-model-or-data-and-re-solving). Pyomo values are fixed, so thzis method seems to work. However, in the LP files, there is no starting value. Also, there is no run time difference.

As the documentation for Pyomo variables says that initialisation "is particularly important for non-linear models", I feel that the starting value might be simply ignored for linear variables.

@p-snft p-snft mentioned this pull request Feb 12, 2022
5 tasks
@p-snft
Copy link
Member Author

p-snft commented Apr 4, 2022

I learned that a parameter warmstart=True has to be used when solving the Pyomo model so that the starting values are used.

Base automatically changed from v0.5 to dev June 24, 2022 10:01
@p-snft p-snft self-assigned this Dec 10, 2024
p-snft and others added 3 commits December 10, 2024 15:48
# Conflicts:
#	src/oemof/solph/_models.py
#	src/oemof/solph/flows/_flow.py
#	src/oemof/solph/flows/_investment_flow.py
#	tests/test_processing.py
The expected value should be a load (in 0 <= load <= 1),
as min, max, and fix are also loads.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants