SourceForge logo
SourceForge logo
Menu

matplotlib-users — Discussion related to using matplotlib

You can subscribe to this list here.

2003 Jan
Feb
Mar
Apr
May
(3)
Jun
Jul
Aug
(12)
Sep
(12)
Oct
(56)
Nov
(65)
Dec
(37)
2004 Jan
(59)
Feb
(78)
Mar
(153)
Apr
(205)
May
(184)
Jun
(123)
Jul
(171)
Aug
(156)
Sep
(190)
Oct
(120)
Nov
(154)
Dec
(223)
2005 Jan
(184)
Feb
(267)
Mar
(214)
Apr
(286)
May
(320)
Jun
(299)
Jul
(348)
Aug
(283)
Sep
(355)
Oct
(293)
Nov
(232)
Dec
(203)
2006 Jan
(352)
Feb
(358)
Mar
(403)
Apr
(313)
May
(165)
Jun
(281)
Jul
(316)
Aug
(228)
Sep
(279)
Oct
(243)
Nov
(315)
Dec
(345)
2007 Jan
(260)
Feb
(323)
Mar
(340)
Apr
(319)
May
(290)
Jun
(296)
Jul
(221)
Aug
(292)
Sep
(242)
Oct
(248)
Nov
(242)
Dec
(332)
2008 Jan
(312)
Feb
(359)
Mar
(454)
Apr
(287)
May
(340)
Jun
(450)
Jul
(403)
Aug
(324)
Sep
(349)
Oct
(385)
Nov
(363)
Dec
(437)
2009 Jan
(500)
Feb
(301)
Mar
(409)
Apr
(486)
May
(545)
Jun
(391)
Jul
(518)
Aug
(497)
Sep
(492)
Oct
(429)
Nov
(357)
Dec
(310)
2010 Jan
(371)
Feb
(657)
Mar
(519)
Apr
(432)
May
(312)
Jun
(416)
Jul
(477)
Aug
(386)
Sep
(419)
Oct
(435)
Nov
(320)
Dec
(202)
2011 Jan
(321)
Feb
(413)
Mar
(299)
Apr
(215)
May
(284)
Jun
(203)
Jul
(207)
Aug
(314)
Sep
(321)
Oct
(259)
Nov
(347)
Dec
(209)
2012 Jan
(322)
Feb
(414)
Mar
(377)
Apr
(179)
May
(173)
Jun
(234)
Jul
(295)
Aug
(239)
Sep
(276)
Oct
(355)
Nov
(144)
Dec
(108)
2013 Jan
(170)
Feb
(89)
Mar
(204)
Apr
(133)
May
(142)
Jun
(89)
Jul
(160)
Aug
(180)
Sep
(69)
Oct
(136)
Nov
(83)
Dec
(32)
2014 Jan
(71)
Feb
(90)
Mar
(161)
Apr
(117)
May
(78)
Jun
(94)
Jul
(60)
Aug
(83)
Sep
(102)
Oct
(132)
Nov
(154)
Dec
(96)
2015 Jan
(45)
Feb
(138)
Mar
(176)
Apr
(132)
May
(119)
Jun
(124)
Jul
(77)
Aug
(31)
Sep
(34)
Oct
(22)
Nov
(23)
Dec
(9)
2016 Jan
(26)
Feb
(17)
Mar
(10)
Apr
(8)
May
(4)
Jun
(8)
Jul
(6)
Aug
(5)
Sep
(9)
Oct
(4)
Nov
Dec
2017 Jan
(5)
Feb
(7)
Mar
(1)
Apr
(5)
May
Jun
(3)
Jul
(6)
Aug
(1)
Sep
Oct
(2)
Nov
(1)
Dec
2018 Jan
Feb
Mar
Apr
(1)
May
Jun
Jul
Aug
Sep
Oct
Nov
Dec
2020 Jan
Feb
Mar
Apr
May
(1)
Jun
Jul
Aug
Sep
Oct
Nov
Dec
2025 Jan
(1)
Feb
Mar
Apr
May
Jun
Jul
Aug
Sep
Oct
Nov
Dec
S M T W T F S




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

Showing 6 results of 6

From: Darren D. <dd...@co...> - 2004年07月28日 19:27:49
Attachments: dd55.vcf
Hi Everyone,
This week I started looking into saving my work to a pickled file so I 
could reload them later and retain their names. In Matlab, all or some 
variables in a workspace can be saved to a .mat file, and it seems 
possible to do this with Python. comp.lang.python gave me some ideas, 
and I wonder if this would be useful to matplotlib.
The primary problems, as I see them, are:
1) all objects are not picklable
2) a variable's class must be defined before instantiating by unpickling
3) others that I am not aware of (well, there's always that)
Have you guys looked into a way to save variables from an interactive 
session? I'm sure there is an easier way; my not-too-Pythonic solution 
looks like:
import shelve
myvars = {}
for key in vars().keys():
 myvar = vars()[key]
 if str(type(myvar)) == "<type 'module'>": print "can't pickle <type 
'module'>"
 elif: str(type(myvar)) == "<type 'function'>": print "can't pickle 
<type 'function'>"
 elif: str(type(myvar)) == "<type 'unpicklable'>": print "can't 
pickle <type 'module'>"
 else: myvars.update({key:myvar})
s = shelve.open('myvars.mpl',protocol=-1)
s.update(myvars)
s.close()
and reloading the data:
import shelve
s = shelve.open('myvars.mpl')
for key in s.keys():
	try:
		vars().update({key:s[key]})
	except:
		print type(s[key]), ' is not currently defined.'
What do you think? A try/except PicklingError might be possiblem, but according to the pickling docs, an unspecified number of bytes may have been written to the file before the 
PicklingError exception is raised.
Also, is there any interest in saving figures as pickled objects, to be reloaded like Matlab's .fig files? 
Darren
-- 
Darren S. Dale
dd...@co...
PGP public key available
From: John H. <jdh...@ac...> - 2004年07月28日 13:03:22
>>>>> "Jin-chung" == Jin-chung Hsu <hs...@st...> writes:
 Jin-chung> One would expect the following will fill up the plot
 Jin-chung> window:
 >>>> n=zeros(20000) n[::2]=1 plot(n)
 Jin-chung> The plot "stops" a little more than half way, as if it
 Jin-chung> "runs out of ink".
 Jin-chung> It happens on Linux as well as Solaris, using either
 Jin-chung> numarray and Numeric, and both TkAgg and GTKAgg, but
 Jin-chung> not GTK. Is this due to some AGG limitation?
Hi Jin-chung,
This is indeed an agg problem. It is not a limitation in the sense of
'n is too large'. It looks like a bug in agg but it is too early to
say.
For example, this is OK
 >>> plot(n)
 >>> ax.set_ylim((-2,2))
as is 
 >>> plot(n, 'o')
or
 >>> plot(rand(20000))
Ie, the problem seems to occur when plotting solid lines where many of
the y values are similar, but is not a problem with the length of n,
per se.
I was able to reproduce the bug in pure agg c++ and posted to the agg
mailing list. Maxim (agg author) is on vacation, but I suspect he'll
provide some insight when he returns.
Thanks for letting me know,
JDH
From: Gregory L. <gre...@ff...> - 2004年07月28日 12:56:51
On Wed, 2004年07月28日 at 14:11, John Hunter wrote:
> >>>>> "Mark" == Mark Engelhardt <ma...@st...> writes:
> 
> Mark> Hi, I am not in interactive mode, I am writing scripts that
> Mark> handle a bunch of data and then plot it all. However, when
> Mark> show() is called, the script stops and waits for all the
> Mark> windows it opens to be closed before continuing. What I was
> Mark> hoping for was a way to have the plots be drawn in windows
> Mark> that were no longer hooked into the script, such that the
> Mark> script could continue running (to completion) regardless of
> Mark> what happened to the open windows. I did try 'draw()',
> Mark> which does not appear to open any new windows.
> 
> Hi Mark, 
> 
> Thanks for the explanation. Now I understand what you are trying to
> do. You are right about draw, all it does is redraw an existing
> figure, eg if you have changed some data in it.
Hi,
I think I recall I observed the requested behavior (i.e. get hand back
in interractive window or script after a show()) in previous version of
matplotlib.
I remember this cause reproducing this non-blocking behavior of show()
has proven to be a little bit hard to reproduce when developing FltkAgg
backend (I have done it using thread, and it works, so a solution would
be to use this backend when it is integrated).
But with TkAgg and GTKAgg, cvs version, on linux, it does not work
anymore (i.e. show() do not return hand, as mentioned)
I tested some earlier version (0.54 on windows, TkAgg) to see if I have
so false souvenir, but it indeed work as Mark want (i.e. show() is
non-blocking )...So I guess something has changed in the show()
mechanism since, maybe to deal with the new event mechanism?
Best regards,
Greg.
From: John H. <jdh...@ac...> - 2004年07月28日 12:35:27
>>>>> "Mark" == Mark Engelhardt <ma...@st...> writes:
 Mark> Hi, I am not in interactive mode, I am writing scripts that
 Mark> handle a bunch of data and then plot it all. However, when
 Mark> show() is called, the script stops and waits for all the
 Mark> windows it opens to be closed before continuing. What I was
 Mark> hoping for was a way to have the plots be drawn in windows
 Mark> that were no longer hooked into the script, such that the
 Mark> script could continue running (to completion) regardless of
 Mark> what happened to the open windows. I did try 'draw()',
 Mark> which does not appear to open any new windows.
Hi Mark, 
Thanks for the explanation. Now I understand what you are trying to
do. You are right about draw, all it does is redraw an existing
figure, eg if you have changed some data in it.
You have to get a little bit into the GTK API / event handling
mechanism to do this right. One way is to use the full blown gtk API
with matplotlib, as in examples/embedding_in_gtk*.py.
The easier way is to just use as much of the API as you need, and take
over the function of the backend 'show' function. You'll be doing an
end run around the matplotlib.matlab figure manager, which means some
of these won't work (like gcf, close, etc.). That's OK, because you
won't be using the matplotlib.matlab interface. Do not import
matplotlib.matlab with this approach as the result is undefined!
There are a few things you need to do
 * Define function(s) / class(es) which create your figures
 * Define a main function which call these functions as necessary.
 Return False from this function
 * Add main to the gtk idle handler. Returning False in 'main' will
 cause this function to be called only once.
 * Start the gtk mainloop yourself. After gtk is started, your
 'main' function will be called and you're off to the races.
 * If there is something you want from matplotlib.matlab, say the
 'axis' command, just look at the src code to see how axis is
 implemented with the matplotlib API and make those calls yourself.
You may want to spend some time with the pygtk class reference at
http://www.pygtk.org/pygtk2reference/gtk-class-reference.html and the
matplotlib class reference at
http://matplotlib.sourceforge.net/classdocs.html. In the example
below
 * canvas inherits from gtk.DrawingArea and
 backends.FigureCanvasGTK (which in turn derives from 
 backend_bases.FigureCanvasBase)
 * manager is a backends.backend_gtk.FigureManagerGTK
 which inherits from backend_bases.FigureManagerBase
 * manager.window is a gtk.Window() (you can also hide or close this
 window with pygtk API calls)
 * ax is a axes.Subplot which inherits from axes.Axes
Here is an example
#!/usr/bin/env python
import matplotlib
matplotlib.use('GTKAgg')
from matplotlib.backends.backend_gtkagg import new_figure_manager
from matplotlib.numerix import *
import gtk
def main(*args):
 manager1 = new_figure_manager(1)
 canvas1 = manager1.canvas
 fig1 = canvas1.figure
 ax1 = fig1.add_subplot(111)
 ax1.plot([1,2,3])
 manager1.window.show() # non blocking
 manager2 = new_figure_manager(2)
 canvas2 = manager2.canvas
 fig2 = canvas2.figure
 ax2 = fig2.add_subplot(111)
 ax2.plot([6,5,4])
 manager2.window.show()
 return False
gtk.idle_add(main)
gtk.mainloop()
From: Mark E. <ma...@st...> - 2004年07月28日 05:44:12
Hi,
I am not in interactive mode, I am writing scripts that handle a bunch 
of data and then plot it all. However, when show() is called, the 
script stops and waits for all the windows it opens to be closed before 
continuing. What I was hoping for was a way to have the plots be drawn 
in windows that were no longer hooked into the script, such that the 
script could continue running (to completion) regardless of what 
happened to the open windows. I did try 'draw()', which does not 
appear to open any new windows.
In answer to your questions, here are the relevant lines from my 
.matplotlibrc:
backend : GTKAgg # the default backend
numerix : numarray #Numeric # Numeric or numarray
interactive : False # see 
http://matplotlib.sourceforge.net/interactive.htm
Thanks for everyone's help on subplot positioning (or avoidance ;)) - 
I'll take a look.
- Mark
On Jul 26, 2004, at 2:06 PM, John Hunter wrote:
> Mark> 2. Is there a way to make the 'show()' command execute so
> Mark> that the script keeps running (instead of waiting for the
> Mark> windows to be closed), and to have the output persist past
> Mark> the end of the run?
>
> You should only call show once per script. I repeat, you should only
> call show once per script -
> http://matplotlib.sourceforge.net/faq.html#SHOW
>
> matplotlib-0.60.2 has a "draw" command to force a canvas redraw. This
> is non blocking. Earlier versions allow you to do, equivalently,
> get_current_fig_manager().canvas.draw(). Does this do what you want?
> I am not sure what you are after when you write "have the output
> persist past the end of the run". Launch the python interpreter?
>
> Please let me know what backend you are using and explain a bit more
> what it is you are trying to do. Are you running in interactive mode?
>
> JDH
>
From: Chris F. <cf...@th...> - 2004年07月28日 04:31:16
 > Which backend are you using? Chris Fuller submitted a tk widget for
 > just this purpose -
 > http://sourceforge.net/mailarchive/message.php?msg_id=8901913. It
 > would be fairly easy to port to other GUIs. It"s on the list of things
 > to do, but I haven"t had time. Other than that, your best option is
 > to manually set the axes size, eg using the "axes" command or calling
the fig_layout.py module is quite agnostic w.r.t. backend, the included demo
(layout_demo.py) is where TkAgg is invoked. The only dependency is on the figure
object itself, so there should be no problem using this functionality with any
backend. The embedded documentation should get you started.
You may need to use matlab.gcf() to get this figure object, if you are not using
the object oriented interface (for instance, interactively)
Chris

Showing 6 results of 6

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 によって変換されたページ (->オリジナル) /