【问题标题】:Code for logistic equation逻辑方程代码
【发布时间】:2024-05-16 22:00:02
【问题描述】:

我正在尝试理解以下逻辑地图图像的代码,但我卡在了

ys = [ ]
rs = numpy.linspace(0, 4, 400) 

rs 是什么意思? i in range() 是什么意思? 非常感谢您的帮助!

def f(x, r):
    """Discrete logistic equation with parameter r"""
    return r*x*(1-x)

if __name__ == '__main__':
    # initial condition for x
    ys = []
    rs = numpy.linspace(0, 4, 400)
    for r in rs:
        x = 0.1
        for i in range(500):
            x = f(x, r)

        for i in range(50):
            x = f(x, r)
            ys.append([r, x])

    ys = numpy.array(ys)
    pylab.plot(ys[:,0], ys[:,1], '.')
    pylab.show()

【问题讨论】:

标签: python numpy pythonxy


【解决方案1】:
rs = numpy.linspace(0, 4, 400) 

创建一个 numpy 数组,其中包含 400 个值,等距在 0 和 4 之间(包括端点)。

以下是一些较小的示例:

In [17]: import numpy as np

In [18]: np.linspace(0, 4, 5)
Out[18]: array([ 0.,  1.,  2.,  3.,  4.])

In [19]: np.linspace(0, 4, 10)
Out[19]: 
array([ 0.        ,  0.44444444,  0.88888889,  1.33333333,  1.77777778,
        2.22222222,  2.66666667,  3.11111111,  3.55555556,  4.        ])

for i in range(50)Python tutorial 中进行了解释(第 4.2 和 4.3 节)。


这里有一些cmets来帮助解释代码。

import numpy as np
import matplotlib.pyplot as plt
import pylab
import numpy

def f(x, r):
    """Discrete logistic equation with parameter r"""
    return r*x*(1-x)

if __name__ == '__main__':
    # initial condition for x
    ys = []
    rs = numpy.linspace(0, 4, 400)

    # Loop through `rs`. `r` is assigned the values in `rs` one at a time. 
    for r in rs:
        x = 0.1
        # Repeat this loop 500 times. 
        # i is just a dummy variable since it is not used inside the for-loop.
        for i in range(500):
            # Evaluate f at (x, r). The return value is assigned to x.
            # x is then fed back into f(x, r). 
            # This makes x jump around 500 times according to the logistic equation.
            # r remains fixed.
            x = f(x, r)

        # Do this 50 times
        for i in range(50):
            # Again make the x jump around according to the logistic equation
            x = f(x, r)
            # Save the point (r, x) in the list ys
            ys.append([r, x])

    # ys is a list of lists.
    # You can also think of ys as a list of [r, x] point.
    # This converts the list of lists into a 2D numpy array.
    ys = numpy.array(ys)

    # ys[:,0] is a 1D array of r values
    # ys[:, 1] is a 1D array of x values
    # This draws a scatter plot of (r, x) points.
    pylab.plot(ys[:,0], ys[:,1], '.')
    pylab.show()

【讨论】:

  • 非常感谢unutbu!
【解决方案2】:
for i in range(500)

表示循环的内容将被计算 500 次(i 将采用 0 到 499 之间的整数值)。

【讨论】:

    【解决方案3】:

    数组ys的索引也存在语法错误。应该是ys[:][0]ys[:][1]。 Python 的数组语法取自 C 和 Java。

    【讨论】:

    • ys 在可能的情况下使用numpy.array 覆盖。