class beam(object):
'''This class is models the deflection of a simply supported beam under
multiple point loads, following Euler-Bernoulli theory and the principle
of superposition
'''
因此,我尝试使用matplotlib模块在一个图形上绘制一个梁函数的图形,并且在尝试这样做时会出现值错误。主要代码是:
def __init__(self, E, I, L):
'''The class costructor
'''
self.E = E # Young's modulus of the beam in N/m^2
self.I = I # Second moment of area of the beam in m^4
self.L = L # Length of the beam in m
self.Loads = [(0.0, 0.0)] # the list of loads applied to the beam
def setLoads(self, Loads):
'''This function allows multiple point loads to be applied to the beam
using a list of tuples of the form (load, position)
'''
self.Loads = Loads
def beamDeflection(self, Load, x):
"""Calculate the deflection at point x due to application of single
load
"""
Force, distanceA = Load #P1 = Force , a = distanceA
E = self.E
I = self.I
L = self.L
distanceB = L - distanceA
i = (Force*distanceB)/(6*L*E*I)
j = ((L/distanceB)*(x-distanceA)**3 - x**3 + (L**2 - distanceB**2)*x)
k = (Force*distanceB*x)/(6*L*E*I)
l = (L**2 - x**2 - distanceB**2)
if x > distanceA:
return i*j
else:
return k*l
def getTotalDeflection(self, x):
"""Calculate total deflection of beam due to multiple loads
"""
#return sum(self.beamDeflection(loadall, x) for loadall in self.Loads)
return sum(self.beamDeflection(load, x) for load in self.Loads)
def getSlope(self, x):
"""Calculate gradient at a point x on beam due to deflection
"""
V = lambda x: self.getTotalDeflection(x)
return scipy.misc.derivative(V, x, dx = 10**-6)
def getMoment(self, x):
"""Calculate bending moment at a point x on beam
"""
E = self.E
I = self.I
W1 = lambda x: self.getSlope(x)
W2 = scipy.misc.derivative(W1, x, dx = 10**-6)
return (-1*E*I)*W2
这是我收到错误的代码部分:
def plotBeamData(self, xs):
"""Plot deflection, slope and bending moment against position x for a
list of floats or numpy.array xs describing positions along beam
"""
deflection = self.getTotalDeflection
slope = self.getSlope
moment = self.getMoment
matplotlib.pyplot.plot(xs, deflection, 'b', label = "deflection (mm)")
matplotlib.pyplot.plot(xs, slope, 'g', label = "slope (mm/m)")
matplotlib.pyplot.plot(xs, moment, 'r', label = "moment (kNm)")
matplotlib.pyplot.xlabel("Distance along beam (m)")
matplotlib.pyplot.ylabel("Value in units")
matplotlib.pyplot.show()
示例输入是:
>>> b = beam(8.0E9, 1.333E-4, 5.0)
>>> b.setLoads([(900, 3.1), (700, 3.8), (1000, 4.2)])
>>> xs = numpy.linspace(0,5,500)
>>> b.plotBeamData(xs)
我收到的错误是:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "C:/Users/Dag/Downloads/beamModel.py", line 97, in plotBeamData
matplotlib.pyplot.plot(xs, deflection, 'b', label = "deflection (mm)")
File "C:\Users\Dag\Anaconda2\lib\site-packages\matplotlib\pyplot.py", line 3099, in plot
ret = ax.plot(*args, **kwargs)
File "C:\Users\Dag\Anaconda2\lib\site-packages\matplotlib\axes\_axes.py", line 1373, in plot
for line in self._get_lines(*args, **kwargs):
File "C:\Users\Dag\Anaconda2\lib\site-packages\matplotlib\axes\_base.py", line 304, in _grab_next_args
for seg in self._plot_args(remaining, kwargs):
File "C:\Users\Dag\Anaconda2\lib\site-packages\matplotlib\axes\_base.py", line 282, in _plot_args
x, y = self._xy_from_xy(x, y)
File "C:\Users\Dag\Anaconda2\lib\site-packages\matplotlib\axes\_base.py", line 223, in _xy_from_xy
raise ValueError("x and y must have same first dimension")
ValueError: x and y must have same first dimension
感谢任何帮助,真的卡住了。感谢。
答案 0 :(得分:1)
您忘了实际调用您的方法来计算结果。以下是绘图功能的修改版本:
def plotBeamData(self, xs):
"""Plot deflection, slope and bending moment against position x for a
list of floats or numpy.array xs describing positions along beam
"""
deflection = self.getTotalDeflection(xs)
slope = self.getSlope(xs)
moment = self.getMoment(xs)
matplotlib.pyplot.plot(xs, deflection, 'b', label = "deflection (mm)")
matplotlib.pyplot.plot(xs, slope, 'g', label = "slope (mm/m)")
matplotlib.pyplot.plot(xs, moment, 'r', label = "moment (kNm)")
matplotlib.pyplot.xlabel("Distance along beam (m)")
matplotlib.pyplot.ylabel("Value in units")
matplotlib.pyplot.show()