>백엔드 개발 >파이썬 튜토리얼 >Python을 사용하여 y = 0인 곡선의 교차점을 정확하게 찾는 방법은 무엇입니까?

Python을 사용하여 y = 0인 곡선의 교차점을 정확하게 찾는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-21 07:17:30669검색

How to Accurately Find Intersection Points of a Curve with y = 0 Using Python?

y = 0으로 곡선의 교차점 식별

NumPy 배열을 사용한 Python 플로팅의 맥락에서, 곡선이 y = 0과 교차하는 y축은 파악하기 어려운 작업일 수 있습니다. 이 기사에서는 이러한 교차점을 정확하게 결정하고 기존 근 찾기 기술의 한계를 해결하는 방법에 대해 설명합니다.

먼저 NumPy 배열을 사용하여 플롯을 정의해 보겠습니다.

<code class="python">import numpy as np
import matplotlib.pyplot as plt
vertical_data = ...
gradient = ...
plt.plot(gradient, vertical_data)
plt.show()</code>

이제 , 곡선의 0 값을 찾고 싶다고 가정합니다. 기존의 근 찾기 알고리즘은 부동 소수점 정밀도 제한으로 인해 부정확한 결과를 제공하는 경우가 많습니다. 이를 극복하기 위해 우리는 간단한 선형 보간 기술을 사용합니다.

<code class="python">import numpy as np

def find_roots(x, y):
    # Compute the sign differences
    s = np.abs(np.diff(np.sign(y))).astype(bool)
    # Perform linear interpolation at sign changes
    return x[:-1][s] + np.diff(x)[s]/(np.abs(y[1:][s]/y[:-1][s])+1)</code>

이 함수는 x 및 y 배열을 입력으로 사용하고 y 값이 0 표시와 교차하는 교차점을 찾습니다. 이 함수를 데이터에 적용하고 결과를 그립니다.

<code class="python">z = find_roots(gradient, vertical_data)

plt.plot(gradient, vertical_data)
plt.plot(z, np.zeros(len(z)), marker="o", ls="", ms=4)
plt.show()</code>

x와 y의 역할을 반대로 하여 x축을 따라 교차점을 결정할 수 있습니다.

<code class="python">plt.plot(vertical_data, gradient)
plt.plot(np.zeros(len(z)), z, marker="o", ls="", ms=4)
plt.show()</code>

게다가 제시된 방법을 사용하면 0이 아닌 y 값에서 교차점을 찾을 수 있습니다. find_roots 함수를 적용하기 전에 곡선에서 원하는 y 값을 뺍니다.

<code class="python">y0 = 1.4
z = find_roots(gradient, vertical_data - y0)
plt.plot(z, np.zeros(len(z))+y0)</code>

마지막으로 두 곡선 사이의 교차점을 결정하려면 곡선 간의 차이를 계산하고 find_roots 함수를 적용하여 교차점을 찾습니다. 포인트:

<code class="python">y2 = ...
z = find_roots(gradient, y2 - y1)
plt.plot(gradient, y1)
plt.plot(gradient, y2, color="C2")
plt.plot(z, np.interp(z, gradient, y1), marker="o", ls="", ms=4, color="C1")</code>

위 내용은 Python을 사용하여 y = 0인 곡선의 교차점을 정확하게 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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