如何在图中找到指定y值的相应x值

发布于 2025-01-29 02:48:00 字数 909 浏览 2 评论 0原文

目前正在实施动量梯度下降,但是我需要在第一个图的特定点找到y值x = 2.000000000052746745,第二个图的x = 3.00000000003516446

def dz_dx(x,y):
    return (x-2)/(np.sqrt(25-(x-2)**2-(y-3)**2))

def dz_dy(x,y):
    return (y-3)/(np.sqrt(25-(x-2)**2-(y-3)**2))

xStart = 5
yStart = 5
learning_rate = 0.01
maxLimit = 10000
xStartHistory = np.zeros(maxLimit)
yStartHistory = np.zeros(maxLimit)
gamma = 0.9
update1 = 0
update2 = 0

for i in range(maxLimit):
    xStartHistory[i] = xStart
    yStartHistory[i] = yStart

    dx = dz_dx(xStart, yStart)
    dy = dz_dy(xStart, yStart)

    update1 = (gamma * update1) + (learning_rate * dx)
    update2 = (gamma * update2) + (learning_rate * dy)
    xStart = xStart - update1
    yStart = yStart - update2

print("xHistory:",xStartHistory[maxLimit-1])
print("yHistory:",yStartHistory[maxLimit-1])

figs, axs = plt.subplots(2)
axs[0].plot(xStartHistory)
axs[1].plot(yStartHistory)

Currently implementing a momentum gradient descent, but I need to find the y value at the specific points x = 2.0000000052746745 for the first plot and x = 3.000000003516446 for the second plot

def dz_dx(x,y):
    return (x-2)/(np.sqrt(25-(x-2)**2-(y-3)**2))

def dz_dy(x,y):
    return (y-3)/(np.sqrt(25-(x-2)**2-(y-3)**2))

xStart = 5
yStart = 5
learning_rate = 0.01
maxLimit = 10000
xStartHistory = np.zeros(maxLimit)
yStartHistory = np.zeros(maxLimit)
gamma = 0.9
update1 = 0
update2 = 0

for i in range(maxLimit):
    xStartHistory[i] = xStart
    yStartHistory[i] = yStart

    dx = dz_dx(xStart, yStart)
    dy = dz_dy(xStart, yStart)

    update1 = (gamma * update1) + (learning_rate * dx)
    update2 = (gamma * update2) + (learning_rate * dy)
    xStart = xStart - update1
    yStart = yStart - update2

print("xHistory:",xStartHistory[maxLimit-1])
print("yHistory:",yStartHistory[maxLimit-1])

figs, axs = plt.subplots(2)
axs[0].plot(xStartHistory)
axs[1].plot(yStartHistory)

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

差↓一点笑了 2025-02-05 02:48:00

您需要一些处理程序才能从轴上获取数据:

line0, = axs[0].plot(xStartHistory)
line1, = axs[1].plot(yStartHistory)

datax0 = line0.get_xdata()
datay0 = line0.get_ydata()

# value of y at x=2.000:
y_at_x0 = datay0[list(datax0).index(2.000)]

datax1 = line1.get_xdata()
datay1 = line1.get_ydata()
# value of y at x=3.000:
y_at_x1 = datay1[list(datax1).index(3.000)]

print(y_at_x0)
print(y_at_x1)

此外,如果您需要一些插值,则可以通过griddata [ link ]。

You need some handler to get data from axes:

line0, = axs[0].plot(xStartHistory)
line1, = axs[1].plot(yStartHistory)

datax0 = line0.get_xdata()
datay0 = line0.get_ydata()

# value of y at x=2.000:
y_at_x0 = datay0[list(datax0).index(2.000)]

datax1 = line1.get_xdata()
datay1 = line1.get_ydata()
# value of y at x=3.000:
y_at_x1 = datay1[list(datax1).index(3.000)]

print(y_at_x0)
print(y_at_x1)

Further, if you need some interpolation over data you can then use numpy interpolation through griddata [link].

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文