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

Wrong function reference for BranchFlowPerPSTAngle factor #324

Merged
merged 5 commits into from
Jul 6, 2021

Conversation

annetill
Copy link
Member

Signed-off-by: Anne Tilloy [email protected]

Please check if the PR fulfills these requirements (please use '[x]' to check the checkboxes, or submit the PR and then click the checkboxes)

  • The commit message follows our guidelines
  • Tests for the changes have been added (for bug fixes / features)
  • Docs have been added / updated (for bug fixes / features)

Does this PR already have an issue describing the problem ? If so, link to this issue using '#XXX' and skip the rest

No, it explains the issue. We want to calculate the sensitivity of a PST angle to a monitored branch. The flow on this monitored branch is right in pre-contingency state. We simulate a contingency of this same PST: the flux on the monitored branch on post-contingency state falls to zero.

What kind of change does this PR introduce? (Bug fix, feature, docs update, ...)

What is the current behavior? (You can also link to an open issue here)

What is the new behavior (if this is a feature change)?

Does this PR introduce a breaking change or deprecate an API? If yes, check the following:

  • The Breaking Change or Deprecated label has been added
  • The migration guide has been updated in the github wiki (What changes might users need to make in their application due to this PR?)

Other information:

(if any of the questions/checkboxes don't apply, please delete them entirely)

@annetill annetill requested a review from geofjamg June 29, 2021 09:46
annetill added 2 commits July 6, 2021 08:58
Signed-off-by: Anne Tilloy <[email protected]>
Signed-off-by: Anne Tilloy <[email protected]>
@annetill annetill requested a review from Hadrien-Godard July 6, 2021 07:24
Comment on lines 225 to 229
if (contingencyElement.getElement().getId().equals(factor.getVariableId())) {
// the equipment responsible for the variable is indeed in contingency, the sensitivity value equals to zero.
// No assumption about the reference flow on the monitored branch.
sensiValue = 0d;
}
Copy link

Choose a reason for hiding this comment

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

If you have multiple contingency elements and the factor variable is the first element, then you will set the sensi value to 0 in the first iteration, and then add contingencyElement.getAlphaForSensitivityValue() * contingencySensitivity for the second contingency element.
So the sensitivity value will not be 0 at the end of the for loop which is an issue.

You could solve this by setting a boolean to true in the for loop if contingencyElement.getElement().getId().equals(factor.getVariableId())) is ever true for one of the contingency elements. Then after the for loop you check if that boolean is true and set sensiValue to 0 if it is the case.
(this would also allow you to put the second if right after the first if for better readability)

Copy link

Choose a reason for hiding this comment

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

It might also be worth it to compute the flows once per contingencyElements set and functionBranch (since it does not depend on the factor variable (pst)), but the gain is probably quite small.

annetill added 2 commits July 6, 2021 11:17
Signed-off-by: Anne Tilloy <[email protected]>
Signed-off-by: Anne Tilloy <[email protected]>
@sonarqubecloud
Copy link

sonarqubecloud bot commented Jul 6, 2021

Kudos, SonarCloud Quality Gate passed!

Bug A 0 Bugs
Vulnerability A 0 Vulnerabilities
Security Hotspot A 0 Security Hotspots
Code Smell A 1 Code Smell

100.0% 100.0% Coverage
0.0% 0.0% Duplication

@annetill annetill merged commit e73157c into master Jul 6, 2021
@annetill annetill deleted the issue-sensi-dephaseur branch July 6, 2021 09:42
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