Skip to content

Commit

Permalink
Deploying to gh-pages from @ 90ee4ff 🚀
Browse files Browse the repository at this point in the history
  • Loading branch information
CAM-Gerlach committed Mar 14, 2024
1 parent aad48b2 commit cd34823
Show file tree
Hide file tree
Showing 6 changed files with 383 additions and 54 deletions.
Binary file modified .lektor/buildstate
Binary file not shown.
50 changes: 50 additions & 0 deletions blog/feed.xml
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,56 @@ This is a part time position to work as a contractor through <a href="https:/
Interested?
<a href="mailto:[email protected]">Contact me</a> to talk more about it!</p>
<p>We hope you will be as thrilled as we are by this fantastic news, and are looking forward to sharing more with you on this project in the near future!</p>
</content></entry><entry><title>Reusable research Birds of a Feather session at Scipy 2023: Solutions and tools</title><link href="https://www.spyder-ide.org/blog/reusable-research-bof-scipy-2023-part-2/" rel="alternate"></link><updated>2023-03-14T02:30:00Z</updated><author><name>camgerlach</name></author><id>urn:uuid:f040d2ae-b8b0-3fe8-b401-598c3e26d73c</id><content type="html">&lt;p&gt;The Spyder team and &lt;a href="https://cfp.scipy.org/2023/speaker/SE7SNC/"&gt;collaborators&lt;/a&gt; hosted &lt;a href="https://cfp.scipy.org/2023/talk/LGZUNG/"&gt;a Birds of a Feather (BoF) session&lt;/a&gt; at &lt;a href="https://www.scipy2023.scipy.org/"&gt;SciPy 2023&lt;/a&gt;, focused on moving beyond just scripts and notebooks toward truly reproducible, reusable research.
In &lt;a href="https://www.spyder-ide.org/blog/reusable-research-bof-scipy-2023/"&gt;Part 1 of this two-part series&lt;/a&gt;, we went over our motivation and goals for the session and the challenges that attendees brought up.
Now, we’ll review the tips, strategies, tools and platforms (including Spyder!) that participants shared as ways to address these obstacles.
We'd again like to thank &lt;a href="https://cfp.scipy.org/2023/speaker/SE7SNC/"&gt;Juanita Gomez&lt;/a&gt; for helping organize the BoF, Hari for his hard work compiling a summary of the outcomes, and everyone for attending and sharing such great ideas and insights!&lt;/p&gt;
&lt;h2&gt;Making notebooks more reusable&lt;/h2&gt;
&lt;p&gt;As far as reproducibility is concerned, it was brought up that it can be difficult to easily compare outputs between notebooks created by different researchers.
In response, one participant mentioned that VSCode recently made &lt;a href="https://code.visualstudio.com/docs/datascience/jupyter-notebooks#_custom-notebook-diffing"&gt;an improvement&lt;/a&gt; to the notebook diff viewers to more easily show just the code changes.
However, users stressed that it was critical to be able to diff the actual notebook output, not just its contents, and expressed a desire for a tool to cover that aspect.&lt;/p&gt;
&lt;p&gt;In response to these concerns, others responded that notebooks should not be considered a unit of reproducible research, which should instead be a complete software project, including notebooks or scripts, an environment/requirements file and a record of commands to run there.
They recommended the &lt;a href="https://www.anaconda.com/blog/8-levels-of-reproducibility"&gt;8-levels of Reproducibility&lt;/a&gt; and &lt;a href="https://github.com/conda-incubator/conda-project"&gt;Conda Project&lt;/a&gt; to help guide and implement this.&lt;/p&gt;
&lt;p&gt;Additionally, attendees recommended &lt;a href="https://papermill.readthedocs.io/en/latest/"&gt;Papermill&lt;/a&gt;, describing it as a very useful tool for parameterizing and executing notebooks programmatically.
Others suggested &lt;a href="https://containers.dev/"&gt;Devcontainers&lt;/a&gt;, to allow collaborating with a lab group or team in a shared environment and seeing everything on their screen, as well as &lt;a href="https://code.visualstudio.com/learn/collaboration/live-share"&gt;Live Share in VSCode&lt;/a&gt;.&lt;/p&gt;
&lt;p&gt;Participants also expressed frustration that despite notebooks being intended to make programming more literate, this often does not happen in practice.
Beginners like the interactivity in notebooks because they don't know how to use more advanced programming tools, but they don't always take advantage of their readability features.
To address this, attendees stressed the importance of getting users accustomed to best practices that can also be helpful for reproducibility.
A participant mentioned a &lt;code&gt;nbflake8&lt;/code&gt; tool to lint notebooks, though it could not be easily found online, and others wished for a &lt;a href="https://github.com/astral-sh/ruff/issues/1218"&gt;Ruff implementation&lt;/a&gt; (which at the time of this writing is &lt;a href="https://github.com/astral-sh/ruff/issues/5188"&gt;now complete&lt;/a&gt;).&lt;/p&gt;
&lt;h2&gt;Migrating notebooks to modules&lt;/h2&gt;
&lt;p&gt;As one participant put it, "I love notebooks, and also love modules, and love the flow of code from notebooks into modules once it approaches that point."
They went on to describe modules as a key unit of documented, tested code, but which doesn't mean a lot on its own, whereas combined with a notebook, it gives them context and meaning.
For communities that may be afraid of modules, the participant recommended trying to make creating and transitioning to them easier, so users have fully importable, reusable Python code.
For students, notebooks often turn into a fancy scratch pad or script file, and once they get stuff that works, they can move that stuff out into modules, and then the notebooks start to morph into examples and the history of what the work was about that can be interpreted by other researchers.&lt;/p&gt;
&lt;p&gt;Other attendees chimed in with similar stories, with a NIST researcher mentioning this is an area they'd been working on for 10 years, with their approach being putting the stuff they want to be modular in a regular Python module, and then have a Jupyter notebook that shows an example using the code, such as in their &lt;a href="https://github.com/usnistgov/iprPy"&gt;IPRPy project&lt;/a&gt;.
To aid this process, participants suggested tools like the &lt;a href="https://marketplace.visualstudio.com/items?itemName=njpwerner.autodocstring"&gt;Autodocstring extension in VSCode&lt;/a&gt; and the docstring generator built into &lt;a href="https://docs.spyder-ide.org/current/panes/editor.html"&gt;Spyder's editor&lt;/a&gt; as great ways to reduce the friction for students when writing documentation, as they just add the triple quotes and the IDE generates a pre-filled docstring for them.&lt;/p&gt;
&lt;p&gt;An important reproducibility and reusability tool many cited for this was &lt;a href="https://github.com/fastai/nbdev"&gt;nbdev&lt;/a&gt;, which can allow users to develop their code and let it grow, and then eventually export the parts as modules at the end.
According to attendees, its documentation mostly talks about everything as packages, but it can also be used for individual notebooks and modules.
Some participants were initially hesitant to show it to their students since they're early Python programmers, but it was actually quite easy for them, only requiring as little as one line of code at the end.
(Unfortunately as of this writing, it seems ndbdev development &lt;a href="https://hamel.dev/blog/posts/nbdev/"&gt;has stalled&lt;/a&gt; due to its expected commercial opportunities not materializing.)
Others asked for more documentation resources for this, since they were still learning Python themselves and would like to learn more about this and teach it to their students.
In addition to this very blog post and guide, one attendee brought up that they did &lt;a href="https://www.youtube.com/watch?v=l7zS8Ld4_iA"&gt;a tutorial on that topic at SciPy&lt;/a&gt;, adding that the documentation is pretty intimidating but it would be great to have something more focused on smaller-scale usage.&lt;/p&gt;
&lt;p&gt;As additional approaches, attendees mentioned they have their students use &lt;a href="https://jupytext.readthedocs.io/"&gt;Jupytext&lt;/a&gt;, which helps the student to convert notebooks to Python files that can be committed to a Git repository.
This allows the code to be committed as a Python file, while allowing Jupyter to open it as a notebook and continue working on it.
Others brought up &lt;a href="https://nbconvert.readthedocs.io/en/latest/index.html"&gt;nb-convert&lt;/a&gt;, a command line tool that can convert notebooks to many different formats including a Python script, which is integrated into IDEs like Spyder, and that there is also a &lt;a href="https://code.visualstudio.com/docs/datascience/jupyter-notebooks#_export-your-jupyter-notebook"&gt;similar VSCode feature&lt;/a&gt;.&lt;/p&gt;
&lt;h2&gt;Enabling reusable Python packages&lt;/h2&gt;
&lt;p&gt;When it comes to overall workflow, all agreed that going from a script or notebook to a reusable, installable Python package could be a major challenge, especially for students and non-programmers.
Attendees from NASA mentioned that for their projects everything has to be documented, and one of the things they've struggled with was converting a notebook to the type of report NASA is typically looking for.
Others described their workflow being as simple and "old school" as writing a &lt;code&gt;aaa_readme.txt&lt;/code&gt; file where they record a diary of what they were doing on that project so if they have a break working on it, they can go back to those notes and remind themselves.&lt;/p&gt;
&lt;p&gt;To help address this, participants recommended a "really cool" &lt;a href="https://github.com/showyourwork/showyourwork"&gt;tool called "Show Your Work"&lt;/a&gt; that comes out of the astrophysics community, which is primarily aimed at producing a paper at the end but also a Python package, and includes all the steps that show users' work along the way.
It is built around a tool called &lt;a href="https://snakemake.readthedocs.io/"&gt;Snakemake&lt;/a&gt;, which then sets up a template for both the Python package and the paper.
Additionally, attendees described it as having a "really helpful" guide for getting started and ensuring all of a user's projects have the same structure.
It was brought up that Azel Donath, maintainer of Gammapy and speaker at SciPy 2023, published &lt;a href="https://arxiv.org/abs/2308.13584"&gt;their Gammapy paper&lt;/a&gt; by &lt;a href="https://github.com/gammapy/gammapy-v1.0-paper"&gt;using this tool&lt;/a&gt;.&lt;/p&gt;
&lt;p&gt;As a followup, participants asked how this differed from &lt;a href="https://quarto.org/"&gt;Quarto&lt;/a&gt;, to which the response was that Quarto is much more general, whereas Show Your Work was specifically built to allow users to produce a PDF in LaTeX at the end.
Others mentioned &lt;a href="https://github.com/duecredit/duecredit/"&gt;Duecredit&lt;/a&gt;, a related tool for citing open source authors which looks at code and finds the authors (via Git commits) that wrote it.&lt;/p&gt;
&lt;p&gt;Additionally, users expressed particular appreciation for the &lt;a href="https://github.com/scientific-python/cookie"&gt;Cookiecutter template&lt;/a&gt; that &lt;a href="https://iscinumpy.dev/"&gt;Henry Schreiner III&lt;/a&gt; has for packaging.
They mentioned that a lot of their workflows are just messing around with their data, and having something like a package structure from the get go helps make it easier to not miss things.
As a followup, a nuclear engineer mentioned they often have two week projects leveraging Jupyter at their center, with a cookiecutter template that has Sphinx, and a directory structure, and metadata that looks familiar and has everything set up by default.
They described how this particularly helps ensure that different colleagues and team members are on the same page with doing things.
Finally, others suggested the &lt;a href="https://drivendata.github.io/cookiecutter-data-science/"&gt;data-driven Cookiecutter template&lt;/a&gt;, which provides an ordered structure for where things go, what they are named and how they are run.&lt;/p&gt;
&lt;h2&gt;Next steps&lt;/h2&gt;
&lt;p&gt;Now that we’ve gathered a wealth of community feedback, ideas and resources, we’re currently working to further translate these insights into an actionable guide (or series of such) on a community platform, to make it easier for everyone to apply them.
Keep an eye out for that, and until then, happy Spydering!&lt;/p&gt;
</content></entry><entry><title>Improvements to the Spyder IDE installation experience</title><link href="https://www.spyder-ide.org/blog/installer-improvements/" rel="alternate"></link><updated>2022-11-30T00:00:00Z</updated><author><name>dalthviz</name></author><id>urn:uuid:f3c4f8f0-f1df-35ed-8b6a-7f517cf5c263</id><content type="html">&lt;p&gt;&lt;em&gt;&lt;a href="https://github.com/jsbautista"&gt;Juan Sebastian Bautista&lt;/a&gt;, &lt;a href="https://github.com/CAM-Gerlach"&gt;C.A.M. Gerlach&lt;/a&gt; and &lt;a href="https://github.com/ccordoba12"&gt;Carlos Cordoba&lt;/a&gt; also contributed to this post.&lt;/em&gt;&lt;/p&gt;
&lt;p&gt;&lt;a href="https://github.com/spyder-ide/spyder/releases/tag/v5.4.0"&gt;Spyder 5.4.0&lt;/a&gt; was released recently, featuring some major enhancements to its Windows and macOS standalone installers.
You'll now get more detailed feedback when new versions are available, and you can download and start the update to them from right within Spyder, instead of having to install them manually.
Expand Down
54 changes: 27 additions & 27 deletions blog/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,33 @@ <h2><a href="/blog/czi-grant/">Spyder gets CZI grant to add remote development f
</div>
</div>

<div class="blog-post">
<div class="blog-header blog-index-header">
<h2><a href="/blog/reusable-research-bof-scipy-2023-part-2/">Reusable research Birds of a Feather session at Scipy 2023: Solutions and tools</a></h2>

<div class="row align-items-center mb-2 g-2">
<div class="col-auto">
<div class="meta-blog-author">
<img alt="C.A.M. Gerlach photo" class="author-img" src="/authors/camgerlach/C-Symbol-Logo-Full-V2.png">
</div>
</div>
<div class="col">
<div class="meta-blog-index">
<div>C.A.M. Gerlach</div>
<div class="small">2023-03-14</div>
</div>
</div>
</div>
</div>
<div class="blog-content">
<p>The Spyder team and collaborators hosted a Birds of a Feather session at SciPy 2023, focused on moving beyond just scripts and notebooks toward truly reproducible, reusable research. Here, we share the tips, tools, platforms and strategies that participants offered to help achieve these goals.</p>

</div>
<div class="blog-footer text-md-end">
<a href="/blog/reusable-research-bof-scipy-2023-part-2/">Read more...</a>
</div>
</div>

<div class="blog-post">
<div class="blog-header blog-index-header">
<h2><a href="/blog/installer-improvements/">Improvements to the Spyder IDE installation experience</a></h2>
Expand Down Expand Up @@ -358,33 +385,6 @@ <h2><a href="/blog/release-spyder-4/">Thanking the people behind Spyder 4</a></h
</div>
</div>

