Arrotonda QUALSIASI numero su / Giù a QUALSIASI intervallo
È possibile arrotondare facilmente i numeri a un intervallo specifico utilizzando l' operatore modulo %%
.
La funzione:
round.choose <- function(x, roundTo, dir = 1) {
if(dir == 1) { ##ROUND UP
x + (roundTo - x %% roundTo)
} else {
if(dir == 0) { ##ROUND DOWN
x - (x %% roundTo)
}
}
}
Esempi:
> round.choose(17,5,1) #round 17 UP to the next 5th
[1] 20
> round.choose(17,5,0) #round 17 DOWN to the next 5th
[1] 15
> round.choose(17,2,1) #round 17 UP to the next even number
[1] 18
> round.choose(17,2,0) #round 17 DOWN to the next even number
[1] 16
Come funziona:
L'operatore modulo %%
determina il resto della divisione del primo numero per il secondo. L'aggiunta o la sottrazione di questo intervallo al numero di interesse può essenzialmente "arrotondare" il numero a un intervallo di tua scelta.
> 7 + (5 - 7 %% 5) #round UP to the nearest 5
[1] 10
> 7 + (10 - 7 %% 10) #round UP to the nearest 10
[1] 10
> 7 + (2 - 7 %% 2) #round UP to the nearest even number
[1] 8
> 7 + (100 - 7 %% 100) #round UP to the nearest 100
[1] 100
> 7 + (4 - 7 %% 4) #round UP to the nearest interval of 4
[1] 8
> 7 + (4.5 - 7 %% 4.5) #round UP to the nearest interval of 4.5
[1] 9
> 7 - (7 %% 5) #round DOWN to the nearest 5
[1] 5
> 7 - (7 %% 10) #round DOWN to the nearest 10
[1] 0
> 7 - (7 %% 2) #round DOWN to the nearest even number
[1] 6
Aggiornare:
La comoda versione a 2 argomenti:
rounder <- function(x,y) {
if(y >= 0) { x + (y - x %% y)}
else { x - (x %% abs(y))}
}
y
Valori positivi roundUp
, mentre y
valori negativi roundDown
:
# rounder(7, -4.5) = 4.5, while rounder(7, 4.5) = 9.
O....
Funzione che arrotonda automaticamente UP o DOWN in base alle regole di arrotondamento standard:
Round <- function(x,y) {
if((y - x %% y) <= x %% y) { x + (y - x %% y)}
else { x - (x %% y)}
}
Arrotonda automaticamente per eccesso se il x
valore è a >
metà tra le istanze successive del valore di arrotondamento y
:
# Round(1.3,1) = 1 while Round(1.6,1) = 2
# Round(1.024,0.05) = 1 while Round(1.03,0.05) = 1.05