Skip to content

Conversation

@Opt-Mucca
Copy link
Collaborator

This creates a lambda expression strongBranch that gets called when evaluating branching candidates. It is purely there to improve code readability and remove some duplicate code. Previously, there was a large amount of extended logic for x <= b and that was mostly repeated for x >= b+1. I've put them into a single function where you give a boolean flag on which one you want to evaluate. That should not change change the solution path whatsoever (completely unsure if there is a potential performance impact for semi-large lambda expressions in C++)

The single line change that may change the solution path of some instances: If there is a single branching candidate then I just now select it (I don't bother evaluating it).

@Opt-Mucca Opt-Mucca requested review from galabovaa and jajhall June 30, 2025 08:58
@codecov
Copy link

codecov bot commented Jun 30, 2025

Codecov Report

❌ Patch coverage is 91.11111% with 4 lines in your changes missing coverage. Please review.
✅ Project coverage is 79.66%. Comparing base (c5e2b14) to head (08b4740).
⚠️ Report is 131 commits behind head on latest.

Files with missing lines Patch % Lines
highs/mip/HighsSearch.cpp 91.11% 4 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           latest    #2444      +/-   ##
==========================================
+ Coverage   79.64%   79.66%   +0.02%     
==========================================
  Files         346      346              
  Lines       86490    86356     -134     
==========================================
- Hits        68884    68797      -87     
+ Misses      17606    17559      -47     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

Copy link
Member

@jajhall jajhall left a comment

Choose a reason for hiding this comment

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

Fine by me. One more minor modification that can be accumulated before baseline testing to assess the effectiveness of expected performance enhancements sitting in PRs

Copy link
Collaborator

@BenChampion BenChampion left a comment

Choose a reason for hiding this comment

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

Nice! Always in favor of removing unnecessary duplicated code. I'm not sure what the overhead of the lambda would be, but my intuition (possibly wrong!) is that it should be minimal. Worth testing, of course.

@fwesselm
Copy link
Collaborator

I ran 424 instances from MIPLIB with these changes and observed different node counts on bell3a, bell5, blp-ar98, harp2, lectsched-4-obj, leo1, lseu, map18, mine-166-5, neos-1440460, neos-476283, noswot, opm2-z7s2, pg, pg5_34, pp08a, ran14x18-disj-8, ran16x16, reblock166, reblock67, rentacar, roll3000 and rout. I am not sure if all these are affected by the single line change you described.

@Opt-Mucca
Copy link
Collaborator Author

@fwesselm I have just simply removed that line (Thought about it a bit more and there could be some fringe case where such a change slows down an instance by a fair bit)

@fwesselm
Copy link
Collaborator

@fwesselm I have just simply removed that line (Thought about it a bit more and there could be some fringe case where such a change slows down an instance by a fair bit)

Ok, I will re-run the instances where the behavior changed shortly.

@fwesselm
Copy link
Collaborator

@fwesselm I have just simply removed that line (Thought about it a bit more and there could be some fringe case where such a change slows down an instance by a fair bit)

Ok, I will re-run the instances where the behavior changed shortly.

I re-ran the instances, and there are no behavior changes with the updated code.

@fwesselm
Copy link
Collaborator

I tried to resolve the merge conflict and hope this is ready to be merged now.

@Opt-Mucca
Copy link
Collaborator Author

Assuming the merge conflict was just for the README? I'm all for this being merged.

@fwesselm
Copy link
Collaborator

Assuming the merge conflict was just for the README? I'm all for this being merged.

Yes, FEATURES.md had a conflict.

@Opt-Mucca Opt-Mucca merged commit a9cb877 into latest Oct 20, 2025
309 checks passed
@Opt-Mucca Opt-Mucca deleted the strong-branch-refactor branch December 15, 2025 11:16
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.

5 participants