René's URL Explorer Experiment


Title: Improvements to Nichols chart plotting by roryyorke · Pull Request #723 · python-control/python-control · GitHub

Open Graph Title: Improvements to Nichols chart plotting by roryyorke · Pull Request #723 · python-control/python-control

X Title: Improvements to Nichols chart plotting by roryyorke · Pull Request #723 · python-control/python-control

Description: These are relatively minor updates to the Nichols chart (AKA grid) plotting. It's far from ideal; further possible improvements: more tightly fitting the chart to the view (or data) xlim and ylim (the "extent"); the pain here is figuring out which contours to plot, and where to place the labels depending on the limits, some contours will end up with a two visible segments recreating the axis on zoom and pan events this might not be too difficult; Axes support 'xlim_changed' and 'ylim_changed' events a deluxe version of this would be too add (secondary?) axes, and show the closed-loop gain and phase in the "data value" text (the "x= , y = " on the Matplotlib toolbar) I wonder if we could use a custom ContourSets, and plug into however that labelling is done? Here are some before-and-after pictures (left is before) of a few example systems. The new code gives a better result in almost all respects. One visible problem is that the closed-loop phase label for "0°" clashes with the "-40dB" (and similar) closed-loop gain label. The gains become crowded when the gain span is large (final figure), but that is the same in both versions. I haven't added tests; I'll see how much time I have to do that. Easyish tests: check for "tight" phase limits (see first example below) check that the axes child text elements are have clip_on (I'd have to not check title & tick labels, presume this is possible) check for existence of phase labels, contingent on label_cl_phases flag test both branches of the if in _inner_extents, and in fact test the behaviour in general by setting xlim & ylim before calling nichols_grid. Please suggest other tests. Details (commit message) Clip closed-loop contour labels. Add labels for constant closed-loop phase contours. Use smaller of data or view extents when deciding on how big, in phase, a chart to create. Use more uniformly spaced closed-loop phase contours, and use more widely-spaced contours when phase extent is large. Add optional ax argument, for axes to add grid to.

Open Graph Description: These are relatively minor updates to the Nichols chart (AKA grid) plotting. It's far from ideal; further possible improvements: more tightly fitting the chart to the view (or data) xlim and y...

X Description: These are relatively minor updates to the Nichols chart (AKA grid) plotting. It's far from ideal; further possible improvements: more tightly fitting the chart to the view (or data) xlim a...

Opengraph URL: https://github.com/python-control/python-control/pull/723

X: @github

direct link

Domain: github.com

route-pattern/:user_id/:repository/pull/:id/files(.:format)
route-controllerpull_requests
route-actionfiles
fetch-noncev2:c8891ee6-836f-6364-42fc-dff316beea4d
current-catalog-service-hashae870bc5e265a340912cde392f23dad3671a0a881730ffdadd82f2f57d81641b
request-idDA40:38B173:109CB15:1571EF2:697E4AAA
html-safe-nonce1a12a6f8f729d37ccc09add37d88b78d482856eb3e168af551b535bf0232c080
visitor-payloadeyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiJEQTQwOjM4QjE3MzoxMDlDQjE1OjE1NzFFRjI6Njk3RTRBQUEiLCJ2aXNpdG9yX2lkIjoiNzI4NzQ1NjE4MTgxODExNjc3OCIsInJlZ2lvbl9lZGdlIjoiaWFkIiwicmVnaW9uX3JlbmRlciI6ImlhZCJ9
visitor-hmac3ef627512fa75ac19cdeb3ef7c78699ba811df458bc6e75dc511360633ad3f36
hovercard-subject-tagpull_request:911276517
github-keyboard-shortcutsrepository,pull-request-list,pull-request-conversation,pull-request-files-changed,copilot
google-site-verificationApib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I
octolytics-urlhttps://collector.github.com/github/collect
analytics-location///pull_requests/show/files
fb:app_id1401488693436528
apple-itunes-appapp-id=1477376905, app-argument=https://github.com/python-control/python-control/pull/723/files
twitter:imagehttps://avatars.githubusercontent.com/u/110974?s=400&v=4
twitter:cardsummary_large_image
og:imagehttps://avatars.githubusercontent.com/u/110974?s=400&v=4
og:image:altThese are relatively minor updates to the Nichols chart (AKA grid) plotting. It's far from ideal; further possible improvements: more tightly fitting the chart to the view (or data) xlim and y...
og:site_nameGitHub
og:typeobject
hostnamegithub.com
expected-hostnamegithub.com
None60279d4097367e16897439d16d6bbe4180663db828c666eeed2656988ffe59f6
turbo-cache-controlno-preview
diff-viewunified
go-importgithub.com/python-control/python-control git https://github.com/python-control/python-control.git
octolytics-dimension-user_id2285872
octolytics-dimension-user_loginpython-control
octolytics-dimension-repository_id22791752
octolytics-dimension-repository_nwopython-control/python-control
octolytics-dimension-repository_publictrue
octolytics-dimension-repository_is_forkfalse
octolytics-dimension-repository_network_root_id22791752
octolytics-dimension-repository_network_root_nwopython-control/python-control
turbo-body-classeslogged-out env-production page-responsive full-width
disable-turbotrue
browser-stats-urlhttps://api.github.com/_private/browser/stats
browser-errors-urlhttps://api.github.com/_private/browser/errors
release7c85641c598ad130c74f7bcc27f58575cac69551
ui-targetfull
theme-color#1e2327
color-schemelight dark

