atan(집계)
$atan
값의 역탄젠트(아크 탄젠트)를 반환합니다.
$atan
의 구문은 다음과 같습니다:{ $atan: <expression> } $atan
은(는) 숫자로 해석되는 유효한 표현식 을 사용합니다.$atan
는 값을 라디안 단위로 반환합니다. 출력 값을 라디안에서 각도로 변환하려면$radiansToDegrees
연산자를 사용하세요.기본적으로
$atan
은 값을double
로 반환합니다.$atan
는<expression>
가 128비트 십진수 값으로 해석되는 한 값을 128비트 십진수 로 반환할 수도 있습니다.표현식에 대한 자세한 내용은 표현식을 참조하세요 .
행동
null
개인정보 정책에 NaN
인수가 null
값으로 해석되거나 누락된 필드 를 참조하는 경우 $atan
는 null
를 반환합니다. 인수가 NaN
로 확인되면 $tan
는 NaN
을 반환합니다.
예시 | 결과 |
---|---|
|
|
|
|
예시
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_b
및 side_a
는 128비트 십진수 로 저장되므로 $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_b
및 side_a
는 128비트 십진수 로 저장되므로 $atan
의 출력은 128비트 십진수입니다.