주요 콘텐츠

이 번역 페이지는 최신 내용을 담고 있지 않습니다. 최신 내용을 영문으로 보려면 여기를 클릭하십시오.

movmean

설명

M = movmean(A,k)는 국소 k평균값을 반환합니다. 여기서 각 평균은 A의 인접 요소들이 포함된 길이 k의 슬라이딩 윈도우에서 계산됩니다. k가 홀수면 윈도우의 중심은 현재 위치의 요소가 됩니다. k가 짝수면 윈도우의 중심은 현재 요소 및 이전 요소가 됩니다. 윈도우를 다 채우기에 요소가 부족할 때는 윈도우 크기가 끝점에서 자동으로 잘립니다. 윈도우가 잘렸을 때는 윈도우를 채우는 요소들의 평균을 구합니다. MA와 크기가 같습니다.

  • A가 벡터인 경우 movmean은 벡터 A의 길이를 따라 연산을 수행합니다.

  • A가 다차원 배열인 경우 movmean은 크기가 1이 아닌 A의 첫 번째 차원을 따라 연산을 수행합니다.

  • A가 테이블 또는 타임테이블인 경우 movmeanA의 변수를 따라 연산을 수행합니다. (R2025a 이후)

예제

M = movmean(A,[kb kf])는 현재 위치에 있는 요소와 그 위치 뒤로 kb개 요소, 그 위치 앞으로 kf개 요소를 포함하는 길이 kb+kf+1의 윈도우에서 평균을 계산합니다.

예제

M = movmean(___,dim)은 위에 열거된 모든 구문에서 연산을 수행할 A의 차원을 지정합니다. 예를 들어 A가 행렬인 경우, movmean(A,k,2)A의 열을 따라 각 행에 대한 k요소 슬라이딩 평균을 계산합니다.

예제

M = movmean(___,nanflag)ANaN 값을 포함시킬지 또는 생략할지 여부를 지정합니다. 예를 들어, movmean(A,k,"omitnan")은 각 평균을 계산할 때 NaN 값을 무시합니다. 기본적으로 movmeanNaN 값을 포함합니다.

예제

M = movmean(___,Name,Value)는 하나 이상의 이름-값 인수를 사용하여 이동평균에 대한 추가 파라미터를 지정합니다. 예를 들어, x가 시간 값의 벡터인 경우 movmean(A,k,"SamplePoints",x)x에 있는 시간에 관한 이동평균을 계산합니다.

예제

예제

모두 축소

행 벡터의 3점 중심 이동 평균을 계산합니다. 끝점에 있는 윈도우의 요소가 3개 미만일 때는 남은 요소들의 평균을 구합니다.

A = [4 8 6 -1 -2 -3 -1 3 4 5];
M = movmean(A,3)
M = 1×10

    6.0000    6.0000    4.3333    1.0000   -2.0000   -2.0000   -0.3333    2.0000    4.0000    4.5000

행 벡터의 3점 후행 이동 평균을 계산합니다. 끝점에 있는 윈도우의 요소가 3개 미만일 때는 남은 요소들의 평균을 구합니다.

A = [4 8 6 -1 -2 -3 -1 3 4 5];
M = movmean(A,[2 0])
M = 1×10

    4.0000    6.0000    6.0000    4.3333    1.0000   -2.0000   -2.0000   -0.3333    2.0000    4.0000

행렬의 각 행에 대한 3점 중심 이동 평균을 계산합니다. 윈도우가 첫 번째 행에서 시작하고, 행 끝까지 수평으로 슬라이딩한 후, 두 번째 행으로 이동합니다. 차원 인수는 2이고, 이것은 A의 열 방향으로 윈도우를 슬라이딩합니다.

A = [4 8 6; -1 -2 -3; -1 3 4]
A = 3×3

     4     8     6
    -1    -2    -3
    -1     3     4

M = movmean(A,3,2)
M = 3×3

    6.0000    6.0000    7.0000
   -1.5000   -2.0000   -2.5000
    1.0000    2.0000    3.5000

NaN 요소 2개가 포함된 행 벡터의 3점 중심 이동 평균을 계산합니다.

A = [4 8 NaN -1 -2 -3 NaN 3 4 5];
M = movmean(A,3)
M = 1×10

    6.0000       NaN       NaN       NaN   -2.0000       NaN       NaN       NaN    4.0000    4.5000

평균을 다시 계산하되, NaN 값을 생략합니다. movmeanNaN 요소를 생략할 경우, 윈도우 내에 남아 있는 요소들의 평균을 구하게 됩니다.

M = movmean(A,3,"omitnan")
M = 1×10

    6.0000    6.0000    3.5000   -1.5000   -2.0000   -2.5000         0    3.5000    4.0000    4.5000

시간 벡터 t에 따라 A에 있는 데이터의 3시간 중심 이동 평균을 계산합니다.

A = [4 8 6 -1 -2 -3];
k = hours(3);
t = datetime(2016,1,1,0,0,0) + hours(0:5)
t = 1×6 datetime
   01-Jan-2016 00:00:00   01-Jan-2016 01:00:00   01-Jan-2016 02:00:00   01-Jan-2016 03:00:00   01-Jan-2016 04:00:00   01-Jan-2016 05:00:00

M = movmean(A,k,"SamplePoints",t)
M = 1×6

    6.0000    6.0000    4.3333    1.0000   -2.0000   -2.5000

행 벡터의 3점 중심 이동 평균을 계산하되, 3개 미만의 점을 사용하는 모든 계산을 출력값에서 무시합니다. 즉, 요소를 3개 가진 완전한 윈도우에서 계산된 평균만 반환하고, 끝점에서의 계산은 무시합니다.

A = [4 8 6 -1 -2 -3 -1 3 4 5];
M = movmean(A,3,"Endpoints","discard")
M = 1×8

    6.0000    4.3333    1.0000   -2.0000   -2.0000   -0.3333    2.0000    4.0000

마방진의 열에서 테이블을 생성합니다.

A = magic(3);
T = array2table(A)
T=3×3 table
    A1    A2    A3
    __    __    __

    8     1     6 
    3     5     7 
    4     9     2 

movmean을 사용하여 테이블 변수의 이동평균을 계산합니다.

M = movmean(T,3)
M=3×3 table
    A1     A2    A3 
    ___    __    ___

    5.5    3     6.5
      5    5       5
    3.5    7     4.5

지정된 변수에 대해서만 이동평균을 계산하려면 DataVariables 이름-값 인수를 지정하십시오.

M2 = movmean(T,3,DataVariables=["A2" "A3"])
M2=3×3 table
    A1    A2    A3 
    __    __    ___

    8     3     6.5
    3     5       5
    4     7     4.5

이동평균으로 값을 대체하는 대신 테이블에 추가하려면 ReplaceValuesfalse로 지정하십시오.

M3 = movmean(T,3,ReplaceValues=false)
M3=3×6 table
    A1    A2    A3    A1_movmean    A2_movmean    A3_movmean
    __    __    __    __________    __________    __________

    8     1     6        5.5            3            6.5    
    3     5     7          5            5              5    
    4     9     2        3.5            7            4.5    

입력 인수

모두 축소

입력 데이터로, 벡터, 행렬, 다차원 배열, table형 또는 timetable형으로 지정됩니다.

데이터형: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical | table | timetable

윈도우 길이로, 숫자형 또는 duration형 스칼라로 지정됩니다. k가 양의 정수 스칼라일 때 중심 위치에서의 평균은 현재 위치의 요소와 주위의 요소를 포함합니다.

예를 들어, movmean(A,3)은 국소 3점 평균값으로 구성된 배열을 계산합니다.

movmean(A,3) computation. The elements in the sample window are 1, 3, and 5, so the resulting local mean is 3.

방향 윈도우 길이로, 2개 요소를 포함하는 숫자형 또는 duration형 행 벡터로 지정됩니다. kbkf가 양의 정수 스칼라일 때 계산은 kb+kf+1개 요소에 대해 이루어집니다. 계산은 현재 위치의 요소, 현재 위치 앞의 kb개 요소, 그리고 현재 위치 뒤의 kf개 요소를 포함합니다.

예를 들어, movmean(A,[2 1])은 국소 4점 평균값으로 구성된 배열을 계산합니다.

movmean(A,[2 1]) computation. The elements in the sample window are 4, 1, 3, and 5, so the resulting local mean is 3.25.

연산을 수행할 차원으로, 양의 정수 스칼라로 지정됩니다. 차원을 지정하지 않을 경우, 디폴트 값은 크기가 1이 아닌 첫 번째 배열 차원이 됩니다.

차원 dimmovmean이 계산되는 차원 즉, 지정한 윈도우가 슬라이딩하는 방향을 나타냅니다.

m×n 입력 행렬 A가 있다고 가정합니다.

  • movmean(A,k,1)A의 각 열에 대해 k-요소 슬라이딩 평균을 계산하고 m×n 행렬을 반환합니다.

    movmean(A,k,1) column-wise operation

  • movmean(A,k,2)A의 각 행에 대해 k-요소 슬라이딩 평균을 계산하고 m×n 행렬을 반환합니다.

    movmean(A,k,2) row-wise operation

A가 테이블 또는 타임테이블이면 dim을 지정할 수 없습니다. movmean 함수는 항상 테이블 및 타임테이블의 변수를 따라 연산을 수행합니다. (R2025a 이후)

누락값 조건으로, 다음 값 중 하나로 지정됩니다.

  • "includemissing" 또는 "includenan" — 각 평균을 계산할 때 ANaN 값을 포함합니다. 윈도우의 요소가 하나라도 NaN인 경우 이에 대응하는 M의 요소도 NaN입니다. "includemissing""includenan"은 동일하게 동작합니다.

  • "omitmissing" 또는 "omitnan"ANaN 값을 무시하고, 더 적은 수의 점을 대상으로 각 평균을 계산합니다. 윈도우의 모든 요소가 NaN인 경우 이에 대응하는 M의 요소는 NaN이 됩니다. "omitmissing""omitnan"은 동일하게 동작합니다.

이름-값 인수

모두 축소

선택적 인수 쌍을 Name1=Value1,...,NameN=ValueN으로 지정합니다. 여기서 Name은 인수 이름이고 Value는 대응값입니다. 이름-값 인수는 다른 인수 뒤에 와야 하지만, 인수 쌍의 순서는 상관없습니다.

R2021a 이전 릴리스에서는 쉼표를 사용하여 각 이름과 값을 구분하고 Name을 따옴표로 묶으십시오.

예: M = movmean(A,k,"Endpoints","fill")

끝점 부근의 윈도우 처리 방법으로, 다음 옵션 중 하나로 지정됩니다.

설명
"shrink"입력값의 끝점 근처의 윈도우 크기를 실제로 존재하는 요소만 포함하도록 축소합니다.
"discard"

윈도우가 실제로 존재하는 요소들과 완전히 겹치지 않을 때는 어떤 평균값도 출력하지 않습니다.

A가 테이블 또는 타임테이블이면 Endpoints"discard"로 지정할 수 없습니다.

"fill"존재하지 않는 요소를 NaN으로 바꿉니다.
숫자형 스칼라 또는 논리형 스칼라존재하지 않는 요소를 지정된 숫자형 값 또는 논리값으로 바꿉니다.

평균을 계산할 샘플 점으로, 벡터로 지정됩니다. 샘플 점은 A에 있는 데이터의 위치를 나타냅니다. 샘플 점은 균일하게 샘플링할 필요가 없습니다. 기본적으로, 샘플 점 벡터는 [1 2 3 ... ]입니다.

이동 윈도우는 샘플 점을 기준으로 하여 정의되며, 이 샘플 점은 정렬되고 고유한 요소를 가져야 합니다. 예를 들어, t가 입력 데이터에 해당하는 시간 벡터인 경우 movmean(rand(1,10),3,"SamplePoints",t)에는 t(i)-1.5 ~ t(i)+1.5 범위의 시간 구간을 나타내는 윈도우가 있습니다.

샘플 점 벡터의 데이터형이 datetime형 또는 duration형인 경우 이동 윈도우 길이는 duration형이어야 합니다.

샘플 점의 간격이 균일하지 않을 때 Endpoints를 지정하면 Endpoints의 값은 "shrink"입니다.

R2025a 이후

연산을 수행할 테이블 또는 타임테이블 변수로, 다음 표에 있는 옵션 중 하나로 지정됩니다.

  • DataVariables를 지정하지 않으면 movmean 함수는 모든 변수에 대해 연산을 수행합니다. 이 동작은 디폴트 동작입니다.

  • DataVariables를 지정하면 movmean 함수는 지정된 변수에 대해서만 연산을 수행합니다. DataVariables로 지정되지 않은 다른 변수는 수정되지 않은 채 출력값으로 전달됩니다.

인덱싱 방식지정할 값예제

변수 이름

  • string형 스칼라 또는 문자형 벡터

  • string형 배열 또는 문자형 벡터로 구성된 셀형 배열

  • pattern 객체

  • "A" 또는 'A'A라는 변수

  • ["A" "B"] 또는 {'A','B'}AB라는 두 개의 변수

  • "Var"+digitsPattern(1)"Var" 다음에 하나의 숫자가 오는 이름을 갖는 변수

변수 인덱스

  • 테이블에서의 변수 위치를 나타내는 인덱스 번호

  • 숫자로 구성된 벡터

  • logical형 벡터. 일반적으로 이 벡터는 변수의 개수와 길이가 같지만 후행 0(false) 값을 생략할 수 있습니다.

  • 3 — 테이블의 세 번째 변수

  • [2 3] — 테이블의 두 번째 변수와 세 번째 변수

  • [false false true] — 세 번째 변수

함수 핸들

  • 테이블 변수를 입력값으로 받고 logical형 스칼라를 반환하는 함수 핸들

  • @isnumeric — 숫자형 값을 포함하는 모든 변수

변수 유형

  • 지정된 유형의 변수를 선택하는 vartype 첨자

  • vartype("numeric") — 숫자형 값을 포함하는 모든 변수

R2025a 이후

값 바꾸기 표시자로, A가 테이블 또는 타임테이블이면 다음 값 중 하나로 지정됩니다.

  • true 또는 1 — 출력 테이블 또는 타임테이블에서 입력 테이블 또는 타임테이블 변수를 movmean에서 얻은 출력값이 포함된 변수로 바꿉니다.

  • false 또는 0movmean에서 얻은 출력값을 포함하는 변수를 출력 테이블 또는 타임테이블에 추가합니다.

벡터, 행렬 또는 다차원 배열 입력 데이터에는 ReplaceValues가 지원되지 않습니다.

세부 정보

모두 축소

확장 기능

모두 확장

버전 내역

R2016a에 개발됨

모두 확장