Docs Menu
Docs Home
/ /
Operadores de tuberías de agregación

$sin (agregación)

$sin

Devuelve el seno de un valor que se mide en radianes.

$sin tiene la siguiente sintaxis:

{ $sin: <expression> }

$sin toma cualquier válido Expresión que se resuelve en un número. Si la expresión devuelve un valor en grados, utilice el operador para convertir el resultado a $degreesToRadians radianes.

De forma predeterminada, devuelve $sin valores double como. también puede$sin 128devolver valores como un decimal de bits siempre que se <expression> resuelva en un 128valor decimal de 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, $sin nulldevuelve. Si se resuelve NaN en, $sin NaNdevuelve. Si se resuelve en infinito negativo o positivo, genera un$sin error.

Ejemplo
Resultados

{ $sin: NaN }

NaN

{ $sin: null }

null

{ $sin : Infinity}

or

{ $sin : -Infinity }

Lanza un mensaje de error similar a la siguiente salida formateada:

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

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("53.13010235415597870314438744090659"),
"hypotenuse" : Decimal128("5")
}

La siguiente operación de agregación utiliza la expresión para calcular el lado opuesto $sin a angle_a y agregarlo al documento de entrada utilizando la etapa de canalización.$addFields

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

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

El comando devuelve la siguiente salida:

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

Dado angle_a que y hypotenuse se almacenan como 128decimales de bits, la salida de es $sin un 128decimal de bits.

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"),
"hypotenuse" : Decimal128("5")
}

La siguiente operación de agregación utiliza la expresión para calcular el lado opuesto $sin a angle_a y agregarlo al documento de entrada utilizando la etapa de canalización.$addFields

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

El comando devuelve la siguiente salida:

{
"_id" : ObjectId("5c50782193f833234ba90d85"),
"angle_a" : Decimal128("0.9272952180016122324285124629224288"),
"side_b" : Decimal128("4.000000000000000000000000000000000"),
"hypotenuse" : Decimal128("5"),
}

Dado angle_a que y hypotenuse se almacenan como 128decimales de bits, la salida de es $sin un 128decimal de bits.

Volver

$size

En esta página