GetDenominator: Unterschied zwischen den Versionen

Aus JACK Wiki
Zur Navigation springen Zur Suche springen
Keine Bearbeitungszusammenfassung
KKeine Bearbeitungszusammenfassung
 
(13 dazwischenliegende Versionen von 6 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
===Zugehörige Evaluatoren===
*'''MathEvaluator'''
=== Beschreibung ===
=== Beschreibung ===
Mit der Funktion ''getDenominator'' erhält man den Nenner eines Bruches. Die Funktion erwartet einen String, bei dem es sich um einen Bruch handeln muss, und gibt eine Zahl zurück.
Mit der Funktion ''getDenominator'' erhält man den Nenner eines Bruches. Die Funktion erwartet ein [[Objekt]], bei dem es sich um einen Bruch handeln muss, und gibt ein [[Objekt]] zurück.


=== Syntax ===
=== Syntax ===
  getDenominator(String bruch)
  getDenominator(Bruch bruch)


=== Parameter ===
=== Parameter ===
Zeile 9: Zeile 12:


=== Return Value ===
=== Return Value ===
* Gibt eine Ganzzahl zurück
* Gibt eine [[Objekt]] zurück


=== Beispiele ===
=== Beispiele ===
getDenominator('3/5')  --> returns 5
==== Standardfälle ====
 
getDenominator(3/5)  --> returns 5
====JUnit Tests====
<span class="mw-customtoggle-myDivision">[Anzeigen]</span>
getDenominator((5+3)/list(1,2))  --> returns {1,2}
<syntaxhighlight lang="java" class="mw-collapsible mw-collapsed" id="mw-customcollapsible-myDivision">
@Before
public void beforeTest() {
  placeFillInVariable(1, OMParser.parse("0"));
  placeFillInVariable(2, OMParser.parse("20/3"));
  placeFillInVariable(3, OMParser.parse("10.3"));
  placeFillInVariable(4, OMParser.parse("-5"));
  placeFillInVariable(5, OMParser.parse("5"));
  placeExerciseVariable("a", OMParser.parse("0"));
  placeExerciseVariable("b", OMParser.parse("20/3"));
  placeExerciseVariable("c", OMParser.parse("10.3"));
  placeExerciseVariable("d", OMParser.parse("-5"));
   placeExerciseVariable("e", OMParser.parse("5"));
}
 
@Test
public void testGetDenominator(){
  assertTrue(7 == (getEvaluator().getNumberResult("getDenominator(3/7)")));
  assertTrue(7 == (getEvaluator().getNumberResult("getDenominator(10/7)")));
  assertTrue(-10 == (getEvaluator().getNumberResult("getDenominator(20/-10)"))); //Error negative denominator
  assertTrue(3.2 == (getEvaluator().getNumberResult("getDenominator('-5/3.2')")));
  assertTrue(5 == (getEvaluator().getNumberResult("getDenominator('0/5')")));
  assertFalse(3 == (getEvaluator().getNumberResult("getDenominator('-5/6')")));
  assertFalse(2 == (getEvaluator().getNumberResult("getDenominator('8/4')")));
}
 
@Test(expected=InvalidEvaluatorFunctionArgumentException.class)
public void testGetDenominatorAtDefinitionZero(){
  getEvaluator().getNumberResult("getDenominator(3/0)")//Result of 3/0 is undefined
}
 
@Test
public void testGetDenominatorWithInput(){
  assertTrue(3 == (getEvaluator().getNumberResult("getDenominator([pos=2])")));
  assertTrue(7 == (getEvaluator().getNumberResult("getDenominator([pos=1]/7)")));
  assertTrue(10.3 == (getEvaluator().getNumberResult("getDenominator(5/[pos=3])")));
  assertTrue(5 == (getEvaluator().getNumberResult("getDenominator([pos=3]/[pos=5])")));
   assertTrue(-5 == (getEvaluator().getNumberResult("getDenominator([pos=3]/[pos=4])"))); //Error negative denominator
}
 
@Test
public void testGetDenominatorWithVariables(){
  assertTrue(3 == (getEvaluator().getNumberResult("getDenominator([var=b])")));
  assertTrue(7 == (getEvaluator().getNumberResult("getDenominator([var=a]/7)")));
  assertTrue(10.3 == (getEvaluator().getNumberResult("getDenominator(5/[var=c])")));
  assertTrue(5 == (getEvaluator().getNumberResult("getDenominator([var=c]/[var=e])")));
  assertTrue(-5 == (getEvaluator().getNumberResult("getDenominator([var=c]/[var=d])"))); //Error negative denominator
}
@Test
public void testGetDenominatorWithExpressions(){
  assertTrue(2 == (getEvaluator().getNumberResult("getDenominator('4/(getDenominator('3/2'))')")));
  assertTrue(5 == (getEvaluator().getNumberResult("getDenominator('4/(getDenominator('3/[pos=5]'))')")));
}
@Test(expected=InvalidEvaluatorFunctionArgumentException.class)
public void testGetDenominatorWithWrongInputPointNumber(){
  getEvaluator().getNumberResult("getDenominator('7.2')");
}
 
@Test(expected=InvalidEvaluatorFunctionArgumentException.class)
public void testGetDenominatorWithWrongInputCharacter(){
  getEvaluator().getNumberResult("getDenominator('a/3.3')");
}
@Test(expected=UnsupportedEvaluatorFunctionException.class)
public void testGetDenominatorWithTwoArguments(){
  getEvaluator().getNumberResult("getDenominator('7/3', '12/2')");
}


@Test(expected=UnsupportedEvaluatorFunctionException.class)
==== Benutzung mit Variablen ====
public void testGetDenominatorWithThreeArguments(){
getDenominator([var=a])
  getEvaluator().getNumberResult("getDenominator('1/1', '3/9', '7/8')");
}


@Test(expected=UndefinedExerciseVariableException.class)
==== Benutzung mit studentischen Eingaben ====
public void testGetDenominatorWithMissingExerciseVariable(){
'''Jack2:'''
  getEvaluator().getNumberResult("getDenominator('[var=j]/3')");
getDenominator([pos=1])
}


@Test(expected=UndefinedFillInVariableException.class)
'''Jack3:'''
public void testGetDenominatorWithMissingInput(){
getDenominator([input=fillin1])
  getEvaluator().getNumberResult("getDenominator('[pos=42]/3')");
}
</syntaxhighlight>


=== Hinweise ===
=== Hinweise ===
* Es finden hier keine mathematischen Berechnungen oder Überprüfungen statt. Solange diese Methode einen Bruch als Parameter übergeben bekommt wird auch der Nenner zurückgegeben, auch wenn der Nenner mathematisch nicht sinnvoll ist(vgl. Beispiele).
* Die Funktion braucht einen Bruch als Eingabe, z.B. kann sie nicht 1 zurückgeben wenn man 7 eingibt.
* Es macht Sinn <code>getDenominator</code> in Verbindung mit <code>[[isFraction]]</code> zu nutzen, z.B. <code>isFraction([input=field1]) && getDenominator([input=field1])==5</code>.
* Wenn Variablen genutzt werden muss darauf geachtet werden, dass diese die Voraussetzung erfüllen.
* Wenn die Eingabe der Studierenden genutzt wird muss auch hier darauf geachtet werden, dass die Voraussetzungen erfüllt sind und ob diese an der Stelle genutzt werden können.


[[Kategorie:Evaluatorfunktion]]
[[Kategorie:Math-Evaluatorfunktion]][[Kategorie:JACK2]][[Kategorie:JACK3]]

Aktuelle Version vom 17. April 2024, 08:45 Uhr

Zugehörige Evaluatoren

  • MathEvaluator

Beschreibung

Mit der Funktion getDenominator erhält man den Nenner eines Bruches. Die Funktion erwartet ein Objekt, bei dem es sich um einen Bruch handeln muss, und gibt ein Objekt zurück.

Syntax

getDenominator(Bruch bruch)

Parameter

  • bruch - der Bruch, dessen Nenner bestimmt werden soll

Return Value

Beispiele

Standardfälle

getDenominator(3/5)   --> returns 5

getDenominator((5+3)/list(1,2))   --> returns {1,2}

Benutzung mit Variablen

getDenominator([var=a])

Benutzung mit studentischen Eingaben

Jack2:
getDenominator([pos=1])
Jack3:
getDenominator([input=fillin1])

Hinweise

  • Es finden hier keine mathematischen Berechnungen oder Überprüfungen statt. Solange diese Methode einen Bruch als Parameter übergeben bekommt wird auch der Nenner zurückgegeben, auch wenn der Nenner mathematisch nicht sinnvoll ist(vgl. Beispiele).
  • Die Funktion braucht einen Bruch als Eingabe, z.B. kann sie nicht 1 zurückgeben wenn man 7 eingibt.
  • Es macht Sinn getDenominator in Verbindung mit isFraction zu nutzen, z.B. isFraction([input=field1]) && getDenominator([input=field1])==5.
  • Wenn Variablen genutzt werden muss darauf geachtet werden, dass diese die Voraussetzung erfüllen.
  • Wenn die Eingabe der Studierenden genutzt wird muss auch hier darauf geachtet werden, dass die Voraussetzungen erfüllt sind und ob diese an der Stelle genutzt werden können.