www.matheraum.de
Das Matheforum.
Das Matheforum des MatheRaum.

Für Schüler, Studenten, Lehrer, Mathematik-Interessierte.
Hallo Gast!einloggen | registrieren ]
Startseite · Forum · Wissen · Kurse · Mitglieder · Team · Impressum
Forenbaum
^ Forenbaum
Status Mathe
  Status Schulmathe
    Status Primarstufe
    Status Mathe Klassen 5-7
    Status Mathe Klassen 8-10
    Status Oberstufenmathe
    Status Mathe-Wettbewerbe
    Status Sonstiges
  Status Hochschulmathe
    Status Uni-Analysis
    Status Uni-Lin. Algebra
    Status Algebra+Zahlentheo.
    Status Diskrete Mathematik
    Status Fachdidaktik
    Status Finanz+Versicherung
    Status Logik+Mengenlehre
    Status Numerik
    Status Uni-Stochastik
    Status Topologie+Geometrie
    Status Uni-Sonstiges
  Status Mathe-Vorkurse
    Status Organisatorisches
    Status Schule
    Status Universität
  Status Mathe-Software
    Status Derive
    Status DynaGeo
    Status FunkyPlot
    Status GeoGebra
    Status LaTeX
    Status Maple
    Status MathCad
    Status Mathematica
    Status Matlab
    Status Maxima
    Status MuPad
    Status Taschenrechner

Gezeigt werden alle Foren bis zur Tiefe 2

Navigation
 Startseite...
 Neuerdings beta neu
 Forum...
 vorwissen...
 vorkurse...
 Werkzeuge...
 Nachhilfevermittlung beta...
 Online-Spiele beta
 Suchen
 Verein...
 Impressum
Das Projekt
Server und Internetanbindung werden durch Spenden finanziert.
Organisiert wird das Projekt von unserem Koordinatorenteam.
Hunderte Mitglieder helfen ehrenamtlich in unseren moderierten Foren.
Anbieter der Seite ist der gemeinnützige Verein "Vorhilfe.de e.V.".
Partnerseiten
Mathe-Seiten:Weitere Fächer:

Open Source FunktionenplotterFunkyPlot: Kostenloser und quelloffener Funktionenplotter für Linux und andere Betriebssysteme
StartseiteMatheForenJavaAnzahl Additionen usw
Foren für weitere Schulfächer findest Du auf www.vorhilfe.de z.B. Deutsch • Englisch • Französisch • Latein • Spanisch • Russisch • Griechisch
Forum "Java" - Anzahl Additionen usw
Anzahl Additionen usw < Java < Programmiersprachen < Praxis < Informatik < Vorhilfe
Ansicht: [ geschachtelt ] | ^ Forum "Java"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien

Anzahl Additionen usw: Frage (beantwortet)
Status: (Frage) beantwortet Status 
Datum: 17:57 Sa 21.01.2012
Autor: emulb

Aufgabe
Bestimmen Sie die Anzahl der Additionen (ohne die Inkrementoperation der Schleifenvariablen), der Multiplikation und die Anzahl der Vergleichsoperationen folgender Methode zur numerischen Ableitung einer 1-dimensionalen Funktion.

1 public static double[] diff(double[] data) {
  final double[] kernel = new double[] {-0.5, 0.0, 0.5};
  final int      n      =data.length;
  double[]       result = new double[n];
  for (int i=1; i<n-1; i++){
       double tmp =0;
       for (int j=-1; j<=1; j++) {
           tmp+= data[i+j] + kernel[j+1];
       }
       result[i] = tmp;
     }
     return result;
}

Um zählen zu können muss ich erst den Quelltext verstehn, was passiert da?

Ich weiß ist eine blöde Frage aber ich verstehe den Ablauf des Quelltexts nicht.

        
Bezug
Anzahl Additionen usw: Antwort
Status: (Antwort) fertig Status 
Datum: 22:41 Sa 21.01.2012
Autor: chrisno


> 1 public static double[] diff(double[] data) {

es gibt einen Datensatz mit einigen Werten

>    final double[]
> kernel = new double[] {-0.5, 0.0, 0.5};

kernel hat drei Elemente -0,5 0, 0,5

>    final int      n      =data.length;

n ist die Anzahl der Daten

>    double[]       result = new double[n];

>    for (int i=1; i<n-1; i++){

beginne bei i=1, mach das solange i kleiner als n-1 ist und erhöhe bei jedem Schleifendurchlauf i um 1.

>         double tmp =0;

eine temporäre Variable wird 0 gesetzt, weil man öfter mal die gleiche Rechnung mit anderen Werten von vorne beginnt.

>         for (int j=-1; j<=1; j++) {

Wie oben, nun mit j. Hier kann man aber direkt sehen: j ist zuerst -1, dann 0, dann 1 und dann ist die Schleife fertig.

>             tmp+= data[i+j] + kernel[j+1];

Das muss auch so sein, dann mehr Werte gibt es in kernel nicht.
In tmp wird nun addiert: der Datenpunkt mit dem Index i-1, der mit dem Index i und der mit dem Index i+1. Dazu immer noch die Werte des Kernel. Wozu das gut ist, weiß ich nicht.

>         }
>         result[i] = tmp;

Das was in den drei Runden eben aufaddiert wurde, wird nun in das Ergebnis geschrieben.
Dann ist da nächste i dran.

>      }
>      return result;

Nachdem alle Datenpunkte abgearbeitet sind, wird das Gesamtergebnis an den Aufrufer zurückgegeben.

> }


