Docs Menu

atan(집계)

이 페이지의 내용

$atan

값의 역탄젠트(아크 탄젠트)를 반환합니다.

$atan 의 구문은 다음과 같습니다:

{ $atan: <expression> }

$atan 은(는) 숫자로 해석되는 유효한 표현식 을 사용합니다.

$atan는 값을 라디안 단위로 반환합니다. 출력 값을 라디안에서 각도로 변환하려면 $radiansToDegrees 연산자를 사용하세요.

기본적으로 $atan 값은 double로 반환합니다. $atan<expression>이 128-비트 십진수 값으로 확인되는 한 값을 128-비트 십진수로 반환할 수도 있습니다.

표현식에 대한 자세한 내용은 표현식을 참조하세요 .

인수가 null 값으로 해석되거나 누락된 필드 를 참조하는 경우 $atannull 를 반환합니다. 인수가 NaN 로 확인되면 $tanNaN 을 반환합니다.

예시
결과

{ $atan: NaN }

NaN

{ $atan: null }

null

trigonometry 컬렉션에는 직각 삼각형의 세 변을 저장하는 문서가 포함되어 있습니다.

{
"_id" : ObjectId("5c50782193f833234ba90d85"),
"side_a" : NumberDecimal("3"),
"side_b" : NumberDecimal("4"),
"hypotenuse" : NumberDecimal("5")
}

다음 집계 작업은 $atan 표현식 을 사용하여 side_a 에 인접한 각도를 계산하고 $addFields 파이프라인 단계를 사용하여 입력 문서 에 추가합니다.

db.trigonometry.aggregate([
{
$addFields : {
"angle_a" : {
$radiansToDegrees : {
$atan : {
$divide : [ "$side_b", "$side_a" ]
}
}
}
}
}
])

$radiansToDegrees 표현식 은 $atan 에서 반환된 라디안 값을 해당 값(단위: 도)으로 변환합니다.

이 명령은 다음 출력을 반환합니다.

{
"_id" : ObjectId("5c50782193f833234ba90d85"),
"side_a" : NumberDecimal("3"),
"side_b" : NumberDecimal("4"),
"hypotenuse" : NumberDecimal("5"),
"angle_a" : NumberDecimal("53.13010235415597870314438744090658")
}

side_bside_a128-비트 십진수로 저장되므로 $atan의 출력은 128-비트 십진수입니다.

trigonometry 컬렉션에는 직각 삼각형의 세 변을 저장하는 문서가 포함되어 있습니다.

{
"_id" : ObjectId("5c50782193f833234ba90d85"),
"side_a" : NumberDecimal("3"),
"side_b" : NumberDecimal("4"),
"hypotenuse" : NumberDecimal("5")
}

다음 집계 작업은 $atan 표현식 을 사용하여 side_a 에 인접한 각도를 계산하고 $addFields 파이프라인 단계를 사용하여 입력 문서 에 추가합니다.

db.trigonometry.aggregate([
{
$addFields : {
"angle_a" : {
$atan : {
$divide : [ "$side_b", "$side_a" ]
}
}
}
}
])

이 명령은 다음 출력을 반환합니다.

{
"_id" : ObjectId("5c50782193f833234ba90d85"),
"side_a" : NumberDecimal("3"),
"side_b" : NumberDecimal("4"),
"hypotenuse" : NumberDecimal("5"),
"angle_a" : NumberDecimal("0.9272952180016122324285124629224287")
}

side_bside_a128-비트 십진수로 저장되므로 $atan의 출력은 128-비트 십진수입니다.

이 페이지의 내용