diff options
author | Matevž Poberžnik <tevzpoberznik@gmail.com> | 2017-10-13 12:42:22 +0200 |
---|---|---|
committer | Matevž Poberžnik <tevzpoberznik@gmail.com> | 2017-10-13 12:42:22 +0200 |
commit | 4b0e419541244969e3177b7da6efc3149c2263aa (patch) | |
tree | f32921d279d87d0d8b3cddd00e79041b2fb57f14 /python/problems/introduction-fkkt/molar_mass | |
parent | 746fa1fb9d1430747b499d667f2cfe1fc77d3718 (diff) |
Python: Add introduction group for FKKT students
Python: Add anchor link to jump to FKKT exercices
Diffstat (limited to 'python/problems/introduction-fkkt/molar_mass')
-rw-r--r-- | python/problems/introduction-fkkt/molar_mass/common.py | 91 | ||||
-rw-r--r-- | python/problems/introduction-fkkt/molar_mass/sl.py | 106 |
2 files changed, 197 insertions, 0 deletions
diff --git a/python/problems/introduction-fkkt/molar_mass/common.py b/python/problems/introduction-fkkt/molar_mass/common.py new file mode 100644 index 0000000..10aa098 --- /dev/null +++ b/python/problems/introduction-fkkt/molar_mass/common.py @@ -0,0 +1,91 @@ +from python.util import has_token_sequence, string_almost_equal, \ + string_contains_number, get_tokens, get_numbers, get_exception_desc +from server.hints import Hint + +id = 25004 +number = 5 +visible = True + +solution = '''\ +hidracija = int(input('Stopnja hidracije: ')) + +Cu = 63.5 +S = 32.1 +O = 16.0 +H = 1.0 +mm = Cu + S + 4 * O + hidracija * (2 * H + O) + +print('Molska masa je', mm, 'g/mol.') +''' + +hint_type = { + 'plan': Hint('plan'), + 'name_error': Hint('name_error'), + 'unsupported_operand': Hint('unsupported_operand'), + 'no_input_call' : Hint('no_input_call'), + 'printing': Hint('printing'), + 'final_hint': Hint('final_hint') +} + +def test(python, code, aux_code=''): + # List of inputs: (expression to eval, stdin). + test_in = [ + (None, '1'), + (None, '2'), + (None, '5') + ] + + test_out = [ + "Molska masa je 177.6 g/mol", + "Molska masa je 195.6 g/mol", + "Molska masa je 249.6 g/mol", + ] + + # List of outputs: (expression result, stdout, stderr, exception). + answers = python(code=aux_code+code, inputs=test_in, timeout=1.0) + outputs = [ans[1] for ans in answers] + + n_correct = 0 + tin = None + for i, (output, correct) in enumerate(zip(outputs, test_out)): + #if string_almost_equal(output, float(correct), prec=2): + if output.rstrip().endswith(correct): + n_correct += 1 + else: + tin = test_in[i][1] + tout = correct + + passed = n_correct == len(test_in) + hints = [{'id': 'test_results', 'args': {'passed': n_correct, 'total': len(test_in)}}] + if tin: + hints.append({'id': 'problematic_test_case', 'args': {'testin': str(tin), 'testout': str(tout)}}) + if passed: + hints.append({'id': 'final_hint'}) + return passed, hints + +def hint(python, code, aux_code=''): + tokens = get_tokens(code) + + # run one test first to see if there are any exceptions + test_in = [(None, '1\n')] + answer = python(code=aux_code+code, inputs=test_in, timeout=1.0) + exc = answer[0][3] + exc_hint = get_exception_desc(answer[0][3]) + if exc: + if 'NameError' in exc: + return [{'id':'name_error', 'args': {'message': exc}}] + elif 'unsupported operand' in exc or 'TypeError' in exc: + return [{'id':'unsupported_operand', 'args': {'message': exc}}] + else: + return exc_hint + + # if input is not present in code, student needs to learn about input + if not has_token_sequence(tokens, ['input']) or \ + (not has_token_sequence(tokens, ['float']) and not has_token_sequence(tokens, ['int'])) or \ + not has_token_sequence(tokens, ['=']): + return [{'id': 'no_input_call'}] + + if not has_token_sequence(tokens, ['print']): + return [{'id' : 'printing'}] + + return None diff --git a/python/problems/introduction-fkkt/molar_mass/sl.py b/python/problems/introduction-fkkt/molar_mass/sl.py new file mode 100644 index 0000000..7a0af3d --- /dev/null +++ b/python/problems/introduction-fkkt/molar_mass/sl.py @@ -0,0 +1,106 @@ +import server +mod = server.problems.load_language('python', 'sl') + +name = 'Molska masa' +slug = 'Molska masa' + +description = '''\ +<p>Molsko maso lahko izračunamo elementom in spojinam. V periodnem sistemu najdemo relativne atomske mase in iz njih izračunamo molske mase. Relativna atomska masa neona je A<sub>r</sub>(Ne) = 20.2. Iz tega sledi, da je molska masa neona M(Ne) = 20.2 g/mol. Pri izračunu molske mase večatomnih molekul (elementov in spojin) moramo upoštevati število posameznih atomov v molekuli. Tako je relativna atomska masa vodika A<sub>r</sub>(H) = 1.0, relativna atomska masa kisika pa A<sub>r</sub>(O) = 16.0. Iz tega sledi, da je relativna molekulska masa vode M<sub>r</sub>(H<sub>2</sub>O) = 2·1.0 + 16.0 = 18.0. Molska masa vode pa je M(H<sub>2</sub>O) = 18.0 g/mol.</p> +<p>Bakrov(II) sulfat je kemijska spojina s formulo CuSO<sub>4</sub>. Spojina ima pravzaprav več kemijskih formul, ki so odvisne od stopnje hidratacije. Tako je <a href="https://sl.wikipedia.org/wiki/Galica">modra galica</a> bakrov(II) sulfat pentahidrat s formulo CuSO<sub>4</sub>·5H<sub>2</sub>O. Izračunajte molsko maso na podlagi preglednice in vnosa uporabnika, ki vnese stopnjo hidracije oz. število molekul vode.</p> +<center id="yui_3_17_2_1_1507822990439_110"> +<table> +<thead> +<tr> +<th scope="col" style="border: 1px solid black;">element</th> +<th scope="col" style="border: 1px solid black;">relativna atomska masa</th> +</tr> +</thead> +<tbody> +<tr> +<td style="border: 1px solid black;">Cu</td> +<td style="border: 1px solid black;">63.5</td> +</tr> +<tr> +<td style="border: 1px solid black;">S</td> +<td style="border: 1px solid black;">32.1</td> +</tr> +<tr> +<td style="border: 1px solid black;">O</td> +<td style="border: 1px solid black;">16.0</td> +</tr> +<tr> +<td style="border: 1px solid black;">H</td> +<td style="border: 1px solid black;">1.0</td> +</tr> +</tbody> +</table> +</center> +<p>Primer uporabe:</p> +<pre>Stopnja hidracije: 5 +Molska masa je 249.6 g/mol</pre> +''' + +no_input_call = ['''\ +<p>Tako kot pri prejšnji nalogi za branje uporabimo funkcijo <code>input</code></p>''', + '''\ +<p>Preberemo vrednost in jo shranimo v spremenljivko:</p> +<pre> + h = float(input("Stopnja hidracije: ")) +</pre>''', + '''\ +<p> Ime <code>h</code> je spremenljivka (angl. variable). +Spremenljivke uporabljamo, kadar želimo kakšno vrednost shraniti, ki jo bomo +potrebovali kasneje v programu. Imena spremenljivk so lahko poljubno + dolga, v našem primeru bi ji lahko rekli tudi <code>hidracija</code>. + Pri programiranju velja, da izbiramo taka imena spremenljivk, + ki bodo naredila program berljiv. </p> + ''' +] + +printing = ['''\ +<p> V Pythonu izpisujemo s funkcijo <code>print</code>. </p>''', + '''\ +<p>Če želimo izpisati več elementov, +jih ločimo z vejico. Recimo, da imamo spremenljivko <code>ime</code>, +ki vsebuje naše ime, potem lahko napišemo:</p> +<pre> +print("Ime mi je", ime, ".") +</pre>'''] + +plan = ['''\ +<p>Program razdelimo na tri dele, kot pri prejšnji nalogi:</p> +<ol> + <li>Preberi vrednost hidracije (h = ?)i</li> + <li>Izračunaj molsko maso mm (mm = …)</li> + <li>Izpiši rezultat (print … )</li> +</ol> +''', + no_input_call, + printing] + +hint = { + 'no_input_call': no_input_call, + + 'printing': printing, + + 'name_error' : [mod.general_msg['error_head'], mod.general_msg['general_exception'], + mod.general_msg['name_error'], ''' + <p>Verjetno uporabljaš spremenljivko, ki nima vrednosti. Ali v izrazu za izračun + uporabljaš napačno spremenljivko? Ali pri izpisu morda poskušaš + izpisati napačno spremenljivko?</p>'''], + + 'unsupported_operand' : [mod.general_msg['error_head'], mod.general_msg['general_exception'], + mod.general_msg['type_error'], ''' +<p>Verjetni razlog: funkcija <code>input</code> vrača vrednost tipa niz, +ki jo moramo najprej pretvoriti v tip <code>float</code>, če želimo z njo računati:</p> +<pre> +v = float(input(" ... +</pre> +'''], + + 'final_hint' : [ + '''\ +<p>Program deluje pravilno! +</p>'''] + +} |