Я создал участок торнадо, вдохновляющий от here. Он имеет входные переменные, помеченные на оси y (a1, b1, c1 ...) и соответствующие им коэффициенты корреляции, расположенные рядом с ними. Смотрите рис ниже:Python: Подключение значений списка со значениями массива
Я тогда отсортировали коэффициенты корреляции таким образом, что наибольшая абсолютная величина без потери знака получает график первой, то следующий по величине и так далее. используя sorted(values,key=abs, reverse=True)
. Смотрите результат ниже
Если вы заметили, во второй картинке, даже несмотря на то, баре были отсортированы в порядке убывания абсолютного, метка оси у по-прежнему остается тем же.
Вопрос: Как сделать метку (переменную) оси y связанной с коэффициентом корреляции так, чтобы она всегда соответствовала ее коэффициенту корреляции.
Ниже мой код:
import numpy as np
from matplotlib import pyplot as plt
#####Importing Data from csv file#####
dataset1 = np.genfromtxt('dataSet1.csv', dtype = float, delimiter = ',', skip_header = 1, names = ['a', 'b', 'c', 'x0'])
dataset2 = np.genfromtxt('dataSet2.csv', dtype = float, delimiter = ',', skip_header = 1, names = ['a', 'b', 'c', 'x0'])
dataset3 = np.genfromtxt('dataSet3.csv', dtype = float, delimiter = ',', skip_header = 1, names = ['a', 'b', 'c', 'x0'])
corr1 = np.corrcoef(dataset1['a'],dataset1['x0'])
corr2 = np.corrcoef(dataset1['b'],dataset1['x0'])
corr3 = np.corrcoef(dataset1['c'],dataset1['x0'])
corr4 = np.corrcoef(dataset2['a'],dataset2['x0'])
corr5 = np.corrcoef(dataset2['b'],dataset2['x0'])
corr6 = np.corrcoef(dataset2['c'],dataset2['x0'])
corr7 = np.corrcoef(dataset3['a'],dataset3['x0'])
corr8 = np.corrcoef(dataset3['b'],dataset3['x0'])
corr9 = np.corrcoef(dataset3['c'],dataset3['x0'])
np.set_printoptions(precision=4)
variables = ['a1','b1','c1','a2','b2','c2','a3','b3','c3']
base = 0
values = np.array([corr1[0,1],corr2[0,1],corr3[0,1],
corr4[0,1],corr5[0,1],corr6[0,1],
corr7[0,1],corr8[0,1],corr9[0,1]])
values = sorted(values,key=abs, reverse=True)
# The y position for each variable
ys = range(len(values))[::-1] # top to bottom
# Plot the bars, one by one
for y, value in zip(ys, values):
high_width = base + value
#print high_width
# Each bar is a "broken" horizontal bar chart
plt.broken_barh(
[(base, high_width)],
(y - 0.4, 0.8),
facecolors=['red', 'red'], # Try different colors if you like
edgecolors=['black', 'black'],
linewidth=1)
# Draw a vertical line down the middle
plt.axvline(base, color='black')
# Position the x-axis on the top/bottom, hide all the other spines (=axis lines)
axes = plt.gca() # (gca = get current axes)
axes.spines['left'].set_visible(False)
axes.spines['right'].set_visible(False)
axes.spines['top'].set_visible(False)
axes.xaxis.set_ticks_position('bottom')
# Make the y-axis display the variables
plt.yticks(ys, variables)
plt.ylim(-2, len(variables))
plt.show()
Большое спасибо заранее
Что-то вроде 'zip (* отсортировано (zip (переменные, значения), key = lambda x: abs (x [1]))) [0]' –
@PatrickHaugh: Ваше предложение сработало. Мне нужно было только отменить порядок, чтобы получить желаемый результат. Цените свою помощь по этому поводу. Спасибо! –