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
(7) |
2
(5) |
3
(18) |
4
(9) |
5
(13) |
6
(14) |
7
(8) |
8
(7) |
9
(6) |
10
(6) |
11
(24) |
12
(14) |
13
(9) |
14
(21) |
15
(6) |
16
(1) |
17
(20) |
18
(42) |
19
(16) |
20
(21) |
21
(41) |
22
(13) |
23
(11) |
24
(15) |
25
(32) |
26
(27) |
27
(29) |
28
(10) |
29
(3) |
30
(1) |
31
(5) |
|
|
|
|
|
Hi all, I have a application using a wxPython gui which has matplotlib figure, axes etc.... The code works fine and the display of mathtext works fine when run in python. When I compile it and try to display any text it doesn't render the text at all (this can be anything from a simple letter to a more complex equation). I get an output error: myDir\dist\library.zip\matplotlib\mathtext.py:722: MathTextWarning: Unrecognized symbol 'y'. Substituting with a dummy symbol. I added the the include "matplotlib.mathtext" as before I got an error that it didn't know what mathtext was. Any ideas? I've looked on line at http://www.py2exe.org/index.cgi/MatPlotLib, and tried all they suggest but no luck so far. Thanks for any ideas. Cheers my py2exe compile.py file is: from distutils.core import setupimport py2exefrom distutils.core import setup# We need to import the glob module to search for all files.import globimport matplotlib opts = { 'py2exe': { "includes" : ["matplotlib.backends.backend_wxagg", "matplotlib.figure","pylab", "numpy", "matplotlib.numerix.fft", "matplotlib.numerix.linear_algebra", "matplotlib.numerix.random_array", "matplotlib.mathtext" ], 'dll_excludes': ['libgdk-win32-2.0-0.dll', 'libgobject-2.0-0.dll'] } } # Looked online and tried this next line - but it doesn't compile. #data_files=[matplotlib.get_py2exe_datafiles()]# Save matplotlib-data to mpl-data ( It is located in the matplotlib\mpl-data # folder and the compiled programs will look for it in \mpl-data# note: using matplotlib.get_mpldata_infodata_files = [(r'mpl-data', glob.glob(r'C:\Python25\Lib\site-packages\matplotlib\mpl-data\*.*')), # Because matplotlibrc does not have an extension, glob does not find it (at least I think that's why) # So add it manually here: (r'mpl-data', [r'C:\Python25\Lib\site-packages\matplotlib\mpl-data\matplotlibrc']), (r'mpl-data\images',glob.glob(r'C:\Python25\Lib\site-packages\matplotlib\mpl-data\images\*.*')), (r'mpl-data\fonts',glob.glob(r'C:\Python25\Lib\site-packages\matplotlib\mpl-data\fonts\*.*'))] setup(windows=[{"script" : "main.py"}], options=opts, data_files=data_files) _________________________________________________________________ Win 100’s of Virgin Experience days with BigSnapSearch.com http://www.bigsnapsearch.com
Michael Droettboom wrote: > I think the real reason this wasn't done is that its tricky to do at the > C level in a cross-platform way. At present it uses the regular POSIX > fopen in C, which isn't really "Unicode aware". The actual error is from trying to put the filename in a std::string, but yes, I'm sure the fopen issue is the driver. Does C++ offer anything better? See the "Unicode > filenames" section of the link below for some of the complications. > Linux is particularly hard to get right: > > http://www.amk.ca/python/howto/unicode Thanks, that's a good one. > you can do the following as a workaround > (with a performance hit from making many Python function calls): > > savefig(open(u"CrazyUnicodeFilename.png", "w")) thanks, I'll give that a try. I'm confused, though, why the many Python function calls? the C++ code doesn't just grab the file pointer? Thanks, -Chris -- Christopher Barker, Ph.D. Oceanographer Emergency Response Division NOAA/NOS/OR&R (206) 526-6959 voice 7600 Sand Point Way NE (206) 526-6329 fax Seattle, WA 98115 (206) 526-6317 main reception Chr...@no...
It's a very good idea, when posting questions to a list like this, to ask not only the specific question, but also give the background, so we can wee what problem you are trying to solve. sa6113 wrote: > I use matplotlib and Backend Agg to draw a plot , I want to show this plot in > my GUI in specific area (Plot area) , This is background we need. However, you've left out a key point: what GUI toolkit are you using? There is no such thing as a python "image", but each toolkit has it's own implementation, so each needs to be treated differently. I need to have the image object in > oder to show it, so I have to convert this plot to string or array or save > in buffer and then load it to an Image , If you are using any of the supported back ends: Tk, QT, wx, GTK, then MPL has already solved that problem for you -- see the "embedded_in**" examples. If you are using something else, then take a look at the various back-end codes -- one of them is probably similar enough to yous to give you inspiration. And yes, you can get a string or buffer object of RBG data from FigureCanvasAgg. > I want to know , can I accomplish > this without using PIL , You shouldn't need PIL. -Chris -- Christopher Barker, Ph.D. Oceanographer Emergency Response Division NOAA/NOS/OR&R (206) 526-6959 voice 7600 Sand Point Way NE (206) 526-6329 fax Seattle, WA 98115 (206) 526-6317 main reception Chr...@no...
More complete: I tried all permunations of backends. Now I stick to PS, because I use matplotlib from commandline with scripts. The environment is debian/etch with a current version of matplotlib (self compiled). Try this script ******************************************** from pylab import * t = arange(0.0, 2.0, 0.01) s = sin(2*pi*t) plot(t, s) grid(True) # matlab handle graphics style xticklines = getp(gca(), 'xticklines') yticklines = getp(gca(), 'yticklines') xgridlines = getp(gca(), 'xgridlines') ygridlines = getp(gca(), 'ygridlines') xticklabels = getp(gca(), 'xticklabels') yticklabels = getp(gca(), 'yticklabels') setp(xticklines, 'linewidth', 3) setp(yticklines, 'linewidth', 3) setp(xgridlines, 'linestyle', '-') setp(ygridlines, 'linestyle', '-') setp(yticklabels, 'color', 'r', fontsize='medium') setp(xticklabels, 'color', 'r', fontsize='medium', family='sans-serif') savefig('axprops_demo') ****************************************** On my system the line setp(xticklabels, 'color', 'r', fontsize='medium', family='sans-serif') doesn't change the font family. Best regards: Gerolf -- Dipl. Phys. Gerolf Ziegenhain (ge...@zi...) Private: Klopstockstrasse 21 - 65187 Wiesbaden - Germany Office: Room 46-332 - Erwin-Schrödinger-Str.46 - TU Kaiserslautern - Germany Web: gerolf.ziegenhain.com Tel.: +49-611-18840590 Fax: +49-611-18840599
Matthias Michler wrote: > I'm not sure that I understand you correctly. The code I refering is the one > which I attached some mails ago. The following works for me: Ah, okay, to get the problem I was having, change your script as follows: > --------------------------------------------------------------------------------- > from pylab import * > from datetime import datetime > from time import sleep > > ion() # interactive mode 'on' > figure() > ax = subplot(111, autoscale_on=True) > > x, y = [datetime.now()], [0] > line = plot(x, y, label="my_data")[0] > # get the line-object as the first element > # of the tuple returned by plot > legend() > for i in arange(30): > x.append(datetime.now()) # append new values > y.append(i**2) > line.set_data(x,y) # reset data > ax.relim() # reset axes limits > ax.autoscale_view() # rescale axes > draw() # redraw current figure > sleep(0.3) # wait 0.3 seconds > > ioff() > show() So, basically make the x axis time instead of numbers. I think the problem is actually that the daets are quite long in their format. If they were rotated through 90 degress it'd likely be fine. How would I do this? Also, how would I get this kind of updating with bar charts or errorbars? cheers, Chris -- Simplistix - Content Management, Zope & Python Consulting - http://www.simplistix.co.uk
More complete: I tried all permunations of backends. Now I stick to PS, because I use matplotlib from commandline with scripts. The environment is debian/etch with a current version of matplotlib (self compiled). Try this script ******************************************** from pylab import * t = arange(0.0, 2.0, 0.01) s = sin(2*pi*t) plot(t, s) grid(True) # matlab handle graphics style xticklines = getp(gca(), 'xticklines') yticklines = getp(gca(), 'yticklines') xgridlines = getp(gca(), 'xgridlines') ygridlines = getp(gca(), 'ygridlines') xticklabels = getp(gca(), 'xticklabels') yticklabels = getp(gca(), 'yticklabels') setp(xticklines, 'linewidth', 3) setp(yticklines, 'linewidth', 3) setp(xgridlines, 'linestyle', '-') setp(ygridlines, 'linestyle', '-') setp(yticklabels, 'color', 'r', fontsize='medium') setp(xticklabels, 'color', 'r', fontsize='medium', family='sans-serif') savefig('axprops_demo') ****************************************** On my system the line setp(xticklabels, 'color', 'r', fontsize='medium', family='sans-serif') doesn't change the font family. Best regards: Gerolf -- Dipl. Phys. Gerolf Ziegenhain (ge...@zi...) Private: Klopstockstrasse 21 - 65187 Wiesbaden - Germany Office: Room 46-332 - Erwin-Schrödinger-Str.46 - TU Kaiserslautern - Germany Web: gerolf.ziegenhain.com Tel.: +49-611-18840590 Fax: +49-611-18840599
Gerolf Ziegenhain wrote: > Dear Mailinglist, > > Today I tried to change the fontset to sans-serif for a whole plot. > Everything except the ticks could be adjusted. > > > This is what I tried first: > ******************************************************* > ffont = {'size':'20','family':'sans-serif'} > xticks(**ffont) > ******************************************************* > Hmmm... This works for me. What backend are you using? Perhaps it isn't updating? Also, do these two lines + show() alone not work, or is it only in the context of something else? Also, what platform are you on? Mike -- Michael Droettboom Science Software Branch Operations and Engineering Division Space Telescope Science Institute Operated by AURA for NASA
Hello Chris, On Thursday 27 March 2008 12:22, Chris Withers wrote: > Matthias Michler wrote: > >>> the above script leads > >>> to a different behaviour on my system. > >> > >> What is that behaviour and what version of matplotlib are you using? > > > > I think it is the expected behaviour. The number of xtick is aproximately > > constant and some tick get sorted out, when the xlimits are increasing. > > I'm using matplotlib-svn r5024 on Debian etch. > > Hmm, do you have a code snippet to demonstrate this? > Maybe I'm missing some vital step that causes the axis to re-calculate > its ticks? I'm not sure that I understand you correctly. The code I refering is the one which I attached some mails ago. The following works for me: --------------------------------------------------------------------------------- from pylab import * from time import sleep ion() # interactive mode 'on' figure() ax = subplot(111, autoscale_on=True) x, y = [0], [0] line = plot(x, y, label="my_data")[0] # get the line-object as the first element # of the tuple returned by plot legend() for i in arange(30): x.append(i) # append new values y.append(i**2) line.set_data(x,y) # reset data ax.relim() # reset axes limits ax.autoscale_view() # rescale axes draw() # redraw current figure sleep(0.3) # wait 0.3 seconds ioff() show() ---------------------------------------------------------------------------------- And your mpltest.py works as well for me. best regards Matthias
Dear Mailinglist, Today I tried to change the fontset to sans-serif for a whole plot. Everything except the ticks could be adjusted. This is what I tried first: ******************************************************* ffont = {'size':'20','family':'sans-serif'} xticks(**ffont) ******************************************************* No change in the font family. But I can change the size without problems. I removed the ~/.matplotlib/FONTCACHE stuff as described here(2). Following (1) I tried again to change the font using ******************************************************* import pylab pylab.figure() ax = pylab.axes() ax.plot(pylab.arange(10)) xlabels = ax.get_xticklabels() xlabel0 = xlabels[0] # one of the xtick labels xlabel0.get_fontsize() xlabel0.set_fontsize(20) pylab.show() ******************************************************* Again nothing changed. Using ipython I got this: ******************************************************* In [192]: xlabels[0].get_fontname() Out[192]: 'Bitstream Vera Serif, New Century Schoolbook, serif' In [195]: xlabels[0].set_family("sans-serif") In [196]: xlabels[0].get_fontname() Out[196]: 'Bitstream Vera Sans, Lucida Grande, Verdana, sans-serif' In [197]: show() ******************************************************* Summary: It appears to me like I can change the default fontfamily, but somehow there is no change in the output. What could be the problem? Best regards: Gerolf (1) http://www.nabble.com/axes-numbers-font-size-td14459877.html (2) http://matplotlib.sourceforge.net/faq.html#FONTMISSING -- Dipl. Phys. Gerolf Ziegenhain Web: http://gerolf.ziegenhain.com Email: mai...@zi... Fax: +49 611 18840599 Phone: +49 611 18840590 Office: Erwin-Schrödinger-Str. 46 / Room 46.332 / 67663 Kaiserslautern / Germany Private: Klopstockstr. 21 / 65187 Wiesbaden / Germany
Matthias Michler wrote: >>> the above script leads >>> to a different behaviour on my system. >> What is that behaviour and what version of matplotlib are you using? > > I think it is the expected behaviour. The number of xtick is aproximately > constant and some tick get sorted out, when the xlimits are increasing. > I'm using matplotlib-svn r5024 on Debian etch. Hmm, do you have a code snippet to demonstrate this? Maybe I'm missing some vital step that causes the axis to re-calculate its ticks? > sorry. I have no idea where this problems comes from. I have seen that using > idle and the latest release of matplotlib on and winxp, but I can't reproduce > it on my linux system. *sigh* ;-) Chris -- Simplistix - Content Management, Zope & Python Consulting - http://www.simplistix.co.uk
And, before someone asks, "Why are you using "h" and this line: h= [seg[0]*0.000278,seg[1]*0.000278] ax.annotate(seqnum[nshape],h)", I was using this, instead, but tried to experiment with things to try to make things work right: ax.annotate(seqnum[nshape],seg) . I usually don't "give up" and post a question unless I've tried a myriad of things, and unfortunately those things sometimes show up in the example code. Regards, Kurt
OK Jeff, Thanks for your help on the previous question - I had been playing with different projections and resolutions, so that's why the comments didn't match the actual settings in the procedure calls. Now for a "real" problem: I'm trying to plot the cities from this web site: http://nationalatlas.gov/metadata/citiesx020.faq.html using that shapefile, which uses points, not polygons (it took a long time to figure out that difference from the example of fillstates.py). http://nationalatlas.gov/atlasftp.html?openChapters=chpref#chpref While I think I'm loading everything and displaying everything correctly, the values are not plotting right, nor do they seem realistic. For instance the point values look like this (which really can't be right): Shape num Fairbanks, coords=(42082.855349492747, 5336578.2660309337) Shape num Anchorage, coords=(-442294.67146861833, 5031412.4918638617) print shp_info - the second value shows to use points not polys: (35432, 1, [-174.20294189453125, 17.711706161499023, 0.0, 0.0], [178.87460327148437, 71.290138244628906, 0.0, 0.0]) Dictionaries: ['STATE_FIPS', 'NAME', 'POP_2000', 'FEATURE', 'COUNTY', 'STATE', 'FIPS', 'CITIESX020', 'FIPS55', 'DISPLAY', 'POP_RANGE'] STATE_FIPS = 02, NAME = Anchorage, POP_2000=260283, FEATURE = County Seat, COUNTY=Anchorage Borough, STATE=AK, FIPS=02020, CITIESX020 = 194, FIPS55=03000, DISPLAY=0, POP_RANGE=250,000 - 499,999 Here's the code: =============== import pylab as p import numpy from matplotlib.toolkits.basemap import Basemap as Basemap from matplotlib.colors import rgb2hex from matplotlib.patches import Polygon # Lambert Conformal map of lower 48 states. # create new figure fig=p.figure() m1 = Basemap(llcrnrlon=-119,llcrnrlat=22,urcrnrlon=-64,urcrnrlat=49,\ projection='lcc',lat_1=33,lat_2=45,lon_0=-95,resolution='c') shp_info = m1.readshapefile(r'C:\Python25\Lib\basemap-0.9.9.1\examples\citiesx020','states',drawbounds=True) ax=p.gca() #define SHPT_POINT 1 Points #define SHPT_ARC 3 Arcs (Polylines, possible in parts) #define SHPT_POLYGON 5 Polygons (possible in parts) #define SHPT_MULTIPOINT 8 MultiPoint (related points) print shp_info print m1.states_info[0].keys() seqnum={} criteriatodisplay=[] ii=0 for shapedict in m1.states_info: if int(shapedict['POP_2000'])>100000: #'STATE_FIPS', 'NAME', 'POP_2000', 'FEATURE', 'COUNTY', 'STATE', 'FIPS', 'CITIESX020', 'FIPS55', 'DISPLAY', 'POP_RANGE'] print 'STATE_FIPS = %s, NAME = %s, POP_2000=%s, FEATURE = %s, COUNTY=%s, STATE=%s, FIPS=%s, CITIESX020 = %s, FIPS55=%s, DISPLAY=%s, POP_RANGE=%s' %\ (str(shapedict['STATE_FIPS']), str(shapedict['NAME']), str(shapedict['POP_2000']), str(shapedict['FEATURE']), str(shapedict['COUNTY']), str(shapedict['STATE']), str(shapedict['FIPS']), str(shapedict['CITIESX020']), str(shapedict['FIPS55']), str(shapedict['DISPLAY']), str(shapedict['POP_RANGE'])) seqnum[shapedict['CITIESX020']]=shapedict['NAME'] criteriatodisplay.append(shapedict['CITIESX020']) ii+=1 print ii for nshape,seg in enumerate(m1.states): if nshape in criteriatodisplay: print 'Shape num %s, coords=%s' % (seqnum[nshape], seg) h= [seg[0]*0.000278,seg[1]*0.000278] ax.annotate(seqnum[nshape],h) m1.drawcoastlines() m1.fillcontinents() m1.drawcountries() m1.drawstates() m1.drawparallels(numpy.arange(25,65,4),labels=[1,0,0,0]) m1.drawmeridians(numpy.arange(-120,-40,4),labels=[0,0,0,1]) p.title('Test Cities') p.show() ============= Regards, Kurt
KURT PETERS wrote: > I'm trying what I thought was a simple test and getting "bad" results. I am > taking some lat long coords, and feeding it into a map. The conversion is > not giving "real" values that can be plotted on a map (and actually produces > an error when I use annotate). > I'm including the simple code and the output: > >>>>>>>>>> CODE<<<<<<<<<<<<<<< >>>>>>>>>> > import pylab as p > import numpy > from matplotlib.toolkits.basemap import Basemap as Basemap > from matplotlib.colors import rgb2hex > from matplotlib.patches import Polygon > > # Lambert Conformal map of lower 48 states. > # create new figure > fig=p.figure() > m1 = Basemap(llcrnrlon=-119,llcrnrlat=22,urcrnrlon=-64,urcrnrlat=49,\ > > projection='ortho',lat_1=33,lat_2=45,lon_0=-95,lat_0=40,resolution='c') > > > #COS > #D + M/60 + S/3600 > COSLat=38+56.0/60.0+0.013 > COSLon=-1*(104+48.0/60.0) > WASHLat=38+53.0/60.0+23.0/3600.0 > WASHLon=-1*(77+32.0/3600.0) > > print COSLat > x, y = m1(COSLat,COSLon) > print 'x =%f, y=%f' % (x,y) > > m1.plot([x],[y],'ko') > ax=p.gca() > ax.annotate('COS1',(COSLat,COSLon)) > #ax.annotate('COS2',(x,y)) > ax.annotate('Wash1',(WASHLat,WASHLon)) > x, y = m1(WASHLat,WASHLon) > #ax.annotate('Wash2',(x,y)) > > m1.drawcoastlines() > m1.fillcontinents() > m1.drawcountries() > m1.drawstates() > m1.drawparallels(numpy.arange(25,65,4),labels=[1,0,0,0]) > m1.drawmeridians(numpy.arange(-120,-40,4),labels=[0,0,0,1]) > p.title('full resolution') > p.show() > <<<<<<<<<Output>>>>>>>>>>> > 38.9463333333 > x =1000000000000000000000000000000.000000, > y=1000000000000000000000000000000.000000 > > Regards, > Kurt > > Kurt: If you want the Lambert conformal projection, you should use projection='lcc', not 'ortho'. Nevertheless, your example works for me if I change the order of the arguments passed to the Basemap instance to x, y = m1(COSLon,COSLat) x, y = m1(WASHLon,WASHLat) Note, longitude goes first. Also, if you want 'full resolution' coastlines, use resolution='h'. -Jeff -- Jeffrey S. Whitaker Phone : (303)497-6313 NOAA/OAR/CDC R/PSD1 FAX : (303)497-6449 325 Broadway Boulder, CO, USA 80305-3328
I think the real reason this wasn't done is that its tricky to do at the C level in a cross-platform way. At present it uses the regular POSIX fopen in C, which isn't really "Unicode aware". See the "Unicode filenames" section of the link below for some of the complications. Linux is particularly hard to get right: http://www.amk.ca/python/howto/unicode However, the Python runtime does take care of many of these details in a (mostly) reasonable way. I think the easiest solution is to open the file on the Python side (rather than using POSIX fopen in C as we do now), and pass the file descriptor itself over to C. There was a bug in extracting the file descriptor from a Python file object in earlier versions of mpl, so it was removed a while ago, but I think I have it working again. This should now be fixed on r5025 (branch) and r5026 (trunk) Note that if you are running 0.91.2 (and not SVN, where this was subsequently broken in r4874), you can do the following as a workaround (with a performance hit from making many Python function calls): savefig(open(u"CrazyUnicodeFilename.png", "w")) On a related note -- there is still an issue where fonts with Unicode paths can not be loaded. That can hopefully be addressed in a similar manner, but there are a few more code paths to fix up there. Mike Christopher Barker wrote: > Hi all, > > I'm writing a little MPL embedded in wxPython app, and just ran into this: > > Traceback (most recent call last): > ... > ... > "..../matplotlib-0.91.2-py2.5-macosx-10.3-fat.egg/matplotlib/backends/backend_agg.py", > > line 397, in print_png > self.get_renderer()._renderer.write_png(filename, > self.figure.dpi.get()) > TypeError: cannot return std::string from Unicode object > > As soon as I saw it, I knew what happened: I'm running the unicode > version of wxPython, so the filename I got back from a SaveFile Dialog > is in unicode. Now, it's easy enough for me to turn that into a string > for now, but as more and more file systems are implemented in unicode, > it might be nice if we could use unicode file names with MPL. > > Are there any plans along these lines? Or are we just going to have to > wait for py3k? > > -CHB > > -- Michael Droettboom Science Software Branch Operations and Engineering Division Space Telescope Science Institute Operated by AURA for NASA
Forget it. I was putting lat/long instead of long/lat. Regards, Kurt
I'm trying what I thought was a simple test and getting "bad" results. I am taking some lat long coords, and feeding it into a map. The conversion is not giving "real" values that can be plotted on a map (and actually produces an error when I use annotate). I'm including the simple code and the output: >>>>>>>>>CODE<<<<<<<<<<<<<<< import pylab as p import numpy from matplotlib.toolkits.basemap import Basemap as Basemap from matplotlib.colors import rgb2hex from matplotlib.patches import Polygon # Lambert Conformal map of lower 48 states. # create new figure fig=p.figure() m1 = Basemap(llcrnrlon=-119,llcrnrlat=22,urcrnrlon=-64,urcrnrlat=49,\ projection='ortho',lat_1=33,lat_2=45,lon_0=-95,lat_0=40,resolution='c') #COS #D + M/60 + S/3600 COSLat=38+56.0/60.0+0.013 COSLon=-1*(104+48.0/60.0) WASHLat=38+53.0/60.0+23.0/3600.0 WASHLon=-1*(77+32.0/3600.0) print COSLat x, y = m1(COSLat,COSLon) print 'x =%f, y=%f' % (x,y) m1.plot([x],[y],'ko') ax=p.gca() ax.annotate('COS1',(COSLat,COSLon)) #ax.annotate('COS2',(x,y)) ax.annotate('Wash1',(WASHLat,WASHLon)) x, y = m1(WASHLat,WASHLon) #ax.annotate('Wash2',(x,y)) m1.drawcoastlines() m1.fillcontinents() m1.drawcountries() m1.drawstates() m1.drawparallels(numpy.arange(25,65,4),labels=[1,0,0,0]) m1.drawmeridians(numpy.arange(-120,-40,4),labels=[0,0,0,1]) p.title('full resolution') p.show() <<<<<<<<<Output>>>>>>>>>>> 38.9463333333 x =1000000000000000000000000000000.000000, y=1000000000000000000000000000000.000000 Regards, Kurt
On Wed, Mar 26, 2008 at 10:38 PM, sa6113 <s.p...@gm...> wrote: > > I use matplotlib and Backend Agg to draw a plot , I want to show this plot in > my GUI in specific area (Plot area) , I need to have the image object in [snip] > Is it clear? Not to me :) Do you mean that you've already created a plot and just want to show it in your GUI? What GUI toolkit are you using? You may want to look in the various embedding_in_*.py examples. A>
Dear matplotlib I have a newbie question (I am new to python, migrating from Matlab). Just like the subject suggests, I need to display an image X stored in a matrix (well, a 2D numpy array in fact) versus the coordinates specified by arrays x and y. Further, it would be nice if mouse position was returned in terms of those coordinates as well, but that's just for a nicety - I can map it myself. But main thing is I failed to find the way to get the image versuscoordinates in imshow() and figimage(). I also failed to find the answer in this forum. Hence I ask for any suggestions. -- View this message in context: http://www.nabble.com/does-matplotlib-have-an-analog-to-imagesc%28x%2Cy%2CX%29-of-Matlab--tp16323613p16323613.html Sent from the matplotlib - users mailing list archive at Nabble.com.
On Wednesday 26 March 2008 19:39, Chris Withers wrote: > Matthias Michler wrote: > >> My x-axis is time, and as new points are plotted, even though I'm > >> following the above recipe pretty closely, the x-tick spacing isn't > >> getting sorted out, so I end up with just a jumble as the tick labels > >> for the x-axis. Do you know why this might be? > > > > I'm not sure I understand correctly, but if the number of xticks > > increases dramatically (nobody could see the individual ticks), > > Indeed, it looks like the Tick spacing is staying as it was when the > first point was plotted, so when hundreds more points are plotted, I > just get a jumble of labels on the x-axis. > > > the above script leads > > to a different behaviour on my system. > > What is that behaviour and what version of matplotlib are you using? I think it is the expected behaviour. The number of xtick is aproximately constant and some tick get sorted out, when the xlimits are increasing. I'm using matplotlib-svn r5024 on Debian etch. > >> Shame I get that horrible exception when I do close the plot window, > >> wish I knew how to make it stop :-S > > > > I don't know which exception you refer to, but sometimes if gives > > problems if the interactive mode wasn't switched off ("ioff()") before > > the scripts ends or "show()" is called. > > If I run the attached script, and hit Ctrl-C in the DOS box running it, > I get: > > C:\>python mpltest.py > Traceback (most recent call last): > File "mpltest.py", line 3, in <module> > show() > File > "C:\Python25\Lib\site-packages\matplotlib\backends\backend_tkagg.py", li > e 76, in show > Tk.mainloop() > File "C:\Python25\lib\lib-tk\Tkinter.py", line 328, in mainloop > _default_root.tk.mainloop(n) > KeyboardInterrupt > Fatal Python error: PyEval_RestoreThread: NULL tstate > > This application has requested the Runtime to terminate it in an unusual > way. > Please contact the application's support team for more information. > > I've had a similar error when I hit the red cross in the corner of the > window with other scripts, although not this one :-S sorry. I have no idea where this problems comes from. I have seen that using idle and the latest release of matplotlib on and winxp, but I can't reproduce it on my linux system. Matthias
I use matplotlib and Backend Agg to draw a plot , I want to show this plot in my GUI in specific area (Plot area) , I need to have the image object in oder to show it, so I have to convert this plot to string or array or save in buffer and then load it to an Image , I want to know , can I accomplish this without using PIL , because I need to build, test and verify any new package added to the system on 6 different platforms, and it might take a long time and at high expertise level to add the module to our entire system. What I have to do? I can convert it to string or array with numpy or FigureCanvas or ect. , my problem is how to load this array or string to image ! Is it clear? Anthony Floyd-2 wrote: > > Forgot to reply-to-list... > > ---------- Forwarded message ---------- > From: Anthony Floyd <ant...@gm...> > Date: Wed, Mar 26, 2008 at 4:54 PM > Subject: Re: [Matplotlib-users] load data from string or array to Image > To: sa6113 <s.p...@gm...> > > > On Wed, Mar 26, 2008 at 1:33 AM, sa6113 <s.p...@gm...> wrote: > > > > > > I have a problem to load data from string or array to Image but > without > > using PIL , because I have to check the application in 6 different > platforms > > like Windows 32bit, Windows X64 (64bit version), Linux 32bit, Linux > 64bit > > x86_64, Linux IPF (Itanium Processor Family) and HP-UX 64. > > > > There is a code but I don't want to use PIL : > > http://mail.python.org/pipermail/image-sig/1998-October/000572.html > > > > Can I accomplish the same thing using the modules that are already on > the > > system, or those that are pure Python (not requiring any compilation > or > > binary download)? > > I went through this just a few weeks ago. Now, mind you I'm using wx > and numpy already. > > My solution was to turn my .png into a Python string using img2py.py > in the wx/tools directory. > > With the string, I then used the following code to return the image (a > watermark) as an array that figimage() or imshow() can use directly. > I'm sure the code can be optimized, but it works fast enough for me... > > def getWatermarkArray(): > rows = 28 > columns = 200 > dimensions = 3 > > image = getWatermarkImage() > # image array is a string of hex values > imageString = image.GetData() > > imageList = [ord(item) for item in imageString] > > imageArray = numpy.zeros(shape=(28,200,3), dtype=numpy.float32) > > imageCounter = 0 > > for rowCounter in range(rows): > for columnCounter in range(columns): > for dimCounter in range(dimensions): > imageArray[rowCounter][columnCounter][dimCounter] = > imageList[imageCounter]/255. > imageCounter += 1 > > return imageArray > > HTH, > A> > > ------------------------------------------------------------------------- > Check out the new SourceForge.net Marketplace. > It's the best place to buy or sell services for > just about anything Open Source. > http://ad.doubleclick.net/clk;164216239;13503038;w?http://sf.net/marketplace > _______________________________________________ > Matplotlib-users mailing list > Mat...@li... > https://lists.sourceforge.net/lists/listinfo/matplotlib-users > > -- View this message in context: http://www.nabble.com/load-data-from-string-or-array-to-Image-tp16297653p16322508.html Sent from the matplotlib - users mailing list archive at Nabble.com.
On 2008年3月26日, Lionel Roubeyrie apparently wrote: > [Attachment: windrose_oo.py : APPLICATION/X-PYTHON, 28502 bytes] Thanks for the update. Cheers, Alan Isaac
At 10:03 AM -0700 3/25/08, mat...@li... wrote: >Message: 1 >Date: 2008年3月25日 09:43:14 -0700 >From: Christopher Barker <Chr...@no...> >Subject: [Matplotlib-users] OT warning! Re: Plotting in C++ >To: 'matplotlib-users' <mat...@li...> >Cc: Francesco Biscani <blu...@gm...> >Message-ID: <47E...@no...> >Content-Type: text/plain; charset=ISO-8859-1; format=flowed > I would add that the enhanced productivity of dynamic languages leads to fewer bugs in the code. I cannot prove that, but that's been my experience. There is one clear advantage to statically-typed languages in my opinion: performance. That one reason can be very important. -Tony -- Tony Mannucci Supervisor, Ionospheric and Atmospheric Remote Sensing Group Mail-Stop 138-308, Tel > (818) 354-1699 Jet Propulsion Laboratory, Fax > (818) 393-5115 California Institute of Technology, Email > Ton...@jp... 4800 Oak Grove Drive, http://genesis.jpl.nasa.gov Pasadena, CA 91109
I think this line in the rc file is the trick #savefig.dpi : 100 On Wed, Mar 26, 2008 at 6:16 PM, Christopher Barker <Chr...@no...> wrote: > Hi all, > > I want to save a figure just like it is displayed i.e. the same dpi > (wxAgg). However, the default Figure.savefig uses a different dpi > setting than the figure as displayed, so I'm doing: > > dpi = Fig.get_dpi() > Fig.savefig(str(path), dpi=dpi) > > which seems to work, but seems more awkward than it should be. Is there > a flag or something I'm missing? > > -Chris > > > > -- > Christopher Barker, Ph.D. > Oceanographer > > Emergency Response Division > NOAA/NOS/OR&R (206) 526-6959 voice > 7600 Sand Point Way NE (206) 526-6329 fax > Seattle, WA 98115 (206) 526-6317 main reception > > Chr...@no... > > ------------------------------------------------------------------------- > Check out the new SourceForge.net Marketplace. > It's the best place to buy or sell services for > just about anything Open Source. > http://ad.doubleclick.net/clk;164216239;13503038;w?http://sf.net/marketplace > _______________________________________________ > Matplotlib-users mailing list > Mat...@li... > https://lists.sourceforge.net/lists/listinfo/matplotlib-users >
Forgot to reply-to-list... ---------- Forwarded message ---------- From: Anthony Floyd <ant...@gm...> Date: Wed, Mar 26, 2008 at 4:54 PM Subject: Re: [Matplotlib-users] load data from string or array to Image To: sa6113 <s.p...@gm...> On Wed, Mar 26, 2008 at 1:33 AM, sa6113 <s.p...@gm...> wrote: > > > I have a problem to load data from string or array to Image but without > using PIL , because I have to check the application in 6 different platforms > like Windows 32bit, Windows X64 (64bit version), Linux 32bit, Linux 64bit > x86_64, Linux IPF (Itanium Processor Family) and HP-UX 64. > > There is a code but I don't want to use PIL : > http://mail.python.org/pipermail/image-sig/1998-October/000572.html > > Can I accomplish the same thing using the modules that are already on the > system, or those that are pure Python (not requiring any compilation or > binary download)? I went through this just a few weeks ago. Now, mind you I'm using wx and numpy already. My solution was to turn my .png into a Python string using img2py.py in the wx/tools directory. With the string, I then used the following code to return the image (a watermark) as an array that figimage() or imshow() can use directly. I'm sure the code can be optimized, but it works fast enough for me... def getWatermarkArray(): rows = 28 columns = 200 dimensions = 3 image = getWatermarkImage() # image array is a string of hex values imageString = image.GetData() imageList = [ord(item) for item in imageString] imageArray = numpy.zeros(shape=(28,200,3), dtype=numpy.float32) imageCounter = 0 for rowCounter in range(rows): for columnCounter in range(columns): for dimCounter in range(dimensions): imageArray[rowCounter][columnCounter][dimCounter] = imageList[imageCounter]/255. imageCounter += 1 return imageArray HTH, A>
Hi all, I want to save a figure just like it is displayed i.e. the same dpi (wxAgg). However, the default Figure.savefig uses a different dpi setting than the figure as displayed, so I'm doing: dpi = Fig.get_dpi() Fig.savefig(str(path), dpi=dpi) which seems to work, but seems more awkward than it should be. Is there a flag or something I'm missing? -Chris -- Christopher Barker, Ph.D. Oceanographer Emergency Response Division NOAA/NOS/OR&R (206) 526-6959 voice 7600 Sand Point Way NE (206) 526-6329 fax Seattle, WA 98115 (206) 526-6317 main reception Chr...@no...