> 백엔드 개발 > 파이썬 튜토리얼 > 더 적은 차원으로 다차원 배열에 액세스하는 방법은 무엇입니까?

더 적은 차원으로 다차원 배열에 액세스하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-10-21 11:32:02
원래의
919명이 탐색했습니다.

How to Access Multidimensional Arrays with Fewer Dimensions?

더 적은 차원으로 다차원 배열에 액세스

a 및 (n-1)차원과 같은 n차원 배열을 고려합니다. 배열, idx. 주어진 차원에서 idx를 사용하여 액세스하려면 고급 인덱싱을 사용할 수 있습니다.

3차원 배열 a의 경우 다음과 같이 idx를 사용하여 첫 번째 차원의 최대값을 계산할 수 있습니다.

<code class="python">m, n = a.shape[1:]
I, J = np.ogrid[:m, :n]
a_max_values = a[idx, I, J]</code>
로그인 후 복사

이 접근 방식은 임의 개수의 차원을 가진 배열에 대해 일반화될 수 있습니다.

<code class="python">def argmax_to_max(arr, argmax, axis):
    new_shape = list(arr.shape)
    del new_shape[axis]
    grid = np.ogrid[tuple(map(slice, new_shape))]
    grid.insert(axis, argmax)
    return arr[tuple(grid)]</code>
로그인 후 복사

n차원 배열을 (n-1)차원 배열로 인덱싱하려면 다음과 같은 그리드를 생성할 수 있습니다. 모든 축에 대한 인덱스:

<code class="python">def all_idx(idx, axis):
    grid = np.ogrid[tuple(map(slice, idx.shape))]
    grid.insert(axis, idx)
    return tuple(grid)</code>
로그인 후 복사

이 그리드를 사용하여 입력 배열에 대한 인덱스를 생성할 수 있습니다.

<code class="python">a_max_values = a[all_idx(idx, axis=axis)]
b_max_values = b[all_idx(idx, axis=axis)]</code>
로그인 후 복사

이 접근 방식은 더 적은 차원으로 다차원 배열에 액세스하기 위한 우아한 솔루션을 제공합니다.

위 내용은 더 적은 차원으로 다차원 배열에 액세스하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