-
Notifications
You must be signed in to change notification settings - Fork 44
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
📚 Multiple docs improvements #1745
Conversation
02e8902
to
6152d07
Compare
0243214
to
ea3efbb
Compare
174a645
to
2fce3a9
Compare
c44bf9e
to
0549284
Compare
0549284
to
2b57382
Compare
Note that the docs sync issue is fixed in pre/2.8 accordingly here. I will manually push to that remote, but I believe it will be fine to merge to develop for now in any case. |
So docs should be finished building anytime live here https://docs.flexcompute.com/projects/tidy3d/en/docs-demo-full_api/ Note that our docs builds after this are >2hrs on RTD |
Thanks @daquinteroflex , so this PR adds back listing of all fields in the API reference? and 2 hours is better than not building at all! |
I definitely like it better with all of the methods. A few comments:
Implementation wise, looks good so I'm approving it for that. Also really appreciate all the nice additions! |
@@ -64,8 +64,10 @@ | |||
autodoc_class_signature = "separated" | |||
autodoc_default_options = { | |||
"members": True, | |||
"inherited-members": True, | |||
"member-order": "bysource", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
On the existing configuration, there are a few options. I believe the methods can be ordered by source
or alphabetical
. Unfortunately, we don't have more control about this in my understanding than this parameter. I had intended to give it some time iterating a few approaches, but then realised we might already be limited on this.
I've raised an issue for the new docs extension to enable this flexcompute/autoflex#12
However, maybe for now this is it?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
one or the other (source or alphabetical) is probably fine enough for now.
docs/conf.py
Outdated
"member-order": "bysource", | ||
"undoc-members": True, | ||
"exclude-members": "SchemaConfig,__init__,Config,attrs,chunk,copy,json,log", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Need to try a few more approaches to remove the dunder methods too so that the inherited members are not recognised.
Am afraid am unable to do these changes until later this afternoon as have been caught up this start of week.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yea no rush! thanks
2b57382
to
06b59ac
Compare
Unfortunate news, it seems like the latest build has again failed despite two previous successful builds. Emailing read-the-docs again. They did mention this build does take a lot of concurrency time, and I did notice another branch build occured at the same time which meant that it could have taken resources out. I'm trying rebuilding now to see if that works this time. However, this would have important implications of reducing the frequency of our documentation builds - possibly only in the |
That's probably fine from my perspective. So right now when do they get rebuilt automatically? |
So right now there are live |
So this is a bit interesting. The same-state build actually works, but it means it needs to use all the build resources available on read the docs project. Ie no other branches can concurrently build when/if this gets merged. It is slightly worrying actually, because of the risk that there comes a point the documentation doesn't build. I've emailed readthedocs about this but still. I don't like that it is a fragile build resources situation because of the risk one day, or specifically, one release - this gets screwed up and it could take days to fix depending if it's a readthedocs server problem again. The thing that concerns me, is that if we merge this, I cannot guarantee that the docs will always build with new documentation information added. I guess worst case scenario we can revert these changes. Maybe we need to start seriously thinking of:
If this PR gets merged, @momchil-flex if you have some thoughts about this too because of the potential implications during a release process. |
Sorry, I think I'm a bit lost here. This PR does something that would require us to only build one branch at a time on readthedocs and we may soon reach a point where this doesn't work either because our build is too heavy? But we may be getting close to that anyway with or without this PR? Readthedocs is definitely convenient to manage versions, visibility, etc. Is there a convenient way to provide our own computational resources for the builds while still using them for the rest? I think having one active build at a time is not terrible but the danger that even that starts breaking is... not good, yeah. :) |
The intention of this PR is to enable us to build the API classes with all the documented members as it used to be before, per user requests. However, I think between last time we did a full build and now, the amount of content within the documentation has increased a lot. This means that the full API build takes a long time locally, and I've done everything I could find to speed it up. However, when we went to build this ifull-api version in the server, the docs began to fail building due to timeout errors. I fought this for a few weeks now, and got in touch with read the docs support, who increased the server configuration for our project so it could actually begin building this. Now, the docs are taking >2.5 hrs to build each time on this PR in read the docs, but they are building. The issue I recently found is that despite it being able to build, if there is another branch or another concurrent build, such as On your comment, the concern is exactly as you describe it. It's the unreliability of this that concerns me particularly and as the project files increase it is unclear to me how this will handle it. As we debug with them, will propose the idea of using our own computation resources but using them to manage the documentation. |
Have we really thought this through? I remember the documentation used to look quite cluttered. There will always be user requests, we need to make sure we're addressing the ones that make sense. :) 2.5h is pretty crazy. Any idea if it is possible to speed up with more cpu resources if we do a local build? No need to say this will only be getting worse... In the end going to a modular documentation may be inevitable. I understand it's unreasonable for you to this now though so it may have to either be someone else who picks this up, or we try to survive until next year. :) |
Ultimately, I think the goal is to implement all the documentation functionality we want in our new sphinx extension flexcompute/autoflex#12 . But because that will take some iterating to get right, the interim approach that made sense at the time was to introduce the full api build with all inherited methods until the sphinx extension was ready. It should be possible to reduce some of the build time by doing the _autosummary locally, but then this has to be deleted and recommited every time. It should reduce some build resources I think and can attempt to automate this. The cpu or gpu resource management is configured by reathedocs, but still need to explore with them about using our own resources. However, I think maybe what I've learnt from the actual implementation challenges for this interim PR supersede the intended functionality as you describe. Because the docs build situation is unstable if we implement the interim rolled-back inherited api build, as only really seems clear after rtd modified their server configuration as it has occured previously, we would be shooting ourselves in the foot in the long run on implementing this if read the docs cannot sort this out. Rather than focus on interim solutions, it seems in the long run, it makes sense just to focus on implementing this desired functionality in the autoflex extension. However, am afraid, after all the attempts I've had at sorting this out in a patch we could roll out sooner, it seems unreasonable to continue to follow this full api approach given the issues that have appeared and I can't think of a feasible approach to sort this out sooner without major changes @tylerflex @tomflexcompute . If you have any suggestions, would be down to explore that or otherwise will just focus on properly developing this in the autoflex extension. |
Closed in favour of #2009 for now. |
Sorts out:
Full API representationGoing through notebooks and adding common methods instead into custom_autosummarypre/2.7
docsI have been trying multiple approaches to reduce the duration of the docs build, but as the project increases, we might have to consider a few alternatives.
Things I have tried:
include_patterns
andexclude_patterns
so sphinx only recognizes the documents related to the documentation buildWe could remove the source code linking but would be nice not to have to do that (it seems to be increasing the sitemap size so catching SEO?)We could commit the autosummary and generate it as we prefer, but this is not an ideal option as it won't be automatically updated on existing generated files. It would speed up the build.rtd
to increase our documentation build time if none else worksGeneral Development FLow
Depreciate all frontend notion documents into the developer's guide
Simplify instructions for users to get started per Introduced RF material library to microwave plugins #1756 (comment)
Fix the
subgrids ForwardRefand annotate_type
Tom raised.Related PRs to be merged before this one: