redondear decimas de un float como excel.
hola
tengo un numero real 9,975 mi funcion en delph =9,97 en excel me da= 9,98 osea cuando es 5 lo sube y en delphi lo baja que funcion puedo utilizar en delphi para esto gracias, |
Hola
Esto redondea pero no se si es lo que buscas. Saludos |
Hola.
Agrego otra posibilidad a la expuesta por el amigo Caral.
Saludos. |
Hola
Muy interesante funcion amigo. Creo que deberías de mostrar un ejemplo de su uso, recuerda que no todos sabemos lo mismo y que muchos pueden tener la misma duda. A algunos nos cuesta mas que a otros entender funciones y su comportamiento. No esta de mas el ejemplo amigo. Saludos |
Creo que también puede valer esto:
Si quires redondear a dos decimales: resultado := redondeo(importe,2);
|
Cita:
La función es muy similar a la de Casimiro. La diferencia es que él conocia una función que yo no: IntPower... :o Por lo que usé dos funciones matemáticas estandard para lograrla. Con ellas obtenemos un número que nos sirve para ajustar la cantidad de dígitos con que queremos redondear. Se almacena en la variable local 'm' de la función RedondeaPorExceso. Luego para redondear por exceso debemos sumar 5 en esa posición. Por último la llamada es como cualquier función:
Saludos. |
Hola.
Veo que por hacer las cosas en el aire, cometí un error al escribir la función. Y aunque añade un dígito en la posición deseada, para que este sea 5, debería ser:
Saludos.:) |
Hola
Muy buena explicacion amigo. Ahora hasta yo la puedo entender.:) Saludos |
Hola a todos
Aunque ya está resuelto, solo quiero comentar otra forma de llegar al mismo resultado. Existe la función SetRoundMode en la unidad Math. Esto es lo que pone la ayuda: Cita:
Saludos |
Hay tantas formas de hacer una misma cosa... cada uno tiene su método/código/truco que al final llevan a la solución. Depende de la imaginación (y conocimientos) de cada uno para lograrlo :)
|
muchas gracias a todos,
sus respuestas han sido certera. haber como finalizo este hilo |
Hola a todos/as.
El tema del redondeo me ha preocupado en varias ocasiones. El problema que tengo es cuando aparece un valor como 0.75444448 y lo quieres redondear a 3 decimales. Lo normal en todas las funciones que he visto (incluidas las que he revisado en este hilo) es que, para redondear a 3 decimales, se utilizan 4 decimales y, en este ejemplo (el valor 0.75444448), el redondeo daría 0.754 . Lo que es muy correcto, pero que no aprovecha la totalidad de decimales disponibles. Si se aprovecharan todos los decimales para redondear, el valor final debería dar 0.755 . Todo ello redondeando con:
Como el tema no se resuelve en las funciones de otras personas que he visto, me he animado a hacer una función en la que se indique lo que es normal, el valor decimal y el número de decimales a los cuales hay que redondear; pero añadiendo otro parámetro: el número de decimales desde el que se empieza a redondear de forma decreciente. En el ejemplo, el valor 9.97444756, se redondea a 3 decimales y se empieza a calcular el redondeo desde los 7 decimales (luego se hará con 6, luego con 5, ... hasta que se llegue a 3). He utilizado recursión y es de la primeras veces que lo hago; así que puede haber algún error, aunque las pruebas que hice salieron bien. Este es el código:
Lo incluyo por si esto le es útil a alguien. Saludos. |
Cita:
0.75444448 El 4 en negrita es el número a redondear. El 4 subrayado es el dígito a evaluar con el modo de redondeo. Dependiendo del modo se verá afectado hacia arriba, abajo, trunca, etc. Fuera del modo, todo se resume a 3 posibilidades para ese 4: Se "convierte" en 3, 4 o 5. Así es que se aplica el redondeo. La última cifra significativa de interés al redondeo se ve afectada por la siguiente. Cita:
Cita:
Recuerda volver al modo de redondeo anterior, de otro modo todos tus cálculos se verán afectados (inflados) y el error tras unas cuantas operaciones será mayor del que te esperas. ;) Cita:
De ser así, disculpame pero creo que no es una buena idea, porque de ese modo se está incrementando el error tras cada avance. Todo comienza con un error de 0.5 ulp, después de moverse al nuevo dígito será de un máximo de 0.5 + 10, luego 0.5 + 10 + 100... y así se irá propagando hasta llegar al dígito en cuestión. Esto en términos absolutos. Imagínate que luego a ese resultado debes aplicar la siguiente operación: Valor2 = Valor1 x 10000; Hagamos de cuenta, como dices que debería ser 0.755 y no 0.745. Si hacemos dicha multiplicación se obtiene 7550 y 7450. La diferencia entre ambos es de 100, ahora multiplícalo por 100000... 75500 y 74500, diferencia: 1000. Cuanto más sigas avanzando, más alta será la diferencia, los cálculos se harán más erróneos. No he probado tu código. Pero si hace lo que me temo, creo que no es buen método de redondeo. Saludos, |
Estoy con Delphius, el modo propuesto por el amigo rrf está bien como ejercicio, pero no es práctico ni vale para el "mundo real", ya me imagino las caras de los clientes protestando por esos "redondeos" tan "cuadrados" :)
Creo que la función que he propuesto sí es válida para "la vida real": function Redondeo (valor: Double; decimales: integer = 0): Double; Indicas el valor a "redondear" y el número de decimales al que quieres el redondeo. |
Hola.
Recién leo el hilo nuevamente... Y coincido cien por ciento con Delphius. Un error que por defecto o exceso ajustemos en diezmilésimas, podrían convertirse en centesimas, por ejemplo. Saludos. |
Cita:
Si uno acepta que sus mediciones serán precisas a 4 decimales, por dar un número, entonces sus mediciones no podrán ser mucho más precisas más allá de 5 decimales. Ergo... no tiene sentido continuar buscando más precisión. Por ejemplo: Estoy midiendo la altura de un andamio con un metro convencional (al centímetro)... y justo la marca está entre los 3,20 y 3,21. No tiene sentido práctico que pretenda medir hasta las milésimas si la cinta métrica no tiene esa unidad de medida. ¿Que valor tomo? ¿3,20 o 3,21? Según esta regla, ... no tengo otra elección... o asumo 3,20 ó 3,21. No puedo asegurar si es 3,205 o 3,209, 3,201... o cualquier otro número que esté en el rango [3,20; 3,21] Es por ello que una vez finalizada la medición, se adopta un criterio de redondeo. Y Por más preciso que sean los cálculos el valor exacto podría (y estará) en un margen de +- 0,5 ulp. Hagamos de cuenta que me consigo un metro con escala al milímetro... llego a que mide 3,203. El valor más preciso y exacto estará en el rango [3,2025; 3,2035]. Cita:
Creo que mis explicaciones se ilustrará mejor con una regla: Código:
+|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||+ Código:
+-|-|-|-|-+-|-|-|-|-+-|-|-|-|-+-|-|-|-|-+-|-|-|-|-+-|-|-|-|-+ Código:
+---------+---------+---------+---------+---------+---------+ Código:
+-------------------+-------------------+-------------------+ Quizá para ciertos números el algoritmo que implementado rrf no provoque demasiada perturbaciones, pero en lo general no es óptimo. Pruébese con decimales como: ,1919191919... o ,91919191... o incluso com estos: ,454545... y ,54545454... ;) Creo que con ello queda más que evidente el porqué es inútil asumir decimales y redondeos más allá de lo que estamos dispuestos a tolerar. Saludos, |
Ha... por cierto, recomiendo que se de una revisión a la unidad Math... Hay una buena cantidad de funciones, para lo que se ha estado debatiendo y viene al caso están las funciones: Round, RoundTo, SimpleRoundTo, además de Ceil y Floor y la posibilidad de indicar el modo de redondeo.
Amigo Casi, tu función me recuerda mucho a SimpleRoundTo.;)
Por último, no olvidarse que en el mundo de la aritmética flotante no existe exactitud absoluta ;). Por más exactamente redondeadas que sean las implementaciones de las operaciones soportadas por el estándar IEEE 754 estamos sujetos a ciertas imprecisiones y limitaciones. Saludos, |
Hola de nuevo.
Oye Delphius, gracias por tu explicación. No he hecho pruebas, pero parece que tienes razón y además, las demás opiniones te apoyan. Cambiando de tema, creo que tienes habilidades para dedicarte a la docencia (y va en serio). Ahora sí, amplío la información sobre esa función. He trabajado con el cálculo de % de una serie de valores. Redondeo a 2 decimales, pero es frecuente que la suma de los resultados finales sea un 100,01%, 100,02%, 99,99% ó 99,98%. Lo que me parece un error "demasiado grande". Pero, por más que hice pruebas, no logré mejorar mucho los resultados. Finalmente me quedó la idea de que posiblemente si hacía un redondeo como el que propuse en mi comentario anterior, la situación mejoraría. No llegué a hacer la función hasta que leí este hilo en el foro. "Sobre la marcha", hice las pruebas y añadí el comentario. En la práctica, no lo probé mas que con un par de ejemplos. Sin embargo, después de leer tu comentario Delphius y el de Casimiro y Ecfisa, creo ver que seguramente es un planteamiento equivocado. Gracias por las aclaraciones y salu2. |
Cita:
Si aplica un redondeo razonable para ciertos números es una casualidad, pero en lo general... lo siento pero no eso no vale. Si me apoyan es que les he dado una coima :D jajaja. No es que me apoyen ciegamente, ellos seguramente saben mucho más de lo que puedo saber yo... además ellos ya venían probando y proponiendo. Nomás es que yo me animé a darle un pequeño giro al asunto. Cita:
Hechando a perder dicen que se aprende... el asunto es que si enseño estaré hechando a perder a algunos jóvenes y futuros profesionales. Debo reconocer que todavía me lo pregunto si vale la pena y me encantaría... el asunto es si los aguanto (y ellos a mí, que es lo principal). Cita:
El formato IEEE 754 impone cierto formato y los números deben adaptarse a éste. Por empezar hay un límite de dígitos significativos a almacenar en los tipo Simple, Double y Extended. Esto hace que los números no pueden ser más precisos de esa cantidad de dígitos. En segundo lugar no todos los números son exactamente representables en el formato por lo que la máquina en realidad almacena un número aproximado (como por ejemplo, 0.1). Y peor aún en los números irracionales... como Pi, la constante de euler... donde los efectos son más notables: no sólo se ven limitados por la precisión sino que no son representables. Otros números que tienen problemas son los números periódicos... 1/3 es 0,333333.... Y por último, el estándar IEEE 754 establece que las operaciones sean redondeadas. En síntesis, son muchas cosas que afectan y por ello nunca se conseguirá una total exactitud. Es por ello que cuando se trata de operaciones con números flotantes se estila trabajar con márgenes de error. No quisiera extenderme demasiado, busca entre los foros "Lo que todo informático debe saber sobre aritmética flotante". He hablado antes al respecto. O mejor aún te hago llegar el enlace a material de consulta. Creo que con ello tienes para darte una mejor idea del tema. Cita:
Cita:
No tienes que agradecerme. Aquí se aprende todos los días, y te lo digo yo que me falta mucho por aprender :). No te creas que se mucho de mucho, nomás es que hago un esfuerzo para aparentar que se mucho:p Saludos, |
Cita:
:eek::eek::eek: hasta el nombre de las variables se parecen, esa función la hicimos entre mi compañero y yo, un día en la que estábamos desesperados con los redondeos y dijimos "de hoy no pasa, hacemos una función que redondee de verdad". Y nos salió esa que he puesto. Seguramente los de delphi se copiaron de nosotros :D |
La franja horaria es GMT +2. Ahora son las 20:01:09. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi