Ceil: Unterschied zwischen den Versionen

Aus JACK Wiki
Zur Navigation springen Zur Suche springen
KKeine Bearbeitungszusammenfassung
 
(12 dazwischenliegende Versionen von 5 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
===Zugehörige Evaluatoren===
*'''MathEvaluator'''
=== Beschreibung ===
=== Beschreibung ===


Zeile 14: Zeile 17:
=== Beispiele ===
=== Beispiele ===
==== Standardfälle ====
==== Standardfälle ====
  ceil('7.3')  --> returns 8
  ceil(7.3)  --> returns 8
  ceil('-2.4')  --> returns -2
 
  ceil(-2.4)  --> returns -2
==== Benutzung von Variablen ====
ceil('[pos=1]')
ceil('[var=a]')
 
====JUnit Tests====
<span class="mw-customtoggle-myDivision">[Anzeigen]</span>
<syntaxhighlight lang="java" class="mw-collapsible mw-collapsed" id="mw-customcollapsible-myDivision">
@BeforeClass
public static void beforeTest() {
OMOBJ fourFive = new OMOBJ();
fourFive.setOMF(OMCreator.createOMF(4.5));
 
fillIn.put(1, fourFive);
 
exerVar.put("a", fourFive);
}
 
@Test
public void testCeil1() {
assertEquals(1, Evaluator.getNumberResult("ceil('0.5')", exerVar, fillIn), 0);
}
 
@Test
public void testCeil2() {
assertEquals(-3, Evaluator.getNumberResult("ceil(-3.000001)", exerVar, fillIn), 0);
}
 
@Test
public void testCeil3() {
assertEquals(1, Evaluator.getNumberResult("ceil(1)", exerVar, fillIn), 0);
}
 
@Test
public void testCeil4() {
assertEquals(0, Evaluator.getNumberResult("ceil(0)", exerVar, fillIn), 0);
}
 
@Test
public void testCeilWithInput1() {
assertEquals(1, Evaluator.getNumberResult("ceil('0.5')", exerVar, fillIn), 0);
}
 
@Test
public void testCeilWithInput2() {
assertEquals(5, Evaluator.getNumberResult("ceil('[pos=1]')", exerVar, fillIn), 0);
}
 
@Test
public void testCeilWithVariables1() {
assertEquals(1, Evaluator.getNumberResult("ceil('0.5')", exerVar, fillIn), 0);
}
 
@Test
public void testCeilWithVariables2() {
assertEquals(5, Evaluator.getNumberResult("ceil('[var=a]')", exerVar, fillIn), 0);
}
 
@Test
public void testCeilWithExpressions1() {
assertEquals(-2, Evaluator.getNumberResult("ceil(ceil(-2.2))", exerVar, fillIn), 0);
 
}
 
@Test
public void testCeilWithExpressions2() {
assertEquals(2, Evaluator.getNumberResult("ceil(ceil(ceil(1.11)))", exerVar, fillIn), 0);
}
 
@Test(expected = FunctionInvalidArgumentTypeException.class) // (expected=InvalidEvaluatorFunctionArgumentException.class)
public void testCeilWithWrongInputCharacter() {
Evaluator.getNumberResult("ceil(a)", exerVar, fillIn);
}


@Test(expected = FunctionInvalidNumberOfArgumentsException.class)
==== Benutzung mit Variablen ====
public void testCeilWithTwoArguments() {
Evaluator.getNumberResult("ceil(2.2, 3.3)", exerVar, fillIn);
}


@Test(expected = FunctionInvalidNumberOfArgumentsException.class)
ceil([var=a])
public void testCeilWithThreeArguments() {
ceil([var=b])
Evaluator.getNumberResult("ceil(2.2, 3.3, -1.1)", exerVar, fillIn);
}


@Test(expected = UndefinedExerciseVariableException.class)
==== Benutzung mit studentischen Eingaben ====
public void testCeilWithMissingExcerciseVariable() {
'''Jack2:'''
Evaluator.getNumberResult("ceil('[var=j]')", exerVar, fillIn);
ceil([pos=1])
}


@Test(expected = UndefinedFillInVariableException.class)
'''Jack3:'''
public void testCeilWithMissingInput() {
ceil([input=field1])
Evaluator.getNumberResult("ceil('[pos=42]')", exerVar, fillIn);
}
</syntaxhighlight >


=== Hinweise ===
=== Hinweise ===
* Weitere Funktionen zum Thema runden sind [[floor]], [[rint]] und [[round]].
* 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:Operator]][[Kategorie:JACK2]][[Kategorie:JACK3]]

Aktuelle Version vom 15. April 2024, 12:31 Uhr

Zugehörige Evaluatoren

  • MathEvaluator

Beschreibung

Die Funktion ceil rundet eine rationale Zahl auf die nächstgrößere ganze Zahl auf. Die Funktion erwartet eine Zahl als Parameter und gibt eine Zahl zurück.

Syntax

ceil(Gleitkommazahl zahl)

Parameter

  • zahl - eine aufzurundende rationale Zahl

Return Value

  • Gibt eine Ganzzahl zurück

Beispiele

Standardfälle

ceil(7.3)   --> returns 8

ceil(-2.4)   --> returns -2

Benutzung mit Variablen

ceil([var=a])
ceil([var=b])

Benutzung mit studentischen Eingaben

Jack2:
ceil([pos=1])
Jack3:
ceil([input=field1])

Hinweise

  • Weitere Funktionen zum Thema runden sind floor, rint und round.
  • 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.