// Numbas version: exam_results_page_options {"name": "Sketching Argand Diagram", "extensions": ["jsxgraph"], "custom_part_types": [], "resources": [], "navigation": {"allowregen": true, "showfrontpage": false, "preventleave": false, "typeendtoleave": false}, "question_groups": [{"pickingStrategy": "all-ordered", "questions": [{"tags": [], "variables": {"c": {"group": "Ungrouped variables", "definition": "random(-4..4)", "description": "", "templateType": "anything", "name": "c"}, "a": {"group": "Ungrouped variables", "definition": "random(-12..12)", "description": "", "templateType": "anything", "name": "a"}, "b": {"group": "Ungrouped variables", "definition": "random(-3..3 except 0)", "description": "", "templateType": "anything", "name": "b"}}, "extensions": ["jsxgraph"], "statement": "

\n

By dragging the points A, B, and C, construct the graph of the function

\n

$ f(x) = \\left\\{ \\begin{array}{cl} \\var{a} \\\\ \\simplify{{b}x + {c}}.\\end{array}\\right.$

\n

Note that in order to be marked correct, the points need to be within 0.2 of their correct $y$-values.

\n

Also note that you have to drag each of the points in order to be able to submit your answer.

", "variablesTest": {"condition": "", "maxRuns": "200"}, "name": "Sketching Argand Diagram", "functions": {"graph": {"type": "html", "parameters": [["a", "number"], ["b", "number"], ["c", "number"]], "definition": "// set up the board\nvar div = Numbas.extensions.jsxgraph.makeBoard('500px','500px',{boundingBox:[-5.5,20,5.5,-21.5],grid:true,withLabel:true,ticks:false});\n\nvar board = div.board;\n\nvar d = board.create('point',[5.1,0],{size:-1,name:'x'});\nd.setProperty({fixed:true});\nvar f = board.create('point',[0,20],{size:-1,name:'y'});\nf.setProperty({fixed:true});\nvar e = board.create('point',[-5,a],{size:5,name:'A'});\ne.setProperty({fixed:true});\nvar g = board.create('point',[0,a],{size:5,name:'B'});\ng.setProperty({fixed:true});\nvar e = board.create('point',[0,c],{size:5,name:'C'});\ne.setProperty({fixed:true});\nvar h = board.create('point',[5,c + b*5],{size:5,name:'D'});\nh.setProperty({fixed:true});\n\nboard.create('functiongraph',[function(x){ return a;},-5,0],{strokeColor:'blue',strokeWidth:2});\nboard.create('functiongraph',[function(x){ return c + b*x;},0,5],{strokeColor:'blue',strokeWidth:2});\n\nreturn div;", "language": "javascript"}}, "ungrouped_variables": ["a", "b", "c"], "rulesets": {}, "parts": [{"type": "gapfill", "variableReplacementStrategy": "originalfirst", "variableReplacements": [], "gaps": [{"correctAnswerFraction": false, "variableReplacements": [], "notationStyles": ["plain", "en", "si-en"], "correctAnswerStyle": "plain", "showCorrectAnswer": true, "marks": "1", "scripts": {}, "minValue": "-0.2", "type": "numberentry", "variableReplacementStrategy": "originalfirst", "allowFractions": false, "maxValue": "0.2", "mustBeReducedPC": 0, "mustBeReduced": false, "showFeedbackIcon": false}, {"correctAnswerFraction": false, "variableReplacements": [], "notationStyles": ["plain", "en", "si-en"], "correctAnswerStyle": "plain", "showCorrectAnswer": true, "marks": "1", "scripts": {}, "minValue": "-0.2", "type": "numberentry", "variableReplacementStrategy": "originalfirst", "allowFractions": false, "maxValue": "0.2", "mustBeReducedPC": 0, "mustBeReduced": false, "showFeedbackIcon": false}, {"correctAnswerFraction": false, "variableReplacements": [], "notationStyles": ["plain", "en", "si-en"], "correctAnswerStyle": "plain", "showCorrectAnswer": true, "marks": "1", "scripts": {}, "minValue": "- 0.2", "type": "numberentry", "variableReplacementStrategy": "originalfirst", "allowFractions": false, "maxValue": "0.2", "mustBeReducedPC": 0, "mustBeReduced": false, "showFeedbackIcon": false}, {"correctAnswerFraction": false, "variableReplacements": [], "notationStyles": ["plain", "en", "si-en"], "correctAnswerStyle": "plain", "showCorrectAnswer": true, "marks": "1", "scripts": {}, "minValue": "- 0.2", "type": "numberentry", "variableReplacementStrategy": "originalfirst", "allowFractions": false, "maxValue": "0.2", "mustBeReducedPC": 0, "mustBeReduced": false, "showFeedbackIcon": false}], "showFeedbackIcon": true, "showCorrectAnswer": true, "marks": 0, "scripts": {}, "prompt": "
"}], "advice": "

The correct graph is shown below.

\n

{graph(a,b,c)}

", "variable_groups": [], "metadata": {"description": "", "licence": "Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International"}, "preamble": {"css": "table#values th {\n background: none;\n text-align: center;\n}", "js": "function dragpoint_board() {\n var scope = question.scope;\n \n var a = scope.variables.a.value;\n var b = scope.variables.b.value;\n var c = scope.variables.c.value;\n\n \n var div = Numbas.extensions.jsxgraph.makeBoard('500px','500px',{boundingBox:[-5.5,20.5,5.5,-21.5],grid:true,withLabel:true});\n $(question.display.html).find('#dragpoint').append(div);\n\n var board = div.board;\n \n// ceeate axis labels\n \n var label1 = board.create('point',[5.1,0.2],{name:'X',size:-1});\n label1.setProperty({fixed:true});\n var label2 = board.create('point',[0,20.3],{name:'y',size:-1});\n label2.setProperty({fixed:true});\n \n \n \n //create draggable points\n\n\n var line0 = board.create('line',[[-5,0],[-5,4]],{visible: false});\n var np0 = board.create('glider',[-5,8,line0],\n {\n name:'A',\n size:5\n }\n );\n\n var line1 = board.create('line',[[0,0],[0,4]],{visible: false});\n var np1 = board.create('glider',[-1,8,line1],\n {\n name:'B',\n size:5\n }\n );\n \n var line2 = board.create('line',[[0,0],[0,4]],{visible: false});\n var np2 = board.create('glider',[0,6,line2],\n {\n name:'C',\n size:5,\n }\n );\n \n var line3 = board.create('line',[[5,0],[5,4]],{visible: false});\n var np3 = board.create('glider',[0,6,line3],\n {\n name:'D',\n size:5,\n }\n );\n \n \n //shorthand to evaluate a mathematical expression to a number\n function evaluate(expression) {\n try {\n var val = Numbas.jme.evaluate(expression,question.scope);\n return Numbas.jme.unwrapValue(val);\n }\n catch(e) {\n // if there's an error, return no number\n return NaN;\n }\n }\n \n // set up points array\n var num_points = 4;\n var points = [np0, np1, np2, np3];\n \n \n // this function sets up the i^th point\n function make_point(i) {\n \n var point = points[i];\n \n var x=point[0];\n var y=point[1];\n \n // the contents of the input box for this point\n var xstudentAnswer = question.parts[0].gaps[i].display.studentAnswer;\n\n \n // when the student drags the point, update the gapfill input\n point.on('drag',function(){\n var x = Numbas.math.niceNumber(point.X());\n var y = Numbas.math.niceNumber(point.Y());\n if(i < 2)\n {\n var diff = y-(a);\n xstudentAnswer(diff);\n }\n if (i===2)\n {\n var diff = y-(c);\n xstudentAnswer(diff);\n }\n if (i===3)\n {\n var diff = y-(b*5+c);\n xstudentAnswer(diff);\n }\n });\n \n }\n \n // create each point\n for(var i=0;i