Overview
Our 2024 fall quarter images bring some major changes to the way notebooks are accessed on our cluster. Previously, users were directed towards an outdated interface known as Notebook 6. Our default is now known as JupyterLab, which brings numerous improvements to the Datahub experience.
Video Guide
(Coming Soon)
Main Differences Between Notebook 6 and JupyterLab
A summary of the new features:
- Modular UI - You can now have multiple tabs in the same window and keep views such as the file explorer easily accessible.
- Visual Debugger - Quickly and efficiently debug issues with your Python code via a new UI.
- Integrated Git Sidebar Tool - A new (graphical) way to create and manage local git repositories.
- Dark Mode - Toggle between a light and dark theme for JupyterLab. Terminals have their own light/dark mode in the Settings tab.
- Latex Editor/Exporter - Edit and export LaTeX (+ bib) files as PDFs.
- Markdown Editor/Exporter - Edit and export Markdown documents as PDFs.
General Guide
New UI
- This is JupyterLab, the default interface that all of our images now use. There is a file browser on the left with several additional extensions installed by default. On the right is the "launcher" which includes a list of shortcuts to several common utilities.
data:image/s3,"s3://crabby-images/e7a24/e7a24cf8d643d8f854c3fb3c46ac7bf3e75d5e25" alt="The landing page for JupyterLab. It has a file inspector on the left side and a pane on the center/right side where a user can choose their Notebook type."
- To navigate the file browser, double click on which directory/file you would like to access. To go back to your home directory, click on the folder icon (highlighted in red below).
data:image/s3,"s3://crabby-images/ca47d/ca47d10421238d62d5b24faf294942728a102bbf" alt="The file inspector for JupyterLab. It has various folders and .ipynb files."
- JupyterLab also now supports dark mode.
data:image/s3,"s3://crabby-images/10a13/10a138d8b3c9e05adf4ec9720a6a5e3bd3eb661c" alt="The JupyterLab UI, but in dark mode."
- You can switch between light and dark mode by going to Settings>Theme.
data:image/s3,"s3://crabby-images/87c65/87c6566fbec0a75903b255fcfe3d6bec90956772" alt="JupyterLab UI, but with the settings menu engaged so that the user can go from Settings to Theme to Dark Mode in order to enable dark mode."
- To turn off your pod, you can go to File>Hub Control Panel followed by Stop My Server. You can also press My Server to return to JupyterLab.
data:image/s3,"s3://crabby-images/7c764/7c76400fef20435318181e8981b218dc66a240af" alt="The JupyterLab UI with the Files tab open. There's a red square hovering over "Hub Control Panel"."
data:image/s3,"s3://crabby-images/85efe/85efeb0fa69c6f3359a8f53eb30b86cfd7b125d2" alt="A mostly white page with the "Shutdown Server" menu option displayed so that a user can turn off their notebook."
Writing + Debugging a Notebook
- To open a notebook, double click on a .ipynb file and you'll be greeted with this:
data:image/s3,"s3://crabby-images/6d904/6d90402130791431136e8b119e40c1743b59ae24" alt="JupyterLab with a .ipynb file opened in the right pane. There are writeable/executable codeblocks."
- You'll notice that most of the buttons are from Notebook 6. The play button runs the code in a target cell, the stop button stops currently running code, and the validate button allows users to ensure that their notebooks pass any given tests. The main advantage of JupyterLab however is that it allows you to have multiple notebooks open in the same tab via the + button in the status bar.
- There are many ways to add a new cell. The buttons outlined in red below add a new cell. The button highlighted in blue clones the current cell and adds it below. The buttons highlighted in orange add a new cell above the currently selected one and below the currently selected one respectively.
data:image/s3,"s3://crabby-images/efe19/efe19d8dba48f0fbc897cb0db162eba964b91339" alt="UI in the notebook for adding new cells. In the top left, a plus symbol is highlighted which adds a new cell. There is a textbox at the bottom of the page that also adds a new cell. Each cell also has a menu above it to either duplicate the cell or add a new cell above/below the selected cell."
- A cell can be three possible types: code, markdown, and raw. To switch between them, select the cell you would like to change and click on the below dropdown menu in the status bar.
data:image/s3,"s3://crabby-images/2d2a8/2d2a8c8d2f12978fa41aaa1545a4dba31b0b8151" alt="A menu setting for changing the cell types from "Cell, Markdown, or Raw"."
- One of the more notable new features of JupyterLab's Notebook editor is the visual debugger. You can use it to easily diagnose issues with your code instead of relying on more primitive methods such as printing variable values. To enable the debugger in your notebook, click on the bug icon in the top right corner.
- Once the button turns orange, the debug UI will appear on the right side of your screen and the line numbers in your cells will be enumerated. Clicking on a line sets a breakpoint as a red dot. Running the cell will cause the Python interpreter to halt at the first breakpoint and display extensive debugging information about the current cell. To proceed to the next breakpoint after running the cell, click on the play button in the Callstack menu. Once all breakpoints have been passed, execution will proceed as normal.
data:image/s3,"s3://crabby-images/78f1e/78f1e90ce91910466995fbf97cc15552e648ae2b" alt="A notebook with the visual debugger enabled. The continue button (F9) is highlighted as well as the UI for setting breakpoints."
NBClassic/Notebook 7
- If you don't prefer the JupyterLab UI, you can also try Notebook 7 or NBClassic which more closely resemble Datahub's previous UI. Notebook 7 has most of the features that JupyterLab does such as the visual debugger, whereas NBClassic does not. Please keep in mind that we consider both of these alternatives to be more experimental in nature. If you have any major issues, please fallback to JupyterLab and send them to datahub@ucsd.edu.
- The quickest way to access Notebook7/NBClassic is by using the Open In dropdown menu on a selected notebook.
data:image/s3,"s3://crabby-images/5e715/5e715cb8ca0ae97808ea803702a4b0f39540e6a9" alt="A notebook with the dropdown for opening it in Notebook7/NBClassic is highlighted."
- Navigating the Notebook7 UI should be more straightforward especially if you've used Notebook 6. Double clicking on a notebook will open the editor in a new browser tab.
data:image/s3,"s3://crabby-images/f0f27/f0f27da0b83df22a4828518aaee1f578a4e74709" alt="A notebook with the NB7 UI. There is no longer the typical JupyterLab file explorer."
data:image/s3,"s3://crabby-images/309f7/309f7e26dffad34917a690b6e5e146a74a4347ae" alt="The file explorer for Notebook 7, which takes up the entire page as opposed to the modal JupyterLab UI."
- As for the second option, NBClassic is almost identical to Notebook 6 but any extensions such as NBGrader are no longer supported. We cannot guarantee long-term support for this view.
data:image/s3,"s3://crabby-images/2cc21/2cc21324e63547ea183b39a8dec57fcf6b54477c" alt="The NBClassic UI, which is virtually identical to the older Notebook 6 UI."
LaTeX/Markdown Editor
We're happy to announce that the Jupyter team has added a native LaTeX parser (the backend being xelatex + bibtex) extension into the latest iteration of JupyterLab. This means that students can drop their assignments into JupyterLab and get to work. While the instructions below are for LaTeX, there is also a Markdown editor in JupyterLab that works in a very similar way.
- Begin by either importing or creating a .tex file. The editor automatically highlights special keywords with appropriate syntax coloring, making the document more readable and easier to navigate.
data:image/s3,"s3://crabby-images/46881/4688174cc857ac163e785ecff4b8fc69621048d6" alt="JupyterLab UI but with a .tex file opened in the right pane. It is a typical LaTeX document."
- To render your properly-formatted, right-click anywhere while in the editor and select Show Latex Preview.
data:image/s3,"s3://crabby-images/3f44e/3f44e4ccc3572d69db51dbd3ee2ad84a53cadf5f" alt="A LaTeX document open in JupyterLab, with the "Show Preview" option visible that will render the .tex file."
- An error will be displayed from the backend LaTeX parser on failure.
data:image/s3,"s3://crabby-images/473e7/473e7fe35d4acb662257f15a686badc281bba83e" alt="A .tex file with syntax errors. Below the file is a console displaying the inability to render the file due to the syntax errors."
- If the parser succeeds, a rendered PDF will then be opened on the right side of your screen.
data:image/s3,"s3://crabby-images/14541/14541fca0e91f388a719ae5d5ee887795884756d" alt="JupyterLab, but with a .tex file and a rendered LaTeX PDF beside it."
- To download your LaTeX document as a PDF, simply click on Show Latex Preview and download the generated PDF from the file browser (right-click on it).
data:image/s3,"s3://crabby-images/0bd71/0bd710e47e35444bc3edd32d43be4a6899629ee4" alt="The JupyterLab file explorer, showing the ability to download a file to your browser by rightclicking the file and clicking "Download" on the popup."
NBGrader
While the NBGrader package itself has not changed too substantially from Notebook 6, there have been some notable changes to conform with JupyterLab's new UI.
Formgrader is accessible via Nbgrader>Formgrader.
data:image/s3,"s3://crabby-images/9862f/9862fb39d5ff3ebb69a5b78e1c092094da4f9c18" alt="The JupyterLab UI, but with the NBGrader dropdown tab highlighted."
Create a formgrader assignment as normal and add a notebook file to its corresponding directory. There are two buttons to create a new assignment while you're editing a notebook. One is accessible via the Nbgrader dropdown and the other is always on the right side of the notebook.
data:image/s3,"s3://crabby-images/6175d/6175dd8746d2199cb70c334f5386a1fa43d040b2" alt="The JupyterLab UI, but with the NBGrader dropdown tab highlighted. The "Create assignment" option is highlighted in red. There is also a "Create assignment" tab on the right side of the notebook."
The Create Assignment UI should appear with each cell having several available grading options. If you need a refresh on what each option does, you can take a look at our Nbgrader documentation for more information.
data:image/s3,"s3://crabby-images/3b42c/3b42cf7a8365a0fc391c8bc8be32692f7c50a381" alt="A JupyterLab notebook with the NBGrader assignment UI opened. It shows each of the individual cells in the notebook and their type (read-only, autograded task, etc.)"
Students can fetch/submit their assignments by going to Nbgrader>Assignment List. The UI is nearly identical to Notebook 6's.
data:image/s3,"s3://crabby-images/68dfb/68dfb83b8aadebc77acff25d22b937abbccddabc" alt="The page that shows up when NBGrader -> Assignments is clicked in the dropdown. It shows assignments as students would see them, with the ability to either download/submit the assignment or look at the instructor's feedback."