AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein C++ Welcher Befehl rundet wie "Round" in Borland C++ ?
Thema durchsuchen
Ansicht
Themen-Optionen

Welcher Befehl rundet wie "Round" in Borland C++ ?

Ein Thema von madina · begonnen am 21. Nov 2010 · letzter Beitrag vom 22. Nov 2010
Antwort Antwort
Seite 3 von 3     123   
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.088 Beiträge
 
Delphi 12 Athens
 
#21

AW: Welcher Befehl rundet wie "Round" in Borland C++ ?

  Alt 22. Nov 2010, 11:18
wie wäre es, wenn du uns mal mitteilst, wie genau gerundet werden soll?
Wurde schon mehrmals beantwortet... genauso runden wie die Delphi Funktion Round() rundet
Nicht ganz: round(8.5) = 8 aber ceil(8.5+0.5) = 9.
Genau und das sagte ich ja schon.

Das Round vom Delphi (also renauer die Recheneinheit des PCs) rundet so wie es die Banken machen.
Code:
Round(0,49) = 0
Round(0,50) = 0 v
Round(0,51) = 1
Round(1,49) = 1
Round(1,50) = 2 ^
Round(1,51) = 2
Round(2,49) = 2
Round(2,50) = 2 v
Round(2,51) = 3
Round(3,49) = 3
Round(3,50) = 4 ^
Round(3,51) = 4
Round(4,49) = 4
Round(4,50) = 4 v
Round(4,51) = 5
Das soll irgendwie gerechter sein, da, wenn man mit einer festen Anzahl an Nachkommastellen arbeitet, sonst mehr auf als abgerundet wird.
Denn es gibt eine ungerade Anzahl an Werten. (ab 0.5 Einer mehr)

mathematisches Runden
abdunden: 0.1 0.2 0.3 0.4
aufrunden: 0.5 0.6 0.7 0.8 0.9
nicht runden: 0.0

dieses Banken-Runden
abdunden: 0.1 0.2 0.3 0.4
im wechsel auf oder ab: 0.5
aufrunden: 0.6 0.7 0.8 0.9
nicht runden: 0.0
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (22. Nov 2010 um 11:23 Uhr)
  Mit Zitat antworten Zitat
Satty67

Registriert seit: 24. Feb 2007
Ort: Baden
1.566 Beiträge
 
Delphi 2007 Professional
 
#22

AW: Welcher Befehl rundet wie "Round" in Borland C++ ?

  Alt 22. Nov 2010, 12:14
Ist mir noch gar nicht aufgefallen (hätte die Werte besser zweimal nacheinander ausgeben lassen). Wie wird gewechselt bzw. wo wird der letzte Wechsel ob auf oder ab gespeichert?

Wäre in dem Fall ja schwer bis gar nicht vorhersagbar, ob ein Round nun gerade auf oder abrundet. Man kann in der C++ DLL ja nicht vorhersehen, wie die Zahl beim nächsten mal von Delphi behandelt wird.

€: Der Wechsel ist wohl auf einen Funktions-Block beschränkt. Neuer Block, immer erst mal aufrunden. Ist aber dann fast einfacher, für Delphi und C++ eine mathematische Version zu verwenden, statt zu versuchen, das in C++ zu raten?

€2: Also runden wie in Delphi nachbauen OK. Runden wie Delphi den gleichen Datenbestand runden wird/würde, schwer bis unmöglich.

Geändert von Satty67 (22. Nov 2010 um 12:31 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.088 Beiträge
 
Delphi 12 Athens
 
#23

AW: Welcher Befehl rundet wie "Round" in Borland C++ ?

  Alt 22. Nov 2010, 13:03
Es ist schon vorhersehbar.

gerade Zahl vor dem Komma > 0.5 abrunden
ungerade Zahl vor dem Komma > 0.5 aufrunden

(also bei den positiven Zahlen ... negative wird es ähnlich sein, hab'sch jetzt aber noch nicht nachgesehn)
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
madina

Registriert seit: 1. Nov 2005
153 Beiträge
 
#24

AW: Welcher Befehl rundet wie "Round" in Borland C++ ?

  Alt 22. Nov 2010, 14:29
Hallo,

wie genau gerundet werden soll?

es sollte auf maximal 2 Vorkomma wie Delphi.Round() in Borland C++ 5.01 gerundet werden.

MFG
mfg
madina
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#25

AW: Welcher Befehl rundet wie "Round" in Borland C++ ?

  Alt 22. Nov 2010, 15:03
es sollte auf maximal 2 Vorkomma wie Delphi.Round() in Borland C++ 5.01 gerundet werden.
Kann es sein, das in dem Satz ein Wort oder so fehlt? So ist er für mich unverständlich. Und was soll das jetzt mit den Vorkomma(stellen)?
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Satty67

Registriert seit: 24. Feb 2007
Ort: Baden
1.566 Beiträge
 
Delphi 2007 Professional
 
#26

AW: Welcher Befehl rundet wie "Round" in Borland C++ ?

  Alt 22. Nov 2010, 15:11
gerade Zahl vor dem Komma > 0.5 abrunden
ungerade Zahl vor dem Komma > 0.5 aufrunden
Das sollte dann ja machbar sein. So ganz banal mit MOD 2 prüfen und dann ensprechen .4 oder .5 addieren und je nach Vorzeichen floor oder ceil oder gleich modf.
  Mit Zitat antworten Zitat
madina

Registriert seit: 1. Nov 2005
153 Beiträge
 
#27

AW: Welcher Befehl rundet wie "Round" in Borland C++ ?

  Alt 22. Nov 2010, 16:49
Hallo,

machen wir's einfach.

1. Wie funktioniert Delphi.Round(); (was steckt dahinter) um dies in BorlandC++.Fkt() umzuschreiben ?

2. Bitte um Beispiele mit Sourcecode

MFG
mfg
madina
  Mit Zitat antworten Zitat
gammatester

Registriert seit: 6. Dez 2005
999 Beiträge
 
#28

AW: Welcher Befehl rundet wie "Round" in Borland C++ ?

  Alt 22. Nov 2010, 17:05
1. Wie funktioniert Delphi.Round(); (was steckt dahinter) um dies in BorlandC++.Fkt() umzuschreiben ?
round rundet zum nächste Integer unter Verwendung des eingestellten Rundungsmodus. Standard-C hat dafür
Code:
int lrint(double x);
Allerdings scheint BorlandC++ genauso wenig Standard, wie Delphi Standard-Pascal ist.
2. Bitte um Beispiele mit Sourcecode
Hier notfalls ein Round-To-Even:
Code:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

long int roundtoeven(double x) {
  double y;
  long l;
  y = 2.0*x;
  if (floor(y)==y) {
    l = (long) y;
    if ((l & 3) == 3) l++;
    l = l >> 1;
  }
  else {
    l = floor(x+0.5);
  }
  return l;
}


int main (void) {
  double x;
  long int l,i;

  for (i=-50;i<=100;i++) {
    x = 0.1*i;
    l = roundtoeven(x);
    printf("%f %d\n", x, l);
  }

  return 0;
}
  Mit Zitat antworten Zitat
madina

Registriert seit: 1. Nov 2005
153 Beiträge
 
#29

AW: Welcher Befehl rundet wie "Round" in Borland C++ ?

  Alt 22. Nov 2010, 19:13
Hallo,

vielen Dank dies ist die Lösung:

roundtoeven(double x);

MFG
mfg
madina
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 3 von 3     123   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:04 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz