-
Notifications
You must be signed in to change notification settings - Fork 280
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
BUG: use tight layout by default when saving matplotlib figures #3635
Conversation
… expected don't have the same shape
…id cropping labels out
Thinking on top of my head on my phone, but have you tried using `constrained_layout=True` when creating the matplotlib figure?
31 Oct 2021 17:58:52 Clément Robert ***@***.***>:
*PR Summary*
This is a second a second attempt to fix #3601[#3601], reusing the patch from #3602[#3602]
combined with the test framework modifications from #3633[#3633] to enable comparisons
for images of different sizes.
Opening as a draft to indicate #3633[#3633] takes priority over this.
----------------------------------------
*You can view, comment on, or merge this pull request online at:*
#3635
*Commit Summary*
* > ENH: Improve 2D figure layout in case the long axis is vertical[4ffc889]
* > TST: modify image comparison method to enable reports when actual and expected don't have the same shape[af7093c]
* > BUG: use tight layout by default when saving figures (PlotMPL) to avoid cropping labels out[af2bf3e]
*File Changes*
(2 files[https://github.com/yt-project/yt/pull/3635/files])
* > *M* yt/utilities/answer_testing/framework.py[https://github.com/yt-project/yt/pull/3635/files#diff-0588597c99a8f042699cce2585f6e885e3dcbc0e2cc13c4618ca58eadf875a6f] (35)
* > *M* yt/visualization/base_plot_types.py[https://github.com/yt-project/yt/pull/3635/files#diff-813fdd3d212be372fea21282904849bdc1a899e20e90523a82a271a2d2074963] (13)
*Patch Links:*
* > https://github.com/yt-project/yt/pull/3635.patch
* > https://github.com/yt-project/yt/pull/3635.diff
…
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub[#3635], or unsubscribe[https://github.com/notifications/unsubscribe-auth/ABJJIIYQLHQVM7WOGWZAYTLUJVYUXANCNFSM5HCPPPRA].
Triage notifications on the go with GitHub Mobile for iOS[https://apps.apple.com/app/apple-store/id1477376905?ct=notification-email&mt=8&pt=524675] or Android[https://play.google.com/store/apps/details?id=com.github.android&referrer=utm_campaign%3Dnotification-email%26utm_medium%3Demail%26utm_source%3Dgithub]. [###24x24:true###][Tracking image][https://github.com/notifications/beacon/ABJJII7LZE4ETW33BHVOKRDUJVYUXA5CNFSM5HCPPPRKYY3PNVWWK3TUL52HS4DFUVEXG43VMWVGG33NNVSW45C7NFSM4PQFFZQQ.gif]
|
I have no experience with this paradigm, so no. What benefits do you expect from this approach ? |
According to few sources on matplotlib's issue tracker (see e.g. matplotlib/cheatsheets#30 (comment)), fig = plt.figure(constrained_layout=True) rather than call |
Excellent. I was afraid this would be marginally better and a lot more expensive to implement/maintain, but the cost seems actually equivalent and MPL core devs seem to be unanimous on their preference, so let's try this |
@cphyc turns out this is more than a single line patch, lets see what CI has to say. |
oh and one thing that should be elucidated is how well this two options play together when combined. Users may already be passing |
So it seems to me that @cphyc, let me know if you want to have a looks, but otherwise I'll just remove the most recent commit (constrained_layout) |
da05037
to
af2bf3e
Compare
I realized that my modified testing framework produce nice reports but will upload polluted artifacts that are not suited to update the answer store. This needs more work, but I don't know when I'll be able to manage this, so I'm closing this PR for now. |
PR Summary
This is a second a second attempt to fix #3601, reusing the patch from #3602
combined with the test framework modifications from #3633 to enable comparisons
for images of different sizes.
Opening as a draft to indicate #3633 takes priority over this.