diff --git a/docs/_static/course_builder/1-course-builder.png b/docs/_static/course_builder/1-course-builder.png new file mode 100644 index 0000000..8c8173a Binary files /dev/null and b/docs/_static/course_builder/1-course-builder.png differ diff --git a/docs/_static/course_builder/10-course-builder.png b/docs/_static/course_builder/10-course-builder.png new file mode 100644 index 0000000..d2dc8a2 Binary files /dev/null and b/docs/_static/course_builder/10-course-builder.png differ diff --git a/docs/_static/course_builder/11-course-builder.png b/docs/_static/course_builder/11-course-builder.png new file mode 100644 index 0000000..c7d44c5 Binary files /dev/null and b/docs/_static/course_builder/11-course-builder.png differ diff --git a/docs/_static/course_builder/12-course-builder.png b/docs/_static/course_builder/12-course-builder.png new file mode 100644 index 0000000..cac5c2a Binary files /dev/null and b/docs/_static/course_builder/12-course-builder.png differ diff --git a/docs/_static/course_builder/13-course-builder.png b/docs/_static/course_builder/13-course-builder.png new file mode 100644 index 0000000..83e2303 Binary files /dev/null and b/docs/_static/course_builder/13-course-builder.png differ diff --git a/docs/_static/course_builder/15-course-builder.png b/docs/_static/course_builder/15-course-builder.png new file mode 100644 index 0000000..35682b8 Binary files /dev/null and b/docs/_static/course_builder/15-course-builder.png differ diff --git a/docs/_static/course_builder/16-course-builder.png b/docs/_static/course_builder/16-course-builder.png new file mode 100644 index 0000000..9b67c1d Binary files /dev/null and b/docs/_static/course_builder/16-course-builder.png differ diff --git a/docs/_static/course_builder/17-course-builder.png b/docs/_static/course_builder/17-course-builder.png new file mode 100644 index 0000000..6fc4ee4 Binary files /dev/null and b/docs/_static/course_builder/17-course-builder.png differ diff --git a/docs/_static/course_builder/18-course-builder.png b/docs/_static/course_builder/18-course-builder.png new file mode 100644 index 0000000..bb14e2c Binary files /dev/null and b/docs/_static/course_builder/18-course-builder.png differ diff --git a/docs/_static/course_builder/19-course-builder.png b/docs/_static/course_builder/19-course-builder.png new file mode 100644 index 0000000..3c01ea1 Binary files /dev/null and b/docs/_static/course_builder/19-course-builder.png differ diff --git a/docs/_static/course_builder/2-course-builder.png b/docs/_static/course_builder/2-course-builder.png new file mode 100644 index 0000000..a4ec7fe Binary files /dev/null and b/docs/_static/course_builder/2-course-builder.png differ diff --git a/docs/_static/course_builder/20-course-builder.png b/docs/_static/course_builder/20-course-builder.png new file mode 100644 index 0000000..6a90ca7 Binary files /dev/null and b/docs/_static/course_builder/20-course-builder.png differ diff --git a/docs/_static/course_builder/21-course-builder.png b/docs/_static/course_builder/21-course-builder.png new file mode 100644 index 0000000..4dd6a09 Binary files /dev/null and b/docs/_static/course_builder/21-course-builder.png differ diff --git a/docs/_static/course_builder/22-course-builder.png b/docs/_static/course_builder/22-course-builder.png new file mode 100644 index 0000000..e89b5af Binary files /dev/null and b/docs/_static/course_builder/22-course-builder.png differ diff --git a/docs/_static/course_builder/23-course-builder.png b/docs/_static/course_builder/23-course-builder.png new file mode 100644 index 0000000..7089ce4 Binary files /dev/null and b/docs/_static/course_builder/23-course-builder.png differ diff --git a/docs/_static/course_builder/24-course-builder.png b/docs/_static/course_builder/24-course-builder.png new file mode 100644 index 0000000..d5f6d2f Binary files /dev/null and b/docs/_static/course_builder/24-course-builder.png differ diff --git a/docs/_static/course_builder/25-course-builder.png b/docs/_static/course_builder/25-course-builder.png new file mode 100644 index 0000000..2d2d338 Binary files /dev/null and b/docs/_static/course_builder/25-course-builder.png differ diff --git a/docs/_static/course_builder/26-course-builder.png b/docs/_static/course_builder/26-course-builder.png new file mode 100644 index 0000000..7ba25ed Binary files /dev/null and b/docs/_static/course_builder/26-course-builder.png differ diff --git a/docs/_static/course_builder/27-course-builder.png b/docs/_static/course_builder/27-course-builder.png new file mode 100644 index 0000000..784a8ea Binary files /dev/null and b/docs/_static/course_builder/27-course-builder.png differ diff --git a/docs/_static/course_builder/28-course-builder.png b/docs/_static/course_builder/28-course-builder.png new file mode 100644 index 0000000..6f3763f Binary files /dev/null and b/docs/_static/course_builder/28-course-builder.png differ diff --git a/docs/_static/course_builder/29-course-builder.png b/docs/_static/course_builder/29-course-builder.png new file mode 100644 index 0000000..d33668a Binary files /dev/null and b/docs/_static/course_builder/29-course-builder.png differ diff --git a/docs/_static/course_builder/3-course-builder.png b/docs/_static/course_builder/3-course-builder.png new file mode 100644 index 0000000..f4f3b99 Binary files /dev/null and b/docs/_static/course_builder/3-course-builder.png differ diff --git a/docs/_static/course_builder/4-course-builder.png b/docs/_static/course_builder/4-course-builder.png new file mode 100644 index 0000000..3f4c12b Binary files /dev/null and b/docs/_static/course_builder/4-course-builder.png differ diff --git a/docs/_static/course_builder/6-course-builder.png b/docs/_static/course_builder/6-course-builder.png new file mode 100644 index 0000000..0239d8d Binary files /dev/null and b/docs/_static/course_builder/6-course-builder.png differ diff --git a/docs/_static/course_builder/9-course-builder.png b/docs/_static/course_builder/9-course-builder.png new file mode 100644 index 0000000..f673ead Binary files /dev/null and b/docs/_static/course_builder/9-course-builder.png differ diff --git a/docs/index.rst b/docs/index.rst index 31905fa..b9bb5a8 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -114,3 +114,4 @@ Documentation lab/troubleshoot lab/pricing lab/ibm_migration + lab/course_builder diff --git a/docs/lab/course_builder.rst b/docs/lab/course_builder.rst new file mode 100644 index 0000000..b64f44f --- /dev/null +++ b/docs/lab/course_builder.rst @@ -0,0 +1,291 @@ +.. _course_builder: + +Course Builder +===================== + +Guide for educators to create and publish quantum computing (or any) courses on qBraid. + +.. note:: + This guide applies for users who already have the relevant permissions for adding courses to their qBraid plan. If you are interested in these permissions, please reach out to us at `contact.qbraid.com `_, and we'll get you set up. + +Overview +-------- + +qBraid boasts a comprehensive Course Builder system that allows for the creation of quantum computing courses. This system is designed to be user-friendly and intuitive, allowing educators to create and publish courses with ease. This guide will walk you through the process of creating a course on qBraid. + +Step 1: Create an Organization +------------------------------- + +The first step in creating a course on qBraid is to create an organization. An organization is a group that can contain multiple courses and people. To create an organization, follow these steps: + +1a. Visit the Organizations page on qBraid Accounts. +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +You can find the qBraid Accounts Dashboard at `accounts.qbraid.com `_ + +Once you're there, you can click on the "Organization" tab to view the organizations you are a part of or to create a new organization. + +.. image:: ../_static/course_builder/1-course-builder.png + :width: 80% + :alt: Organization Page + :target: javascript:void(0); + +If you already have an organization, you can skip till Step 2. Otherwise, continue to Step 1b. + +1b. Create a New Organization +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +To create a new organization, either click the "Add an organization" button or the "Create an organization" button. + +.. image:: ../_static/course_builder/2-course-builder.png + :width: 80% + :alt: Organization Create + :target: javascript:void(0); + +In the pop-up dialog that appears, change the name of the organization and add a description. + +.. image:: ../_static/course_builder/3-course-builder.png + :width: 80% + :alt: Organization Create Dialog + :target: javascript:void(0); + +After you've filled in the details, add users to the organization. In order for students to join your class, they should first be added to the organization. Then, click "Add Organization". + +.. image:: ../_static/course_builder/4-course-builder.png + :width: 80% + :alt: Organization Create Dialog + :target: javascript:void(0); + +Refresh and your organization should appear! + +Step 2: Create an Organization on GitHub +---------------------------------------- + +qBraid uses GitHub to validate and link course content. To create an organization on GitHub, follow `these steps `_. + +Step 3: Create a Course +------------------------ + +Once you have created an organization on qBraid and GitHub, you can create a course. To create a course, follow these steps: + +3a. Open qBraid Lab. +^^^^^^^^^^^^^^^^^^^^^ + +Visit `lab.qbraid.com `_ and log in with your qBraid account. Start the lab environment of your choice from the landing page. + +3b. Open the Course Builder. +^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +From the Launcher tab, click on the "Course Builder" icon. + +.. image:: ../_static/course_builder/6-course-builder.png + :width: 80% + :alt: Course Builder Icon + :target: javascript:void(0); + +You should be prompted for your GitHub organization link. Enter the link in the given field. Retrieve a personal access token from GitHub and enter it in the next field. Click "Continue". + +.. note:: + You can use the link on the page to find your Personal Access Token if you're having any difficulty. + +3c. Create a New Course. +^^^^^^^^^^^^^^^^^^^^^^^^ + +Now you can start by creating a new course. On the page that appears, click on the "Build New Course" button. + +Here, you can add your course title and description. You can select your desired visibility from the first drop-down. From the second drop-down, you can select the domain you want to host your course on. In the example, we are creating a private course on the qBraid domain. + + +.. image:: ../_static/course_builder/9-course-builder.png + :width: 80% + :alt: Course Title and Description + :target: javascript:void(0); + + +The domain will determine where your course appears. If your organization has an existing hosting deal with qBraid, this is where you can select it. + +Step 4: Add Course Content +-------------------------- + +Now that the skeleton of our course has been created, we can start adding the relevant content. To add content to your course, follow these steps: + +4a. Add a new Chapter. +^^^^^^^^^^^^^^^^^^^^^^^ + +qBraid courses are organized into chapters. Each chapter is a Jupyter notebook with a blend of markdown information and code cells for demonstration. You can add whichever notebook you want in order to create your first chapter. + +Start by clicking the "Add Chapter" button. Select the notebook you desire. In this example, we use the "Grover's Algorithm" notebook from IBM Quantum. + +.. image:: ../_static/course_builder/10-course-builder.png + :width: 80% + :alt: Add New Chapter + :target: javascript:void(0); + +.. image:: ../_static/course_builder/11-course-builder.png + :width: 80% + :alt: Add New Chapter + :target: javascript:void(0); + +After that, you can attach your chapter. Add as many chapters as you'd like! You can add sections to your chapter by navigating to the "Add Sections panel". + +.. image:: ../_static/course_builder/12-course-builder.png + :width: 80% + :alt: Add Sections + :target: javascript:void(0); + +We'll come back here later. + +4b. Publish your course. +^^^^^^^^^^^^^^^^^^^^^^^^ + +When your desired chapters have been added, it's time to publish! Click on the hamburger in the top-right corner of the course builder. + +.. image:: ../_static/course_builder/13-course-builder.png + :width: 80% + :alt: Hamburger + :target: javascript:void(0); + +Then, click "Publish". + +On the page that appears, select the organization that you created, then click "Next". + +.. image:: ../_static/course_builder/15-course-builder.png + :width: 80% + :alt: Select Organization + :target: javascript:void(0); + +You can then assign roles to the users in your organization. These include "Student", "Instructor", and "TA". After you've assigned your desired roles to the users, click "Next". + +.. image:: ../_static/course_builder/16-course-builder.png + :width: 80% + :alt: Assign Roles + :target: javascript:void(0); + +Now, click on the "Class Info" button and assign your desired time duration. + +.. image:: ../_static/course_builder/17-course-builder.png + :width: 80% + :alt: Class Info + :target: javascript:void(0); + +Finally, click "Publish" to publish your course. You can now view your course on the qBraid platform! + +4c. Check out your new course! +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +From the landing page, click "Qbook qBraid" to see your course in action. + +.. image:: ../_static/course_builder/18-course-builder.png + :width: 80% + :alt: Qbook qBraid + :target: javascript:void(0); + +You should see your course on the qBraid platform, rendered beautifully, with text and mini-kernels for you to run your code. + +.. image:: ../_static/course_builder/19-course-builder.png + :width: 80% + :alt: Course on qBraid + :target: javascript:void(0); + +Congratulations! You've successfully created and published a course on qBraid. You can now share your course with students and colleagues. As long as they are added to your organization and on your course, they should be able to access the materials directly through the URL! + +Step 5: Bonus Features +---------------------- + +qBraid offers a variety of features to enhance your course. You can add MCQ (Multiple Choice Questions) and FRQ (Free Response Questions) to your course to test your students' knowledge. + +Let's go through these features! + +5a. Add MCQ and FRQ. +^^^^^^^^^^^^^^^^^^^^ + +Navigate back to the Course Builder. Click on the "VIEW ALL QUESTIONS" button in the top-left corner. + +.. image:: ../_static/course_builder/20-course-builder.png + :width: 80% + :alt: View All Questions + :target: javascript:void(0); + +Here, you can add a new MCQ and a new FRQ. We will demonstrate how to create an MCQ. Click on the "Add New Question" button in the top-left corner. + +.. image:: ../_static/course_builder/21-course-builder.png + :width: 80% + :alt: Add New Question + :target: javascript:void(0); + +Start by filling out the "Custom Id" and "Question" fields. Your Custom ID will help you link questions to the notebook directly on the course that you have created. + +.. image:: ../_static/course_builder/22-course-builder.png + :width: 80% + :alt: MCQ Question + :target: javascript:void(0); + +You can add as many choices as you like. Separate each choice with an "Enter" or "Return". qBraid supports LaTeX formatting, so you can add math equations to your questions. + +.. image:: ../_static/course_builder/23-course-builder.png + :width: 80% + :alt: MCQ Choices + :target: javascript:void(0); + +When your choices are added, click the checkbox next to the correct one to validate it. + +.. image:: ../_static/course_builder/24-course-builder.png + :width: 80% + :alt: MCQ Correct Answer + :target: javascript:void(0); + +Finally, click "Save" to save your question. + +5b. Embed your questions into your course. +------------------------------------------- + +Open a new file, and create a Jupyter notebook. In a cell, add the following code: `MultipleChoiceQuestion("your-custom-id")`. Replace "your-custom-id" with the custom ID you created for your MCQ. + +.. image:: ../_static/course_builder/25-course-builder.png + :width: 80% + :alt: Embed MCQ + :target: javascript:void(0); + +Go back to the Course Builder. Click the "View" button on your course. Click the downward arrow next to your chapter. Click on the "Attach" icon. + +.. image:: ../_static/course_builder/26-course-builder.png + :width: 80% + :alt: Course Builder View + :target: javascript:void(0); + +In the pop-up that appears, you can select the file you just created. Double-click to upload. + +.. image:: ../_static/course_builder/27-course-builder.png + :width: 80% + :alt: Attach File + :target: javascript:void(0); + +After your file is uploaded, click outside the box to close it. You should see your file attached to the chapter. Click the hamurger in the top-right corner and hit "Update" to ensure that the changes are saved. + +.. image:: ../_static/course_builder/28-course-builder.png + :width: 80% + :alt: Update + :target: javascript:void(0); + +Now, when you view your course on qBook, you should be able to see the question! Navigate to the chapter, click the dropdown to access the question, and answer at will. + +.. image:: ../_static/course_builder/29-course-builder.png + :width: 80% + :alt: MCQ on qBook + :target: javascript:void(0); + + +Conclusion +---------- + +This has been a rapid-fire overview on how to create your first course. These docs are a work in progress, and more features will be added with time! If you have any questions or feedback, please reach out to us at `contact.qbraid.com `_. We're excited to see the courses you create! + + + + + + + + + +