www.vorhilfe.de
Vorhilfe

Kostenlose Kommunikationsplattform für gegenseitige Hilfestellungen.
Hallo Gast!einloggen | registrieren ]
Startseite · Forum · Wissen · Kurse · Mitglieder · Team · Impressum
Forenbaum
^ Forenbaum
Status Vorhilfe
  Status Geisteswiss.
    Status Erdkunde
    Status Geschichte
    Status Jura
    Status Musik/Kunst
    Status Pädagogik
    Status Philosophie
    Status Politik/Wirtschaft
    Status Psychologie
    Status Religion
    Status Sozialwissenschaften
  Status Informatik
    Status Schule
    Status Hochschule
    Status Info-Training
    Status Wettbewerbe
    Status Praxis
    Status Internes IR
  Status Ingenieurwiss.
    Status Bauingenieurwesen
    Status Elektrotechnik
    Status Maschinenbau
    Status Materialwissenschaft
    Status Regelungstechnik
    Status Signaltheorie
    Status Sonstiges
    Status Technik
  Status Mathe
    Status Schulmathe
    Status Hochschulmathe
    Status Mathe-Vorkurse
    Status Mathe-Software
  Status Naturwiss.
    Status Astronomie
    Status Biologie
    Status Chemie
    Status Geowissenschaften
    Status Medizin
    Status Physik
    Status Sport
  Status Sonstiges / Diverses
  Status Sprachen
    Status Deutsch
    Status Englisch
    Status Französisch
    Status Griechisch
    Status Latein
    Status Russisch
    Status Spanisch
    Status Vorkurse
    Status Sonstiges (Sprachen)
  Status Neuerdings
  Status Internes VH
    Status Café VH
    Status Verbesserungen
    Status Benutzerbetreuung
    Status Plenum
    Status Datenbank-Forum
    Status Test-Forum
    Status Fragwürdige Inhalte
    Status VH e.V.

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
Dt. Schulen im Ausland: Mathe-Seiten:

Open Source FunktionenplotterFunkyPlot: Kostenloser und quelloffener Funktionenplotter für Linux und andere Betriebssysteme
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.vorhilfe.de