-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Enhancement: Additional controls over bridges #8263
Enhancement: Additional controls over bridges #8263
Conversation
I love it! Have you considered adding a flow multiplier for the 2nd bridge layer? Printing the first bridge layer at less than 100% density can help avoid interference between lines. Then an above 1 multiplier on the next layer flow could help to fill in the gaps and recover more quickly. Another thought I had for bridging in general, is to first print every other bridge line (let's call it odd numbers), then come back and fill in the remaining even lines. The thought there is to allow 100% density, without interference between lines as they cool and tighten up, then they potentially help scaffold the second pass of bridging between gaps. |
For sure!! There are plenty of things that can be done with it, print the second bridge layer faster is also one of those :) For now I’ve been focusing on generating the surfaces themselves, it as that part wasn’t simple at all (polygon calculations etc). Hopefully either myself, time allowing, or the community can take the polygon calculations and the new logic and create new surface types that have their own dedicated attributes (speed, density, infill pattern type, flow etc). |
OK so the PR is now ready for review. @SoftFever @Noisyfox for your review :) Fully appreciate that there is a TON more that can be done with the new surface types created here (that differentiate the second bridge layer over internal and external bridges). Ideas include specific settings like the below:
However this is a pretty big undertaking, so I would really appreciate if the code could be included in orca, even if this is not 1000% feature complete, so the rest of the community can also step in and take them further, building on the work to identify, segment and create those new surface types :) |
This is a huge step forward and something that lots of people are desperting. Thanks for your awesome work! |
Thank you, hugely appreciated :D I've run out of steam to do more with it, but hope that we can use the new surface types to do more cool stuff with them in the future : ) Trying to figure out the polygon math, where in the code to do them and actually coding them took the best out of me haha! |
Thank you! Is there any way I can buy you a cup of coffee? |
Yay! Looking forward to this getting released! |
haha I do love a coffee! And had way too many for this one :P In all seriousness though if you do feel like donating, and I know everyone would appreciate that highly no matter how small the amount, the official donation route is the way to go https://github.com/sponsors/SoftFever |
What is that Cura has? I don't remember such settings |
Is there anything we can do to help get this pushed to mainline? |
Some testing would definitely help. Mostly focusing on whether the bridge areas are identified correctly. I've done pretty extensive testing already on it but it always helps to double confirm. Finally any print quality improvement testing always helps :) |
@igiannakas When I enable "two external bridge layers" It is creating bridges that do not exist when I have that option disabled. I have fuzzy skin enabled, but disabling it does not have any impact on the result. I can change the value of the inner and outer wall width and it will get the extra bridge to disappear. In my test setting it to 0.4 outer and 0.42 inner triggers the odd bridge. Adjusting the internal solid infill width also has an impact. Here is a closeup of one area it happens (in order of layers 27 to 29 in my slice): |
OK some more changes done. Applied shrink expand operations, filtered out secondary internal bridge based on min width/height, introduced use of unions to ensure no overlapping polygons generate odd geometry later. Hopefully this fixes it :S If not I honestly dont know what else to look at haha! edit: turns out I think I do … |
OK not fully fixed yet. I'm guessing there is a race condition going on there. Will refactor the second internal bridge over sparse infill to move it to its own block after the existing infill detection and generation block is completed. |
…p to avoid thread deadlocks
Code for the second internal bridge infill has been refactored into its own parallel for loop to remove race conditions with the existing infill code, that were causing the issue identified by @SoftFever above. As a bonus we got the second internal bridge infill type now defined properly as a surface. That’s what happens when all your CompSci teaching about 24 years ago was done at single core machines 😂 Ready for testing. |
…nal bridge layer. This resulted in partly unsupported solid infill areas above as the remainder was too narrow to generate sparse infill
Looks all good now. |
No worries! Fingers crossed no more bugs 😂 |
Nice work peeps! Can't wait to try this out! When can we expect this to be released? |
It’s in the nightly release already if I’m not mistaken. |
Ah. Sorry about that. I didn't see the list of assets at the bottom of the post about nightly build, at first; so I was a bit confused. |
No worries :) |
Hmm, just downloaded the nightly Windows build, and the extra bridge layer is missing on the first project I tried: NoExtraBridge.mp4 |
Very small in length or very narrow in width bridges are filtered out as there is no benefit to them getting a second bridge layer. Basically any bridge that is less wide or less long than 2x the number of walls set in that area. Tooltip explains it all :) |
Prusa just implemented something very similar to the second bridge layer in the latest prusa slicer alpha: prusa3d/PrusaSlicer@5430596 maybe consider in the future doing a merge between the two. Approach is very similar but they have gone the extra mile of defining a new surface type with its own speed too :) |
Found a little glitch where it is inserting bridge inside a completely solid model: |
Description
Introducing additional controls over bridges.
This is the first in a potential series of PR's aiming to improve how bridging is handled by Orca. None of the upstream sources (prusa slicer / bambu slicer) have implemented logic to detect polygons directly above bridges, either internal or external, so we are going in new territory with this code and coming closer to the granularity of control over bridging that Cura has available today.
In this PR I am focusing on setting the foundation by detecting and carving out solid surfaces that are extruded over bridges and implementing some rudimentary improvements to the bridging logic (two bridge layers) that should already yield printing benefit.
Hopefully once this PR is merged, the community can take it to the next logical step which is to create dedicated surface types for layers over internal/external bridges with their own dedicated settings. This is a lot of work, hence splitting this in "chunks".
The first "chunk" is done - this PR now successfully allows Orca to detect and segment solid infill areas over internal and external bridges and tag them accordingly. The settings below have been implemented to yield some immediate benefit (as the bridges are now multi-layer, hence by default more reliable), but as said above, much more can be done now that we have those polygons tagged with their own surface types.
The following features have been developed
Fixes #6958
Fixes #3847
Fixes #3822
Screenshots/Recordings/Graphs
Internal Bridge Density
data:image/s3,"s3://crabby-images/73f9e/73f9ec52e68c922cfcda70a35288c9a854755dd0" alt="image"
shown at 50% for display purposes. More realistic values are around the 80-90%
Second bridge layer over internal bridge:
data:image/s3,"s3://crabby-images/cb9eb/cb9eb9131b73ac286c7d52294b8eb1782dea36a7" alt="image"
Shown with bridge density at 50% for display purposes.
Second bridge layer over external bridge:
data:image/s3,"s3://crabby-images/619c2/619c2283b2bff22ec470a06762431b8b48e0daac" alt="image"
data:image/s3,"s3://crabby-images/3108b/3108b0335485639ba521ad83641824a6bd41858a" alt="image"
Small external bridges are filtered out as they do not benefit from the feature.
Bridges that are shorter and/or narrower than the total number of extruded walls in the region are omitted from the dual external bridge calculation.
Print results
Left - Old / Right - Two bridge layers enabled
Bridges are significantly improved, with no separation of the bridge layer from the perimeters caused by the faster infill
data:image/s3,"s3://crabby-images/757f4/757f4b513e9fb92c8bf1a65efedac9cfb5b646ed" alt="IMG_5467"
Tests
Tested with simple and complex multi-layer/text cut out top surface models. No issues identified. Settings are on a per object basis.
Please note that the settings labels are slightly different from the final commit
Internal bridging tests
data:image/s3,"s3://crabby-images/479ce/479ce5d71d0f416d54533b6f044d5b57db3f48ce" alt="image"
data:image/s3,"s3://crabby-images/a397e/a397ef43ffb4f2674de2bb196ad153861a6ade66" alt="image"
data:image/s3,"s3://crabby-images/82954/829543737d24e7ff31efead74759f2d1c5b6ff78" alt="image"
External bridging tests
data:image/s3,"s3://crabby-images/22685/22685681af5187eae6e198095fc04a1fb30fac99" alt="image"
data:image/s3,"s3://crabby-images/35560/3556033f407d1f7524533686da19e853f594e7d7" alt="image"
data:image/s3,"s3://crabby-images/5e6af/5e6af87074b50fe84e87bc7850ff51478a941620" alt="image"