# MultipleChoiceProblems

(Difference between revisions)
Jump to: navigation, search

## Multiple Choice Problems: PG Code Snippet

This code snippet shows the essential PG code to include multiple-choice questions in a problem. Note that these are insertions, not a complete PG file. This code will have to be incorporated into the problem file on which you are working.

Note that in this example we use old-style multiple choice answer objects. The new-style MathObjects have a multiple choice object as well, but its behavior is sufficiently different than that suggested here that is not documented here.

<tr valign="top"> <td style="background-color:#ffdddd;border:black 1px dashed;">
```BEGIN_TEXT

\{ \$mc->print_q() \}
\$BR
\{ \$mc->print_a() \}

END_TEXT
```

<td style="background-color:#ffcccc;padding:7px;">

Main text: In the text section we print the question and answers.

</td> </tr> <tr valign="top"> <td style="background-color:#eeddff;border:black 1px dashed;">

```install_problem_grader(~~&std_problem_grader);

\$showPartialCorrectAnswers = 0;

ANS( radio_cmp( \$mc->correct_ans() ) );

ENDDOCUMENT();
```

<td style="background-color:#eeccff;padding:7px;">

Answer Evaluation: Use the standard problem grader to give credit only if all answers are correct, and do not give feedback on partial correct answers. Otherwise, students can use the feedback or the partial credit received to guess and check if their answers are correct. We grade the problem with `radio_cmp`.

</td> </tr> </table>

##### follow us

PG problem file Explanation
```DOCUMENT();

loadMacros(
"PG.pl",
"PGbasicmacros.pl",
"PGchoicemacros.pl",
"PGanswermacros.pl",
"PGcourse.pl",
);

TEXT(beginproblem());
```

Initialization: Include `PGchoicemacros.pl` in the list of loaded macro files.

```\$mc = new_multiple_choice();
\$mc->qa(
"What is your favorite color?",
"blue"
);
\$mc->extra(
"red",
"green"
);
\$mc->makeLast("none of the above");
```

Setup: Create a new multiple choice object with `new_multiple_choice`, and then store the question and correct answer with the `qa` method. Other answers are specified as a list of arguments to the `extra` method. To force an answer (either a new extra answer, or the correct answer) to appear last in the list of options, use the `makeLast` method. All other answers will be scrambled when the multiple choice problem is shown to students. <p> To make answers appear in a certain order (e.g., Yes followed by No and Maybe), use `\$mc->qa("question","Yes"); \$mc->makeLast("Yes","No","Maybe");` and do not use `extra( )` at all. In this case, to randomize the question and answer, where the answer to question 1 is Yes and the answer to question 2 is No, use

```@quest = ("question 1","question 2");
@ans = ("Yes","No");
\$pick = random(0,1,1);
\$mc->new_checkbox_multiple_choice();
\$mc->qa(\$quest[\$pick],\$ans[\$pick]);
\$mc->makeLast("Yes","No","Maybe");
```

</p>