График с меньшим количеством маркеров, чем точек данных (или лучший способ для построения CDF?) [Matplotlib, или общая помощь в построении графиков] - PullRequest
27 голосов
/ 11 января 2010

Я строю кумулятивные функции распределения с большим количеством точек данных. Я строю несколько линий на одном графике, которые обозначены маркерами, так как они будут напечатаны в черно-белом варианте. То, что я хотел бы, чтобы маркеры были равномерно распределены в x-измерении. То, что я получаю, это один маркер на точку данных (и учитывая количество точек, они все перекрываются)

Я не уверен, что это мое понимание того, как правильно строить сюжет, или просто отсутствие понимания matplotlib. Я не могу найти параметр «частота маркера».

Простым решением для одной строки было бы взять каждое N-е значение из строки и использовать это как отдельную строку с linestyle = '', но я бы хотел, чтобы маркеры были выровнены по вертикали, а другой х массивы имеют разную длину.

# in reality, many thousands of values
x_example = [ 567, 460, 66, 1034, 275, 26, 628, 99, 287, 157, 705, 421, 1093, \ 
     139, 204, 14, 240, 179, 94, 139, 645, 670, 47, 520, 891, 450, 56, 964,   \
     1728, 99, 277, 356, 1628, 745, 364, 88, 112, 810, 816, 523, 401, 89,     \ 
     278, 917, 370, 53, 39, 90, 853, 356 ] 
x = sort(x_example)
y = linspace(0,1,len(x))

ax = subplot(1,1,1)
plots[w] = ax.plot(x,y, marker='o')

1 Ответ

42 голосов
/ 11 января 2010

Вы можете сделать plot(x,y,marker='o',markevery=5), чтобы отметить каждую пятую точку, но я не думаю, что есть какая-либо встроенная поддержка для установки отметок на четных интервалах. Вы можете выбрать x мест, где вы хотите метки, например, использовать. numpy.searchsorted, чтобы найти точки данных, между которыми расположены местоположения, а затем выполнить интерполяцию между соседними точками, чтобы найти координаты y.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...