Acos: Unterschied zwischen den Versionen

Aus JACK Wiki
Zur Navigation springen Zur Suche springen
 
(19 dazwischenliegende Versionen von 4 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
===Zugehörige Evaluatoren===
*'''MathEvaluator'''
===Beschreibung===
===Beschreibung===
Der Arkuskosinus wird durch die Funktion ''acos'' beschrieben. Sie erwartet einen Parameter und gibt den Wert an der Stelle zurück.
Der Arkuskosinus wird durch die Funktion ''acos'' beschrieben. Sie erwartet einen Parameter und gibt den Wert an der Stelle zurück.


===Syntax===
===Syntax===
  acos(String zahl)
  acos([[Gleitkommazahl]] zahl)


===Parameter===
===Parameter===
* '''zahl''' - Ein Zahlenwert zwischen '-1' und '1'.
* '''zahl''' - Ein Zahlenwert zwischen \(-1\) und \(1\).


===Return Value===
===Return Value===
Zeile 12: Zeile 15:


===Beispiele===
===Beispiele===
acos('1')    --> returns 0
==== Standardfälle ====
 
acos(1)   --> returns 0
====JUnit Tests====
acos(0)   --> returns \( \frac{1}{2} \cdot \pi \)
<span class="mw-customtoggle-myDivision">[Anzeigen]</span>
<syntaxhighlight lang="java" class="mw-collapsible mw-collapsed" id="mw-customcollapsible-myDivision">
private double PI = Math.PI;
 
@Test
public void testAcos1() {
assertEquals(0, Evaluator.getNumberResult("acos('1')", exerciseVariableMap, fillInVariableMap), 0.0);
}
 
@Test
public void testAcos2() {
assertEquals(PI, Evaluator.getNumberResult("acos('-1')", exerciseVariableMap, fillInVariableMap), 0.0);
}
 
@Test
public void testAcos3() {
assertEquals(PI / 2, Evaluator.getNumberResult("acos('0')", exerciseVariableMap, fillInVariableMap), 0.000001);
}
 
@Test
public void testAcos4() {
assertEquals(PI / 2, Evaluator.getNumberResult("acos('0')", exerciseVariableMap, fillInVariableMap), 0.000001);
}
 
@Test
public void testAcos5() {
assertEquals(0.795398830184144, Evaluator.getNumberResult("acos(0.7)", exerciseVariableMap, fillInVariableMap),
0.0);
}
 
@Test
public void testAcosWithInput1() {
assertEquals(PI / 2, Evaluator.getNumberResult("acos([pos=1])", exerciseVariableMap, fillInVariableMap),
0.0001);
}
 
@Test
public void testAcosWithInput2() {
assertEquals(0, Evaluator.getNumberResult("acos([pos=2])", exerciseVariableMap, fillInVariableMap), 0.0);
}
 
@Test
public void testAcosWithInput3() {
assertEquals(PI, Evaluator.getNumberResult("acos([pos=3])", exerciseVariableMap, fillInVariableMap), 0.0);
}
 
@Test
public void testAcosWithVariables1() {
assertEquals(PI / 2, Evaluator.getNumberResult("acos([var=a])", exerciseVariableMap, fillInVariableMap),
0.000001);
}
 
@Test
public void testAcosWithVariables2() {
assertEquals(0, Evaluator.getNumberResult("acos([var=b])", exerciseVariableMap, fillInVariableMap), 0.0);
}
 
@Test
public void testAcosWithVariables3() {
assertEquals(PI, Evaluator.getNumberResult("acos([var=c])", exerciseVariableMap, fillInVariableMap), 0.0);
}
 
@Test
public void testAcosWithExpressions1() {
assertEquals(0.861722668365136,
Evaluator.getNumberResult("acos(acos(acos(0.7)))", exerciseVariableMap, fillInVariableMap), 0.0);
}
 
@Test
public void testAcosWithExpressions2() {
assertEquals(PI / 2, Evaluator.getNumberResult("acos(acos(1))", exerciseVariableMap, fillInVariableMap), 0.0001);
}


@Test(expected = FunctionInvalidArgumentTypeException.class)
==== Benutzung mit Variablen ====
public void TestAcosWithONECharacter() {
Evaluator.getNumberResult("acos(a)", exerciseVariableMap, fillInVariableMap);
fail();
}


@Test(expected = FunctionInvalidArgumentTypeException.class)
acos([var=a])
public void testAcosWithEmptyStringArgument() {
acos([var=b])
Evaluator.getNumberResult("acos('')", exerciseVariableMap, fillInVariableMap);
fail();
}


@Test(expected = FunctionInvalidNumberOfArgumentsException.class)
==== Benutzung mit studentischen Eingaben ====
public void testAcosWithEmptyArgument() {
Evaluator.getNumberResult("acos()", exerciseVariableMap, fillInVariableMap);
fail();
}


@Test(expected = UndefinedExerciseVariableException.class)
'''Jack2:'''
public void testAcosWithoutExerciseVariable() {
acos([pos=1])
Evaluator.getNumberResult("acos('[var=j]')", exerciseVariableMap, fillInVariableMap);
fail();
}


@Test(expected = UndefinedFillInVariableException.class)
'''Jack3:'''
public void testAcosWithoutInput() {
acos([input=field1])
Evaluator.getNumberResult("acos('[pos=42]')", exerciseVariableMap, fillInVariableMap);
fail();
}
</syntaxhighlight>


===Hinweise===
===Hinweise===
* Diese Funktion wird nicht ausgerechnet, außer es gibt eine genaue Repräsentation (z.B. Pi oder eine Ganzzahl). Soll das Ergebnis gerundet ausgegeben werden, muss eine Rundungsfunktion oder die [[Approx|Approx-Funktion]] genutzt werden.
* 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.
* Wenn die Konstante Pi genutzt werden soll muss [[constPi|constPi()]] verwendet werden.
* Die Funktion [[toDegree|toDegree(x)]] wandelt den Radiant-Werte x in Grad um.
* Die Funktion [[toRadian|toRadian(x)]] wandelt den Grad-Wert x in Radiant um.


[[Kategorie:Evaluatorfunktion]]
[[Kategorie:Math-Evaluatorfunktion]][[category:Trigonometrische Funktionen]][[Kategorie:JACK2]][[Kategorie:JACK3]]

Aktuelle Version vom 17. April 2024, 11:58 Uhr

Zugehörige Evaluatoren

  • MathEvaluator

Beschreibung

Der Arkuskosinus wird durch die Funktion acos beschrieben. Sie erwartet einen Parameter und gibt den Wert an der Stelle zurück.

Syntax

acos(Gleitkommazahl zahl)

Parameter

  • zahl - Ein Zahlenwert zwischen 1 und 1.

Return Value

  • Gibt den Wert des Arkuskosinus an der Stelle zurück.

Beispiele

Standardfälle

acos(1)    --> returns 0
acos(0)    --> returns \( \frac{1}{2} \cdot \pi \)

Benutzung mit Variablen

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

Benutzung mit studentischen Eingaben

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

Hinweise

  • Diese Funktion wird nicht ausgerechnet, außer es gibt eine genaue Repräsentation (z.B. Pi oder eine Ganzzahl). Soll das Ergebnis gerundet ausgegeben werden, muss eine Rundungsfunktion oder die Approx-Funktion genutzt werden.
  • 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.
  • Wenn die Konstante Pi genutzt werden soll muss constPi() verwendet werden.
  • Die Funktion toDegree(x) wandelt den Radiant-Werte x in Grad um.
  • Die Funktion toRadian(x) wandelt den Grad-Wert x in Radiant um.