MongoDB聚合操作符:$acosh

$acosh操作符返回给定值的反双曲余弦。

语法

js 复制代码
{ $acosh: <expression> }
  • $acosh的可以接受解析为1到正无穷之间数字的表达式,即 1 <= value <= +∞
  • $acosh返回值以弧度为单位,使用$radiansToDegrees操作符可以把输出值由弧度转换为角度。
  • 缺省情况下$acosh范围值为double,如果<expression>的值被解析为128-bit decimal$acosh也会返回128-bit decimal

使用

null、NaN和±∞

如果参数被解析为null或应用不存在的字段,$acosh返回null;如果参数为解析为NaN$acosh返回NaN;如果参数解析为负无穷,即value∉[-1,1]$acosh将抛出错误;如果参数解析为正无穷,$acosh返回正无穷;如果参数解析的结果超出边界值[-1, 正无穷]$acosh抛出错误。

参数举例 返回值
{ $acos: NaN } NaN
{ $acos: null } null
{ $acos : 正无穷} 正无穷
{ $acosh : 0 } 抛出异常: "errmsg" : "Failed to optimize pipeline :: caused by :: cannot apply $acos to -inf, value must in [1,inf]"

举例

以度数为单位的反双曲余弦

trigonometry集合包含一个文档,用于存储二维图形x轴上的数值:

json 复制代码
{
  "_id" : ObjectId("5c50782193f833234ba90d85"),
  "x-coordinate" : NumberDecimal("3")
}

下面的聚合操作使用$acosh表达式计算x-coordinate的反双曲余弦值,并使用$addFields管道阶段将其添加到输入文档。

js 复制代码
db.trigonometry.aggregate([
  {
    $addFields : {
      "y-coordinate" : {
        $radiansToDegrees : { $acosh : "$x-coordinate" }
      }
    }
  }
])

$radiansToDegrees表达式将$acosh返回的弧度值转换为度数。

上面的命令执行后返回下面的结果:

json 复制代码
{
  "_id" : ObjectId("5c50782193f833234ba90d85"),
  "x-coordinate" : NumberDecimal("3"),
  "y-coordinate" : NumberDecimal("100.9979734210524228844295260083432")
}

由于x-coordinate使用128-bit decimal,所以$acosh也输出128-bit decimal

以弧度为单位的反双曲余弦

以上例数据为基础,执行下面的命令:

js 复制代码
db.trigonometry.aggregate([
  {
    $addFields : {
      "y-coordinate" : {
        $acosh : "$x-coordinate"
      }
    }
  }
])

返回结果:

json 复制代码
{
  "_id" : ObjectId("5c50782193f833234ba90d85"),
  "x-coordinate" : NumberDecimal("3"),
  "y-coordinate" : NumberDecimal("1.762747174039086050465218649959585")
}
相关推荐
广州智造30 分钟前
OptiStruct实例:3D实体转子分析
数据库·人工智能·算法·机器学习·数学建模·3d·性能优化
技术宝哥4 小时前
Redis(2):Redis + Lua为什么可以实现原子性
数据库·redis·lua
学地理的小胖砸5 小时前
【Python 操作 MySQL 数据库】
数据库·python·mysql
dddaidai1235 小时前
Redis解析
数据库·redis·缓存
数据库幼崽5 小时前
MySQL 8.0 OCP 1Z0-908 121-130题
数据库·mysql·ocp
Amctwd6 小时前
【SQL】如何在 SQL 中统计结构化字符串的特征频率
数据库·sql
betazhou6 小时前
基于Linux环境实现Oracle goldengate远程抽取MySQL同步数据到MySQL
linux·数据库·mysql·oracle·ogg
lyrhhhhhhhh7 小时前
Spring 框架 JDBC 模板技术详解
java·数据库·spring
喝醉的小喵8 小时前
【mysql】并发 Insert 的死锁问题 第二弹
数据库·后端·mysql·死锁
付出不多8 小时前
Linux——mysql主从复制与读写分离
数据库·mysql