<div class="blog-post">
<div class="blog-header blog-index-header">
<h2><a href="/blog/spyder-terminal-030/">Creating the ultimate terminal experience in Spyder 4 with Spyder-Terminal</a></h2>

<div class="row align-items-center mb-2 g-2">
<div class="col-auto">
<div class="meta-blog-author">
<img alt="Stephannie Jimenez Gacha photo" class="author-img" src="/authors/steff456/steff456.jpeg">
</div>
</div>
<div class="col">
<div class="meta-blog-index">
<div>Stephannie Jimenez Gacha</div>
<div class="small">2020-04-22</div>
</div>
</div>
</div>
</div>
<div class="blog-content">
<p>The Spyder-Terminal project is revitalized! The new 0.3.0 version adds numerous features that improve the user experience, and enhances compatibility with the latest Spyder 4 release, in part thanks to the improvements made in the xterm.js project.</p>

</div>
<div class="blog-footer text-md-end">
<a href="/blog/spyder-terminal-030/">Read more...</a>
</div>
</div>


<div class="row blog-pagination">
<div class="small-6 columns previous">
Expand Down
54 changes: 27 additions & 27 deletions blog/page/2/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,33 @@ <h1>Welcome to Spyder&#39;s Blog</h1>
</div>
<div id="blog-center" class="center">

