summaryrefslogtreecommitdiff
path: root/python/problems/introduction-fkkt/molar_mass
diff options
context:
space:
mode:
authorMatevž Poberžnik <tevzpoberznik@gmail.com>2017-10-13 12:42:22 +0200
committerMatevž Poberžnik <tevzpoberznik@gmail.com>2017-10-13 12:42:22 +0200
commit4b0e419541244969e3177b7da6efc3149c2263aa (patch)
treef32921d279d87d0d8b3cddd00e79041b2fb57f14 /python/problems/introduction-fkkt/molar_mass
parent746fa1fb9d1430747b499d667f2cfe1fc77d3718 (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.py91
-rw-r--r--python/problems/introduction-fkkt/molar_mass/sl.py106
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>''']
+
+}