Links:

Skip to contenthttps://github.com/python-control/python-control/pull/723/files#start-of-content
https://github.com/
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fpython-control%2Fpython-control%2Fpull%2F723%2Ffiles
GitHub CopilotWrite better code with AIhttps://github.com/features/copilot
GitHub SparkBuild and deploy intelligent appshttps://github.com/features/spark
GitHub ModelsManage and compare promptshttps://github.com/features/models
MCP RegistryNewIntegrate external toolshttps://github.com/mcp
ActionsAutomate any workflowhttps://github.com/features/actions
CodespacesInstant dev environmentshttps://github.com/features/codespaces
IssuesPlan and track workhttps://github.com/features/issues
Code ReviewManage code changeshttps://github.com/features/code-review
GitHub Advanced SecurityFind and fix vulnerabilitieshttps://github.com/security/advanced-security
Code securitySecure your code as you buildhttps://github.com/security/advanced-security/code-security
Secret protectionStop leaks before they starthttps://github.com/security/advanced-security/secret-protection
Why GitHubhttps://github.com/why-github
Documentationhttps://docs.github.com
Bloghttps://github.blog
Changeloghttps://github.blog/changelog
Marketplacehttps://github.com/marketplace
View all featureshttps://github.com/features
Enterpriseshttps://github.com/enterprise
Small and medium teamshttps://github.com/team
Startupshttps://github.com/enterprise/startups
Nonprofitshttps://github.com/solutions/industry/nonprofits
App Modernizationhttps://github.com/solutions/use-case/app-modernization
DevSecOpshttps://github.com/solutions/use-case/devsecops
DevOpshttps://github.com/solutions/use-case/devops
CI/CDhttps://github.com/solutions/use-case/ci-cd
View all use caseshttps://github.com/solutions/use-case
Healthcarehttps://github.com/solutions/industry/healthcare
Financial serviceshttps://github.com/solutions/industry/financial-services
Manufacturinghttps://github.com/solutions/industry/manufacturing
Governmenthttps://github.com/solutions/industry/government
View all industrieshttps://github.com/solutions/industry
View all solutionshttps://github.com/solutions
AIhttps://github.com/resources/articles?topic=ai
Software Developmenthttps://github.com/resources/articles?topic=software-development
DevOpshttps://github.com/resources/articles?topic=devops
Securityhttps://github.com/resources/articles?topic=security
View all topicshttps://github.com/resources/articles
Customer storieshttps://github.com/customer-stories
Events & webinarshttps://github.com/resources/events
Ebooks & reportshttps://github.com/resources/whitepapers
Business insightshttps://github.com/solutions/executive-insights
GitHub Skillshttps://skills.github.com
Documentationhttps://docs.github.com
Customer supporthttps://support.github.com
Community forumhttps://github.com/orgs/community/discussions
Trust centerhttps://github.com/trust-center
Partnershttps://github.com/partners
GitHub SponsorsFund open source developershttps://github.com/sponsors
Security Labhttps://securitylab.github.com
Maintainer Communityhttps://maintainers.github.com
Acceleratorhttps://github.com/accelerator
Archive Programhttps://archiveprogram.github.com
Topicshttps://github.com/topics
Trendinghttps://github.com/trending
Collectionshttps://github.com/collections
Enterprise platformAI-powered developer platformhttps://github.com/enterprise
GitHub Advanced SecurityEnterprise-grade security featureshttps://github.com/security/advanced-security
Copilot for BusinessEnterprise-grade AI featureshttps://github.com/features/copilot/copilot-business
Premium SupportEnterprise-grade 24/7 supporthttps://github.com/premium-support
Pricinghttps://github.com/pricing
Search syntax tipshttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
documentationhttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fpython-control%2Fpython-control%2Fpull%2F723%2Ffiles
Sign up https://github.com/signup?ref_cta=Sign+up&ref_loc=header+logged+out&ref_page=%2F%3Cuser-name%3E%2F%3Crepo-name%3E%2Fpull_requests%2Fshow%2Ffiles&source=header-repo&source_repo=python-control%2Fpython-control
Reloadhttps://github.com/python-control/python-control/pull/723/files
Reloadhttps://github.com/python-control/python-control/pull/723/files
Reloadhttps://github.com/python-control/python-control/pull/723/files
python-control https://github.com/python-control
python-controlhttps://github.com/python-control/python-control
Notifications https://github.com/login?return_to=%2Fpython-control%2Fpython-control
Fork 448 https://github.com/login?return_to=%2Fpython-control%2Fpython-control
Star 2k https://github.com/login?return_to=%2Fpython-control%2Fpython-control
Code https://github.com/python-control/python-control
Issues 87 https://github.com/python-control/python-control/issues
Pull requests 9 https://github.com/python-control/python-control/pulls
Discussions https://github.com/python-control/python-control/discussions
Actions https://github.com/python-control/python-control/actions
Projects 0 https://github.com/python-control/python-control/projects
Wiki https://github.com/python-control/python-control/wiki
Security 0 https://github.com/python-control/python-control/security
Insights https://github.com/python-control/python-control/pulse
Code https://github.com/python-control/python-control
Issues https://github.com/python-control/python-control/issues
Pull requests https://github.com/python-control/python-control/pulls
Discussions https://github.com/python-control/python-control/discussions
Actions https://github.com/python-control/python-control/actions
Projects https://github.com/python-control/python-control/projects
Wiki https://github.com/python-control/python-control/wiki
Security https://github.com/python-control/python-control/security
Insights https://github.com/python-control/python-control/pulse
Sign up for GitHub https://github.com/signup?return_to=%2Fpython-control%2Fpython-control%2Fissues%2Fnew%2Fchoose
terms of servicehttps://docs.github.com/terms
privacy statementhttps://docs.github.com/privacy
Sign inhttps://github.com/login?return_to=%2Fpython-control%2Fpython-control%2Fissues%2Fnew%2Fchoose
bnavigatorhttps://github.com/bnavigator
python-control:masterhttps://github.com/python-control/python-control/tree/master
roryyorke:rory/nichols-improvementshttps://github.com/roryyorke/python-control/tree/rory/nichols-improvements
Conversation 9 https://github.com/python-control/python-control/pull/723
Commits 5 https://github.com/python-control/python-control/pull/723/commits
Checks 0 https://github.com/python-control/python-control/pull/723/checks
Files changed https://github.com/python-control/python-control/pull/723/files
Please reload this pagehttps://github.com/python-control/python-control/pull/723/files
Improvements to Nichols chart plotting https://github.com/python-control/python-control/pull/723/files#top
Show all changes 5 commits https://github.com/python-control/python-control/pull/723/files
782e526 Improvements to Nichols chart plotting roryyorke Apr 16, 2022 https://github.com/python-control/python-control/pull/723/commits/782e526059f17dc15ec68f2d1eb7855ece740969
3281a8d nichols_grid returns artists of grid elements; further tighten phase … roryyorke Apr 27, 2022 https://github.com/python-control/python-control/pull/723/commits/3281a8d6eafe8980eb1cf967cb357bd86f292912
b813e0c Add tests for nichols_grid roryyorke Apr 27, 2022 https://github.com/python-control/python-control/pull/723/commits/b813e0caea6f994ec0f718043218fda1255799f6
71f3b61 Fix nichols_grid test roryyorke Apr 27, 2022 https://github.com/python-control/python-control/pull/723/commits/71f3b6134b0622d337eefa3521a3409c0de3ef9b
59cd872 In nichols_grid tests: use mplcleanup, and remove plt.clf calls roryyorke Apr 27, 2022 https://github.com/python-control/python-control/pull/723/commits/59cd8728bd4835897471674b301b0cf605ac4bc3
Clear filters https://github.com/python-control/python-control/pull/723/files
Please reload this pagehttps://github.com/python-control/python-control/pull/723/files
Please reload this pagehttps://github.com/python-control/python-control/pull/723/files
nichols.py https://github.com/python-control/python-control/pull/723/files#diff-b581de8c6f5f8f72c517e49ebb7ec697d93fc31e16b6e9f9d36a10ec2aecd510
nichols_test.py https://github.com/python-control/python-control/pull/723/files#diff-e3f6d4ed537006dde56c8339324c326b030fcdb64a8541d9617193df745691a7
control/nichols.pyhttps://github.com/python-control/python-control/pull/723/files#diff-b581de8c6f5f8f72c517e49ebb7ec697d93fc31e16b6e9f9d36a10ec2aecd510
View file https://github.com/roryyorke/python-control/blob/59cd8728bd4835897471674b301b0cf605ac4bc3/control/nichols.py
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/python-control/python-control/pull/723/{{ revealButtonHref }}
https://github.com/python-control/python-control/pull/723/files#diff-b581de8c6f5f8f72c517e49ebb7ec697d93fc31e16b6e9f9d36a10ec2aecd510
https://github.com/python-control/python-control/pull/723/files#diff-b581de8c6f5f8f72c517e49ebb7ec697d93fc31e16b6e9f9d36a10ec2aecd510
https://github.com/python-control/python-control/pull/723/files#diff-b581de8c6f5f8f72c517e49ebb7ec697d93fc31e16b6e9f9d36a10ec2aecd510
https://github.com/python-control/python-control/pull/723/files#diff-b581de8c6f5f8f72c517e49ebb7ec697d93fc31e16b6e9f9d36a10ec2aecd510
https://github.com/python-control/python-control/pull/723/files#diff-b581de8c6f5f8f72c517e49ebb7ec697d93fc31e16b6e9f9d36a10ec2aecd510
https://github.com/python-control/python-control/pull/723/files#diff-b581de8c6f5f8f72c517e49ebb7ec697d93fc31e16b6e9f9d36a10ec2aecd510
https://github.com/python-control/python-control/pull/723/files#diff-b581de8c6f5f8f72c517e49ebb7ec697d93fc31e16b6e9f9d36a10ec2aecd510
control/tests/nichols_test.pyhttps://github.com/python-control/python-control/pull/723/files#diff-e3f6d4ed537006dde56c8339324c326b030fcdb64a8541d9617193df745691a7
View file https://github.com/roryyorke/python-control/blob/59cd8728bd4835897471674b301b0cf605ac4bc3/control/tests/nichols_test.py
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/python-control/python-control/pull/723/{{ revealButtonHref }}
https://github.com/python-control/python-control/pull/723/files#diff-e3f6d4ed537006dde56c8339324c326b030fcdb64a8541d9617193df745691a7
https://github.com/python-control/python-control/pull/723/files#diff-e3f6d4ed537006dde56c8339324c326b030fcdb64a8541d9617193df745691a7
Please reload this pagehttps://github.com/python-control/python-control/pull/723/files
https://github.com
Termshttps://docs.github.com/site-policy/github-terms/github-terms-of-service
Privacyhttps://docs.github.com/site-policy/privacy-policies/github-privacy-statement
Securityhttps://github.com/security
Statushttps://www.githubstatus.com/
Communityhttps://github.community/
Docshttps://docs.github.com/
Contacthttps://support.github.com?tags=dotcom-footer

Viewport: width=device-width


URLs of crawlers that visited me.