Formel für Sonnenwinkel in ein Programm überführen

SHacker

Mitglied
Hallo,
ich möchte nach Jahren mal wieder programmieren
und versuche mich gerade bei einem kleinen Programm,
das den Sonnenwinkel und die Sonnenhöhe berechnen soll.

Ich glaube mein Problem ist eher mathematischer Natur,
aber da die Mathematik ein Teilgebiet der Informatik ist versuche ich es hier einfach mal.

Es könnte aber auch sein, dass ich irgendwo einen Fehler in meinem Code habe, da mein Programmierzeit über 5 Jahre her ist.

Für die Grundlage des Programms habe ich mir einen deutschen Wikipedia Artikel als Grundlage genommen,
weshalb ich auch nach einem deutschen Forum gesucht habe, damit die selbe Basis vorhanden ist.
Da ich erstmal nur die Formel testen wollte, habe ich diese in BlueJ runter geschrieben.

Der Code ist nicht schön und die Parameter sind aktuell als Member-Variablen aufgeführt.

Nun zu dem eigentlichen Problem:
Wenn ich die Formel so ändere, dass die Fallunterscheidung für alpha (Rektaszension) (atan2) umkehre ist als im Wiki Artikel,
bekomme ich für das aufgeführte Beispiel "München" die gleichen Werte.
Gehe ich aber nur einen Tag weiter vom 6.8.2006 zum 7.8.2006,
unterscheidet sich der Sonnenwinkel um die gleiche Uhrzeit sehr stark.

Vielleicht hat ja jemand Lust und Zeit meinen Code mal zu testen und abzugleichen.

Gruß
SHacker

Wiki Artikel:

Java:
/**
 * Beschreiben Sie hier die Klasse sonne2.
 *
 * @author (Ihr Name)
 * @version (eine Versionsnummer oder ein Datum)
 */
public class sonne2
{
    private double Year = 2006;         //Jahr
    private double Month = 8;           //Monat
    private double Day = 6;             //Tag
    private double Hour = 6;            //Stunde
    private double Minute = 0;          //Minute
    private double Second = 0;          //Sekunde
    private double longitude = 11.6;    //Längengrad
    private double latitude = 48.1;     //Breitengrad

    private double B;
    private double D;                   //Tagesbuchteil
    private double JD0;                 //Julianische Tageszahl (0:00 Uhr)
    private double JD;                  //Julianische Tageszahl mit Tagesbuchteilen
    private double n;
    private double L;                   //mittlere ekliptikale Länge der Sonne
    private double g;                   //mittlere Anomalie der ekliptikale Länge der Sonne
    private double c;
    private double Lambda;              //ekliptikale Länge der Sonne
    private double epsilon;             //Ekliptik
    private double alpha;               //Rektaszension
    private double delta;               //Deklination
    private double T0;                 
    private double T;
    private double ThetahG;             //mittlere Sternzeit (Greenwich) in Stunden
    private double ThetaG;              //mittlere Sternzeit (Greenwich) im Gradmaß
    private double Theta;               //mittlere Sternzeit (Berechnungsort) im Gradmaß
    private double tau;                 //Stundenwinkel
    private double a1;
    private double a;                   //Azimuth
    private double h;                   //Höhenwinkel

    /**
     * Konstruktor für Objekte der Klasse sonne2
     */
    public sonne2()
    {

    }

