>  기사  >  백엔드 개발  >  NumPy 배열에서 높은 가치의 요소를 효율적으로 교체하는 방법은 무엇입니까?

NumPy 배열에서 높은 가치의 요소를 효율적으로 교체하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-25 07:47:28705검색

How to Efficiently Replace High-Value Elements in NumPy Arrays?

NumPy 배열에서 높은 값의 요소를 효율적으로 교체하기

문제:

2차원 NumPy 배열에서 임계값(예: T = 255)보다 큰 값을 특정 값(예: x = 255)으로 바꾸려고 합니다. 기존 접근 방식에는 시간이 많이 걸리는 for 루프가 포함됩니다.

해결책:

NumPy는 명시적인 루프가 필요 없는 간결하고 효율적인 솔루션을 제공합니다. Fancy 인덱싱을 활용하면 교체 작업을 쉽게 수행할 수 있습니다.

<code class="python">arr[arr > 255] = x</code>

이 한 줄의 코드는 조건(> 255)을 충족하는 배열의 모든 요소를 ​​지정된 값(x)으로 바꿉니다.

성능:

타이밍 측정에서 알 수 있듯이 Fancy 인덱싱 접근 방식은 for-loop 방법보다 훨씬 빠릅니다. 500 x 500 무작위 행렬의 경우 팬시 인덱싱을 사용하여 0.5보다 큰 값을 5로 바꾸는 데 평균 7.59밀리초가 걸립니다.

<code class="python">import numpy as np
A = np.random.rand(500, 500)
%timeit A[A > 0.5] = 5</code>

장점:

  • 간결성: Fancy 인덱싱 솔루션은 단 한 줄의 코드만으로 매우 간결합니다.
  • 효율성: for-loop 접근 방식보다 훨씬 빠릅니다.
  • 명확성: 구문이 간단하고 이해하기 쉽습니다.

위 내용은 NumPy 배열에서 높은 가치의 요소를 효율적으로 교체하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.