MongoDB聚合运算符:$cosh

文章目录

$cosh聚合运算符用来计算双曲余弦值,返回指定表达式的双曲余弦值。

语法

js 复制代码
{ $cosh: <expression> }
  • <expression>为可被解析为数值的表达式
  • $cosh返回弧度,使用$radiansToDegrees运算符可以把弧度转换为角度
  • $cosh默认返回双精度数double,如果表达式<expression>解析为128-bit decimal则返回同样类型。

使用

如果参数解析为null或引用不存在的字段,则结果返回null;如果参数解析为NaN,返回NaN;如果参数为负无穷或正无穷,则返回正无穷。如果如下表所示:

示例 结果
{ $cosh: NaN } NaN
{ $cosh: null } null
{ $cosh: 正无穷 } 正无穷
{ $cosh: 负无穷 } 正无穷

举例

双曲余弦值角度

trigonometry集合中有下面的文档,包含了以度为单位的角度值:

json 复制代码
db.trigonometry.insertOne(
   {
      "_id" : ObjectId( "5c50782193f833234ba90d85" ),
      "angle" : NumberDecimal( "53.1301023541559787031443874490659" )
   }
)

下面的聚合操作使用$radiansToDegrees运算符将angle转换为度数,使用$cosh表达式计算双曲余弦值,然后,最后使用$addFields管道阶段将其添加到输入文档。

js 复制代码
db.trigonometry.aggregate( [
   {
      $addFields : {
         "cosh_output" : { $cosh : { $degreesToRadians : "$angle" } }
      }
   }
] )

执行的结果为:

json 复制代码
{
   "_id" : ObjectId("5c50782193f833234ba90d85"),
   "angle" : NumberDecimal("53.1301023541559787031443874490659"),
   "cosh_output" : NumberDecimal("1.461642741099671277595921778079396")
}

双曲余弦值弧度

trigonometry集合中有下面的文档,包含了以弧度为单位的角度值:

json 复制代码
db.trigonometry.insertOne(
   {
      "_id" : ObjectId( "5c50782193f833234ba90d15" ),
      "angle" : NumberDecimal( "1.6301023541559787031443874490659" )
   }
)

下面的聚合操作使用$cosh表达式计算angle的双曲余弦,然后使用$addFields管道阶段将其添加到输入文档。

js 复制代码
db.trigonometry.aggregate([
  {
    $addFields : {
      "side_b" : {
        $multiply : [
          { $cosh : "$angle_a" },
          "$hypotenuse"
        ]
      }
    }
  }
])

结果为:

json 复制代码
{
   "_id" : ObjectId("5c50782193f833234ba90d15"),
   "angle" : NumberDecimal("1.6301023541559787031443874490659"),
   "cosh_output" : NumberDecimal("2.650153334504361016712328539738000")
}
相关推荐
2301_813599552 小时前
Go语言怎么做秒杀系统_Go语言秒杀系统实战教程【实用】
jvm·数据库·python
NCIN EXPE6 小时前
redis 使用
数据库·redis·缓存
MongoDB 数据平台6 小时前
为编码代理引入 MongoDB 代理技能和插件
数据库·mongodb
极客on之路6 小时前
mysql explain type 各个字段解释
数据库·mysql
代码雕刻家7 小时前
MySQL与SQL Server的基本指令
数据库·mysql·sqlserver
lThE ANDE7 小时前
开启mysql的binlog日志
数据库·mysql
yejqvow127 小时前
CSS如何控制placeholder文字的颜色_使用--placeholder伪元素
jvm·数据库·python
oLLI PILO7 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库
m0_743623927 小时前
HTML怎么创建多语言切换器_HTML语言选择下拉结构【指南】
jvm·数据库·python