MongoDB聚合运算符:$cos

文章目录

    • 语法
    • 使用
    • 举例
      • 余弦值角度
      • 余弦值弧度

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

语法

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

使用

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

示例结果
{ $cos: NaN }NaN
{ $cos: null }null
{ $cos: 正无穷 }报错
{ $cos: 负无穷 }报错

举例

余弦值角度

trigonometry集合中有下面的文档,包含了直角三角形的斜边和一个角:

{"_id" : ObjectId("5c50782193f833234ba90d85"),"angle_a" : NumberDecimal("53.13010235415597870314438744090659"),"hypotenuse" : NumberDecimal("5")
}

下面的聚合操作使用$cos表达式计算与角angle_a相邻的边,然后使用$radiansToDegrees运算符将结果转换为度数,最后使用$addFields管道阶段将其添加到输入文档。

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

执行的结果为:

{"_id" : ObjectId("5c50782193f833234ba90d85"),"angle_a" : NumberDecimal("53.13010235415597870314438744090659"),"side_a" : NumberDecimal("2.999999999999999999999999999999999"),"hypotenuse" : NumberDecimal("5"),
}

余弦值弧度

trigonometry集合中有下面的文档,包含了直角三角形的斜边和一个角:

{"_id" : ObjectId("5c50782193f833234ba90d85"),"angle_a" : NumberDecimal("0.9272952180016122324285124629224288"),"hypotenuse" : NumberDecimal("5")
}

下面的聚合操作使用$cos表达式计算与角angle_a相邻的边,然后使用$addFields管道阶段将其添加到输入文档。

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

结果为:

{"_id" : ObjectId("5c50782193f833234ba90d85"),"angle_a" : NumberDecimal("0.9272952180016122324285124629224288"),"side_b" : NumberDecimal("3.000000000000000000000000000000000"),"hypotenuse" : NumberDecimal("5"),
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/710295.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

现代企业架构框架——应用架构

现代企业架构框架——应用架构。 现代企业架构中的应用架构是指企业在构建和维护应用系统时所采用的一种架构框架。应用架构旨在实现应用系统的可扩展性、灵活性、可维护性和可重用性,以满足企业在数字化时代对应用系统的快速交付和持续创新的需求。下面将详细介绍应用架构的…

文生视频基础1:sora技术报告学习

sora技术报告学习 背景学后理解训练流程技术拆解编码解码扩散模型训练用数据 28号直播交流会后的一些想法自身的一点点想法 参考 原文地址&#xff1a;Video generation models as world simulators 背景 此项目的背景是基于Datawhale的关于sora技术文档的拆解和相关技术讲解…

GEE入门篇|图像处理(二):在Earth Engine中进行波段计算

目录 波段计算 1.NDVI的计算 2.NDVI 归一化差值的单次运算计算 3.使用 NDWI 的归一化差值 波段计算 许多指数可以使用 Earth Engine 中的波段运算来计算。 波段运算是对图像中两个或多个波段进行加、减、乘或除的过程。 在这里&#xff0c;我们将首先手动执行此操作&#x…

mac 终端 任何命令都运行不了了

特殊情况 记录一下 mac 配置是发生错误 导致几乎所有命令都运行不了了 下面解决方案 这可能是由于你的 PATH 没有设置正确&#xff0c;或者 .bash_profile 或 .zshrc 文件中存在语法错误。你可以尝试以下方法来解决这个问题&#xff1a; 打开一个新的终端窗口。 通过输入 /bin…

Redis第6讲——主从复制模式详解

Redis的读写性能很高&#xff0c;但在面对大规模数据和高发访问的挑战时&#xff0c;单节点的Redis可能无法满足需求&#xff0c;这就引出了Redis集群的概念。本节先介绍一下Redis高可用方案之一的主从复制模式&#xff0c;虽说现在基本不会用这种模式&#xff0c;但是无论是哨…

特征值和特征向量及其在机器学习中的应用

特征值和特征向量是线性代数中的概念&#xff0c;用于分析和理解线性变换&#xff0c;特别是由方阵表示的线性变换。它们被用于许多不同的数学领域&#xff0c;包括机器学习和人工智能。 在机器学习中&#xff0c;特征值和特征向量用于表示数据、对数据执行操作以及训练机器学…

掌握电子邮件的未来:深入解析IMAP4的革命性特性与实践

IMAP4基本概念 Internet Message Access Protocol, Version 4 (IMAP4) 是一种广泛使用的邮件获取协议&#xff0c;它允许邮件客户端访问和操作远程邮件服务器上存储的邮件信息。IMAP4是IMAP协议的最新版本&#xff0c;提供了更加丰富的邮件处理功能&#xff0c;如邮件搜索、标…

SpringSecurity入门demo(四)权限校验

用户认证授权后&#xff0c;就可以进行接口权限控制。思路是拿用户&#xff08;已授予的&#xff09;权限与接口所需权限进行比较&#xff0c;不包含则视为无权。在SpringSecurity中&#xff0c;权限校验可以通过以下方式实现&#xff1a; &#xff08;1&#xff09;自定义拦截…

SQL 语句创建数据库

文章目录 MysqlPostgreInfluxDB语法使用 DROP DATABASE 删除数据库 Mysql mysql创建数据库需要账号具有高权限,我们创建一个test001数据库 mysql> CREATE DATABASE test001;使用该SHOW语句找出服务器上当前存在哪些数据库&#xff1a; mysql> SHOW DATABASES; -------…

使用分布式锁解决分布式环境下的并发安全问题

分布式锁 分布式锁的基本概念 在我们进行单机应用开发&#xff0c;涉及并发同步的时候&#xff0c;我们往往采用synchronized或者Lock的方式来解决多线程间的代码同步问题&#xff0c;这时多线程的运行都是在同一个JVM之下。但当我们的应用是分布式集群工作的情况下&#xff…

windows下使用vscode + NDK搭建 Android c++编译环境

需要的环境&#xff1a; NDK cmake&#xff08;若用android studio用过cmake则在sdk下有&#xff09; main.cpp 测试printf打印和log打印 #include <jni.h> // 需要智能提示则在 .vscode/c_cpp_properties.json 将 ndk 下的 toolchains\\llvm\\prebuilt\\windows-x8…

MWC 2024 | 广和通携手意法半导体发布智慧家居解决方案

世界移动通信大会2024期间&#xff0c;广和通携手横跨多重应用领域、全球排名前列的半导体公司意法半导体&#xff08;STMicroelectronics&#xff0c;以下简称ST&#xff1b;纽约证券交易所代码&#xff1a;STM&#xff09;发布支持Matter协议的智慧家居解决方案。该方案在广和…

【两万字面试系列】三年前的面试题。Service里面的线程安全问题

前言 三年前&#xff0c;大概是21年&#xff0c;那会刚学完java&#xff0c;然后去面试&#xff0c;被打的一塌糊涂&#xff0c;今天来盘一盘之前的面试&#xff0c;到底是怎样的问题整住了。然后发现了去年整的线程安全东西&#xff0c;也贴到文章后面了。那个贴的还不太准&a…

如何在Jupyter Notebook切换conda虚拟环境

大家好我是咕噜美乐蒂&#xff0c;很高兴又和大家见面了&#xff01;在 Jupyter Notebook 中切换 Conda 虚拟环境可以通过以下步骤完成。首先&#xff0c;确保您已经安装了 Conda&#xff0c;并且创建了多个虚拟环境。接下来&#xff0c;我将详细介绍在 Jupyter Notebook 中如何…

【大数据面试题】012 谈谈 Hive 性能优化常用的方法

一步一个脚印&#xff0c;一天一道面试题 数据分区和分桶&#xff1a;合适的分区和分桶能减少数据量的输入 合适的数据格式&#xff1a;Parquet&#xff0c;ORC 是可以减少 I/O &#xff0c;网络传输速率等的 列裁剪&#xff1a;一般不要使用 SELECT *&#xff0c;只获取真正…

设计模式:行为型模式

行为型设计模式是一类设计模式&#xff0c;它们关注的是对象之间的相互作用&#xff0c;以及对象如何通过消息传递来实现松耦合。这些模式涉及到算法和对象之间职责的分配。在本文中&#xff0c;我们将深入探讨几种常见的行为型模式&#xff0c;并提供详细的解释、示例和应用场…

HQL,SQL刷题,尚硅谷

目录 相关表数据&#xff1a; 题目及思路解析&#xff1a; 查询结果排序&分组指定条件 1、查询学生的总成绩并按照总成绩降序排序 2、按照如下格式显示学生的语文、数学、英语三科成绩&#xff0c;没有成绩的输出为0&#xff0c;按照学生的有效平均成绩降序显示 3、查询一…

hosts.allow限制可通过SSH登录到服务器的IP

hosts.allow限制可通过SSH登录到服务器的IP 网络防火墙是阻挡非授权主机访问网络的第一道防护&#xff0c;但是它们不应该仅有一道屏障。Linux使用了两个文件!。/etc/hosts.allow和/etc/hosts.deny&#xff0c;根据网络请求的来源限制对服务的访问。 hosts.allow文件列出了允…

常用SQL查询方法与实例

目录 SELECT查询 INSERT查询 UPDATE查询 DELETE查询 JOIN查询 GROUP BY查询 HAVING查询 窗口函数 公共表表达式&#xff08;CTEs&#xff09; 递归查询 透视表 分析函数 解透视 条件聚合 日期函数 合并语句 情况语句 常用SQL查询方法有以下几种&#xff1a; S…

【无监督学习之聚类】

曾梦想执剑走天涯&#xff0c;我是程序猿【AK】 目录 简述概要知识图谱1. K-Means聚类2. 层次聚类&#xff08;Hierarchical Clustering&#xff09;3. DBSCAN&#xff08;Density-Based Spatial Clustering of Applications with Noise&#xff09;4. 谱聚类&#xff08;Spect…