$sin (agregação)
Nesta página
Definição
$sin
Retorna o seno de um valor que é medido em radianos.
$sin
tem a seguinte sintaxe:{ $sin: <expression> } $sin
usa qualquerexpressão válida que resolva para um número. Se a expressão retornar um valor em graus, utilize o operador$degreesToRadians
para converter o resultado para radianos.Por padrão,
$sin
retorna valores comodouble
.$sin
também pode retornar valores como um decimal de 128 bits, desde que o<expression>
resolva para um valor decimal de 128 bits.Para mais informações sobre expressões, consulte Operadores de Expressão.
Comportamento
null
, NaN
e +/- Infinity
Se o argumento for resolvido para um valor de null
ou se referir a um campo ausente, $sin
retornará null
. Se o argumento for resolvido em NaN
, $sin
retornará NaN
. Se o argumento for resolvido para infinito negativo ou positivo, $sin
lançará um erro.
Exemplo | Resultados | |||
---|---|---|---|---|
{ $sin: NaN } | NaN | |||
{ $sin: null } | null | |||
ou
| Lança uma mensagem de erro semelhante à seguinte saída formatada:
|
Exemplo
A collection trigonometry
contém um documento que armazena a hipotenusa e um ângulo em um triângulo retângulo:
{ "_id" : ObjectId("5c50782193f833234ba90d85"), "angle_a" : NumberDecimal("53.13010235415597870314438744090659"), "hypotenuse" : NumberDecimal("5") }
A operação de agregação a seguir usa a expressão $sin
para calcular o lado oposto a angle_a
e adicioná-lo ao documento de entrada usando o estágio do pipeline $addFields
.
db.trigonometry.aggregate([ { $addFields : { "side_b" : { $multiply : [ { $sin : {$degreesToRadians : "$angle_a"} }, "$hypotenuse" ] } } } ])
A expressão $degreesToRadians
converte o valor do grau de angle_a
no valor equivalente em radianos.
O comando retorna a seguinte saída:
{ "_id" : ObjectId("5c50782193f833234ba90d85"), "angle_a" : NumberDecimal("53.13010235415597870314438744090659"), "side_b" : NumberDecimal("4.000000000000000000000000000000000"), "hypotenuse" : NumberDecimal("5"), }
Como angle_a
e hypotenuse
são armazenados como decimais de 128bits, a saída de $sin
é um decimal de 128bits.
A collection trigonometry
contém um documento que armazena a hipotenusa e um ângulo em um triângulo retângulo:
{ "_id" : ObjectId("5c50782193f833234ba90d85"), "angle_a" : NumberDecimal("0.9272952180016122324285124629224288"), "hypotenuse" : NumberDecimal("5") }
A operação de agregação a seguir usa a expressão $sin
para calcular o lado oposto a angle_a
e adicioná-lo ao documento de entrada usando o estágio do pipeline $addFields
.
db.trigonometry.aggregate([ { $addFields : { "side_b" : { $multiply : [ { $sin : "$angle_a" }, "$hypotenuse" ] } } } ])
O comando retorna a seguinte saída:
{ "_id" : ObjectId("5c50782193f833234ba90d85"), "angle_a" : NumberDecimal("0.9272952180016122324285124629224288"), "side_b" : NumberDecimal("4.000000000000000000000000000000000"), "hypotenuse" : NumberDecimal("5"), }
Como angle_a
e hypotenuse
são armazenados como decimais de 128bits, a saída de $sin
é um decimal de 128bits.