    public void Berechnung()
    {   
        //Berechnungen für die Julianische Tageszahl
        //Fallunterscheidung für Schalttag, Jahresberechnung startet im März
        if (Month < 3) {
            Year -= 1;
            Month += 12;
        }

        B = 2 - Math.floor(Year/100) + Math.floor(Year/400);
        D = (Hour/24) + (Minute/1440) + (Second/86400);
        JD0 = Math.floor(365.25 * (Year + 4716)) + Math.floor(30.6001 * (Month + 1)) + Day + B - 1524.5;
        JD = JD0 + D;
        
        //Sonnenwinkelberechnung
        
        n = JD - 2451545.0;
        L = 280.460 + (0.9856474 * n);
        g = 357.528 + (0.9856003 * n);
        Lambda = (L%360) + (1.915 * Math.sin(Math.toRadians((g%360)))) + (0.01997 * Math.sin(Math.toRadians(2*(g%360))));
        epsilon = 23.439 - (0.0000004 * n);

        alpha = Math.toDegrees(Math.atan(Math.cos(Math.toRadians(epsilon)) * Math.tan(Math.toRadians(Lambda))));
        c = Math.cos(Math.toDegrees(Lambda));

        if(c > 0) {
            alpha +=  180;
        }

        delta = Math.toDegrees(Math.asin(Math.sin(Math.toRadians(epsilon)) * Math.sin(Math.toRadians(Lambda))));

        T0 = (JD0 - 2451545.0) / 36525;
        T = Hour + ((Second + (Minute * 60))/3600);

        ThetahG = 6.697376 + (2400.05134 * T0) + (1.002738 * T);
        ThetaG = (ThetahG%24) * 15;
        Theta = ThetaG + longitude;
        tau = Theta - alpha;

        a1 = (Math.cos(Math.toRadians(tau))   * Math.sin(Math.toRadians(latitude)))
           - (Math.tan(Math.toRadians(delta)) * Math.cos(Math.toRadians(latitude)));

        a = Math.toDegrees(Math.atan(Math.sin(Math.toRadians(tau)) / a1));

        if(a1 < 0) {
            a += 180;
        }

        h = Math.toDegrees(Math.asin((Math.cos(Math.toRadians(delta)) * Math.cos(Math.toRadians(latitude)) * Math.cos(Math.toRadians(tau)))
                                   + (Math.sin(Math.toRadians(delta)) * Math.sin(Math.toRadians(latitude)))));
    }
}
 

CarloMonte

Mitglied
aber da die Mathematik ein Teilgebiet der Informatik ist versuche ich es hier einfach mal
das ist umstritten.

Nun zu dem eigentlichen Problem:
Wenn ich die Formel so ändere, dass die Fallunterscheidung für alpha (Rektaszension) (atan2) umkehre ist als im Wiki Artikel,
bekomme ich für das aufgeführte Beispiel "München" die gleichen Werte.
Gehe ich aber nur einen Tag weiter vom 6.8.2006 zum 7.8.2006,
unterscheidet sich der Sonnenwinkel um die gleiche Uhrzeit sehr stark.
Ich denke, das liegt einfach an double Ungenauigkeiten und Fehlerfortpflanzung. An der Formel scheint erstmal nüx Auffälliges zu sein.
 

M.L.

Top Contributor
Mathematik ein Teilgebiet der Informatik...BlueJ
Die Mathematik liefert (naturgemäss mathematische) Verhaltensweisen und Werkzeuge um die Stromflüsse im Rechner so zu steuern, dass ein menschliches Individuum irgendwelche (primär optische und akustische) (Re)Aktionen desselben mit seinen Sinnen wahrnehmen kann.
BlueJ übernimmt Hintergrundaktivitäten um das Ausführen eines Programms zu erleichtern, z.B. eine Methode aufrufen und deren Ergebnisse ausgeben (andere IDE verlangen hier mehr Java-Anweisungen zwecks selben Resultats). Bei den Datentypen oder den Berechnungen könnte die bereits genannte pauschale Verwendung von "double" (oder Ergebnisauslöschung) das Problem sein.
 

SHacker

Mitglied
Ich habe den Fehler gefunden.

Die Ungenauigkeiten und Fehlerfortpflanzung hatte ich auch im Kopf,
aber die Zwischenwerte, bis auf ein paar,
schienen logisch, da sie sich auch nur wenig Veränderung hatten und sich auch um den richtigen Betrag geändert hatten.

Eine Sache ist mir aber aufgefallen, die Variable c = cos(Lambda) für die Fallunterscheidung wechselte das Vorzeichen.
Wobei Lambda 133° für den 6.8.2006 auf 135° für den 8.8.2006 hatte.
Ich glaubte schon mein Rechner sei defekt (RAM, MacBook 2009).

Komisch waren nur die immer gleichen und reproduzierbaren Ergebnisse.

Die Berechnung des Cosinus muss im Bogenmaß erfolgen:
Alter Code:
c = Math.cos(Math.toDegree(Lambda));
Neuer Code:
c = Math.cos(Math.toRadians(Lambda));

Da war ich wohl etwas zu schnell bei der Autovervollstänigung in BlueJ.
12 Jahre her, dass ich damit gearbeitet habe und mein MacBook etwas zu träge für meine Eingaben.
 

KonradN

Super-Moderator
Mitarbeiter
Ja, so ein Fehler ist schwer zu finden. Daher an der Stelle einfach einmal ein Vorschlag, wie man so Fehler deutlich reduzieren kann:

Unterteile die Methode in mehrere Methoden!

Wenn Du also viele Aufrufe vom Math.cos(Math.toRadians(...)) hast, dann pack das in eine Methode. Dann hast Du nur noch einen Aufruf cos(x) mit x in Degree.
Ebenso bei asin und so.
==> Dann hast Du einfache Methoden, die mit der Einheit arbeiten, die Du nutzen willst.

Das zweite sind Namen - hier würde ich Dir generell empfehlen, aussagekräftige Namen zu nutzen. (Und dabei dann auch auf Gross-/Kleinschreibung achten denn es gibt da gewisse Coding Styleguides, die man einhalten könnte ...)

Das kann generell helfen, die Fehlerwahrscheinlichkeit zu reduzieren.
 

SHacker

Mitglied
Danke für die Hilfe.
Die ganzen Sachen sind mir aus meinem Studium und früheren Beruf bekannt,
bin aber seit Jahren raus (wie es sich nun mal so entwickelt).

Das ganze ist nur eine Teilfunktion, die ich für ein größeres Projekt brauche.
Top/Down-Bottom/Up.
Ging erstmal nur darum eine funktionierende Funktion/Formel für das Problem zu finden und diese zum implementieren.
Jetzt überlege ich mir das Klassendesign und die Unterfunktionen für Datum usw.

Das habe ich früher anders gemacht, mit dem Problem,
dass ich mit dem Designs der Klassen und Methode zu viel Zeit verschwendet habe und zu verkompliziert (over engineering) habe, ohne wirklich mit dem Code weiter zu kommen.
 

CarloMonte

Mitglied
im Artikel steht extra ein Hinweis:

Hinweis: Die Rechnungen sind mit einer ausreichenden Stellenzahl zu führen (z. B. doppelter Genauigkeit, bei achtstelligen Taschenrechnern ist Vorsicht geboten); insbesondere für T 0 {\displaystyle T_{0}} T_{0} müssen ausreichend viele Stellen berücksichtigt werden. Es ist zu beachten, dass manche Rechenprogramme und Programmiersprachen Winkelangaben im Bogenmaß und nicht in Grad erwarten; die Winkel sind dann entsprechend umzurechnen.
 

CarloMonte

Mitglied
Das heißt, um genauere Ergebnisse zu erhalten, könnte man die Verwendung von BigDecimal in betracht ziehen...

PS: Der Sonnenstand kann sich zwischen 24 Stunden auch "enorm" ändern - man darf nicht vergessen, das zwischen Min und Max nur ein halbes Jahr, also ca. 182 Tage liegen....
 

CarloMonte

Mitglied
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Formel Bubble Sort Allgemeine Java-Themen 1
Zrebna Random Number - Generische Formel zwischen zwei INKLUSIVEN Werten Allgemeine Java-Themen 16
X Template Matching (subimage recognition via Formel) vs KNN Allgemeine Java-Themen 36
G Umsetzen einer Formel in Java Allgemeine Java-Themen 10
L SWT Mathematische Formel mit SWT Textfield auswerten? Allgemeine Java-Themen 3
M Excel Formel in Java Allgemeine Java-Themen 7
E Falsche Ergebnisse bei PQ-Formel Berechnung Allgemeine Java-Themen 12
N Applet Apache Poi Wert einer Formel ausgeben Allgemeine Java-Themen 5
A JExcel Formel einlesen Allgemeine Java-Themen 2
Landei Design-Problem Formel-Parser Allgemeine Java-Themen 10
W Formel in Java Allgemeine Java-Themen 9
S reelle Funktionen Formel Allgemeine Java-Themen 13
B Formel Interpreter gesucht Allgemeine Java-Themen 7
M Math-String-Formel berechnen lassen Allgemeine Java-Themen 4
M Formel in einem String während Laufzeit berechnen. Allgemeine Java-Themen 4
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
_user_q Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 61
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
H OOP Setting(config) für Applikation sicheren? Allgemeine Java-Themen 9
OnDemand PDF Libary für Formulare Allgemeine Java-Themen 7
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
M Brainstorming für mein Projekt Allgemeine Java-Themen 30
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1

Ähnliche Java Themen

Neue Themen


Oben