3

次のようにhttp://pyinsci.blogspot.com/2009/09/violin-plot-with-matplotlib.htmlのコードを少し変更すると、次のように Python で生成されたバイオリン プロットを取得できます。

# Import modules
import pylab as pl
from scipy import stats
import numpy as np

# Function for Violin Plot

def violin_plot(ax,data,groups,bp=False):
    '''Create violin plot along an axis'''
    dist = max(groups) - min(groups)
    w = min(0.15*max(dist,1.0),0.5)
    for d,p in zip(data,groups):
        k = stats.gaussian_kde(d) #calculates the kernel density
        m = k.dataset.min() #lower bound of violin
        M = k.dataset.max() #upper bound of violin
        x = np.arange(m,M,(M-m)/100.) # support for violin
        v = k.evaluate(x) #violin profile (density curve)
        v = v/v.max()*w #scaling the violin to the available space
        ax.fill_betweenx(x,p,v+p,facecolor='y',alpha=0.3)
        ax.fill_betweenx(x,p,-v+p,facecolor='y',alpha=0.3)
    if bp:
        ax.boxplot(data,notch=1,positions=pos,vert=1)

groups = range(3)
a = np.random.normal(size=100)
b = np.random.normal(size=100)
c = np.random.normal(size=100)

data = np.vstack((a,b,c))
fig = pl.figure()
ax = fig.add_subplot(111)
violin_plot(ax,data,groups,bp=0)
pl.show()

これにより、次のような図が生成されます。

ここに画像の説明を入力

私がやりたいことは、目盛りのラベル付けを変更して、0.5 の数字で -0.5 から 2.5 ではなく、0.0 が「A」、1.0 が「B」、1.0 が「C」になるようにすることです。 2.0。

これを行う簡単な方法はありますか?

4

1 に答える 1

4

に電話する前に、次pl.showを使用してください。

ax.set_xticks([0, 1, 2])
ax.set_xticklabels(['A', 'B', 'C'])
于 2013-02-26T05:39:31.770 に答える