Skip to main content

graphics - Consistent Plot Styles across multiple MMA files and data sets


I am starting to write a thesis for which I want to use MMA for all my plotting needs, mostly because a lot of the basic analysis has been done there. To ensure that I am applying styles consistently (plot colors, image size, label size, etc.), I need a method which I can use across multiple files.


There are several types of plots that I will need:



  1. ListPlot / Plot

  2. ListDensityPlot / DensityPlot

  3. ListContourPlot / ContourPlot



I can think of several way of doing this:



  1. Define my own functions thPlot, thListPlot, etc which have my default styles applied

  2. Define my own style options into a variable, and use some combination of FilterRules and Options to make sure that options from that variable are applied to the right type of plot

  3. Set default options using Default for the different types of plots.


I am assuming that each of my datasets (which may have one or more plots) will be self-contained mathematica files that I can re-run. So, if I decide to change the style in some central location (via one of the methods above) I can re-run the MMA files and get the plots in the new style.


What have people done in the past?



Answer



For an example of plot option customization that I am still rather proud of please see:

How to change the default ColorData used in Mathematica's Plot?


For general customization I think you already outlined some good options. I personally favor the custom function method for maximum control. Another, perhaps cleaner method that I crudely copy from Leonid works well if you can pool options for all plot types in one list ($myoptions):


Update: changed withOptions to use the "injector pattern" so as not to disrupt functions if withOptions is used indiscriminately (withOptions[ 1 + 1 ]).


$myoptions = {Filling -> {1 -> {{2}, {Red, Purple}}}};

SetAttributes[withOptions, HoldFirst]

withOptions[head_Symbol[body__]] :=
FilterRules[$myoptions, Options[head]] /. {opts___} :> head[body, opts]


withOptions @ Plot[{Sin @ Log @ x, Cos[3 x]}, {x, 0, Pi}]

Mathematica graphics




Here I posted another method in answer to specifying plot ranges, but the method is very general and can be used for any options or parameters. It works by creating an UpValue assignment for the symbol given that applies to any head. This could of course be further restricted to apply to only one head or a list of heads. One could also include FilterRules as shown in the code above, depending on the effect desired. For example:


SetAttributes[setOpts, HoldAllComplete]

Quiet[
setOpts[s_Symbol, pat_: _, spec__?OptionQ] :=
s /: (h : pat)[pre__, s, post___] :=

FilterRules[{spec}, Options[h]] /. {opts___} :> h[pre, opts, post],
Optional::"opdef"
]

Now a single option as used above is assigned to op1:


setOpts[op1, Filling -> {1 -> {{2}, {Red, Purple}}}]

And used in Plot:


 Plot[{Sin @ Log @ x, Cos[3 x]}, {x, 0, Pi}, op1]


Mathematica graphics


Alternatively the options can be restricted to a particular head or head pattern. Here a different set of options, also named op1, is defined only for ParametricPlot:


setOpts[op1, ParametricPlot, Frame -> True, PlotStyle -> Thick, Axes -> None, 
MeshShading -> {Red, Blue}, Mesh -> 15]

ParametricPlot[{{2 Cos[t], 2 Sin[t]}, {2 Cos[t], Sin[t]}}, {t, 0, 2 Pi}, op1]

enter image description here


Using op1 in Plot will still produce the result shown earlier.


You could also use Alternatives in the pattern, e.g: Plot | ListPlot | Histogram or more complication patterns with conditions, etc.



Comments

Popular posts from this blog

functions - Get leading series expansion term?

Given a function f[x] , I would like to have a function leadingSeries that returns just the leading term in the series around x=0 . For example: leadingSeries[(1/x + 2)/(4 + 1/x^2 + x)] x and leadingSeries[(1/x + 2 + (1 - 1/x^3)/4)/(4 + x)] -(1/(16 x^3)) Is there such a function in Mathematica? Or maybe one can implement it efficiently? EDIT I finally went with the following implementation, based on Carl Woll 's answer: lds[ex_,x_]:=( (ex/.x->(x+O[x]^2))/.SeriesData[U_,Z_,L_List,Mi_,Ma_,De_]:>SeriesData[U,Z,{L[[1]]},Mi,Mi+1,De]//Quiet//Normal) The advantage is, that this one also properly works with functions whose leading term is a constant: lds[Exp[x],x] 1 Answer Update 1 Updated to eliminate SeriesData and to not return additional terms Perhaps you could use: leadingSeries[expr_, x_] := Normal[expr /. x->(x+O[x]^2) /. a_List :> Take[a, 1]] Then for your examples: leadingSeries[(1/x + 2)/(4 + 1/x^2 + x), x] leadingSeries[Exp[x], x] leadingSeries[(1/x + 2 + (1 - 1/x...

How to thread a list

I have data in format data = {{a1, a2}, {b1, b2}, {c1, c2}, {d1, d2}} Tableform: I want to thread it to : tdata = {{{a1, b1}, {a2, b2}}, {{a1, c1}, {a2, c2}}, {{a1, d1}, {a2, d2}}} Tableform: And I would like to do better then pseudofunction[n_] := Transpose[{data2[[1]], data2[[n]]}]; SetAttributes[pseudofunction, Listable]; Range[2, 4] // pseudofunction Here is my benchmark data, where data3 is normal sample of real data. data3 = Drop[ExcelWorkBook[[Column1 ;; Column4]], None, 1]; data2 = {a #, b #, c #, d #} & /@ Range[1, 10^5]; data = RandomReal[{0, 1}, {10^6, 4}]; Here is my benchmark code kptnw[list_] := Transpose[{Table[First@#, {Length@# - 1}], Rest@#}, {3, 1, 2}] &@list kptnw2[list_] := Transpose[{ConstantArray[First@#, Length@# - 1], Rest@#}, {3, 1, 2}] &@list OleksandrR[list_] := Flatten[Outer[List, List@First[list], Rest[list], 1], {{2}, {1, 4}}] paradox2[list_] := Partition[Riffle[list[[1]], #], 2] & /@ Drop[list, 1] RM[list_] := FoldList[Transpose[{First@li...

front end - keyboard shortcut to invoke Insert new matrix

I frequently need to type in some matrices, and the menu command Insert > Table/Matrix > New... allows matrices with lines drawn between columns and rows, which is very helpful. I would like to make a keyboard shortcut for it, but cannot find the relevant frontend token command (4209405) for it. Since the FullForm[] and InputForm[] of matrices with lines drawn between rows and columns is the same as those without lines, it's hard to do this via 3rd party system-wide text expanders (e.g. autohotkey or atext on mac). How does one assign a keyboard shortcut for the menu item Insert > Table/Matrix > New... , preferably using only mathematica? Thanks! Answer In the MenuSetup.tr (for linux located in the $InstallationDirectory/SystemFiles/FrontEnd/TextResources/X/ directory), I changed the line MenuItem["&New...", "CreateGridBoxDialog"] to read MenuItem["&New...", "CreateGridBoxDialog", MenuKey["m", Modifiers-...