Heim > Backend-Entwicklung > C++ > Hauptteil

Warum erzeugen die C/C-Funktionen „sin()' und „cos()' unerwartete Ergebnisse für bekannte Winkel wie 180 Grad?

Linda Hamilton
Freigeben: 2024-11-24 07:00:13
Original
680 Leute haben es durchsucht

Why are C/C  's `sin()` and `cos()` functions producing unexpected results for known angles like 180 degrees?

Sin- und Cos-Funktionen liefern unerwartete Ergebnisse für bekannte Winkel

Problem:

Bei der Verwendung Bei den cos()- und sin()-Funktionen von C/C mit einem Winkel von 180 Grad weichen die erhaltenen Ergebnisse ab erheblich von den erwarteten Werten abweichen, z. B. sin(0,0547) und cos(0,99). Stattdessen geben diese Funktionen sin(3.5897934739308216e-009) und cos(-1.00000) zurück.

Code in Frage:

double radians = DegreesToRadians(angle);
double cosValue = cos(radians);
double sinValue = sin(radians);
Nach dem Login kopieren

Where DegreesToRadians() Grad umwandelt ins Bogenmaß mit dem Formel:

double DegreesToRadians(double degrees)
{
    return degrees * PI / 180;
}
Nach dem Login kopieren

Erklärung:

Die trigonometrischen Funktionen von C/C (sin(), cos(), tan() usw.) erfordern ihre Eingabe im Bogenmaß statt in Grad. Die im Code bereitgestellte Funktion DegreesToRadians() bietet eine ungefähre Umrechnung von Grad in Bogenmaß unter Verwendung von PI als Konstante. Näherungen führen jedoch zu Rundungsfehlern, und die Verwendung von M_PI stimmt möglicherweise nicht genau mit dem mathematischen Wert von π überein.

Darüber hinaus kann die direkte Übergabe des konvertierten Bogenmaßes an die Funktionen sin() und cos() diese noch verstärken Fehler, die für bestimmte Winkel zu falschen Ergebnissen führen.

Lösung:

Um dieses Problem zu beheben Problem: Die Winkelreduktion in Grad kann vor dem Aufruf der trigonometrischen Funktionen durchgeführt werden. Diese Technik reduziert den Winkel auf einen Bereich zwischen -45° und 45° und behebt so Rundungsfehler. Betrachten Sie beispielsweise die folgende Funktion sind():

double sind(double x) {
  if (!isfinite(x)) {
    return sin(x);
  }
  if (x < 0.0) {
    return -sind(-x);
  }
  int quo;
  double x90 = remquo(fabs(x), 90.0, &amp;quo);
  switch (quo % 4) {
    case 0:
      // Use * 1.0 to avoid -0.0
      return sin(d2r(x90)* 1.0);
    case 1:
      return cos(d2r(x90));
    case 2:
      return sin(d2r(-x90) * 1.0);
    case 3:
      return -cos(d2r(x90));
  }
  return 0.0;
}
Nach dem Login kopieren

Diese Funktion kapselt die Winkelreduzierungslogik und sorgt für genauere Ergebnisse für verschiedene Winkel, einschließlich 180 Grad.

Das obige ist der detaillierte Inhalt vonWarum erzeugen die C/C-Funktionen „sin()' und „cos()' unerwartete Ergebnisse für bekannte Winkel wie 180 Grad?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage