2016-07-23 1 views
0

Я новичок в ipython. У меня есть этот фрагмент кода в моей IPythonValueError: x и y должны иметь такое же первое измерение, ipython 3.5

def derivative(x): 
    return 3*(x^2) 
derivative_estimate = lambda x: difference_quotient(cube, x, h=0.00001) 

x = range(-10, 10) 
import matplotlib.pyplot as plt 
plt.title("Actual Derivatives vs Estimates") 
x = range(-10,10) 
plt.plot(x, map(derivative, x), 'rx', label = 'Actual')   # red x 
plt.plot(x, map(derivative_estimate, x), 'b+', label = 'Estimate') # blue + 
plt.show() 

Когда я пытаюсь запустить это, он показывает мне эти ошибки


ValueError        Traceback (most recent call last) 
<ipython-input-12-211954bb4dc5> in <module>() 
     6 plt.title("Actual Derivatives vs Estimates") 
     7 x = range(-10,10) 
----> 8 plt.plot(x, map(derivative, x), 'rx')   # red x 
     9 plt.plot(x, map(derivative_estimate, x), 'b+') # blue + 
    10 plt.show() 

C:\Users\User\Anaconda3\lib\site-packages\matplotlib\pyplot.py in plot(*args, **kwargs) 
    3152   ax.hold(hold) 
    3153  try: 
-> 3154   ret = ax.plot(*args, **kwargs) 
    3155  finally: 
    3156   ax.hold(washold) 

C:\Users\User\Anaconda3\lib\site-packages\matplotlib\__init__.py in inner(ax, *args, **kwargs) 
    1809      warnings.warn(msg % (label_namer, func.__name__), 
    1810         RuntimeWarning, stacklevel=2) 
-> 1811    return func(ax, *args, **kwargs) 
    1812   pre_doc = inner.__doc__ 
    1813   if pre_doc is None: 

C:\Users\User\Anaconda3\lib\site-packages\matplotlib\axes\_axes.py in plot(self, *args, **kwargs) 
    1422    kwargs['color'] = c 
    1423 
-> 1424   for line in self._get_lines(*args, **kwargs): 
    1425    self.add_line(line) 
    1426    lines.append(line) 

C:\Users\User\Anaconda3\lib\site-packages\matplotlib\axes\_base.py in _grab_next_args(self, *args, **kwargs) 
    384     return 
    385    if len(remaining) <= 3: 
--> 386     for seg in self._plot_args(remaining, kwargs): 
    387      yield seg 
    388     return 

C:\Users\User\Anaconda3\lib\site-packages\matplotlib\axes\_base.py in _plot_args(self, tup, kwargs) 
    362    x, y = index_of(tup[-1]) 
    363 
--> 364   x, y = self._xy_from_xy(x, y) 
    365 
    366   if self.command == 'plot': 

C:\Users\User\Anaconda3\lib\site-packages\matplotlib\axes\_base.py in _xy_from_xy(self, x, y) 
    221   y = _check_1d(y) 
    222   if x.shape[0] != y.shape[0]: 
--> 223    raise ValueError("x and y must have same first dimension") 
    224   if x.ndim > 2 or y.ndim > 2: 
    225    raise ValueError("x and y can be no greater than 2-D") 

ValueError: x and y must have same first dimension, 

Может кто-нибудь, пожалуйста, помогите мне решить эту проблему?

+1

FYI: В Python '^' не является возведением в степень; это «побитовое исключение или». Используйте «x ** 2» для «x square». –

+0

Да, я позже выясню это –

ответ

1

функция Matplotlib в plot не может справиться с итератор, возвращаемый map Expand итератор к списку перед вызовом plot:.

plt.plot(x, list(map(derivative, x)), 'rx', label = 'Actual') 
+0

Да, это ответ. Ну, я был слишком занят, чтобы ответить на свой пост. Но вы уже это сделали. Так что принимаю это :) –

0

Попробуйте ввести numpy, а затем используйте numpy.linspace или numpy.arange вместо range. Я считаю, что ваша проблема создана внутри вашей функции derivative, где вы принимаете 3*x. Если x список (который возвращается из стандартного range, 3*x вернется [1, 2, 3, 4, 1, 2, 3, 4, 1, 2, 3, 4] если x=[1, 2, 3, 4] Что вы хотите, чтобы получить это 3*x = [3, 6, 9, 12], и это будет в случае, если вы используете numpy.linspace или numpy.arange вместо

Documentation ссылки..: numpy.arange и numpy.linspace

+0

Нет, это не имеет ничего общего с numpy –

+0

Какова длина вашего x-списка и какова длина списка, возвращаемого из вашей производной функции? Если я использую 'x = range (-10, 10)', я получаю 'len (x) = 20' и' len (производное (x)) = 60'. – pathoren

Смежные вопросы