Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs Menu
Docs Home
/ /

$tan (operador de expresión)

$tan

Devuelve la tangente de un valor medido en radianes.

$tan tiene la siguiente sintaxis:

{ $tan: <expression> }

$tan takes any valid expresión que resuelve un número. Si la expresión retorna un valor en grados, utiliza el operador $degreesToRadians para convertir el resultado a radianes.

Por defecto, $tan devuelve valores como un double. $tan también puede devolver valores como un decimal de128-bits, siempre y cuando el <expression> se resuelva en un valor decimal de 128-bits.

Para obtener más información sobre las expresiones, consulta Expresiones.

Si el argumento se resuelve en un valor de null o hace referencia a un campo que falta, $tan devuelve null. Si el argumento se resuelve en NaN, $tan devuelve NaN. Si el argumento se resuelve en infinito negativo o positivo, $tan arroja un error.

Ejemplo
Resultados

{ $tan: NaN }

NaN

{ $tan: null }

null

{ $tan : Infinity}

or

{ $tan : -Infinity }

Genera un mensaje de error que se asemeja al siguiente resultado formateado:

"errmsg" :
"Failed to optimize pipeline :: caused by :: cannot
apply $tan to -inf, value must in (-inf,inf)"

La colección trigonometry contiene un documento que almacena un lado y un ángulo en un triángulo rectángulo:

{
"_id" : ObjectId("5c50782193f833234ba90d85"),
"angle_a" : Decimal128("53.13010235415597870314438744090659"),
"side_a" : Decimal128("3")
}

La siguiente operación de agregación utiliza la expresión $tan para calcular el lado opuesto a angle_a y añadirlo al documento de entrada usando la etapa de pipeline $addFields.

db.trigonometry.aggregate([
{
$addFields : {
"side_b" : {
$multiply : [
{ $tan : {$degreesToRadians : "$angle_a"} },
"$side_a"
]
}
}
}
])

La expresión $degreesToRadians convierte el valor en grados de angle_a al valor equivalente en radianes.

El comando devuelve la siguiente salida:

{
"_id" : ObjectId("5c50782193f833234ba90d85"),
"angle_a" : Decimal128("53.13010235415597870314438744090659"),
"side_a" : Decimal128("3")
"side_b" : Decimal128("4.000000000000000000000000000000000")
}

Dado que angle_a y side_a se almacenan como decimales de128bits, la salida de $tan es un decimal de 128bits.

La colección trigonometry contiene un documento que almacena la hipotenusa y un ángulo en un triángulo rectángulo:

{
"_id" : ObjectId("5c50782193f833234ba90d85"),
"angle_a" : Decimal128("0.9272952180016122324285124629224288"),
"side_a" : Decimal128("3")
}

La siguiente operación de agregación utiliza la expresión $tan para calcular el lado adyacente a angle_a y añadirlo al documento de entrada usando la etapa de pipeline $addFields.

db.trigonometry.aggregate([
{
$addFields : {
"side_b" : {
$multiply : [
{ $tan : "$angle_a" },
"$side_a"
]
}
}
}
])

El comando devuelve la siguiente salida:

{
"_id" : ObjectId("5c50782193f833234ba90d85"),
"angle_a" : Decimal128("0.9272952180016122324285124629224288"),
"side_a" : Decimal128("3")
"side_b" : Decimal128("3.999999999999999999999999999999999")
}

Dado que angle_a y side_a se almacenan como decimales de128bits, la salida de $tan es un decimal de 128bits.

Volver

$switch

En esta página