Bezug
                
Bezug
Anzahl Additionen usw: Frage (beantwortet)
Status: (Frage) beantwortet Status 
Datum: 23:33 Sa 21.01.2012
Autor: emulb

Wieso sind wird es 3 mal addiert ich komm nur auf 2 und wo bleibt da die Multiplikation und die Vergleichsoperationen?

Ich komm nur auf zwei, weil i=1; i<n-1: und da gehen doch nur 2 additionsschritte oder hab ich da einen denkfehler?

Bezug
                        
Bezug
Anzahl Additionen usw: Antwort
Status: (Antwort) fertig Status 
Datum: 22:42 So 22.01.2012
Autor: chrisno


> Wieso sind wird es 3 mal addiert ich komm nur auf 2 und wo
> bleibt da die Multiplikation und die
> Vergleichsoperationen?
>  
> Ich komm nur auf zwei, weil i=1; i<n-1: und da gehen doch
> nur 2 additionsschritte oder hab ich da einen denkfehler?

Einen ziemlich dicken Denkfehler. Nimm an, es sind 10 000 Funktionswerte. Dann ist n=10 000, also n-1 = 9 999. Also hast Du 9 999 Durchläufe der äußeren Schleife. Wie viele Additionen in einem Schleifednurchlauf entstehen, dass musst Du selbst nachzählen.

Da Du kein Multiplikatinszeichen gschrieben hast, gibt es auch keine Multiplikationen. Vielleicht änderst Du ja den Code noch. Ich vermute an der gleichen Stelle wie felixf eine Multiplikation, aber Du scheinst es ja nicht so zu sehen.

Oben schreibst Du "i<n-1". Dabei handelt es sich um eine Vergleichsoperation. Die andere Vergleichsoperation befindet sich in der inneren Schleife, der mit "j". Mein Vorschlag:
Zähle mal die Additionen, ... in der inneren Schleife.




Bezug
                
Bezug
Anzahl Additionen usw: Mitteilung
Status: (Mitteilung) Reaktion unnötig Status 
Datum: 17:53 So 22.01.2012
Autor: felixf

Eingabefehler: "{" und "}" müssen immer paarweise auftreten, es wurde aber ein Teil ohne Entsprechung gefunden (siehe rote Markierung)
Eingabefehler: "{" und "}" müssen immer paarweise auftreten, es wurde aber ein Teil ohne Entsprechung gefunden (siehe rote Markierung)
Eingabefehler: "{" und "}" müssen immer paarweise auftreten, es wurde aber ein Teil ohne Entsprechung gefunden (siehe rote Markierung)

Moin!

> > 1 public static double[] diff(double[] data) {
>  es gibt einen Datensatz mit einigen Werten
>  >    final double[]
> > kernel = new double[] {-0.5, 0.0, 0.5};
>  kernel hat drei Elemente -0,5 0, 0,5
>  
> >    final int      n      =data.length;

>  n ist die Anzahl der Daten
>  >    double[]       result = new double[n];
>  
> >    for (int i=1; i<n-1; i++){

>  beginne bei i=1, mach das solange i kleiner als n-1 ist
> und erhöhe bei jedem Schleifendurchlauf i um 1.
>  
> >         double tmp =0;

>  eine temporäre Variable wird 0 gesetzt, weil man öfter
> mal die gleiche Rechnung mit anderen Werten von vorne
> beginnt.
>  >         for (int j=-1; j<=1; j++) {
>  Wie oben, nun mit j. Hier kann man aber direkt sehen: j
> ist zuerst -1, dann 0, dann 1 und dann ist die Schleife
> fertig.
>  >             tmp+= data[i+j] + kernel[j+1];
>  Das muss auch so sein, dann mehr Werte gibt es in kernel
> nicht.
>  In tmp wird nun addiert: der Datenpunkt mit dem Index i-1,
> der mit dem Index i und der mit dem Index i+1. Dazu immer
> noch die Werte des Kernel. Wozu das gut ist, weiß ich
> nicht.

Ich vermute stark, dass data[i+j] und kernel[j+1] multipliziert werden sollten anstelle addiert. Dann wuerde die Funktion naemlich das zurueckliefern, was sie angeblich zurueckliefern soll.

LG Felix


Bezug
                        
Bezug
Anzahl Additionen usw: Mitteilung
Status: (Mitteilung) Reaktion unnötig Status 
Datum: 18:21 So 22.01.2012
Autor: emulb

Danke für die Mitteilung aber das hilft mir gar nicht weiter :/


Bezug
Ansicht: [ geschachtelt ] | ^ Forum "Java"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien


^ Seitenanfang ^
www.matheforum.net
[ Startseite | Forum | Wissen | Kurse | Mitglieder | Team | Impressum ]