User Tools

Site Tools


other:python:jyp_steps

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
Next revision Both sides next revision
other:python:jyp_steps [2019/06/03 16:32]
jypeter [Matplotlib] improved
other:python:jyp_steps [2019/06/27 08:49]
jypeter [Matplotlib] Added example of get/set_position
Line 211: Line 211:
 bottom_plot = plot_array[2]</​code>​ bottom_plot = plot_array[2]</​code>​
           * creating a figure and axes with a single line: ''​my_page,​ plot_array = **plt**.subplots(3,​ 1)''​           * creating a figure and axes with a single line: ''​my_page,​ plot_array = **plt**.subplots(3,​ 1)''​
 +        * use [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.figure.Figure.html#​matplotlib.figure.Figure.add_axes|my_page.add_axes(...)]] to add an axis in an arbirary location of the page\\ ''​my_page.add_axes([left,​ bottom, width, height])''​
       * a Matplotlib **//​Artist//​** or //Patch// is //​something//​ (e.g a line, a group of markers, text, the legend...) plotted ​ on the Figure/Axis       * a Matplotlib **//​Artist//​** or //Patch// is //​something//​ (e.g a line, a group of markers, text, the legend...) plotted ​ on the Figure/Axis
       * **clearing** the //page// (or part of it): you probably won't need that...       * **clearing** the //page// (or part of it): you probably won't need that...
Line 222: Line 223:
         * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.subplots.html|plt.subplots(...)]] with an **s** at the end ([[https://​matplotlib.org/​gallery/​subplots_axes_and_figures/​subplots_demo.html|demo]])         * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.subplots.html|plt.subplots(...)]] with an **s** at the end ([[https://​matplotlib.org/​gallery/​subplots_axes_and_figures/​subplots_demo.html|demo]])
         * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.subplots_adjust.html|subplots_adjust]] can be used to change the overall boundaries of the subplots on the figure, and the spacing between the subplots\\ ''​plt.subplots_adjust(left=None,​ bottom=None,​ right=None, top=None, wspace=None,​ hspace=None)''​\\ or ''​my_page.subplots_adjust(left=None,​ bottom=None,​ right=None, top=None, wspace=None,​ hspace=None)''​         * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.subplots_adjust.html|subplots_adjust]] can be used to change the overall boundaries of the subplots on the figure, and the spacing between the subplots\\ ''​plt.subplots_adjust(left=None,​ bottom=None,​ right=None, top=None, wspace=None,​ hspace=None)''​\\ or ''​my_page.subplots_adjust(left=None,​ bottom=None,​ right=None, top=None, wspace=None,​ hspace=None)''​
 +          * ''​hspace''/''​wspace''​ is the amount of height/​width between the subplots
 +            * ''​hspace=0.1''​ is enough for just displaying the ticks and the labels, without the axis name
 +            * use ''​hspace=0''​ to stick the plots together vertically
 +              * do not forget to disable the ticks where there is no space to plot them: ''​my_plot.set_xticks([])''​
 +          * ''​my_page.subplots_adjust(right=0.75)''​ will leave 25% on the right of the page for adding a legend outside of a plot
 +        * You can also **resize an existing (sub)plot** the following way:
 +          - Get the current size information:​ ''​pl_x_bottomleft,​ pl_y_bottomleft,​ pl_width, pl_height = my_plot.get_position().bounds''​
 +          - Set the new size: e.g reduce the height with ''​my_plot.set_position( (pl_x_bottomleft,​ pl_y_bottomleft,​ pl_width, pl_height ​ * 0.5) )''​
       * [[https://​matplotlib.org/​gallery/​index.html#​subplots-axes-and-figures|Subplots,​ axes and figures]] gallery       * [[https://​matplotlib.org/​gallery/​index.html#​subplots-axes-and-figures|Subplots,​ axes and figures]] gallery
       * [[https://​matplotlib.org/​tutorials/​intermediate/​gridspec.html#​sphx-glr-tutorials-intermediate-gridspec-py|Customizing Figure Layouts Using GridSpec and Other Functions]],​ [[https://​matplotlib.org/​tutorials/​intermediate/​constrainedlayout_guide.html|constrained layout]] and [[https://​matplotlib.org/​tutorials/​intermediate/​tight_layout_guide.html|tight layout]]       * [[https://​matplotlib.org/​tutorials/​intermediate/​gridspec.html#​sphx-glr-tutorials-intermediate-gridspec-py|Customizing Figure Layouts Using GridSpec and Other Functions]],​ [[https://​matplotlib.org/​tutorials/​intermediate/​constrainedlayout_guide.html|constrained layout]] and [[https://​matplotlib.org/​tutorials/​intermediate/​tight_layout_guide.html|tight layout]]
Line 251: Line 260:
   * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.scatter.html|scatter(...)]]:​ A scatter plot of y vs x with varying marker size and/or color   * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.scatter.html|scatter(...)]]:​ A scatter plot of y vs x with varying marker size and/or color
     * The ''​plot''​ function will be faster for scatterplots where markers don't vary in size or color     * The ''​plot''​ function will be faster for scatterplots where markers don't vary in size or color
 +  * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.axes.Axes.contourf.html|contour(...) and contourf(...)]]:​ draw contour lines and filled contours
   * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.lines.Line2D.html|line]] parameters   * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.lines.Line2D.html|line]] parameters
     * ''​linestyle'':​ ''​solid'',​ ''​None'',​ [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.lines.Line2D.html#​matplotlib.lines.Line2D.set_linestyle|other]] ([[https://​matplotlib.org/​examples/​lines_bars_and_markers/​line_styles_reference.html|default styles example]], [[https://​matplotlib.org/​examples/​lines_bars_and_markers/​linestyles.html|custom styles example]])     * ''​linestyle'':​ ''​solid'',​ ''​None'',​ [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.lines.Line2D.html#​matplotlib.lines.Line2D.set_linestyle|other]] ([[https://​matplotlib.org/​examples/​lines_bars_and_markers/​line_styles_reference.html|default styles example]], [[https://​matplotlib.org/​examples/​lines_bars_and_markers/​linestyles.html|custom styles example]])
   * [[https://​matplotlib.org/​api/​markers_api.html|marker types]]   * [[https://​matplotlib.org/​api/​markers_api.html|marker types]]
-    * ''​fillstyle'':​ ''​full'',​ ''​None'',​ [[https://​matplotlib.org/​gallery/​lines_bars_and_markers/​marker_fillstyle_reference.html|other]] +    ​* Default marker size and edge width: 
-    Other attributes: ''​markersize'',​ ''​markerfacecolor''​ (and ''​markerfacecoloralt'' ​for dual color markers), ''​markeredgecolor'',​ ''​markeredgewidth''​ +      ​* ''​mpl.rcParams['lines.markersize'] %%**%% 2''​ => 36 
-  * [[https://​matplotlib.org/​api/​colors_api.html|colors]]+      * ''​mpl.rcParams['​lines.linewidth'​]''​ => 1.5 
 +    * Other marker attributes. For ''​plot'',​ all the markers have the same attributes, and for ''​scatter''​ the attributes can be the same, or specified for each marker 
 +      * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.plot.html|plot(...)]]:​ //fmt// (see documentation) or ''​marker''​ and ''​markerfacecolor''/''​mfc''​ (and ''​markerfacecoloralt''/''​mfcalt''​ for dual color markers), ''​markersize'',​ ''​markeredgewidth''/''​mew'',​ ''​markeredgecolor'',​ ''​fillstyle''​ (''​full'',​ ''​None'',​ [[https://​matplotlib.org/​gallery/​lines_bars_and_markers/​marker_fillstyle_reference.html|other]]) 
 +      [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.scatter.html|scatter(...)]]: ''​marker'' ​(marker type), ''​c''​ (color), ​''​s'' ​(size), ''​linewidths'' ​(linewidth of the marker edges), ''​edgecolors''​ 
 +  * [[https://​matplotlib.org/​api/​colors_api.html|colors]] ​and colormaps
     * [[https://​matplotlib.org/​gallery/​color/​color_demo.html|color demo]]     * [[https://​matplotlib.org/​gallery/​color/​color_demo.html|color demo]]
     * [[https://​matplotlib.org/​examples/​color/​named_colors.html|named colors]]     * [[https://​matplotlib.org/​examples/​color/​named_colors.html|named colors]]
 +    * Reverting the colors: add ''​_r''​ at the end of the colormap name
 +    * Special colormap colors
 +      * ''​cmap.set_bad(color='​k'​)'':​ color to be used for masked values
 +      * ''​cmap.set_over(color='​k'​)'':​ color to be used for high out-of-range values
 +      * ''​cmap.set_under(color='​k'​)'':​ color to be used for low out-of-range values
 +  * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.figure.Figure.html#​matplotlib.figure.Figure.colorbar|colorbar]] and ([[https://​matplotlib.org/​gallery/​images_contours_and_fields/​contourf_demo.html|contourf + colorbar demo]])
   * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.text.html|text(...)]] and [[https://​matplotlib.org/​tutorials/​text/​annotations.html|annotations]]   * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.pyplot.text.html|text(...)]] and [[https://​matplotlib.org/​tutorials/​text/​annotations.html|annotations]]
 +    * Some titles:
 +      * [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.figure.Figure.html#​matplotlib.figure.Figure.suptitle|Figure title]]: ''​my_figure.suptitle('​Figure title',​ ...)''​
 +      * [[https://​matplotlib.org/​api/​axes_api.html#​axis-labels-title-and-legend|Axis Labels, title, and legend]]: ''​my_plot.set_title('​Plot title',​ ...)''​
     * ''​fontsize'':​ size in points, or (better!) string specifying a relative size (''​xx-small'',​ ''​x-small'',​ ''​small'',​ ''​medium'',​ ''​large'',​ ''​x-large'',​ ''​xx-large''​)     * ''​fontsize'':​ size in points, or (better!) string specifying a relative size (''​xx-small'',​ ''​x-small'',​ ''​small'',​ ''​medium'',​ ''​large'',​ ''​x-large'',​ ''​xx-large''​)
     * [[https://​matplotlib.org/​api/​text_api.html#​matplotlib.text.Text|all the text properties]]     * [[https://​matplotlib.org/​api/​text_api.html#​matplotlib.text.Text|all the text properties]]
Line 273: Line 296:
   * The [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.figure.Figure.html|figure(...)]] and the associated methods   * The [[https://​matplotlib.org/​api/​_as_gen/​matplotlib.figure.Figure.html|figure(...)]] and the associated methods
   * The [[https://​matplotlib.org/​api/​axes_api.html|axes]] and the associated methods   * The [[https://​matplotlib.org/​api/​axes_api.html|axes]] and the associated methods
-  * [[https://​matplotlib.org/​tutorials/​introductory/​customizing.html#​matplotlib-rcparams|matplotlib default settings]] can be queried and updated+  * [[https://​matplotlib.org/​tutorials/​introductory/​customizing.html#​matplotlib-rcparams|matplotlib default ​config/settings]] can be queried and updated
     * example: the default figure size (inches) is ''​mpl.rcParams['​figure.figsize'​]''​ (''​[6.4,​ 4.8]''​)     * example: the default figure size (inches) is ''​mpl.rcParams['​figure.figsize'​]''​ (''​[6.4,​ 4.8]''​)
     * current settings'​ file:  ''​mpl.matplotlib_fname()''​     * current settings'​ file:  ''​mpl.matplotlib_fname()''​
other/python/jyp_steps.txt · Last modified: 2024/03/07 10:15 by jypeter