我正在尝试研究如何在两个(或更多)列中显示ipywidgets的滑块。有没有人有一个例子怎么做?我的代码(在jupyter笔记本中)现在如下:
import matplotlib.pylab as plt
import numpy as np
from ipywidgets import interact,FloatSlider,IntSlider
%matplotlib inline
def plotPP(p,p_LP,Tperiods):
t=np.linspace(0,Tperiods*(np.pi*2),1000)
f = plt.figure(figsize=(1.618*6,6))
p_t = p*(1.0+np.cos(t))
plt.plot(t,p_t,'b',lw=2.0)
plt.axhline(p_LP,color='r',lw=2.0)
plt.xlim([t[0],t[-1]])
plt.ylim([min(p_LP,np.amin(p_t))-0.1,np.amax(p_t)+0.1])
plt.ylabel(r'$p$')
plt.xlabel(r'$t$')
p_s = FloatSlider(min=0, max=2, step=0.01, value=1.0)
p_LP_s = FloatSlider(min=0, max=2., step=0.01, value=0.481343)
Tperiods_s= IntSlider(min=1,max=10,value=1)
interact(plotPP,p=p_s,p_LP=p_LP_s,Tperiods=Tperiods_s)
答案 0 :(得分:2)
还有另一种方法可以水平放置滑块并立即查看图形而不移动滑块。
from IPython.display import display
import matplotlib.pylab as plt
import numpy as np
from ipywidgets import FloatSlider, IntSlider, interactive_output, HBox
%matplotlib inline
def plotPP(p,p_LP,Tperiods):
t=np.linspace(0,Tperiods*(np.pi*2),1000)
f = plt.figure(figsize=(1.618*6,6))
p_t = p*(1.0+np.cos(t))
plt.plot(t,p_t,'b',lw=2.0)
plt.axhline(p_LP,color='r',lw=2.0)
plt.xlim([t[0],t[-1]])
plt.ylim([min(p_LP,np.amin(p_t))-0.1,np.amax(p_t)+0.1])
plt.ylabel(r'$p$')
plt.xlabel(r'$t$')
p_s = FloatSlider(min=0, max=2, step=0.01, value=1.0)
p_LP_s = FloatSlider(min=0, max=2., step=0.01, value=0.481343)
Tperiods_s= IntSlider(min=1,max=10,value=1)
区别在这里:
out = interactive_output(plotPP, {'p': p_s, 'p_LP': p_LP_s})
display(HBox([p_s, p_LP_s]), out)
答案 1 :(得分:1)
有几个你可以根据你想做的事情来解决这个问题。最简单的想法是使用interactive
代替interact
以及HBox
和IPython.display.display
。关于这个解决方案的唯一问题是你可能必须在看到图表之前开始移动淤泥。
from IPython.display import display
import matplotlib.pylab as plt
import numpy as np
from ipywidgets import interact,FloatSlider,IntSlider,interactive,HBox
%matplotlib inline
def plotPP(p,p_LP,Tperiods):
t=np.linspace(0,Tperiods*(np.pi*2),1000)
f = plt.figure(figsize=(1.618*6,6))
p_t = p*(1.0+np.cos(t))
plt.plot(t,p_t,'b',lw=2.0)
plt.axhline(p_LP,color='r',lw=2.0)
plt.xlim([t[0],t[-1]])
plt.ylim([min(p_LP,np.amin(p_t))-0.1,np.amax(p_t)+0.1])
plt.ylabel(r'$p$')
plt.xlabel(r'$t$')
p_s = FloatSlider(min=0, max=2, step=0.01, value=1.0)
p_LP_s = FloatSlider(min=0, max=2., step=0.01, value=0.481343)
Tperiods_s= IntSlider(min=1,max=10,value=1)
ip = interactive(plotPP,p=p_s,p_LP=p_LP_s,Tperiods=Tperiods_s)
display(HBox(ip.children[:-1]))#Show all controls
display(ip.children[-1])#Show the output
如果不清楚或不适合您,请在下面发表评论。