$tanh以弧度为单位返回数值的双曲正切值。
$tanh通过以下语法实现:{ $tanh: <expression> } $tanh接受解析为数字(以弧度为单位)的任何有效表达式。 如果表达式返回以度为单位的值,请使用$degreesToRadians操作符将该值转换为弧度。默认情况下,
$tanh以double形式返回值。 如果<expression>解析为128位十进制值,$tanh还可以返回128位十进制值。有关表达式的更多信息,请参阅表达式。
行为
null、NaN 和+/- Infinity
如果输入参数解析为null值或引用了缺失的字段,则$tanh返回null 。 如果参数解析为NaN ,则$tanh返回NaN 。 如果参数解析为负数或正数Infinity ,则$tanh分别返回-1或1 。
例子 | 结果 |
|---|---|
|
|
|
|
|
|
|
|
例子
trigonometry以下collection包含一个文档,其中存储了一个以度数为单位的angle 值:
db.trigonometry.insertOne( { "_id" : ObjectId( "5c50782193f833234ba90d45" ), "angle" : Decimal128( "53.1301023541559787031443874490659" ) } )
以下聚合操作使用$tanh表达式计算angle的双曲正切,并使用$addFields管道阶段将其添加到输入文档:
db.trigonometry.aggregate( [ { $addFields : { "tanh_output" : { $tanh : { $degreesToRadians : "$angle" } } } } ] )
$degreesToRadians表达式将以度为单位的angle转换为弧度。
示例输出:
{ "_id" : ObjectId("5c50782193f833234ba90d45"), "angle" : Decimal128("53.1301023541559787031443874490659"), "tanh_output" : Decimal128("0.7293303448445332820512777329448416") }
以下trigonometry集合包含一个文档,其中存储了以弧度为单位的angle值:
db.trigonometry.insertOne( { "_id" : ObjectId( "5c50782193f833234ba90d55" ), "angle" : Decimal128( "1.6301023541559787031443874490659" ) } )
以下聚合操作使用$tanh表达式计算angle的双曲正切,并使用$addFields管道阶段将其添加到输入文档:
db.trigonometry.aggregate( [ { $addFields : { "tanh_output" : { $tanh : "$angle" } } } ] )
示例输出:
{ "_id" : ObjectId("5c50782193f833234ba90d55"), "angle" : Decimal128("1.6301023541559787031443874490659"), "tanh_output" : Decimal128("0.9260761562750713360156803177935379") }