Commit 356b10c2 by Mark Hoeber

Update component templates for accessibility and content

parent 4a4c3c56
...@@ -55,9 +55,9 @@ def see_a_multi_step_component(step, category): ...@@ -55,9 +55,9 @@ def see_a_multi_step_component(step, category):
if category == 'HTML': if category == 'HTML':
html_matcher = { html_matcher = {
'Text': '\n \n', 'Text': '\n \n',
'Announcement': '<p> Words of encouragement! This is a short note that most students will read. </p>', 'Announcement': '<h3>Announcement Date</h3>',
'Zooming Image Tool': '<h2>Zooming Image Tool</h2>', 'Zooming Image Tool': '<h2>Zooming Image Tool</h2>',
'E-text Written in LaTeX': '<h2>Example: E-text page</h2>', 'E-text Written in LaTeX': '<h3>Example: E-text page</h3>',
'Raw HTML': '<p>This template is similar to the Text template. The only difference is', 'Raw HTML': '<p>This template is similar to the Text template. The only difference is',
} }
actual_html = world.css_html(selector, index=idx) actual_html = world.css_html(selector, index=idx)
......
...@@ -2,22 +2,17 @@ ...@@ -2,22 +2,17 @@
metadata: metadata:
display_name: Announcement display_name: Announcement
data: | data: |
<ol> <p>To use this template, replace the example text with your own text.</p>
<li> <p>When you add the component, be sure to select <strong>Settings</strong>
<h2> September 21 </h2> to specify a <strong>Display Name</strong> and other values that apply.</p>
<h3>Announcement Date</h3>
<section class='update-description'> <section class='update-description'>
<section class='primary'> <section class='primary'>
<p> Words of encouragement! This is a short note that most students will read. </p> <p>Short note that introduces the topic</p>
<p class='author'>Anant Agarwal (6.002x Principal Instructor)</p> <p class='author'>Instructor's name</p>
</section> </section>
<h3>Primary versus Secondary Updates:</h3><p>Unfortunately, the internet throws a lot of text at students, and they <h4>Heading for announcement 1</h4>
do not read everything that they are given. However, many students <em>do</em> read all that they are <p>Announcement 1 text</p>
given, and so detailed explainations in this section will benefit the most concientious. <h4>Heading for announcement 2</h4>
Any essential information should be extremely quickly summarized in the primary section for skimmers.</p> <p>Announcement 2 text</p>
<h3>Star Forum Poster</h3><p> </section>
Students appreciate knowing that the course staff is reading what they post, and one of several ways \ No newline at end of file
that you can do this is by acknowledging the star posters in your announcements.
</p>
</section>
</li>
</ol>
...@@ -4,18 +4,18 @@ metadata: ...@@ -4,18 +4,18 @@ metadata:
source_code: | source_code: |
\subsection{Example of E-text in LaTeX} \subsection{Example of E-text in LaTeX}
It is very convenient to write complex equations in LaTeX. You can write complex equations in LaTeX.
\begin{equation} \begin{equation}
x = \frac{-b\pm\sqrt{b^2-4*a*c}}{2a} x = \frac{-b\pm\sqrt{b^2-4*a*c}}{2a}
\end{equation} \end{equation}
Seize the moment.
data: | data: |
<html> <html>
<h2>Example: E-text page</h2> <h3>Example: E-text page</h3>
<p> <p>You can write complex equations in LaTeX.</p>
It is very convenient to write complex equations in LaTeX. <p>When you add the component, be sure to select <strong>Settings</strong>
</p> to specify a <strong>Display Name</strong> and other values that apply.</p>
<p>When editing this component, select <strong>Launch Latex Source Compiler</strong> to edit equations.</p>
<p>Then, in the equation editor, select <strong>Save and Compile to edX XML</strong> to see the equation in the component.</p>
</html> </html>
...@@ -2,23 +2,49 @@ ...@@ -2,23 +2,49 @@
metadata: metadata:
display_name: Checkboxes display_name: Checkboxes
markdown: | markdown: |
A checkboxes problem presents checkbox buttons for student input. Students can select more than one option presented. Checkbox problems allow learners to select multiple options. Learners can see all the options along with the problem text.
>>Select the answer that matches<<
When you add the problem, be sure to select Settings to specify a Display Name and other values that apply.
[x] correct You can use the following example problem as a model.
[ ] incorrect _____________________________________________________________________________
[x] correct
>>The following languages are in the Indo-European family:<<
[x] Urdu
[ ] Finnish
[x] Marathi
[x] French
[ ] Hungarian
Note: Make sure you select all of the correct options—there may be more than one!
[explanation]
Urdu, Marathi, and French are all Indo-European languages, while Finnish and Hungarian are in the Uralic family.
[explanation]
data: | data: |
<problem> <problem>
<p>A checkboxes problem presents checkbox buttons for student input. Students can select more than one option presented.</p> <p>Checkbox problems allow learners to select multiple options. Learners can see all the options along with the problem text.</p>
<p>Select the answer that matches</p> <p>When you add the component, be sure to select <strong>Settings</strong>
<choiceresponse> to specify a <strong>Display Name</strong> and other values that apply.</p>
<checkboxgroup direction="vertical" label="Select the answer that matches"> <p>You can use the following example problem as a model.</p>
<choice correct="true">correct</choice> <fieldset>
<choice correct="false">incorrect</choice> <legend>The following languages are in the Indo-European family:</legend>
<choice correct="true">correct</choice> <choiceresponse>
</checkboxgroup> <checkboxgroup direction="vertical">
</choiceresponse> <choice correct="true" name="urdu">Urdu</choice>
</problem> <choice correct="false" name="finnish">Finnish</choice>
<choice correct="true" name="marathi">Marathi</choice>
<choice correct="true" name="french">French</choice>
<choice correct="false" name="hungarian">Hungarian</choice>
</checkboxgroup>
</choiceresponse>
</fieldset>
<p><strong>Note</strong>: Make sure you select all of the correct options—there may be more than one!</p>
<solution>
<div class="detailed-solution">
<p>Explanation</p>
<p>Urdu, Marathi, and French are all Indo-European languages, while Finnish and Hungarian are in the Uralic family.</p>
</div>
</solution>
</problem>
\ No newline at end of file
...@@ -3,9 +3,22 @@ metadata: ...@@ -3,9 +3,22 @@ metadata:
display_name: Circuit Schematic Builder display_name: Circuit Schematic Builder
markdown: !!null markdown: !!null
data: | data: |
<problem > <problem>
Please make a voltage divider that splits the provided voltage evenly. <p>
Circuit schematic problems allow students to create virtual circuits by
arranging elements such as voltage sources, capacitors, resistors, and
MOSFETs on an interactive grid. The system evaluates a DC, AC, or
transient analysis of the circuit.
</p>
<p>
For more information, see
<a href="http://edx.readthedocs.org/projects/edx-partner-course-staff/en/latest/exercises_tools/circuit_schematic_builder.html" target="_blank">
Circuit Schematic Builder Problem</a> in <i>Building and Running an edX Course</i>.</p>
<p>When you add the problem, be sure to select <strong>Settings</strong>
to specify a <strong>Display Name</strong> and other values that apply.</p>
<p>You can use the following example problems as models.</p>
<fieldset>
<legend>Make a voltage divider that splits the provided voltage evenly.</legend>
<schematicresponse> <schematicresponse>
<center> <center>
<schematic height="500" width="600" parts="g,r" analyses="dc" <schematic height="500" width="600" parts="g,r" analyses="dc"
...@@ -25,8 +38,10 @@ data: | ...@@ -25,8 +38,10 @@ data: |
correct = ['incorrect'] correct = ['incorrect']
</answer> </answer>
</schematicresponse> </schematicresponse>
</fieldset>
<fieldset>
<legend>Make a high-pass filter.</legend>
<schematicresponse> <schematicresponse>
<p>Make a high pass filter</p>
<center> <center>
<schematic height="500" width="600" parts="g,r,s,c" analyses="ac" <schematic height="500" width="600" parts="g,r,s,c" analyses="ac"
submit_analyses="{&quot;ac&quot;:[[&quot;NodeA&quot;,1,9]]}" submit_analyses="{&quot;ac&quot;:[[&quot;NodeA&quot;,1,9]]}"
...@@ -47,13 +62,14 @@ data: | ...@@ -47,13 +62,14 @@ data: |
correct = ['incorrect'] correct = ['incorrect']
</answer> </answer>
</schematicresponse> </schematicresponse>
</fieldset>
<solution> <solution>
<div class="detailed-solution"> <div class="detailed-solution">
<p>Explanation</p> <p>Explanation</p>
<p>A voltage divider that evenly divides the input voltage can be formed with two identically valued resistors, with the sampled voltage taken in between the two.</p> <p>You can form a voltage divider that evenly divides the input voltage with two identically valued resistors, with the sampled voltage taken in between the two.</p>
<p><img src="/static/images/voltage_divider.png"/></p> <p><img src="/static/images/voltage_divider.png"/></p>
<p>A simple high-pass filter without any further constaints can be formed by simply putting a resister in series with a capacitor. The actual values of the components do not really matter in order to meet the constraints of the problem.</p> <p>You can form a simple high-pass filter without any further constraints by simply putting a resistor in series with a capacitor. The actual values of the components do not really matter in this problem.</p>
<p><img src="/static/images/high_pass_filter.png"/></p> <p><img src="/static/images/high_pass_filter.png"/></p>
</div> </div>
</solution> </solution>
......
...@@ -4,11 +4,32 @@ metadata: ...@@ -4,11 +4,32 @@ metadata:
markdown: !!null markdown: !!null
data: | data: |
<problem> <problem>
<p>
In custom Python-evaluated input (also called "write-your-own-grader"
problems), the grader uses a Python script that you create and embed in
the problem to evaluate a learner's response or provide hints. These
problems can be any type. Numerical input and text input problems are
the most common write-your-own-grader problems.
</p>
<p>
You can use script tag format or answer tag format to create these problems.
</p>
<p> <p>
A custom python-evaluated input problem accepts one or more lines of text input from the You can create custom Python-evaluated input problems that provide
student, and evaluates the inputs for correctness based on evaluation using a partial credit or that randomize variables in the Python code. You can
python script embedded within the problem. also add images to the solution by using an HTML "img" tag. Note that
the "img" tag must be between the "div" tags that are inside the
"solution" tags, and that learners do not see these images until they
click the "Show Answer" button.
</p> </p>
<p> For more information, see <a
href="http://edx.readthedocs.org/projects/edx-partner-course-staff/en/latest/exercises_tools/custom_python.html" target="_blank">
Write-Your-Own-Grader Problem</a> in <i>Building and Running an edX Course</i>.
</p>
<p>When you add the problem, be sure to select <strong>Settings</strong>
to specify a <strong>Display Name</strong> and other values that apply.</p>
<p>You can use the following example problem as a model.</p>
<p>______________________________________________________________________________</p>
<script type="loncapa/python"> <script type="loncapa/python">
...@@ -24,25 +45,29 @@ data: | ...@@ -24,25 +45,29 @@ data: |
return test_add(10, ans) return test_add(10, ans)
</script> </script>
<fieldset>
<p>Enter two integers which sum to 10: </p> <legend>Enter two integers that sum to 10.</legend>
<customresponse cfn="test_add_to_ten"> <customresponse cfn="test_add_to_ten">
<textline size="40" correct_answer="3" label="Integer #1"/><br/> <textline size="40" correct_answer="3" label="Integer #1"/><br/>
<textline size="40" correct_answer="7" label="Integer #2"/> <textline size="40" correct_answer="7" label="Integer #2"/>
</customresponse> </customresponse>
</fieldset>
<p>Enter two integers which sum to 20: </p> <fieldset>
<customresponse cfn="test_add" expect="20"> <legend>Enter two integers that sum to 20.</legend>
<textline size="40" correct_answer="11" label="Integer #1"/><br/> <customresponse cfn="test_add" expect="20">
<textline size="40" correct_answer="9" label="Integer #2"/> <textline size="40" correct_answer="11" label="Integer #1"/><br/>
</customresponse> <textline size="40" correct_answer="9" label="Integer #2"/>
</customresponse>
<solution> </fieldset>
<div class="detailed-solution"> <solution>
<p>Explanation</p> <div class="detailed-solution">
<p>Any set of integers on the line \(y = 10 - x\) and \(y = 20 - x\) satisfy these constraints.</p> <p>Explanation</p>
<p>You can also add images within the solution clause like so:</p> <p>Any set of integers on the line \(y = 10 - x\) and \(y = 20 - x\) satisfy these constraints.</p>
<img src="/static/images/placeholder-image.png"/> <p>To add an image to the solution, use an HTML "img" tag. Make sure to include alt text.</p>
</div> <img src="/static/images/placeholder-image.png" width="400"
</solution> alt="Description of image, with a primary goal of explaining its
relevance to the problem or concept being illustrated for someone
who is unable to see the image."/>
</div>
</solution>
</problem> </problem>
...@@ -4,22 +4,36 @@ metadata: ...@@ -4,22 +4,36 @@ metadata:
markdown: !!null markdown: !!null
data: | data: |
<problem> <problem>
Here's an example of a "Drag and Drop" question set. Click and drag each word in the scrollbar below, up to the numbered bucket which matches the number of letters in the word. <p>
In drag and drop problems, students respond to a question by dragging text or objects to a specific location on an image.
</p>
<p>
For more information, see
<a href="http://edx.readthedocs.org/projects/edx-partner-course-staff/en/latest/exercises_tools/drag_and_drop.html" target="_blank">
Drag and Drop Problem</a> in <i>Building and Running an edX Course</i>.</p>
<p>When you add the problem, be sure to select <strong>Settings</strong>
to specify a <strong>Display Name</strong> and other values that apply.</p>
<p>You can use the following example problems as models.</p>
<p>_____________________________________________________________________________</p>
<customresponse> <customresponse>
<drag_and_drop_input img="https://studio.edx.org/c4x/edX/DemoX/asset/L9_buckets.png"> <h3>Simple Drag and Drop</h3>
<draggable id="1" label="a"/> <fieldset>
<draggable id="2" label="cat"/> <legend>Drag each word in the scrollbar to the bucket that matches the number of letters in the word.</legend>
<draggable id="3" label="there"/> <drag_and_drop_input img="https://studio.edx.org/c4x/edX/DemoX/asset/L9_buckets.png">
<draggable id="4" label="pear"/> <draggable id="1" label="a"/>
<draggable id="5" label="kitty"/> <draggable id="2" label="bog"/>
<draggable id="6" label="in"/> <draggable id="3" label="droll"/>
<draggable id="7" label="them"/> <draggable id="4" label="oboe"/>
<draggable id="8" label="za"/> <draggable id="5" label="swain"/>
<draggable id="9" label="dog"/> <draggable id="6" label="in"/>
<draggable id="10" label="slate"/> <draggable id="7" label="onyx"/>
<draggable id="11" label="few"/> <draggable id="8" label="of"/>
</drag_and_drop_input> <draggable id="9" label="tap"/>
<answer type="loncapa/python"> <draggable id="10" label="strop"/>
<draggable id="11" label="few"/>
</drag_and_drop_input>
</fieldset>
<answer type="loncapa/python">
correct_answer = { correct_answer = {
'1': [[70, 150], 121], '1': [[70, 150], 121],
'6': [[190, 150], 121], '6': [[190, 150], 121],
...@@ -36,13 +50,12 @@ data: | ...@@ -36,13 +50,12 @@ data: |
correct = ['correct'] correct = ['correct']
else: else:
correct = ['incorrect'] correct = ['incorrect']
</answer> </answer>
</customresponse> </customresponse>
<customresponse> <customresponse>
<text> <h3>Drag and Drop with Outline</h3>
<h2>Drag and Drop with Outline</h2> <fieldset>
<p>Please label hydrogen atoms connected with left carbon atom.</p> <legend>Label the hydrogen atoms connected with the left carbon atom.</legend>
</text>
<drag_and_drop_input img="https://studio.edx.org/c4x/edX/DemoX/asset/ethglycol.jpg" target_outline="true" one_per_target="true" no_labels="true" label_bg_color="rgb(222, 139, 238)"> <drag_and_drop_input img="https://studio.edx.org/c4x/edX/DemoX/asset/ethglycol.jpg" target_outline="true" one_per_target="true" no_labels="true" label_bg_color="rgb(222, 139, 238)">
<draggable id="1" label="Hydrogen" /> <draggable id="1" label="Hydrogen" />
<draggable id="2" label="Hydrogen" /> <draggable id="2" label="Hydrogen" />
...@@ -58,7 +71,8 @@ data: | ...@@ -58,7 +71,8 @@ data: |
<target id="t9_o" x="445" y="162" w="100" h="100"/> <target id="t9_o" x="445" y="162" w="100" h="100"/>
<target id="t10" x="591" y="132" w="70" h="70"/> <target id="t10" x="591" y="132" w="70" h="70"/>
</drag_and_drop_input> </drag_and_drop_input>
<answer type="loncapa/python"> </fieldset>
<answer type="loncapa/python">
correct_answer = [{ correct_answer = [{
'draggables': ['1', '2'], 'draggables': ['1', '2'],
'targets': ['t2', 't3', 't4' ], 'targets': ['t2', 't3', 't4' ],
......
...@@ -5,40 +5,53 @@ metadata: ...@@ -5,40 +5,53 @@ metadata:
data: | data: |
<problem> <problem>
<p> <p>
A math expression input problem accepts a line of text representing a mathematical expression from the In math expression input problems, learners enter text that represents a
student, and evaluates the input for equivalence to a mathematical expression provided by the mathematical expression into a field, and text is converted to a symbolic
grader. Correctness is based on numerical sampling of the symbolic expressions. expression that appears below that field. You can refer learners to
<a href="http://edx.readthedocs.org/projects/edx-guide-for-students/en/latest/SFD_mathformatting.html" target="_blank">
Entering Mathematical and Scientific Expressions</a> in the <i>edX Guide for
Students</i> for information about how to enter text into the field.
</p> </p>
<p> <p>
The answer is correct if both the student provided response and the grader's mathematical Math expression problems can include unknown variables and relatively
expression are equivalent to specified numerical tolerance, over a specified range of values for each complicated symbolic expressions. The grader uses a numerical sampling to
variable. determine whether the student’s response matches your math expression, to a
specified numerical tolerance. You must specify the allowed variables in the
expression as well as the range of values for each variable.
</p> </p>
<p>
To create these problems, you use MathJax to change your plain text into
"beautiful math." For more information about how to use MathJax in Studio,
see <a href="http://edx.readthedocs.org/projects/edx-partner-course-staff/en/latest/exercises_tools/mathjax.html" target="_blank">
A Brief Introduction to MathJax in Studio</a> in <i>Building and Running an edx
Course</i>.
</p>
<p>When you add the problem, be sure to select <strong>Settings</strong>
to specify a <strong>Display Name</strong> and other values that apply.</p>
<p>You can use the following example problems as models.</p>
<p>_____________________________________________________________________________</p>
<p>This kind of response checking can handle symbolic expressions, but places an extra burden <p>Write an expression for the product of \( R_1\), \( R_2\), and
on the problem author to specify the allowed variables in the expression, and the the inverse of \( R_3\) .</p>
numerical ranges over which the variables must be sampled in order to test for correctness.</p> <formularesponse type="ci" samples="R_1,R_2,R_3@1,2,3:3,4,5#10" answer="$VoVi">
<responseparam type="tolerance" default="0.00001"/>
<formulaequationinput size="40" label="Enter the equation"/>
</formularesponse>
<script type="loncapa/python"> <script type="loncapa/python">
VoVi = "(R_1*R_2)/R_3" VoVi = "(R_1*R_2)/R_3"
</script> </script>
<p>Give an equation for the relativistic energy of an object with mass m. Explicitly indicate multiplication with a <tt>*</tt> symbol.</p>
<formularesponse type="cs" samples="m,c@1,2:3,4#10" answer="m*c^2">
<responseparam type="tolerance" default="0.00001"/>
<br/><text>E =</text> <formulaequationinput size="40" />
</formularesponse>
<p>The answer to this question is (R_1*R_2)/R_3. </p> <p>Let \( x\) be a variable, and let \( n\) be an arbitrary constant.
What is the derivative of \( x^n\)?</p>
<script type="loncapa/python">
derivative = "n*x^(n-1)"
</script>
<formularesponse type="ci" samples="R_1,R_2,R_3@1,2,3:3,4,5#10" answer="$VoVi"> <formularesponse type="ci" samples="x,n@1,2:3,4#10" answer="$derivative">
<responseparam type="tolerance" default="0.00001"/> <responseparam type="tolerance" default="0.00001"/>
<formulaequationinput size="40" label="Enter the equation"/> <formulaequationinput size="40" label="Enter the equation"/>
</formularesponse> </formularesponse>
<solution>
<div class="detailed-solution">
<p>Explanation</p>
<p>The mathematical summary of many of the theory of relativity developed by Einstein is that the amount of energy contained in a mass m is the mass time the speed of light squared.</p>
<p>As you can see with the formula entry, the answer is \(\frac{R_1*R_2}{R_3}\)</p>
</div>
</solution>
</problem> </problem>
...@@ -4,19 +4,35 @@ metadata: ...@@ -4,19 +4,35 @@ metadata:
markdown: !!null markdown: !!null
data: | data: |
<problem> <problem>
<p> <p>
An image mapped input problem presents an image for the student. In an image mapped input problem, also known as a "pointing on a picture"
Input is given by the location of mouse clicks on the image. problem, students click inside a defined region in an image. You define this
Correctness of input can be evaluated based on expected dimensions of a rectangle. region by including coordinates in the body of the problem. You can define
</p> one rectangular region, multiple rectangular regions, or one non-rectangular
<p>Which animal shown below is a kitten?</p> region. For more information, see
<a href="http://edx.readthedocs.org/projects/edx-partner-course-staff/en/latest/exercises_tools/image_mapped_input.html" target="_blank">Image Mapped Input
Problem</a> in <i>Building and Running an edx Course</i>.
</p>
<p>When you add the problem, be sure to select <strong>Settings</strong>
to specify a <strong>Display Name</strong> and other values that apply.</p>
<p>You can use the following example problem as a model.</p>
<p>_____________________________________________________________________________</p>
<fieldset>
<legend>What country is home to the Great Pyramid of Giza as well as the cities
of Cairo and Memphis? Click the country on the map below.</legend>
<imageresponse> <imageresponse>
<imageinput src="https://studio.edx.org/c4x/edX/DemoX/asset/Dog-and-Cat.jpg" width="640" height="400" rectangle="(385,98)-(600,337)" alt="Two animals side by side. On the left, a brown furry animal with floppy ears and a large dark nose, on the right, a smaller furry animal with pointy ears and a small pink nose."/> <imageinput src="https://studio.edx.org/c4x/edX/DemoX/asset/Africa.png"
width="600" height="638" rectangle="(338,98)-(412,168)" alt="Map of
Africa"/>
</imageresponse> </imageresponse>
<solution> </fieldset>
<div class="detailed-solution"> <solution>
<p>Explanation</p> <div class="detailed-solution">
<p>The animal on the right is a kitten. The animal on the left is a puppy, not a kitten.</p> <p>Explanation</p>
</div> <p>Egypt is home to not only the Pyramids, Cairo, and Memphis, but also
</solution> the Sphinx and the ancient Royal Library of Alexandria.</p>
</div>
</solution>
</problem> </problem>
...@@ -3,37 +3,57 @@ metadata: ...@@ -3,37 +3,57 @@ metadata:
display_name: Custom Javascript Display and Grading display_name: Custom Javascript Display and Grading
markdown: !!null markdown: !!null
data: | data: |
<problem display_name="webGLDemo"> <problem>
<p>
In these problems (also called custom JavaScript problems or JS Input
problems), you add a problem or tool that uses JavaScript in Studio.
Studio embeds the problem in an IFrame so that your students can
interact with it in the LMS. You can grade your students' work using
JavaScript and some basic Python, and the grading is integrated into the
edX grading system.
</p>
<p>
The JS Input problem that you create must use HTML, JavaScript, and cascading
style sheets (CSS). You can use any application creation tool, such as the
Google Web Toolkit (GWT), to create your JS Input problem.
</p>
<p>
For more information, see
<a href="http://edx.readthedocs.org/projects/edx-partner-course-staff/en/latest/exercises_tools/custom_javascript.html" target="_blank">
Custom JavaScript Problem</a> in <i>Building and Running an edX Course</i>.
</p>
<p>JavaScript developers shoud also see <a href="http://edx.readthedocs.org/projects/edx-developer-guide/en/latest/extending_platform/javascript.html" target="_blank">
Custom JavaScript Applications</a> in the <i>edX Developer's Guide</i>.</p>
<p>When you add the problem, be sure to select <strong>Settings</strong>
to specify a <strong>Display Name</strong> and other values that apply.</p>
<p>You can use the following example problem as a model.</p>
<p>_____________________________________________________________________________</p>
<script type="loncapa/python"> <script type="loncapa/python">
<![CDATA[ <![CDATA[
import json import json
def vglcfn(e, ans): def vglcfn(e, ans):
''' '''
par is a dictionary containing two keys, "answer" and "state" par is a dictionary that contains two keys, "answer" and "state".
The value of answer is the JSON string returned by getGrade The value of "answer" is the JSON string that "getGrade" returns.
The value of state is the JSON string returned by getState The value of "state" is the JSON string that "getState" returns.
Clicking either "Check" or "Save" registers the current state.
''' '''
par = json.loads(ans) par = json.loads(ans)
# We can use either the value of the answer key to grade # You can use the value of the answer key to grade:
answer = json.loads(par["answer"]) answer = json.loads(par["answer"])
return answer["cylinder"] and not answer["cube"] return answer["cylinder"] and not answer["cube"]
''' '''
# Or we could use the value of the state key # Or you can use the value of the state key to grade:
state = json.loads(par["state"]) state = json.loads(par["state"])
selectedObjects = state["selectedObjects"] selectedObjects = state["selectedObjects"]
return selectedObjects["cylinder"] and not selectedObjects["cube"] return selectedObjects["cylinder"] and not selectedObjects["cube"]
''' '''
]]> ]]>
</script> </script>
<p> <p>In the following image, click the objects until the cone is yellow
The shapes below can be selected (yellow) or unselected (cyan). and the cube is blue.</p>
Clicking on them repeatedly will cycle through these two states.
</p>
<p>
If the cone is selected (and not the cube), a correct answer will be
generated after pressing "Check". Clicking on either "Check" or "Save"
will register the current state.
</p>
<customresponse cfn="vglcfn"> <customresponse cfn="vglcfn">
<jsinput gradefn="WebGLDemo.getGrade" <jsinput gradefn="WebGLDemo.getGrade"
get_statefn="WebGLDemo.getState" get_statefn="WebGLDemo.getState"
......
...@@ -2,40 +2,53 @@ ...@@ -2,40 +2,53 @@
metadata: metadata:
display_name: Multiple Choice display_name: Multiple Choice
markdown: | markdown: |
A multiple choice problem presents radio buttons for student input. Students can only select a single option presented. Multiple Choice questions have been the subject of many areas of research due to the early invention and adoption of bubble sheets. Multiple choice problems allow learners to select only one option. Learners can see all the options along with the problem text.
One of the main elements that goes into a good multiple choice question is the existence of good distractors. That is, each of the alternate responses presented to the student should be the result of a plausible mistake that a student might make. When you add the problem, be sure to select Settings to specify a Display Name and other values that apply.
>>What Apple device competed with the portable CD player?<< You can use the following example problem as a model.
( ) The iPad _____________________________________________________________________________
( ) Napster
(x) The iPod >>Which of the following countries has the largest population?<<
( ) The vegetable peeler ( ) Brazil
( ) Germany
(x) Indonesia
( ) Russia
[explanation] [explanation]
The release of the iPod allowed consumers to carry their entire music library with them in a format that did not rely on fragile and energy-intensive spinning disks. According to September 2014 estimates:
The population of Indonesia is approximately 250 million.
The population of Brazil is approximately 200 million.
The population of Russia is approximately 146 million.
The population of Germany is approximately 81 million.
[explanation] [explanation]
data: | data: |
<problem> <problem>
<p> <p>Multiple choice problems allow learners to select only one option.
A multiple choice problem presents radio buttons for student Learners can see all the options along with the problem text.</p>
input. Students can only select a single option presented. Multiple Choice questions have been the subject of many areas of research due to the early invention and adoption of bubble sheets.</p> <p>When you add the problem, be sure to select <strong>Settings</strong>
<p> One of the main elements that goes into a good multiple choice question is the existence of good distractors. That is, each of the alternate responses presented to the student should be the result of a plausible mistake that a student might make. to specify a <strong>Display Name</strong> and other values that apply.</p>
</p> <p>You can use the following example problem as a model.</p>
<fieldset>
<p>What Apple device competed with the portable CD player?</p> <legend>Which of the following countries has the largest population?</legend>
<multiplechoiceresponse> <multiplechoiceresponse>
<choicegroup type="MultipleChoice" label="What Apple device competed with the portable CD player?"> <choicegroup type="MultipleChoice">
<choice correct="false" name="ipad">The iPad</choice> <choice correct="false" name="brazil">Brazil</choice>
<choice correct="false" name="beatles">Napster</choice> <choice correct="false" name="germany">Germany</choice>
<choice correct="true" name="ipod">The iPod</choice> <choice correct="true" name="indonesia">Indonesia</choice>
<choice correct="false" name="peeler">The vegetable peeler</choice> <choice correct="false" name="russia">Russia</choice>
</choicegroup> </choicegroup>
</multiplechoiceresponse> </multiplechoiceresponse>
<solution> </fieldset>
<div class="detailed-solution"> <solution>
<p>Explanation</p> <div class="detailed-solution">
<p>The release of the iPod allowed consumers to carry their entire music library with them in a format that did not rely on fragile and energy-intensive spinning disks. </p> <p>Explanation</p>
</div> <p>According to September 2014 estimates:</p>
</solution> <p>The population of Indonesia is approximately 250 million.</p>
</problem> <p>The population of Brazil is approximately 200 million.</p>
<p>The population of Russia is approximately 146 million.</p>
<p>The population of Germany is approximately 81 million.</p>
</div>
</solution>
</problem>
\ No newline at end of file
...@@ -2,66 +2,66 @@ ...@@ -2,66 +2,66 @@
metadata: metadata:
display_name: Numerical Input display_name: Numerical Input
markdown: | markdown: |
A numerical input problem accepts a line of text input from the student, and evaluates the input for correctness based on its numerical value. In a numerical input problem, learners enter numbers or a specific and relatively simple mathematical expression. Learners enter the response in plain text, and the system then converts the text to a symbolic expression that learners can see below the response field.
The answer is correct if it is within a specified numerical tolerance of the expected answer. The system can handle several types of characters, including basic operators, fractions, exponents, and common constants such as "i". You can refer learners to "Entering Mathematical and Scientific Expressions" in the edX Guide for Students for more information.
>>Enter the numerical value of Pi:<< When you add the problem, be sure to select Settings to specify a Display Name and other values that apply.
= 3.14159 +- .02
>>Enter the approximate value of 502*9:<<
= 4518 +- 15%
>>Enter the number of fingers on a human hand<< You can use the following example problems as models.
= 5 _____________________________________________________________________________
[explanation] >>How many miles away from Earth is the sun? Use scientific notation to answer.<<
Pi, or the the ratio between a circle's circumference to its diameter, is an irrational number known to extreme precision. It is value is approximately equal to 3.14.
Although you can get an exact value by typing 502*9 into a calculator, the result will be close to 500*10, or 5,000. The grader accepts any response within 15% of the true value, 4518, so that you can use any estimation technique that you like. = 9.3*10^6
or= 9.296*10^6
If you look at your hand, you can count that you have five fingers. >>The square of what number is -100?<<
[explanation]
= 10*i
[explanation]
The sun is 93,000,000, or 9.3*10^6, miles away from Earth.
-100 is the square of 10 times the imaginary number, i.
[explanation]
data: | data: |
<problem> <problem>
<p>
A numerical input problem accepts a line of text input from the <p>In a numerical input problem, learners enter numbers or a specific and
student, and evaluates the input for correctness based on its relatively simple mathematical expression. Learners enter the response in
numerical value. plain text, and the system then converts the text to a symbolic expression
</p> that learners can see below the response field.</p>
<p>The system can handle several types of characters, including basic
operators, fractions, exponents, and common constants such as i. You can
refer learners to
<a href="http://edx.readthedocs.org/projects/edx-guide-for-students/en/latest/SFD_mathformatting.html" target="_blank">
Entering Mathematical and Scientific Expressions</a> in the <i>edX Guide for
Students</i> for information about how to enter text into the field.</p>
<p>When you add the problem, be sure to select <strong>Settings</strong>
to specify a <strong>Display Name</strong> and other values that apply.</p>
<p> <p>You can use the following example problems as models.</p>
The answer is correct if it is within a specified numerical tolerance <p>_____________________________________________________________________________</p>
of the expected answer.
</p>
<script type="loncapa/python">
computed_response = 502*9
</script>
<p>Enter the numerical value of Pi: <fieldset>
<numericalresponse answer="3.14159"> <legend>How many miles away from Earth is the sun? Use scientific notation to answer.</legend>
<responseparam type="tolerance" default=".02" /> <numericalresponse answer="9.3*10^6">
<formulaequationinput label="Enter the numerical value of Pi" /> <formulaequationinput label="How many million miles are between Earth and the sun? Use scientific notation to answer." />
</numericalresponse> </numericalresponse>
</p> </fieldset>
<p>Enter the approximate value of 502*9:
<numericalresponse answer="$computed_response">
<responseparam type="tolerance" default="15%"/>
<formulaequationinput label="Enter the approximate value of 502 times 9"/>
</numericalresponse>
</p>
<p>Enter the number of fingers on a human hand: <fieldset>
<numericalresponse answer="5"> <legend>The square of what number is -100?</legend>
<formulaequationinput label="Enter the number of fingers on a human hand"/> <numericalresponse answer="10*i">
</numericalresponse> <formulaequationinput label="The square of what number is -100?" />
</p> </numericalresponse>
<solution> </fieldset>
<div class="detailed-solution"> <solution>
<p>Explanation</p> <div class="detailed-solution">
<p>Pi, or the the ratio between a circle's circumference to its diameter, is an irrational number known to extreme precision. It is value is approximately equal to 3.14.</p> <p>Explanation</p>
<p>Although you can get an exact value by typing 502*9 into a calculator, the result will be close to 500*10, or 5,000. The grader accepts any response within 15% of the true value, 4518, so that you can use any estimation technique that you like.</p> <p>The sun is 93,000,000, or 9.3*10^6, miles away from Earth.</p>
<p>If you look at your hand, you can count that you have five fingers.</p> <p>-100 is the square of 10 times the imaginary number, i.</p>
</div> </div>
</solution> </solution>
</problem> </problem>
\ No newline at end of file
...@@ -2,35 +2,39 @@ ...@@ -2,35 +2,39 @@
metadata: metadata:
display_name: Dropdown display_name: Dropdown
markdown: | markdown: |
Dropdown problems give a limited set of options for students to respond with, and present those options in a format that encourages them to search for a specific answer rather than being immediately presented with options from which to recognize the correct answer. Dropdown problems allow learners to select only one option from a list of options.
The answer options and the identification of the correct answer is defined in the <b>optioninput</b> tag. When you add the problem, be sure to select Settings to specify a Display Name and other values that apply.
>>Translation between Dropdown and __________ is extremely straightforward:<< You can use the following example problem as a model.
[[(Multiple Choice), Text Input, Numerical Input, External Response, Image Response]] _____________________________________________________________________________
[explanation] >>Which of the following countries celebrates its independence on August 15?<<
Multiple Choice also allows students to select from a variety of pre-written responses, although the format makes it easier for students to read very long response options. Dropdowns also differ slightly because students are more likely to think of an answer and then search for it rather than relying purely on recognition to answer the question.
[explanation] [[(India), Spain, China, Bermuda]]
[explanation]
India became an independent nation on August 15, 1947.
[explanation]
data: | data: |
<problem> <problem>
<p>Dropdown problems give a limited set of options for students to respond with, and present those options <p>Dropdown problems allow learners to select only one option from a list of options.</p>
in a format that encourages them to search for a specific answer rather than being immediately presented with options from which to recognize the correct answer.</p> <p>When you add the problem, be sure to select <strong>Settings</strong>
to specify a <strong>Display Name</strong> and other values that apply.</p>
<p> <p>You can use the following example problem as a model.</p>
The answer options and the identification of the correct answer is defined in the <b>optioninput</b> tag. <fieldset>
</p> <legend>Which of the following countries celebrates its independence on August 15?</legend>
<p>Translation between Dropdown and __________ is extremely straightforward: <br/>
<optionresponse>
<optionresponse> <optioninput options="('India','Spain','China','Bermuda')" correct="India"></optioninput>
<optioninput options="('Multiple Choice','Text Input','Numerical Input','External Response','Image Response')" correct="Multiple Choice" label="Translation between Dropdown and __________ is extremely straightforward"></optioninput> </optionresponse>
</optionresponse> </fieldset>
</p> <solution>
<solution> <div class="detailed-solution">
<div class="detailed-solution"> <p>Explanation</p>
<p>Explanation</p> <p>India became an independent nation on August 15, 1947.</p>
<p>Multiple Choice also allows students to select from a variety of pre-written responses, although the format makes it easier for students to read very long response options. Optionresponse also differs slightly because students are more likely to think of an answer and then search for it rather than relying purely on recognition to answer the question.</p> </div>
</div> </solution>
</solution>
</problem> </problem>
...@@ -2,38 +2,45 @@ ...@@ -2,38 +2,45 @@
metadata: metadata:
display_name: Text Input display_name: Text Input
markdown: | markdown: |
A text input problem accepts a line of text from the student, and evaluates the input for correctness based on an expected answer. In text input problems, also known as "fill-in-the-blank" problems, learners enter text into a response field. The text can include letters and characters such as punctuation marks. The text that the learner enters must match your specified answer text exactly. You can specify more than one correct answer. Learners must enter a response that matches one of the correct answers exactly.
The answer is correct if it matches every character of the expected answer. This can be a problem with international spelling, dates, or anything where the format of the answer is not clear.
>>Which US state has Lansing as its capital?<<
= Michigan
When you add the problem, be sure to select Settings to specify a Display Name and other values that apply.
You can use the following example problem as a model.
_____________________________________________________________________________
>>What was the first post-secondary school in China to allow both male and female students?<<
= Nanjing Higher Normal Institute
or= National Central University
or= Nanjing University
[explanation] [explanation]
Lansing is the capital of Michigan, although it is not Michigan's largest city, or even the seat of the county in which it resides. Nanjing Higher Normal Institute first admitted female students in 1920.
[explanation] [explanation]
data: | data: |
<problem> <problem>
<p> <p>In text input problems, also known as "fill-in-the-blank" problems,
learners enter text into a response field. The text that the learner enters
A text input problem accepts a line of text from the must match your specified answer text exactly. You can specify more than
student, and evaluates the input for correctness based on an expected one correct answer. Learners must enter a response that matches one of the
answer. correct answers exactly.</p>
</p> <p>When you add the problem, be sure to select <strong>Settings</strong>
<p> to specify a <strong>Display Name</strong> and other values that apply.</p>
The answer is correct if it matches every character of the expected answer. This can be a problem with international spelling, dates, or anything where the format of the answer is not clear. <p> You can use the following example problem as a model.</p>
</p> <fieldset>
<legend>What was the first post-secondary school in China to allow both male and female students?</legend>
<p>Which US state has Lansing as its capital? </p> <stringresponse answer="Nanjing Higher Normal Institute" type="ci" >
<stringresponse answer="Michigan" type="ci"> <additional_answer>National Central University</additional_answer>
<textline size="20" label="Which US state has Lansing as its capital?"/> <additional_answer>Nanjing University</additional_answer>
</stringresponse> <textline label="What was the first post-secondary school in China to allow both male and female students?" size="40"/>
<solution> </stringresponse>
<div class="detailed-solution"> </fieldset>
<p>Explanation</p> <solution>
<p>Lansing is the capital of Michigan, although it is not Michigan's largest city, or even the seat of the county in which it resides.</p> <div class="detailed-solution">
</div> <p>Explanation</p>
</solution> <p>Nanjing Higher Normal Institute first admitted female students in 1920.</p>
</div>
</solution>
</problem> </problem>
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment