SourceForge logo
SourceForge logo
Menu

matplotlib-devel — matplotlib developers

You can subscribe to this list here.

2003 Jan
Feb
Mar
Apr
May
Jun
Jul
Aug
Sep
Oct
(1)
Nov
(33)
Dec
(20)
2004 Jan
(7)
Feb
(44)
Mar
(51)
Apr
(43)
May
(43)
Jun
(36)
Jul
(61)
Aug
(44)
Sep
(25)
Oct
(82)
Nov
(97)
Dec
(47)
2005 Jan
(77)
Feb
(143)
Mar
(42)
Apr
(31)
May
(93)
Jun
(93)
Jul
(35)
Aug
(78)
Sep
(56)
Oct
(44)
Nov
(72)
Dec
(75)
2006 Jan
(116)
Feb
(99)
Mar
(181)
Apr
(171)
May
(112)
Jun
(86)
Jul
(91)
Aug
(111)
Sep
(77)
Oct
(72)
Nov
(57)
Dec
(51)
2007 Jan
(64)
Feb
(116)
Mar
(70)
Apr
(74)
May
(53)
Jun
(40)
Jul
(519)
Aug
(151)
Sep
(132)
Oct
(74)
Nov
(282)
Dec
(190)
2008 Jan
(141)
Feb
(67)
Mar
(69)
Apr
(96)
May
(227)
Jun
(404)
Jul
(399)
Aug
(96)
Sep
(120)
Oct
(205)
Nov
(126)
Dec
(261)
2009 Jan
(136)
Feb
(136)
Mar
(119)
Apr
(124)
May
(155)
Jun
(98)
Jul
(136)
Aug
(292)
Sep
(174)
Oct
(126)
Nov
(126)
Dec
(79)
2010 Jan
(109)
Feb
(83)
Mar
(139)
Apr
(91)
May
(79)
Jun
(164)
Jul
(184)
Aug
(146)
Sep
(163)
Oct
(128)
Nov
(70)
Dec
(73)
2011 Jan
(235)
Feb
(165)
Mar
(147)
Apr
(86)
May
(74)
Jun
(118)
Jul
(65)
Aug
(75)
Sep
(162)
Oct
(94)
Nov
(48)
Dec
(44)
2012 Jan
(49)
Feb
(40)
Mar
(88)
Apr
(35)
May
(52)
Jun
(69)
Jul
(90)
Aug
(123)
Sep
(112)
Oct
(120)
Nov
(105)
Dec
(116)
2013 Jan
(76)
Feb
(26)
Mar
(78)
Apr
(43)
May
(61)
Jun
(53)
Jul
(147)
Aug
(85)
Sep
(83)
Oct
(122)
Nov
(18)
Dec
(27)
2014 Jan
(58)
Feb
(25)
Mar
(49)
Apr
(17)
May
(29)
Jun
(39)
Jul
(53)
Aug
(52)
Sep
(35)
Oct
(47)
Nov
(110)
Dec
(27)
2015 Jan
(50)
Feb
(93)
Mar
(96)
Apr
(30)
May
(55)
Jun
(83)
Jul
(44)
Aug
(8)
Sep
(5)
Oct
Nov
(1)
Dec
(1)
2016 Jan
Feb
Mar
(1)
Apr
May
Jun
(2)
Jul
Aug
(3)
Sep
(1)
Oct
(3)
Nov
Dec
2017 Jan
Feb
(5)
Mar
Apr
May
Jun
Jul
(3)
Aug
Sep
(7)
Oct
Nov
Dec
2018 Jan
Feb
Mar
Apr
May
Jun
Jul
(2)
Aug
Sep
Oct
Nov
Dec
S M T W T F S


1
(2)
2
(1)
3
4
(21)
5
6
7
(4)
8
(16)
9
(15)
10
(12)
11
12
13
14
15
16
17
(2)
18
(1)
19
(1)
20
21
(8)
22
(7)
23
(9)
24
(1)
25
(3)
26
(2)
27
(4)
28
(2)
29
(10)
30
(6)
31
(14)


Showing 2 results of 2

From: Michael D. <md...@st...> - 2008年01月17日 16:09:56
Quick status update, and moving to matplotlib-devel, since I think this 
is no longer relevant to the OP --
The difference seems to be due to the simplification/clipping/decimation 
loop in the old draw_lines. It appears that even when you have a sine 
wave line plotted with 100,000 points, only 75 of them actually end up 
being sent to Agg. Valgrind's callgrind tells me that most of the time 
spent on the trunk when you have many line segments is spent stroking 
the line. So, clearly, drastically reducing the number of line segments 
should help immensely.
When I made the conversion from draw_lines to everything using 
draw_path, I had skipped over the simplification step because a) the 
problem is a little harder with general polycurves (since you can't stop 
in the middle of a curve) and b) I had assumed, with no evidence, that 
Agg would be doing some of this anyway.
So, I'm in the process of porting the big loop in draw_lines over to the 
trunk. It's complicated by curve problem and the desire to avoid a 
copy, of course, but it should be doable. There's probably a cross-over 
point at which the time spent simplifying the line becomes less than the 
time spent stroking the line. That will probably have to be arrived at 
by experimentation.
Cheers,
Mike
Michael Droettboom wrote:
> 
> John Hunter wrote:
>> On Jan 15, 2008 7:46 AM, Michael Droettboom <md...@st...> wrote:
>>> Ah -- just thought of something else.
>>>
>>> If I adjust simple_plot_fps.py to have 100,000 data points rather than
>>> 1,000 I see something that starts to match with what you're seeing:
>>>
>>> GtkAgg:
>>> wallclock: 4.23297405243
>>> user: 3.33
>>> fps: 23.6240522057
>>>
>>> Gtk:
>>> wallclock: 15.0203828812
>>> user: 14.92
>>> fps: 6.65761990165
>>>
>>> TkAgg:
>>> wallclock: 4.8252530098
>>> user: 4.67
>>> fps: 20.7243018754
>>>
>>> You can see that the Gtk time is starting to explode. If I go to
>>> 1,000,000 points, Gtk runs out of memory before the first plot, whereas
>>> the other two continue to chug along at a reasonable pace.
>>>
>>> From looking at the code, I suspect the crucial difference is that the
>>> Gdk backend uses the Python sequence API (rather slow) to access the
>>> data as it gets rendered, whereas GtkAgg uses the numpy array interface
>>> which is essentially raw access to a C array.
>> This is not likely to be the culprit -- for drawing markers, the old
>> matplotlib API made a separate call to draw_polygon for every marker,
>> with a new gc each time. Many moons ago, we implemented draw_markers
>> as a renderer method to avoid this problem. For hundreds of thousands
>> of markers, we saw performance benefits of 25x to 100x. The backends
>> which implement draw_markers (Agg and PS) get the benefits, but the
>> other backends which did not are still slow. Basically it is a problem
>> with a lot of redundant function call overhead. The backend_bases
>> renderer method _draw_markers discusses this a little bit (it is
>> underscore hidden).
> 
> Markers are not the issue here. These benchmarks were done with lines. 
> There are markers for the ticks, of course, but the number of those 
> are fixed. I agree it's function call overhead, but I believe it's in 
> the overhead of PySequence_GetItem vs. array[index]. In both cases, the 
> line is still getting drawn with a single Python -> C function call.
> 
>> My guess is this difference will not be so pronounced on the trunk.
> 
> Actually, I'm getting surprising results there. Numbers are in fps.
> 
> 				Gtk		GtkAgg	
> 0.91.2, 1000 points		50		26
> 0.91.2, 10000 points		6		23
> trunk, 1000 points		38		31
> trunk, 10000 points		3		9
> 
> So, yes, the ratio between Gtk and GtkAgg on the trunk is not as 
> pronounced. I'm a little disappointed by the timings on the trunk -- 
> while one could say that Agg is a little better on the trunk with 1000 
> points, it doesn't scale nearly as well. That's certainly something to 
> look into -- and I don't have any thoughts offhand. I would expect the 
> trunk to do better since it doesn't perform a memory copy on the data 
> with each call to draw_line/draw_path.
> 
> Cheers,
> Mike
> 
-- 
Michael Droettboom
Science Software Branch
Operations and Engineering Division
Space Telescope Science Institute
Operated by AURA for NASA
From: John H. <jd...@gm...> - 2008年01月17日 04:14:03
On Jan 2, 2008 12:53 PM, Gurz=F3 P=E9ter <gu...@gm...> wrote:
> i think in print_png we must use "str(filename)" as we do it in
> print_raw, not "filename".
Added in maintenance branch and trunk -- thanks.
JDH

Showing 2 results of 2

Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.
Thanks for helping keep SourceForge clean.
X





Briefly describe the problem (required):
Upload screenshot of ad (required):
Select a file, or drag & drop file here.
Screenshot instructions:

Click URL instructions:
Right-click on the ad, choose "Copy Link", then paste here →
(This may not be possible with some types of ads)

More information about our ad policies

Ad destination/click URL:

AltStyle によって変換されたページ (->オリジナル) /