将一个函数计算的值传递给另一个函数

1 投票
2 回答
813 浏览
提问于 2025-04-16 22:17

我最近在做一个项目,用Python编程,刚开始不久。这可能是个小问题。我有一段代码,需要在poly_root()这个函数里计算一个值x,然后把这个值用作bezier()函数里的u。在poly_root()函数之后,这个值应该传递给bezier()函数。我不太确定我这样做是否正确。虽然没有报错,但bezier()函数里的t没有打印出来。非常感谢!

import copy

import math

poly = [[-0.8,3], [0.75,2], [-0.75,1], [0.1,0]]

def poly_diff(poly):
    """ Differentiate a polynomial. """
    newlist = copy.deepcopy(poly)

    for term in newlist:
        term[0] *= term[1]
        term[1] -= 1

    return newlist

def poly_apply(poly, x):
    """ Apply values to the polynomial. """

    sum = 0.0 # force float

    for term in poly:
        sum += term[0] * (x ** term[1])

    return sum

def poly_root(poly, start, n, r_i):
    """ Returns a root of the polynomial, with a starting value."""

    poly_d = poly_diff(poly)
    x = start # starting guess value
    counter = 0

    while True:
        if (n >= 0) and (n < 1):
            break

        x_n = x - (float(poly_apply(poly, x)) / poly_apply(poly_d, x))

        if x_n == x:
            break

        x = x_n # this is the u value corresponding to the given time which will be used in bezier equation

        n -= 1
        counter += 1

    if r_i:
        #print [x, counter])
        return [x, counter]
    else:
        #print x
        return x
    bezier(x)

def bezier(value) :
    """ Calculates control points using rational bezier curve equation"""

    u = value
    w = 5

    t = math.pow(1-u,3) * points[0][0] + 3 * u * math.pow(1-u,2) * points[1][0] \
        + 3 * (1-u) * math.pow(u,2) * points[2][0] + math.pow(u,3) * points[3][0]

    t = t * w

    d = math.pow(1-u,3) * w + 3 * u * w * math.pow(1-u,2) + 3 * (1-u) * w \  
        * math.pow(u,2) + math.pow(u,3) * w  


    t = t / d
    print t

if __name__ == "__main__" :
    poly_root(poly, 0.42, 1, 0)

2 个回答

1

在这两种情况下,poly_root 返回相同类型的东西会更好,比如返回一个包含两个元素的列表...

if r_i:
    return [x, counter]
else:
    return [x, None]

然后在最后,你可以有...

if __name__ == "__main__" :
    x, counter = poly_root(poly, 0.42, 1, 0)
    if counter is None:  # I don't know if this is what you intended with your code.
        bezier(x)
3

在这段代码中:

if r_i:
    #print [x, counter])
    return [x, counter]
else:
    #print x
    return x
bezier(x)

bezier(x) 是无法到达的。你需要重新写一下它。

撰写回答