Aritmética Bash
Otra posible solución es agregar una función simple para la aritmética integrada de Bash. Pon esto en tu .bashrc
archivo para probar:
=() {
echo "$(($@))"
}
Así que ahora, ya no necesitas $((...))
más, solo lo =
que parece bastante natural.
Reemplazo
Otra cosa si quieres ser aún más rápido: puedes reemplazarlo p
con +
y x
con *
. Esto funcionará para eso:
=() {
local IFS=' '
local calc="${*//p/+}"
calc="${calc//x/*}"
echo "$(($calc))"
}
= 5 x 5 # Returns 25
= 50p25 # Returns 75
Ahora ya ni siquiera lo necesitas Shift, lo único está =
delante de la aritmética.
Salida hexadecimal
La salida se puede mostrar en decimal y hexadecimal, si así se desea. ( Nota : el uso de la x
sustitución entrará en conflicto con la 0x...
sintaxis hexadecimal)
=() {
local answer="$(($@))"
printf '%d (%#x)\n' "$answer" "$answer"
}
Ejemplo:
$ = 16 + 0x10
272 (0x110)
$ = 16**3 + 16**4
69632 (0x11000)
Utilizando bc
Si desea cálculos un poco más avanzados, puede canalizarlo bc
así:
=() {
local IFS=' '
local calc="${*//p/+}"
calc="${calc//x/*}"
bc -l <<<"scale=10;$calc"
}
= 'sqrt(2)' # Returns 1.4142135623
= '4*a(1)' # Returns pi (3.1415926532)
Las funciones proporcionadas por bc
son las siguientes (y se pueden encontrar en man bc
):
sqrt ( expression )
The value of the sqrt function is the square root of the expression.
If the expression is negative, a run time error is generated.
s (x) The sine of x, x is in radians.
c (x) The cosine of x, x is in radians.
a (x) The arctangent of x, arctangent returns radians.
l (x) The natural logarithm of x.
e (x) The exponential function of raising e to the value x.
j (n,x)
The Bessel function of integer order n of x.
También es compatible con if
, for
, while
y variables como un lenguaje de programación, aunque si puede ser mejor para escribir en un archivo si quería eso.
Tenga en cuenta que sustituirá p
y x
en nombres de funciones / variables. Puede ser mejor simplemente eliminar los reemplazos.
Utilizando gcalccmd
También puede hacer que la función llame gcalccmd
(desde gnome-calculator
) así:
=() {
local IFS=' '
local calc="$*"
# Uncomment the below for (p → +) and (x → *)
#calc="${calc//p/+}"
#calc="${calc//x/*}"
printf '%s\n quit' "$calc" | gcalccmd | sed 's:^> ::g'
}
= 'sqrt(2)' # Returns 1.4142135623
= '4^4' # Returns 256
Las funciones disponibles parecen ser (tomadas directamente del código fuente ), ==
denotan funciones equivalentes:
ln()
sqrt()
abs()
int()
frac()
sin()
cos()
tan()
sin⁻¹() == asin()
cos⁻¹() == acos()
tan⁻¹() == atan()
sinh()
cosh()
tanh()
sinh⁻¹() == asinh()
cosh⁻¹() == acosh()
tanh⁻¹() == atanh()
ones()
twos()