<div class="blog-post">
<div class="blog-header blog-index-header">
<h2><a href="/blog/spyder-terminal-030/">Creating the ultimate terminal experience in Spyder 4 with Spyder-Terminal</a></h2>

<div class="row align-items-center mb-2 g-2">
<div class="col-auto">
<div class="meta-blog-author">
<img alt="Stephannie Jimenez Gacha photo" class="author-img" src="/authors/steff456/steff456.jpeg">
</div>
</div>
<div class="col">
<div class="meta-blog-index">
<div>Stephannie Jimenez Gacha</div>
<div class="small">2020-04-22</div>
</div>
</div>
</div>
</div>
<div class="blog-content">
<p>The Spyder-Terminal project is revitalized! The new 0.3.0 version adds numerous features that improve the user experience, and enhances compatibility with the latest Spyder 4 release, in part thanks to the improvements made in the xterm.js project.</p>

</div>
<div class="blog-footer text-md-end">
<a href="/blog/spyder-terminal-030/">Read more...</a>
</div>
</div>

<div class="blog-post">
<div class="blog-header blog-index-header">
<h2><a href="/blog/spyder-variable-explorer/">Variable Explorer improvements in Spyder 4</a></h2>
Expand Down Expand Up @@ -355,33 +382,6 @@ <h2><a href="/blog/spyder-status-2018-present/">State of the Spyder, Part 2: Loo
</div>
</div>

<div class="blog-post">
<div class="blog-header blog-index-header">
<h2><a href="/blog/spyder-status-2018-past/">State of the Spyder, Part 1: Looking back</a></h2>

<div class="row align-items-center mb-2 g-2">
<div class="col-auto">
<div class="meta-blog-author">
<img alt="C.A.M. Gerlach photo" class="author-img" src="/authors/camgerlach/C-Symbol-Logo-Full-V2.png">
</div>
</div>
<div class="col">
<div class="meta-blog-index">
<div>C.A.M. Gerlach</div>
<div class="small">2018-05-06</div>
</div>
</div>
</div>
</div>
<div class="blog-content">
<p>In the first of a three part series, we look back at the major events, project changes, milestones, and progress over the past six months since our previous funding ended. We'll also go over funding and development stats and status up to the present.</p>

</div>
<div class="blog-footer text-md-end">
<a href="/blog/spyder-status-2018-past/">Read more...</a>
</div>
</div>


<div class="row blog-pagination">
<div class="small-6 columns previous">
Expand Down
27 changes: 27 additions & 0 deletions blog/page/3/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,33 @@ <h1>Welcome to Spyder&#39;s Blog</h1>
</div>
<div id="blog-center" class="center">

<div class="blog-post">
<div class="blog-header blog-index-header">
<h2><a href="/blog/spyder-status-2018-past/">State of the Spyder, Part 1: Looking back</a></h2>

<div class="row align-items-center mb-2 g-2">
<div class="col-auto">
<div class="meta-blog-author">
<img alt="C.A.M. Gerlach photo" class="author-img" src="/authors/camgerlach/C-Symbol-Logo-Full-V2.png">
</div>
</div>
<div class="col">
<div class="meta-blog-index">
<div>C.A.M. Gerlach</div>
<div class="small">2018-05-06</div>
</div>
</div>
</div>
</div>
<div class="blog-content">
<p>In the first of a three part series, we look back at the major events, project changes, milestones, and progress over the past six months since our previous funding ended. We'll also go over funding and development stats and status up to the present.</p>

</div>
<div class="blog-footer text-md-end">
<a href="/blog/spyder-status-2018-past/">Read more...</a>
</div>
</div>

<div class="blog-post">
<div class="blog-header blog-index-header">
<h2><a href="/blog/introducing-unittest-plugin/">Introducing the unittest plugin</a></h2>
Expand Down
Loading

0 comments on commit cd34823

Please sign in to comment.