galaaz 0.4.2 → 0.4.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/LICENSE +25 -0
- data/Rakefile +8 -0
- data/bin/gknit +9 -5
- data/bin/gstudio +4 -2
- data/bin/gstudio.rb +32 -2
- data/blogs/dev/dev.html +219 -34
- data/blogs/dev/dev.md +26 -26
- data/blogs/dev/dev_files/figure-html/bubble-1.png +0 -0
- data/blogs/dev/dev_files/figure-html/diverging_bar.png +0 -0
- data/blogs/dplyr/dplyr.rb +63 -0
- data/blogs/galaaz_ggplot/galaaz_ggplot.Rmd +38 -26
- data/blogs/galaaz_ggplot/galaaz_ggplot.aux +16 -17
- data/blogs/galaaz_ggplot/galaaz_ggplot.pdf +0 -0
- data/blogs/galaaz_ggplot/galaaz_ggplot.tex +65 -31
- data/blogs/oh_my/not_so.rb +2342 -0
- data/blogs/oh_my/oh_my.Rmd +493 -0
- data/blogs/oh_my/oh_my.html +680 -0
- data/blogs/oh_my/oh_my.md +597 -0
- data/blogs/oh_my/old.Rmd +2100 -0
- data/blogs/ruby_plot/figures/facets_with_decorations.png +0 -0
- data/blogs/ruby_plot/figures/facets_with_jitter.png +0 -0
- data/blogs/ruby_plot/figures/final_box_plot.png +0 -0
- data/blogs/ruby_plot/figures/final_violin_plot.png +0 -0
- data/blogs/ruby_plot/figures/violin_with_jitter.png +0 -0
- data/blogs/ruby_plot/ruby_plot.Rmd +147 -122
- data/blogs/ruby_plot/ruby_plot.Rmd_external_figs +662 -0
- data/blogs/ruby_plot/ruby_plot.html +49 -54
- data/blogs/ruby_plot/ruby_plot.md +147 -122
- data/blogs/ruby_plot/ruby_plot.pdf +0 -0
- data/blogs/ruby_plot/ruby_plot.tex +776 -157
- data/blogs/ruby_plot/ruby_plot_files/figure-html/dose_len.svg +57 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/facet_by_delivery.svg +106 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/facet_by_dose.svg +110 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/facets_by_delivery_color.svg +174 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/facets_by_delivery_color2.svg +236 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/facets_with_decorations.png +0 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/facets_with_jitter.svg +296 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/facets_with_points.svg +236 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/final_box_plot.svg +218 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/final_violin_plot.svg +128 -0
- data/blogs/ruby_plot/ruby_plot_files/figure-html/violin_with_jitter.svg +150 -0
- data/examples/islr/ch2.spec.rb +21 -18
- data/examples/islr/ch3_boston.rb +14 -5
- data/examples/islr/ch3_multiple_regression.rb +2 -3
- data/examples/islr/ch6.spec.rb +1 -1
- data/examples/islr/x_y_rnorm.jpg +0 -0
- data/lib/R_interface/r.rb +14 -10
- data/lib/R_interface/r_libs.R +9 -0
- data/lib/R_interface/r_methods.rb +77 -6
- data/lib/R_interface/{expression.rb → r_module_s.rb} +13 -14
- data/lib/R_interface/rbinary_operators.rb +58 -71
- data/lib/R_interface/rdata_frame.rb +2 -1
- data/lib/R_interface/rdevices.R +4 -0
- data/lib/R_interface/rdevices.rb +1 -1
- data/lib/R_interface/renvironment.rb +34 -1
- data/lib/R_interface/rexpression.rb +108 -2
- data/lib/R_interface/rindexed_object.rb +3 -1
- data/lib/R_interface/rlanguage.rb +18 -2
- data/lib/R_interface/rmatrix.rb +14 -0
- data/lib/R_interface/rmd_indexed_object.rb +5 -1
- data/lib/R_interface/robject.rb +61 -23
- data/lib/R_interface/rsupport.rb +111 -53
- data/lib/R_interface/rsymbol.rb +6 -5
- data/lib/R_interface/ruby_extensions.rb +130 -4
- data/lib/R_interface/runary_operators.rb +35 -3
- data/lib/R_interface/rvector.rb +1 -0
- data/lib/galaaz.rb +0 -2
- data/lib/gknit/knitr_engine.rb +58 -4
- data/lib/gknit/ruby_engine.rb +5 -6
- data/lib/util/exec_ruby.rb +55 -9
- data/specs/all.rb +13 -3
- data/specs/figures/dose_len.png +0 -0
- data/specs/r_dataframe.spec.rb +49 -26
- data/specs/r_environment.spec.rb +140 -0
- data/specs/r_eval.spec.rb +0 -15
- data/specs/r_formula.spec.rb +232 -0
- data/specs/r_function.spec.rb +7 -8
- data/specs/r_list.spec.rb +4 -0
- data/specs/r_list_apply.spec.rb +11 -11
- data/specs/r_matrix.spec.rb +3 -3
- data/specs/{r_plots.spec.rb~ → r_nse.spec.rb} +29 -6
- data/specs/r_vector_creation.spec.rb +6 -0
- data/specs/r_vector_object.spec.rb +2 -2
- data/specs/r_vector_operators.spec.rb +3 -3
- data/specs/r_vector_subsetting.spec.rb +4 -4
- data/specs/ruby_expression.spec.rb +324 -0
- data/specs/tmp.rb +12 -524
- data/sty/galaaz.sty +71 -0
- data/version.rb +1 -1
- metadata +31 -41
- data/bin/gknit2~ +0 -6
- data/bin/ogk~ +0 -4
- data/bin/prepareR.rb~ +0 -1
- data/blogs/dev/dev.Rmd~ +0 -104
- data/blogs/galaaz_ggplot/galaaz_ggplot.dvi +0 -0
- data/blogs/galaaz_ggplot/midwest_external_png~ +0 -1
- data/blogs/gknit/gknit.Rmd~ +0 -184
- data/blogs/gknit/gknit.Rnd~ +0 -17
- data/blogs/gknit/model.rb~ +0 -46
- data/blogs/ruby_plot/ruby_plot.Rmd~ +0 -215
- data/examples/islr/Figure.jpg +0 -0
- data/examples/misc/moneyball.rb~ +0 -16
- data/examples/misc/subsetting.rb~ +0 -372
- data/lib/R/eng_ruby.R~ +0 -63
- data/lib/R_interface/capture_plot.rb~ +0 -23
- data/lib/R_interface/r.rb~ +0 -121
- data/lib/R_interface/rdevices.rb~ +0 -27
- data/lib/gknit.rb~ +0 -26
- data/lib/gknit/knitr_engine.rb~ +0 -102
- data/lib/gknit/ruby_engine.rb~ +0 -72
- data/lib/util/inline_file.rb~ +0 -23
- data/r_requires/knitr.rb~ +0 -4
- data/specs/r_language.spec.rb +0 -157
@@ -10,6 +10,7 @@
|
|
10
10
|
|
11
11
|
|
12
12
|
<meta name="author" content="Rodrigo Botafogo" />
|
13
|
+
<meta name="author" content="Daniel Mossé - University of Pittsburgh" />
|
13
14
|
|
14
15
|
|
15
16
|
<title>How to make Beautiful Ruby Plots with Galaaz</title>
|
@@ -123,16 +124,15 @@ $(document).ready(function () {
|
|
123
124
|
|
124
125
|
<h1 class="title toc-ignore">How to make Beautiful Ruby Plots with Galaaz</h1>
|
125
126
|
<h4 class="author"><em>Rodrigo Botafogo</em></h4>
|
127
|
+
<h4 class="author"><em>Daniel Mossé - University of Pittsburgh</em></h4>
|
126
128
|
<h4 class="date"><em>November 19th, 2018</em></h4>
|
127
129
|
|
128
130
|
</div>
|
129
131
|
|
130
132
|
|
131
|
-
<
|
132
|
-
<
|
133
|
-
<p>
|
134
|
-
<p>Python, a similar language to Ruby, ranks 4th in the index. Java, C and C++ take the first three positions. Ruby is often criticized for its focus on web applications. But Ruby can do <a href="https://github.com/markets/awesome-ruby">much more</a> than just web applications. Yet, for scientific computing, Ruby lags way behind Python and R. Python has Django framework for web, NumPy for numerical arrays, Pandas for data analysis. R is a free software environment for statistical computing and graphics with thousands of libraries for data analysis.</p>
|
135
|
-
<p>Until recently, there was no real perspective for Ruby to bridge this gap. Implementing a complete scientific computing infrastructure would take too long. Comes GraalVM into the picture:</p>
|
133
|
+
<p>According to Wikipedia “Ruby is a dynamic, interpreted, reflective, object-oriented, general-purpose programming language. It was designed and developed in the mid-1990s by Yukihiro”Matz" Matsumoto in Japan." It reached high popularity with the development of Ruby on Rails (RoR) by David Heinemeier Hansson. RoR is a web application framework first released around 2005. It makes extensive use of Ruby’s metaprogramming features. With RoR, Ruby became very popular. According to <a href="https://www.tiobe.com/tiobe-index/ruby/">Ruby’s Tiobe index</a> it peeked in popularity around 2008, then declined until 2015 when it started picking up again. At the time of this writing (November 2018), the Tiobe index puts Ruby in 16th position as most popular language.</p>
|
134
|
+
<p>Python, a language similar to Ruby, ranks 4th in the index. Java, C and C++ take the first three positions. Ruby is often criticized for its focus on web applications. But Ruby can do <a href="https://github.com/markets/awesome-ruby">much more</a> than just web applications. Yet, for scientific computing, Ruby lags way behind Python and R. Python has Django framework for web, NumPy for numerical arrays, Pandas for data analysis. R is a free software environment for statistical computing and graphics with thousands of libraries for data analysis.</p>
|
135
|
+
<p>Until recently, there was no real perspective for Ruby to bridge this gap. Implementing a complete scientific computing infrastructure would take too long. Enters <a href="https://www.graalvm.org/">Oracle’s GraalVM</a>:</p>
|
136
136
|
<blockquote>
|
137
137
|
<p>GraalVM is a universal virtual machine for running applications written in JavaScript, Python 3, Ruby, R, JVM-based languages like Java, Scala, Kotlin, and LLVM-based languages such as C and C++.</p>
|
138
138
|
<p>GraalVM removes the isolation between programming languages and enables interoperability in a shared runtime. It can run either standalone or in the context of OpenJDK, Node.js, Oracle Database, or MySQL.</p>
|
@@ -145,14 +145,13 @@ $(document).ready(function () {
|
|
145
145
|
</ul>
|
146
146
|
<p>With GraalVM we aim to allow developers to freely choose the right language for the task at hand without making compromises.</p>
|
147
147
|
</blockquote>
|
148
|
-
<p>As stated above, GraalVM is a <em>universal</em> virtual machine that allows Ruby and R (and other languages) to run on the same environment. GraalVM allows polyglot applications to <em>seamlessly</em> interact with one another and pass values from one language to the other. Galaaz, a gem for Ruby,
|
149
|
-
<p>Library wrapping is
|
150
|
-
<p>Galaaz, instead of wrapping a single C or R library, wraps the whole
|
151
|
-
<p>
|
152
|
-
<p>In this article we will explore the R ToothGrowth dataset.
|
153
|
-
<p>We will also create a Corporate Template ensuring that plots will have a consistent visualization. This template is
|
154
|
-
<p
|
155
|
-
</div>
|
148
|
+
<p>As stated above, GraalVM is a <em>universal</em> virtual machine that allows Ruby and R (and other languages) to run on the same environment. GraalVM allows polyglot applications to <em>seamlessly</em> interact with one another and pass values from one language to the other. Although a great idea, GraalVM still requires application writers to know several languages. To eliminate that requirement, we built Galaaz, a gem for Ruby, to tightly couple Ruby and R and allow those languages to interact in a way that the user will be unaware of such interaction. In other words, a Ruby programmer will be able to use all the capabilities of R without knowing the R syntax.</p>
|
149
|
+
<p>Library wrapping is a usual way of bringing features from one language into another. To improve performance, Python often wraps more efficient C libraries. For the Python developer, the existence of such C libraries is hidden. The problem with library wrapping is that for any new library, there is the need to handcraft a new wrapper.</p>
|
150
|
+
<p>Galaaz, instead of wrapping a single C or R library, wraps the whole R language in Ruby. Doing so, all thousands of R libraries are available immediately to Ruby developers without any new wrapping effort.</p>
|
151
|
+
<p>To show the power of Galaaz, we show in this article how Ruby can use R’s ggplot2 library tranparantly bringing to Ruby the power of high quality scientific plotting. We also show that migrating from R to Ruby with Galaaz is a matter of small syntactic changes. By using Ruby, the R developer can use all of Ruby’s powerful object-oriented features. Also, with Ruby, it becomes much easier to move code from the analysis phase to the production phase.</p>
|
152
|
+
<p>In this article we will explore the R ToothGrowth dataset. To illustrate, we will create some boxplots. A primer on boxplot is available in <a href="https://towardsdatascience.com/understanding-boxplots-5e2df7bcbd51">this article</a>.</p>
|
153
|
+
<p>We will also create a Corporate Template ensuring that plots will have a consistent visualization. This template is built using a Ruby module. There is a way of building ggplot themes that will work the same as the Ruby module. Yet, writing a new theme requires specific knowledge on theme writing. Ruby modules are standard to the language and don’t need special knowledge.</p>
|
154
|
+
<p><a href="https://towardsdatascience.com/ruby-plotting-with-galaaz-an-example-of-tightly-coupling-ruby-and-r-in-graalvm-520b69e21021">Here</a> we show a scatter plot in Ruby also with Galaaz.</p>
|
156
155
|
<div id="gknit" class="section level1">
|
157
156
|
<h1>gKnit</h1>
|
158
157
|
<p><em>Knitr</em> is an application that converts text written in rmarkdown to many different output formats. For instance, a writer can convert an rmarkdown document to HTML, <span class="math inline">\(LaTex\)</span>, docx and many other formats. Rmarkdown documents can contain text and <em>code chunks</em>. Knitr formats code chunks in a grayed box in the output document. It also executes the code chunks and formats the output in a white box. Every line of output from the execution code is preceded by ‘##’.</p>
|
@@ -161,8 +160,8 @@ $(document).ready(function () {
|
|
161
160
|
</div>
|
162
161
|
<div id="exploring-the-dataset" class="section level1">
|
163
162
|
<h1>Exploring the Dataset</h1>
|
164
|
-
<p>Let’s start by exploring our selected dataset. ToothGrowth is an R dataset. A dataset is like
|
165
|
-
<p>The ToothGrowth dataset contains three columns: ‘len’, ‘supp’ and ‘dose’. Let’s take a look at a few rows of this dataset. In Galaaz,
|
163
|
+
<p>Let’s start by exploring our selected dataset. ToothGrowth is an R dataset. A dataset is like a simple excel spreadsheet, in which each column has only one type of data. For instance one column can have float, the other integer, and a third strings. This dataset analyzes the length of odontoblasts (cells responsible for tooth growth) in 60 guinea pigs, where each animal received one of three dose levels of Vitamin C (0.5, 1, and 2 mg/day) by one of two delivery methods, orange juice OJ or ascorbic acid (a form of vitamin C and coded as VC).</p>
|
164
|
+
<p>The ToothGrowth dataset contains three columns: ‘len’, ‘supp’ and ‘dose’. Let’s take a look at a few rows of this dataset. In Galaaz, R variables are accessed by using the corresponding Ruby symbol preceeded by the tilda (‘~’) function. Note in the following chunk that ‘ToothGrowth’ is the R variable and Ruby’s ‘<span class="citation">@tooth_growth</span>’ is assigned the value of ‘~:ToothGrowth’.</p>
|
166
165
|
<pre class="ruby"><code># Read the R ToothGrowth variable and assign it to the
|
167
166
|
# Ruby instance variable @tooth_growth that will be
|
168
167
|
# available to all Ruby chunks in this document.
|
@@ -181,14 +180,14 @@ puts @tooth_growth.head</code></pre>
|
|
181
180
|
# elements of this column with the 'head' method.
|
182
181
|
puts @tooth_growth.len.head</code></pre>
|
183
182
|
<pre><code>## [1] 4.2 11.5 7.3 5.8 6.4 10.0</code></pre>
|
184
|
-
<p>The ‘dose’ column contains a numeric value
|
183
|
+
<p>The ‘dose’ column contains a numeric value with either, 0.5, 1 or 2, although the first 6 rows as seen above only contain the 0.5 values. Even though those are number, they are better interpreted as a <a href="https://swcarpentry.github.io/r-novice-inflammation/12-supp-factors/">factor or cathegory</a>. So, let’s convert our ‘dose’ column from numeric to ‘factor’. In R, the function ‘as.factor’ is used to convert data in a vector to factors. To use this function from Galaaz the dot (‘.’) in the function name is substituted by ’__‘(double underline). The function ’as.factor’ becomes ’R.as__factor’ or just ’as__factor’ when chaining.</p>
|
185
184
|
<pre class="ruby"><code># convert the dose to a factor
|
186
185
|
@tooth_growth.dose = @tooth_growth.dose.as__factor</code></pre>
|
187
186
|
<p>Let’s explore some more details of this dataset. In particular, let’s look at its dimensions, structure and summary statistics.</p>
|
188
187
|
<pre class="ruby"><code>puts @tooth_growth.dim</code></pre>
|
189
188
|
<pre><code>## [1] 60 3</code></pre>
|
190
189
|
<p>This dataset has 60 rows, one for each subject and 3 columns, as we have already seen.</p>
|
191
|
-
<p>Note that we do not call ‘puts’ when using the ‘str’ function. This functions does not return anything and prints the structure of the dataset as a side effect.</p>
|
190
|
+
<p>Note that we do not need to call ‘puts’ when using the ‘str’ function. This functions does not return anything and prints the structure of the dataset as a side effect.</p>
|
192
191
|
<pre class="ruby"><code>@tooth_growth.str</code></pre>
|
193
192
|
<pre><code>## 'data.frame': 60 obs. of 3 variables:
|
194
193
|
## $ len : num 4.2 11.5 7.3 5.8 6.4 10 11.2 11.2 5.2 7 ...
|
@@ -209,13 +208,13 @@ puts @tooth_growth.len.head</code></pre>
|
|
209
208
|
<h1>Doing the Data Analysis</h1>
|
210
209
|
<div id="quick-plot-for-seing-the-data" class="section level2">
|
211
210
|
<h2>Quick plot for seing the data</h2>
|
212
|
-
<p>Let’s now create our first plot with the given data by accessing ggplot2 from Ruby. For
|
211
|
+
<p>Let’s now create our first plot with the given data by accessing ggplot2 from Ruby. For Rubyists that have never seen or used ggplot2, here is the description of ggplot found in its home page:</p>
|
213
212
|
<blockquote>
|
214
213
|
<p>“ggplot2 is a system for declaratively creating graphics, based on <em>The Grammar of Graphics</em>. You provide the data, tell ggplot2 how to map variables to aesthetics, what graphical primitives to use, and it takes care of the details.”</p>
|
215
214
|
</blockquote>
|
216
215
|
<p>This description might be a bit cryptic and it is best to see it at work to understand it. Basically, in the <em>grammar of graphics</em> developers add layers of components such as grid, axis, data, title, subtitle and also graphical primitives such as <em>bar plot</em>, <em>box plot</em>, to form the final graphics.</p>
|
217
|
-
<p>In order to make a plot, we use the ‘ggplot’ function to the dataset. In R, this would be written as <code>ggplot(<dataset>, ...)</code>.
|
218
|
-
<p>Note also that we have a call to ‘R.png’ before plotting and ’R.dev__off’ after the print statement. ‘R.png’ opens a ‘png
|
216
|
+
<p>In order to make a plot, we use the ‘ggplot’ function to the dataset. In R, this would be written as <code>ggplot(<dataset>, ...)</code>. Galaaz gives you the flexibility to use either <code>R.ggplot(<dataset>, ...)</code> or <code><dataset>.ggplot(...)</code>. In the graph s pecification bellow, we use the second notation that looks more like Ruby. ggplot uses the ‘aes’ method to specify x and y axes; in this case, the ‘dose’ on the <span class="math inline">\(x\)</span> axis and the ‘length’ on the <span class="math inline">\(y\)</span> axis: ‘E.aes(x: :dose, y: :len)’. To specify the type of plot add a geom to the plot. For a boxplot, the geom is R.geom_boxplot.</p>
|
217
|
+
<p>Note also that we have a call to ‘R.png’ before plotting and ’R.dev__off’ after the print statement. ‘R.png’ opens a ‘png device’ for outputting the plot. If we do no pass a name to the ‘png’ function, the image gets a default name of ‘Rplot<nnn>’ where <nnn> is the number of the plot. ’R.dev__off’ closes the device and creates the ‘png’ file. We can then include the generated ‘png’ file in the document by adding an rmarkdown directive.</p>
|
219
218
|
<pre class="ruby"><code>require 'ggplot'
|
220
219
|
|
221
220
|
R.png("figures/dose_len.png")
|
@@ -228,12 +227,12 @@ R.dev__off</code></pre>
|
|
228
227
|
<img src="data:image/png;base64,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" />
|
229
228
|
|
230
229
|
</div>
|
231
|
-
<p>Great! We’ve just managed to create and save our first plot in Ruby with only four lines of code. We can see with this plot a clear trend: as the dose of the supplement is increased, so is the length of teeth.</p>
|
230
|
+
<p>Great! We’ve just managed to create and save our first plot in Ruby with only four lines of code. We can now easily see with this plot a clear trend: as the dose of the supplement is increased, so is the length of teeth.</p>
|
232
231
|
</div>
|
233
232
|
<div id="facetting-the-plot" class="section level2">
|
234
233
|
<h2>Facetting the plot</h2>
|
235
|
-
<p>This first plot shows a trend, but our data has information about two different forms of delivery method, either by Orange Juice
|
236
|
-
<p>In Galaaz
|
234
|
+
<p>This first plot shows a trend, but our data has information about two different forms of delivery method, either by Orange Juice OJ or by Vitamin C VC. Let’s then try to create a plot that helps us discern the effect of each delivery method. This next plot is a <em>facetted</em> plot where each delivery method gets is own plot. On the left side, the plot shows the OJ delivery method. On the right side, we see the VC delivery method. To obtain this plot, we use the ‘R.facet_grid’ function, that automatically creates the facets based on the delivery method factors. The parameter to the ‘facet_grid’ method is a <a href="https://thomasleeper.com/Rcourse/Tutorials/formulae.html"><em>formula</em></a>.</p>
|
235
|
+
<p>In Galaaz we give programmers the flexibility to use two different ways to write formulas. In the first way, the following changes from writing formulas (for example ‘x ~ y’) in R are necessary:</p>
|
237
236
|
<ul>
|
238
237
|
<li>R symbols are represented by the same Ruby symbol prefixed with the ‘+’ method. The symbol <code>x</code> in R becomes <code>+:x</code> in Ruby;</li>
|
239
238
|
<li>The ‘~’ operator in R becomes ‘=~’ in Ruby. The formula <code>x ~ y</code> in R is written as <code>+:x =~ +:y</code> in Ruby;</li>
|
@@ -260,7 +259,7 @@ R.dev__off</code></pre>
|
|
260
259
|
</div>
|
261
260
|
<div id="adding-color" class="section level2">
|
262
261
|
<h2>Adding Color</h2>
|
263
|
-
<p>If
|
262
|
+
<p>If we were writing about data analysis, we would make a better analysis of the trends and improve the statistical analysis. But here we are interested in working with ggplot in Ruby. So, let’s add some color to this plot to make the trend and comparison more visible. In the following plot, the boxes are color coded by dose. To add color, it is enough to add <code>fill: :dose</code> to the aesthetic of boxplot. With this command each ‘dose’ factor gets its own color.</p>
|
264
263
|
<pre class="ruby"><code>R.png("figures/facets_by_delivery_color.png")
|
265
264
|
|
266
265
|
@bp = @bp + R.geom_boxplot(E.aes(fill: :dose))
|
@@ -271,11 +270,11 @@ R.dev__off</code></pre>
|
|
271
270
|
<img src="data:image/png;base64,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" />
|
272
271
|
|
273
272
|
</div>
|
274
|
-
<p>Facetting helps us compare the general trends
|
273
|
+
<p>Facetting helps us compare the general trends for each delivery method. Adding color allow us to compare specifically how each dosage impacts the tooth growth. It is possible to observe that with smaller doses, up to 1mg, OJ performs better than VC (red color). For 2mg, both OJ and VC have the same median, but OJ is less disperse (blue color). For 1mg (green color), OJ is significantly bettern than VC. By this very quick visual analysis, it seems that OJ is a better delivery method than VC.</p>
|
275
274
|
</div>
|
276
275
|
<div id="clarifying-the-data" class="section level2">
|
277
276
|
<h2>Clarifying the data</h2>
|
278
|
-
<p>Boxplots give us a nice idea of the distribution of data, but looking at those plots with large colored boxes leaves us wondering what is going on
|
277
|
+
<p>Boxplots give us a nice idea of the distribution of data, but looking at those plots with large colored boxes leaves us wondering what else is going on. According to Edward Tufte in Envisioning Information:</p>
|
279
278
|
<blockquote>
|
280
279
|
<p>Thin data rightly prompts suspicions: “What are they leaving out? Is that really everything they know? What are they hiding? Is that all they did?” Now and then it is claimed that vacant space is “friendly” (anthropomorphizing an inherently murky idea) but <em>it is not how much empty space there is, but rather how it is used. It is not how much information there is, but rather how effectively it is arranged.</em></p>
|
281
280
|
</blockquote>
|
@@ -283,7 +282,7 @@ R.dev__off</code></pre>
|
|
283
282
|
<blockquote>
|
284
283
|
<p>A most unconventional design strategy is revealed: <em>to clarify, add detail.</em></p>
|
285
284
|
</blockquote>
|
286
|
-
<p>Let’s
|
285
|
+
<p>Let’s use this wisdom and add yet another layer of data to our plot, so that we clarify it with detail and do not leave large empty boxes. In this next plot, we add data points for each of the 60 pigs in the experiment. For that, add the function ‘R.geom_point’ to the plot.</p>
|
287
286
|
<pre class="ruby"><code>R.png("figures/facets_with_points.png")
|
288
287
|
|
289
288
|
# Split in vertical direction
|
@@ -296,8 +295,8 @@ R.dev__off</code></pre>
|
|
296
295
|
<img src="data:image/png;base64,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" />
|
297
296
|
|
298
297
|
</div>
|
299
|
-
<p>Now we can see the actual distribution of all the 60
|
300
|
-
<p>But no sweat! Another layer might solve the problem. In the following plot a new layer called ‘geom_jitter’ is added to the plot.
|
298
|
+
<p>Now we can see the actual distribution of all the 60 subjects. Actually, this is not totally true. We have a hard time seing all 60 subjects. It seems that some points might be placed one over the other hiding useful information.</p>
|
299
|
+
<p>But no sweat! Another layer might solve the problem. In the following plot a new layer called ‘geom_jitter’ is added to the plot. Jitter adds a small amount of random variation to the location of each point, and is a useful way of handling overplotting caused by discreteness in smaller datasets. This makes it easier to see all of the points and prevents data hiding. We also add color and change the shape of the points, making them even easier to see.</p>
|
301
300
|
<pre class="ruby"><code>R.png("figures/facets_with_jitter.png")
|
302
301
|
|
303
302
|
# Split in vertical direction
|
@@ -305,7 +304,7 @@ puts @bp + R.geom_jitter(shape: 23, color: "cyan3", size: 1)
|
|
305
304
|
|
306
305
|
R.dev__off</code></pre>
|
307
306
|
<div class="figure">
|
308
|
-
<img src="data:image/png;base64,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" />
|
307
|
+
<img src="data:image/png;base64,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" />
|
309
308
|
|
310
309
|
</div>
|
311
310
|
<p>Now we can see all 60 points in the graph. We have here a much higher information density and we can see outliers and subjects distribution.</p>
|
@@ -313,12 +312,12 @@ R.dev__off</code></pre>
|
|
313
312
|
</div>
|
314
313
|
<div id="preparing-the-plot-for-presentation" class="section level1">
|
315
314
|
<h1>Preparing the Plot for Presentation</h1>
|
316
|
-
<p>We have come a long way since our first plot. As
|
315
|
+
<p>We have come a long way since our first plot. As we already said, this is not an article about data analysis and the focus is on the integration of Ruby and ggplot. So, let’s assume that the analysis is now done. Yet, ending the analysis does not mean that the work is done. On the contrary, the hardest part is yet to come!</p>
|
317
316
|
<p>After the analysis it is necessary to communicate it by making a final plot for presentation. The last plot has all the information we want to share, but it is not very pleasing to the eye.</p>
|
318
317
|
<div id="improving-colors" class="section level2">
|
319
318
|
<h2>Improving Colors</h2>
|
320
319
|
<p>Let’s start by trying to improve colors. For now, we will not use the jitter layer. The previous plot has three bright colors that have no relashionship between them. Is there any obvious, or non-obvious for that matter, interpretation for the colors? Clearly, they are just random colors selected automatically by our software. Although those colors helped us understand the data, for a final presentation random colors can distract the viewer.</p>
|
321
|
-
<p>In the following plot we use shades function ‘scale_fill_manual’ to change the colors of the boxes and order of labels. For colors we use shades of blue for each dosage, with light blue (‘cyan’) representing the lower dose and deep blue (‘deepskyblue4’) the higher dose. Also the smaller value (0.5)
|
320
|
+
<p>In the following plot we use shades function ‘scale_fill_manual’ to change the colors of the boxes and order of labels. For colors, we use shades of blue for each dosage, with light blue (‘cyan’) representing the lower dose and deep blue (‘deepskyblue4’) the higher dose. Also, the legend could be improved: we use the ‘breaks’ parameter to put the smaller value (0.5) at the botton of the labels and the largest (2) at the top. This ordering seems more natural and matches with the actual order of the colors in the plot.</p>
|
322
321
|
<pre class="ruby"><code>R.png("figures/facets_by_delivery_color2.png")
|
323
322
|
|
324
323
|
@bp = @bp +
|
@@ -353,15 +352,15 @@ puts @violin
|
|
353
352
|
|
354
353
|
R.dev__off</code></pre>
|
355
354
|
<div class="figure">
|
356
|
-
<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAeAAAAHgCAIAAADytinCAAAxOklEQVR42u3df3AV1f3/8YAiP7+MYVpHrAICMv5ApEanKEWihFTxA0mJQoL2awMJYCsFp5B24JNU+gd+SaVWKUM+gJDQ8h0s8yXRkUColMhQJCW5TNQwpf6gGKk40UwMBhII8XuSheVyf+7de3b37N7na3acvfeG696cPY+c+96zu0nfEkIIUTJJ/AoIIQSgCSGEADQhhAA0IYQQgCaEEIAmhBAC0AZznCRGaH1anwA0AWgC0AAN0ASgCUADNAFoAtAADdAEoAlAAzRdlC5K6wM0QAM0AWgC0AAN0ASgCUADNAFoAtAADdAEoAlAA7THU1paOnHixGHDhon/lpWV6c/fdNNNAO29vPTSS3PmzAl+PicnR7wkVrZu3Tpp0iSxP9x3332vvPIKQAM0QDuW8vLysWPHbt++/YMPPhD/FesVFRUA7eHP+/7774tWfuedd/yfFA/Fk+KlnTt3ipU///nPDQ0N+/fvnzt3LkADNEA7lieffPIPf/iD/lCsz5o1C6C9/ZFXrFjxi1/8wv+ZRYsWiSfFyhNPPPHqq69S4gBogFYid9xxx+HDh/WH77777p133gnQ3v7I//jHP8Qw2efzaQ/r6uruuusu8aRYv/3222tqagAaoAFaidxyyy3Hjh3TH4p18QxAe/5TL1y4cOXKldq6WBEPQ+4PAA3QAM0IGqDtzt/+9rfvf//7x3oiVsRD7XlG0ASgFcoTTzwRUIN+8sknAToRPvjs2bPXrVv3xz/+Uaz47w9r164FaIAGaCWiHbXfvn17Q0PD66+/LtbFMwCdIE0/efLkhx56SG9x7cm7775727Zt2iyOefPmATRAA7ST2bJly4MPPnjLLbeI/4p17cn3339/+PDhAO3tTO1JwJP6POj777/f8zM64Big3Zdjx4699NJLjzzyCEATgAZogFYrN99884QJE8rLywGaADRAAzQBaALQAA3QBKAJQAM0AWgC0AAN0ASgCUADNAFoAtAADdAEoAlAAzRA00VpfVqfADQBaALQAB1/mizL+fPnz50716Re1Nwwq7eK1k/kDYNjgKYnADStD9AADdAADdBsGEADND0BoGl9gAZox9JiWS5cuNDR0dGiXtTcMKu3itZP5A2DY7cC3WpZOjs7xaCgVb2ouWFWbxWtn8gbBseUOPguSYmD1qfEAdAADdAAzYYBNEDTEwCa1gdogAZogAZogAZogKaLAjStD9AADdB0UYCm9QEaoAEaoAGaDQNogKYnADStD9AADdAADdBsGEADND0BoGl9aSlvbDwF0AAN0AAN0Kpt2MaTJ6/x+aY0NJwCaIAGaIAGaHU2TNM5qa5OLFGNrq6u/rVfioqKCgsL9Yc+nw+gAZouCtC0vnydxSLWyxsbI/x8bm7uuAkTx6Q+FryM/8EDwmiABmi6KEDT+vKBFiviYeSfF0CP+NETSQt/F7wIowEaoOmiAE3ryzfaiM4ADdAADdAAbfeGCZqN6AzQAA3QAA3Q6m4YQAM0QAM0QAM0QAM0XRSgaX2ABmiABmiABmiABmi6KEDT+gAN0AAN0AAN0AAN0HRRgKb1AZoANF0UoGl9gAZogAZogAZogAZouihA0/rGc6rn8tAADdAADdAArdaGCZ2nNDSEuzQHQAM0QAM0QDuzYZrOES5uB9AADdAADdDObFh5Y2PA5aEDjAZogAZogAZoxzYs8hWiARqgARqgAdrJDYtwhWiABmiABmiAdnjDwl0hGqABGqABGqAV3TCABmiABmiABmiABmi6KEDT+gAN0AAN0AAN0AAN0HRRgKb1ARqgARqgARqgARqg6aIATesDNAFouihA0/oADdAADdAADdAADdB0UYCm9QEaoAEaoAEaoAEaoOmiAE3rAzRAAzRdFKBpfYAGaID2AtDhLoQG0AAN0ABNF3VyqyJcShigARqgAZouakmqq6t/HZSioqLCwkL9Yca6db1qa7WbcfSuq4vfaFofoAlA00UN9cxxEyaKThhhGbqkIOky0EJqgE40oKdPn+7z+QAaoOmidg+f09LSwvXMq5bfbU2qrRNMi9E0JQ6PbVjk3SB59uLxP3hA4iAajgGaLhrD8HnQ0wXRge4xWgylpQymaH2lNizqbiC3ygHHAE0XjfeLraWDKVpfNaAj7wYADdB0URcALauv0voATQCaLgrQtD5AA/TlHDlyRDTkzJkz58yZU1xc/OWXX2rPd3V1bdmyJTs7Oycnp6ysTDykiwI0rQ/QxFagly9ffujQoW+++ebs2bOvv/76smXLtOd37969dOnSr3oiVqqqquiiAE3rAzRxrMTR0dGRlZWlrQup6+vrtXWxUlBQQBcFaFofoIkzQIvdbseOHStXrtQezp49u62tTVsXK9nZ2XRRgKb1AZo4APT0njz99NP/+c9/tGdmzJih153FSkZGhv/Pv3A55yzLxYsXOzs7z6kXZzcsLy/PBNCFhYVx/n/D/VGn9dXcDaQ0euTWB2hbI4bJ27dvF391jYyg51/Oecsi/iqIznBevTi7Yfn5+SaALioqivP/G3KfofWV3Q2kNHrk1gdoB2rQM2fOpAZNiYMSByUOShxKAP373//+008/Fd/ampubX3vtteXLl2vPV1ZWCqO1WRxihVkcAE3rAzSxG+iDBw8uWrQoMzPz6aeffvnll1taWgLmQYuUlpYyD9ozQJu7ij+t7zqgc9asOQXQXipxmAhd1F1Am76KP63vLqCHLinoVVs7paHhFEADNF3UFUBrOmsXiY7VaFrfTUB3X2n20tXApRgNxwBNFwVoWl/GbqBdB7yuTm/o8sZGgAZouiglDlpfLaAtvSMlQAM0XVQy0E0cJEyYEoeUW50BNEDTRW0FWmIXpfWV3Q2GLimQcqszgAZouihA0/qSdwPR6IsXLwZogKaLAjStb2uM3Dh4aEZuSkrKm2++CdAATRcFaFrf1n0g6o2Dey0ovvOHj8g6mRCOAZouCtC0vsx9QOLZ3nAM0HRRgKb1ARqgARqgARqgARqg6aIATesDNEADdEJ0USOH7wEaoAEaoOmizvTMqIfvQ3bU6dOn+3w+gAZogAZouqhC9Q2xJM9ePP4HD8TZV2l9gCYATReNlJycHBNAS+mrtD5AE4Cmi4ZNWVlZSkrKd5541hzQcVY5aH03Ai3rbG84Bmi6aPRuedsj/2VCZylVDlpfkQ0zfqBY4tnecAzQdFE53dKiQTStr8iGGT9QLPFsbzgGaLqonG5p0SCa1lcHaON/p2WVoeEYoOmiFg6f4x9E0/oATQCaLhoiOTk5cQ6f4x9E0/oATQCaLhqYeCZvSBxE0/oATQCaLhqiuGF68ka4QbQJo2l9gCYAbVNPMHfjVPu7aPzHBiMXOoz/HgAaoAlA29ETBEnX+Hym70hvWxeVdWwwXKHj//T8Egz+HgAaoAlAW94TNJ2T6urEEtImweKvI6aoqKiwsDDCD8R5WSJ/naUPn/VB9IifPdertjbC7wGgARqgAVo5oLurCqnpY2bNN7eM/2GqlC5hRXHDf7l++SqAdt2GxfqlSsqFDAEaoBUqcXSPUBa+kLT/W3OLMDp+oK0rbvifZnbzL54XRveuq6PE4ZYNi/XPtpQLGQI0QCt0kFAFoGVNfDZS6MhYt46DhC4CWp3bNQA0QDtzTaI4gY7zS6Xcic+yvgIDNEATgHa4J1yqLcQBdPKr++IpQ0uf+CxrWjRA27NhkSc+AjRAJzTQ2hHCQZuPmgY6ziqH1ccGTZcpAdqeylvkiY8ADdCJDnQ8w+c4gbbh2KDpQgdA23PsWp9Xs/7kyfLGRoAGaIBWBWj7h8/GB9EAbTPQY997L3goDdAADdASgNYGpDGdUG5m+LxyU9LP10j4GQODaIC2s8QhdA45RR2gATpxgY7/CKH/ccKMdetiOqE85uHz77Ym1dYlVeyN5K+RnzE2iAZo2w4S/vKjj/ShdIDRAA3QiQu0lCOE2jL0N6tjOk8v5r6nyav14XD+GvkZwz0ZoO3csHDnuwI0QCc00PEPn80BHVt9w19esYj1lZvM/EwsVQ6AtnnDQs7oAGiABmgJQI+ZNT+mEkds9Q1/fMWKeGjuZ2KpcgC0/RsWfAwDoAEaoOUALXqF8YOEMXc8zd/I8hr5GcOdGaAd3zBzszClXC8JjgHa/UBXdyUdaDU3087EyKib3ajyGvkZgHbJhpmbhSnleklwDNAuB1roXPNhUp0v6WCziStymAHamjNWAFploM3tJPFXOeAYoB3uCXHNsbuks1bz7TY61ityADRAAzRAA3TE74+m59gdaO12WZ8y0WN0TFWOK33v52uiTrcAaIAGaIBOOKDjKkAfbPYz2izQQueKvTEd1gNogI6nWQ0ex4ZjgHY50FeMvlKGjgno4Y9nd+scy8Q4gAboeJrV+N2T4Rig3Q+0ZnSPziaAvvHZXwaeWmK70QCdOEBHvTknQAO054AOc027U01NwZeODNH3Yj+7BKABGqABGqDNAy10ntLQELkPXOl7sZ9dAtAATYkDoAHaDNCazlHHKVf1vRjPLgFogOYgIUADtBmgyxsbw106MuD/PjIt09lJ0IOeLhg3YSJAJxTQBgPHAO3ZEoeRYl9xcXFKSkryrEXOnqWSlpZWXV0N0AAN0B4BusWyXLhwoaOjo8WuzJ07VzrQy5cv195882efacU+sRLy//7VV19lZWU5ezKh6Mb6BgfH263vig3r3kXNAh2hZY0Ejt0KdKtl6ezsFKOVVrsyb9486UCvWLFCf/8tp06JJcoGSAHabAn7joem+m9wQLzd+q7YMNN7iAA6QssaCRxT4vDyNDuDGzB2Ymq/nxbGq7OpSSA3ZsxNSUkpKyuL6UsuJQ5KHAAN0AkBdEVFxeTJk+MaREeYRh3tEh+iDy9YsCDWLgrQAA3QAJ0QQDfFf027cEAbuMTHHQ9Njby1AA3QBKATHeh4qxzBJQ5N54hnJ0atbwA0QBOATnSgJVQ5gg8SrtwU9RIfUesbAA3QBKATHegmi85YiXiJj8jnpwA0QAM0QAP0pVh1xkr42R2Rz08BaIAGaIAG6Es5ffq0VWeshJkfbbD3AjRAE4BOdKCbZE2IlnH9DYAGaIAGaIC24FChjOtvADRAAzRAA7S0rmhd1wVogCYADdD2VTmM1zcAGqAJQAO0rVUO4/UNgFYEaHNTMKOeJgrQAK1cTwi4l4RSQNtT5YhpYAXQjm+YuSmYRk4TBWiAVqsnBN+NTUGgLa1yxFTfAGgHN0wfSZibgmnkNFGABmiFekLIW5yoBrTVVY6Y6hsA7dSGBYwkTHyvir8AbSnQSUlJAA3QqgB9qmdRocoRa78FaPs3LHhHBWiApsRhFdDaHb7FcsppoGOtbwA0QAM0QHv5IKGms9bZDBptXRk61voGQDu1YfP/9S9tnxEr3ihxbN68eeTIkX369Bk9enRJSYk/0OLhqFGjxEvivxs2bNCfP3bs2GOPPTZ48ODrrrvu3nvv3b59u/7SG2+8MX78ePH88OHDN23aBNBenmY3MrfAIqD9dTZudGAZOtpdUSzttADNCDr+7Ny5U+BbU1PT0dHx7rvv3nrrrTrQW7duHTFihHhSvHTo0CEB7rZt27SXbr/99rVr13799dfiJfFvZ86cqT2/Z8+e5ORk8Z7t7e319fVjxowRXQagvdlFL81hernKCqDLGxv1nqb3N/FkDFUOA3dFAWiAVhzoCRMmVFVV6Q93796tAy16X2Vlpf7Srl277r//fm29X79+n332WfC7TZo0SeisPzxy5Mi4ceMA2ptd9NIcJnlVjjsyf+LfMUIemTQKtIG7olhagAZoZnFISf/+/c+ePas/bGtr04EWCge8JJ7R1p9//vkbbrjh2WefLS0tbWxs1H9mwIABSVend+/eAO3ZLiqxDH1jUWnw2QHBRyYNlqGv++9Xot4VxdICNEA7uGH+B0sSE2iRuro68R131qxZQ4YMefHFF/V/cubMGQ4SArSZ+kbIswMCjkxGzZUydMS7otjQYwFahQ3zdolDPNRfqqys1Esc/vnkk0/EwFlbnzhxohhnADRA232WSug+Gf6uKAAN0K4AeseOHaNHj66pqRG/xsOHDwccJBw5cqR4Un9JP0j46KOP7t2795tvvhHj5Q0bNtx1113a82+//fZ999136NCh9vZ28ap4OG3aNIAGaLuBvjLZLsxdUawuQAO0OkDHer0k1abZbdq0acSIESGn2a1fv37UqFHXXnttwDS7Xbt2ie+Rffv2HTx48OOPP378+HH9JTGCfvjhhwcOHNi/f//U1NS33noLoAHaVqDlnvNtrgAN0FI2LNYCV3BivV6S6b/H1gHtmQA0QJv/Yit9PAXQcW6YiUPEwYn1ekmm/x4DNEADtKkqR/CyclP3PDyLx1OJCbSg7ddXp6ioqLCw0P8Zn89nUOdYJ1nG/9daSn0DoAEaoKNXOYTRomcGLN9dVphUW9v///5l+OPZwa8GLEJn0+OpxARa7BLjUtNFa4Zbxv8w1UhDAzRAA7RngdaMzg1K6qpVvWprtW5/S3l57oIFudFi+ttuwgIdeZcw3tBSShwADdAArSLQkQdl2rhsz5dfWve/A+j4Gzr+g4QADdAA7T6gxcq2piZLf10JC/TYH2X2e/2Egw0N0AAN0IZ6o1JAB3xrtvrXlZhAX5rjGObP9qDNR8elpgM0QAO0871RQaD9vzUDtP3fq0QrS5nEBtAADdD2VTkcGVgBtCNA29zKTTGeTAjQAA3QSgysANr+wpcjQBs/mVDWaYQAnaBAn+q5kr0ngba/3wK0zYUvR74nNUU4mfDnawLOV5J1GqEsoEtKSp6zJuKdAVoy0NpdoCJMCwVogG5SIyH3Cke+J4UtQ2u3dBCLn9Gy6huygBaS3jPhwdGP/JfcRbyneGeAlgm0/z36whkN0ACtDtDBVQ5HWjk00P433PEzWkGghafS74As3hOgJQMdcI8+3Wj/Sx/4X/TAyOUOABqgbatyOFXfCAG0v85XGw3QAG2+i4a8OkH3pQ/S08fMn++/jE9Nta0nADRAG9kxHKxvBAK9ctNVt0PTbrjTc/d3gAbouLpo8NUJuve8F15I6vnw+iKMdg3QB5vFAtCeBHpkboEK9Y0QJY4wt0MDaICOt4sGXJ3A3UALnevEdwLf0N+sBmiPAX1pctvLVSoCHeZ2aAAN0N/K3/NcCvQlnbVRTG3GunUA7SWgL01u69k3nC1AN4U7mTDodmgADdA2AT19+nR7jhOavxwHQHsaaP8/3s4WoJui3sDh8nLHQ1MBGqAtBzp53z7bjhPGdTmOy0YPW7KUEoe3gXZw+Nxk7DaVN2bMTUlJKSsrA2iAthZod5Whh/5mtSPDK4BOHKCbDFwyaUzqYwsWLLC09QEaoN03kcOp3gvQtpW/3AK0xI10F9C7d+9+5JFH+vXrN2TIkKeeeuqLL74AaIAGaI8DrZe/AFpxoKdOnVpZWXnmzBlB889+9jOBNUBLSHV1dVpaGkADtJpA6/sGQLuoxNHW1ta3b1+AlrPPjUtPH3T0KEADNEADtBSgxfeeBx54AKAtrG8ANECrkEvf8ADaPUAfPXr05ptvFv8FaE8B7X9SL0AD9JVveKnpgzYfBWhXAL1//36h8zvvvOPuWRx1dXUrVqzIysqaM2fOmjVrWlpatOe7urq2bNmSnZ2dk5NTVlYmHiYI0AEn9ca63JH5E4D2KtDummaXyEBv3779pptuqqmpcf00u8LCwtraWtEZBM3r168XWOtTVZYuXfpVT8RKVVVVggDtf1Jv2KW6q3sJev7GolKJZwcANEADtAmgxUBz2LBhx44d89o86Pb29pkzZ2rry5Ytq6+v19bFSkFBQYIAHb0MLWiu+bB7CTJadF2JZwcANEBH2JgIZ3tLvBuhG4FOCsqZM2e8APThw4eFy9r67Nmz29ra9Kkq2dnZzgK9ePFiJYDWdNauuRFktINdF6DtBNq2i8OES+SzvSXejdDVBwk9NYL++OOPxS4o/qs9nDFjhl53FisZGRn+P/zC5ZyTl7y8vHBAD33ttZSUlL17956zJd1bEhJof51DGS26bmFh4TkncvHixc7OTuveP+Q+496PE2tqamqmTp2q7RXJr+4b/8NUpxr6qr00PNByNw+g5QB9+vRpIenAgQMDRvhR/+F7770ndP7ggw/0ZyKPoOdfznl5yc/PDwd0r87OO2fNKioqOm9LurckJNAHWq9csu7S4ut+0u9S/bZtZEDEH1GBmnXvH3K3ce/HMbFLaFM49L/ETjX0VXtpeKDlbh5AywH6xz/+sfi72tzcHNO/OnDgwDPPPHP8+HH/J5WqQSs0Fdr/sqJiRTx0+lL9lDjs3yVUqHJEOE4o9wghJQ5pQA8aNCjW32Z5efncuXM//fTTgOcrKyuF0dosDrHi7CwO+4GOdFXoyxxfrbNjV4IGaKujn6Ki7wNalcPZQ4UA7T6g+/btG+v3kelB0UpO+jxokdLSUqvnQUe4EIf9QEe/KnRPQSN4TN0LoL0ItH6KiiIHhAHarUCPHz/+0KFDbjyTMMKFOFScaRdyTF1be/cvf+nUjTYA2rrk5OQE7wyOVzkA2n1Ab9u2TRh97NixcANelYGOMHxWHejLl+p3cEgF0BalrKwsJSXlO6srAlrc8SoHQLsP6KQwAWjLgXb6Oy9AW7cn3PbUonAtbuf0fIDmjioADdAAHenwoP8y9L+7p+e/+eabAG0Q6HsmPCg8lbuI93QT0Dt37rz77rt79+6tPZw2bdquXbsA2sT2xHp7b4D2HtAhDw/qS699nXc+PsupRo9wtrfE+3lLBPqf//znYWsi3tkdQG/YsGHMmDFHjhzRyxp//etfp0yZ4g2g7TwmE+vtvUUfFj0ZoL0EdOThs+OHCsOd7S33ft4SgS4pKXnOmoh3dgfQw4YN084u0YE+c+bMgAEDPAB08r5941NTla1yiI7qyM28Adqp4bMKhwpDVjnk3s9bcoljctropxbJXcR7uqbE0adPn/b2dn+gxV4+aNAgDwCteBna8VmxAB1rNp48KZYIPxBydp1Sg+hwQEvfFaUdJAxzuDWeRbyna4C+55573njjDX+gDx48aNFNbQEaoN37cQTN1/h8YglndLjZdUoNogHaZUDv3LlzyJAh5eXl2iVQ9+/fL3Yy8b1bcaCjnkYI0AAtXWft5M9wRovh822GNXFqEA3QLgNau4bGpEmTBgwY0K9fv4kTJ7799tvqT7OLehqh+hM5ANpLQBsfPjs7iAZo9wHtxnnQRuob9gNtfCKH41M4AFpuiSOm4bP0QXR5Y+MpgPYS0EnRAtCWVjkcn8IB0BIPEsY6fJY7iNb+ckxpaDgF0IygAVoW0I7fpA6gZcXE8FnWINq/9mLEaO1cFWG0/yL3boQADdAADdCqAG1u+CxlEO2vs1YcL29sjFqFy72c/Pz8vLw8bV36lzmABmhDQNt8rBygEwpobTbRbXEgEs8g2sjcEqd+Y+4C2obSLkCrcjLhyNwCgE4QoI2cOmhkEB2n0SZ0BuiQR+YA2lag7a9yFBcXiy+8yS9XKT6FA6BlDZ9jvYShFYUOEzoDNEAnItCnT5/OysqKerkcx6dwALQUneMcPjt73gpAA7QlXdTgaYTKHidUob4B0HEmJydHls7xFzoAGqAVAtrgaYQADdAWJZ6ZG5GNtvN+KwAN0FYBbXD4DNAAbVFx4zYL4LD5fisADdDOAd3c3L0ANEArXHoOeb8V2wodAA3QDgEtaPb5upfmZkeAjnzJJIB2L9ByS8/OFqMBOngetKWzoQHaT2ft9Cqfb+jq1TZrGPmSSYrMsQNoRUrPDhajAZozCZUA2v4JTBGqHIrMsQNoc8WNG3/7+6SDzZYCbVsxGqAB2vkSh/0nE0YFWoXhM0Cb0HnYkqU9f/h90Y0+0JpU3aV4MRqgAdr5g4SqHScEaDd+nJycnMs610U3WrwkfqDmw3iMtqEYDdAA7fw0O4AGaCml5/9Vureb3ahAazprPybDaOv2FoAGaIAGaNcDfeVyz5fwNaaz5viBVmVPAQdogJbfRWM6zxugAVrK8PnKzA1BcNTihpEyiAKDaIAGaPldNKbzvAEaoONvythOGow6ylZmEA3QAG0J0DENn50COtxVoQHaRR/H5AVFI4+ylRlEAzRAJyjQEa4KDdAu+jjxX49f1iAaoAEaoKUlwlWh78j8CUC7COj4r8cP0KZz+PDh//fO4S2ffyt3Ee8pAtCuAdr0PSli7ds3FpWKkXVZWRlAA7TxSogA2oozv9UHuqSk5DlrIt4ZoN0BdDx3dYu1b4uetmDBgiY1AtBWAW1E3liOJVp05rcrShz3pKWNXrRI7iLekxKHO4CO877IJoBWpL4B0FYBbUTeGGfj9drXeffU6dL3HHfUoBctiqmzG1nEewI0QAN04gFtUN4YgbaoMgbQAE2JA6ABOt4Sh0WVMYAGaFWAjnyMxbaDhABNicPcQcLEnWYH0J4Heuhr3cdY9uzZYyd/AM1BQqbZATRAR196dXbeOWuWCmd7A7TrgI589zLmQQM0QMcLtDqX4wBod32cyHcvA2iABmiABmgnP47jJxNadxNLgAZogAZogI53+GzRTSwBGqABGqBdD3S4CxOGWKq74rmFis2XPwRoPV1dXQUFBddff31ycrL4bYuHIXi9OgAN0ADt/MeJcGHCEDrXfBjnba7svLoWQOspKSmZMGHCqZ6IlY0bN4YEmhE0QAO0Wh8nwoUJQ+gs41aEtl1dC6D1PPDAA/v27dPWxcrEiRMBGqAB2h0fJ3oZ2l9nqUZbenUtgNYzePDgr7/+WltvaWm5/vrrQwI9ZMiQPn36jBkzZtWqVZ2dnQAN0ACtBNBRZkMfaL36XrESbhdrww4D0Hp69+598eJFbV2sXHPNNeE2SbhcX1//8MMPL1myBKCjAd3amtTVBdAAbenHMTQbWvbtYi2dYAfQJkbQ/vn888+j/kzCA93cnOTzJX34oRGjARqgra1y6JfgkHq7WIsm2AG0iRq0f7744gthOkCHB1rTWRuwGDAaoAHawiqH//D5H8dkHSG0em8BaD3r168XRmuzOMSKPovD/8Bgdnb2+++/f+HChY8++mjatGlz584F6NBd5bsbNlzRWSxivbUVoAHauo8TqcpxVXFDWvXZ6voGQAfMg162bNn1PfnVr36lz4P2B/ovf/nLuHHjrr322u9973vPP//82bNnvQl0S3wRf7iuAlqsiNG0gRLH8uXLW2yM2M7gExwE0DZvRoSIsUBHR4d1729F6zv4cUSDGgBaZn1j6tSpBw8edOlvjDMJ3Qp0a3yZN2/elRKHMZ01oFesWNFqY9asWRN8goPodTZvRoR0dnaKMZR1729F6zv4ccSOF7bKEcvV940DbfWuYulvDKA5SNhsUGdHShwhT3CgxOHejxNlLofUa0DbUN+gxAHQCT0POmQZGqDd+3GaYr0uh8LzNwAaoF0DtPT7XelvCNAeA7q4uHjkwoUD/1zt0uuLAjRAuwxo6XeM9X9DgPYY0P9z4kSv2toksUi9o5Ujw2eABmjVgdYw1Y6/SzE64A1TV60a+6NMYbS+2DMyAmgr4t+43Ys1Rts2fAZogE50oJfu3Zvbk/z8/Ly8PG3dhpERQFsOtGWDaNuGzwAN0Ile4rDz2zdA2/BL1hq3d13dyIULDV0hWuHhM0ADdKIfJARojwGtNe7/nDiRlZVlxXQOO4fPbgH6nrQ04ancRbwnQDPNDqA9CLSWGG6zourw2RVAr1+//jlrUlJSAtAADdDeBFo7CynKRaLVHj67AmiPBaABGqBtiqGLRCs8fAZogAZogPYs0E1G7rSi8PAZoAEaoAHay0DLGkQ7MnwGaIAGaID2MtAmB9FXX1ZJ09n+4TNAAzRAA7THgdYG0TFMuQu6MKkjxQ2ABmiABmjvA910ecqdMNr/nP6Qy3d/tyGp9vKZ4rV14qGzZ/8DNEADNEB7HOjTp0+/9NJLueGjn+ifumpV97WWeoAWK+Khs2f/AzRAAzRAexzomDZM+qUFABqgARqgAVrahkm/tABAAzRAAzRAs2EADdAADdA4CNAADdAADdAADdAADdAADdAADdAJAHROTg5AAzQOAjRAKwd0WVlZSkrKdyoqABqgcRCgAVotoHNzc28zdQscgAZoWh+gAdpyoE3UNwAaoAEaoAEaoAEaoNkwgAZogAZoHARogAZogAZoNgygARqgARoHARqgAZouCtAADdAArQ7QixcvposCNK0P0ACtHNBDX3stJSVlz549dFGApvUBGqDVArpXZ+eds2Z58t5CAA3QAA3Q7gba2TI0QAM0QBOABmiABmiABmgngK6urk5LSwNogMZBgAZo5YAWw+dx6emDjh4FaIA2/nEcvwcgQJNEAdr08BmgExNoFe6iDdAEoAHa40BXV1f/OmKKiooKCwv9n8lYt65XbW1SXZ1YxIp46PP5aH2ABmiABugm6a0/Lj1dNKLxZejq1UmXgRYrI5YscWQHAGgC0ADtTaDLGxtP9ayYu9VZUnNzks/XDbTPJ7wGaIAGaHWBnj59Ol9yXQS0VkGe0tDw2p/+ZO5WZ1eA7hlEZ6xbR+sDNECrCHTyvn3jU1MZQ7kFaE1nzdabd+4cvWSJmXYHaIAGaFcA7WCVA6BjbX1/nbVDfDeuXWuy3TWjKXEANEADNEBLB1qspK5aFVfTC6Obm2l9gAZogAZomSUObQpz/E1P6wM0QFsIdJznedNFXXqQUDvBBKABGqCVBjrO87zpom4EWuKXJ1ofoAHaWqDpogBN6wM0QAM0QAM0QAM0QNNFAZrWB2iABmi6qKuBHpuZ2e/ECVofoAE6SqZfTsDzXV1dW7Zsyc7OzsnJKSsrEw8BGqCltH5FRcXkyZOZwwPQAB0D0wHP7N69e+nSpV/1RKxUVVUBNEAzCx6giRJAL1u2rL6+XlsXKwUFBVYB3XNiGF3Uw0DrF7EDaIAGaDlAz549u62tTVsXK9nZ2ZYAffnSCiaMpou6Amj9InanABqgAVoW0DNmzNDrzmIlIyPD/9UXLuecqeTl5XX3T/+Lk8VutOiihYWF52zPxYsXOzs7zykWq7cq5G4T9V/96Ysv9Ktw/Oj48ZazZ6/aAczqPOjo0XHp6bS+bRsGxy4bQc+/nPPRsujkSbEEPJmfny8F6KKiovO2R/y5Ep3hvGKxeqtC7jaR/8m2pib/i9iJ9b3NzVftAHEMn9PT048cOULr27NhcOzNGvT8f/1L65xihRJHopU4Ai5i53+nV+6nQ4kDoOMCurKyUhitzeIQKyZmceg6BxvNQcIEqUGHuw+32AFGFhQANEADtNF50AGzofV50CKlpaUm5kGHBPpUz8I0u4Q6SBigs0hxcXFKSkpyVRVAAzRAW5iYShyC5ikNDWL53/EdIwJod02zC87p06ezsrJM7wMADdAALQFozWh/nfW70g3/7W8BOmGBjrMMDdAADdBygNbir7O29N+9O6mrC6ABGqABGqAdBrq8sdF/xtWlpbUVoAEaoAEaoB0GuunqSVe9amu/u2EDJQ6ABmiABmglgG7ym3QV732dARqgARqgAVou0E2XJ10xzQ6gARqgAVo5oOPvnAAN0AAN0ABtLdDcUwOgARqgAVpFoLmnBkADNEADtKJAN3FFYIAGaIAGaIAGaIAGaIAGaFuB1i7ZDtAATesDNEArB7ToomlpadXV1XRRgKb1ARqglQOaLupqoHNycgAaoAE6gYAOeelhgFYQ6LKyspSUlO9UVAA0QAO0okCPzcwURptbggvQ4W7eAdAKAi1a/7ZFi/j+BNAArSjQFRUVuRGTn5+fl5cX4Qf8C9ARbn8H0GoCHef3p+nTp/t8PoAGaIC2BGi5OxxAJxTQyfv2jU9NZQ4PQAO0O4CmxJFQQDMLHqAB2mVAN3GQ0CVAV1dXp6WlATRAA3RiAZ3IXdRFQIvh87j09EFHjwI0QAM0QAO0ckBLudisI8cJAZoANEADtKLHCQGaADRAexZoKQVoB6scAE0AGqA9C3ToAnRzc/cC0AAN0AAN0M4CHTh8FjT7fN1LjEY7UoYGaALQAJ0wQGs695xhFKvRjpShAZoANEB7FujAi9gZBLqrK6m1VYUqB0ATgAZobwId+iJ2UUscQucPPwz5AwAN0AAN0AAtB+iwF7GLcJBQ0znMEBugARqgARqgpQEd8wS71tYrNZAgo+0/TgjQBKABGqC/NVKntv84IUATgAZogP7WYJ3a5ioHQBOABmgPAh3vOYRh6tQADdAADdAAHW/rS7mIHUADNEADNEBbAnS8l+AINYgGaIAGaIAGaKeBDlOGBmiABmiABmhHgQ4/kQOgARqgARqg1QXazqnQAE0AGqAB2miJw+ap0ABNABqgAdroQcJBR4+OS08HaIAGaIAGaEeBDjPNLi0trbq6GqABGqABGqBVArq5eejq1RwkBGiABmiAVgxorSpdW5uxbh1AAzRAAzRAKwO037yOXrW1G0+eBGiABmiABmjzQI8sKABogAZogAZo5YAuLi5OSUlJrqqixAHQAA3QAK0W0KdPn87KypJehuYgIUADNEADtITWt2IiB6d6AzRAAzRAWwl0hHsSRlxsPksFoAlAA3SCAR31rt7KnKUC0ASgAdrLQI/NzOx34oSRqyApWN8AaALQAO1ZoCsqKiZPnnzVIBqgARqgrUuLZblw4UJHR0eLelFzw6zeKlmtP3fu3MAqh9kSh1aAXr58Oa1v9YbBsVuBbrUsnZ2dYlDQql7U3DCrt0pW68+bNy/E6SqmDhKK4fPUqVP//ve/0/pWbxgcU+Lgu6T3SxxNUk9Xsb++QYmDADRAexloWaer2D/BDqAJQAO0x4FuknRRDvsn2AE0AWiA9j7QUqocjtQ3AJoANEB7HOj4qxxO1TcAmgA0QHsc6KaQZ6yYrW+c6lkAGqABGqABWk7rhzhjxVR9Q9A8paFBLKcAGqABGqABWlbrm76ynV7f0HTWzkK0zWiAJgAN0AkB9NjMTGF0rIvQOS0t7a/vvKPrbKfRAE0AGqC9D3RFRUVu+OTn5+fl5YV7tbq6uryx8Rr9Ih49i3gongRogAZogAZo51t/48mTutFixZ7bEgI0AWiABmhDH0cz2jadAZoANEADdAwfR9Bsm84ATQAaoAGa1gdogAZogAZoNgygAZqeANC0PkADNEADNEADNEADNF0UoGl9gAZogKaLAjStD9AADdAADdBsGEADND0BoGl9gAZogAZogGbDABqg6QkATesDNEADNF0UoGl9gAZogAZogAZoAtD0BICm9QEaoAEaoAGaDQNogDad3Nxc7cagqkXNDbN6q2j9RN4wOHYr0NZl/vz5L7zwAhvm9l8Xrc8OANAADdAAzYYBNEATQghA8ysghBCAJoQQAtCEEALQhBBCADqudHV1bdmyJTs7Oycnp6ysTDwM/pnpV8epTXV8A0Kmrq5uxYoVWVlZc+bMWbNmTUtLC62fOK3v9h0AoFXP7t27ly5d+lVPxEpVVVXIvqHOBqvWRQsLC2tra8+dOyd65vr160VfpfUTp/XdvgMAtOpZtmxZfX29ti5WCgoK6KKm097ePnPmTFo/MVvfjTsAQKue2bNnt7W1aetiRXzbDdkrxNe3zMzMhQsX7tix4+LFi3TRkDl8+LAgj9ZPWKBdtwMAtOqZMWOGXnkUKxkZGeF+UvTMEydOLF++fOPGjXTR4Hz88ce5ubniv7R+YgLtxh0AoL0whvJPc3Nz1J9JwC763nvvic75wQcf0PqJCbRLdwCAVj1GqpD+aWlpEb2aLuqfAwcOPPPMM8ePH6f1ExNo9+4AAK16KisrRS/VjuOLFf04vn9PKC4u/ve//93Z2fn555+vXLnylVdeoYvqKS8vnzt37qeffkrrJybQrt4BAFr16DNhRUpLS/WKpH9POHjw4KJFizIzM3/6059u2rSpo6PDqc6pwoTcyFslcu7cOVo/QVrf7TsAQBNCCAFoQggBaEIIIQBNCCEEoAkhBKAJIYQANCGEADQhhBCAJoQQgCaEEALQhBBCAJoQQgCaEEIIQBNCCEATYvmel8S+RwhAE4AmBKAJAWhCAJq4L5s3bx45cmSfPn1Gjx5dUlLiD7R4OGrUKPGS+O+GDRv0548dO/bYY48NHjz4uuuuu/fee7dv366/9MYbb4wfP148P3z48E2bNvHrJQBNiMns3LlT4FtTU9PR0fHuu+/eeuutOtBbt24dMWKEeFK8dOjQIQHutm3btJduv/32tWvXfv311+Il8W9nzpypPb9nz57k5GTxnu3t7fX19WPGjKmoqOCXTACaEDOZMGGCfqtWkd27d+tAp6SkVFZW6i/t2rXr/vvv19b79ev32WefBb/bpEmThM76wyNHjowbN45fMgFoQsykf//+Z8+e1R+2tbXpQAuFA14Sz2jrzz///A033PDss8+WlpY2NjbqPzNgwICkq9O7d29+yQSgCbEPaJG6urri4uJZs2YNGTLkxRdf1P/JmTNn+K0SgCZEQiKXOMRD/aXKykq9xOGfTz75RAyctfWJEydWV1fzWyUATYiE7NixY/To0TU1NefPnz98+HDAQcKRI0eKJ/WX9IOEjz766N69e7/55hsxXt6wYcNdd92lPf/222/fd999hw4dam9vF6+Kh9OmTeOXTACaEJPZtGnTiBEjQk6zW79+/ahRo6699tqAaXa7du2aPHly3759Bw8e/Pjjjx8/flx/SYygH3744YEDB/bv3z81NfWtt97iN0wAmhBCCEATQghAE0IIAWhCCCEATQghAE0IIQSgCSEEoAkhhAA0IYQQgCaEEIAmhBASd/4/GOui4Ze4Yl0AAAAASUVORK5CYII=" />
|
355
|
+
<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAeAAAAHgCAIAAADytinCAAAxY0lEQVR42u3dDXAV9f3v8QAij5cxzNURq4iBMj4iNTp/NEWiBKp4IUgUErTXAgkPKhWmJPWSJsJ/5uKfKLVqM+QPCAlTZrDMJdGBYKiUyFBIykmYqDClVC2GVJxUJgYDCYR4f8nCujmP+/x03p/ZcfacE46b89vfK7/z3d/uJnxPCCHElUngIyCEEIAmhBAC0IQQAtCEEEIAmhBCAJoQQghAq8wJEh+h9Wl9AtAEoAlAAzRAE4AmAA3QBKAJQAM0QBOAJgAN0HRRuiitD9AADdAEoAlAAzRAE4AmAA3QBKAJQAM0QBOAJgAN0D5PaWlpSkrKyJEjxX/Lysrk52+66SaA9l9ef/31uXPnhj6flZUlXhIrW7dunThxotgf7r///jfffBOgARqgHUt5efndd9+9ffv2Tz/9VPxXrFdUVAC0j3/fTz75RLTyRx99pHxSPBRPipd27twpVv7whz8cO3Zs//798+fPB2iABmjH8vTTT//ud7+TH4r12bNnA7S/f+X8/Pxf/vKXymeWLl0qnhQrTz311FtvvUWJA6AB2hW54447ampq5IeHDx++8847Adrfv/Jf//pXMUyur6+XHtbV1d11113iSbF+++2319bWAjRAA7Qrcssttxw/flx+KNbFMwDt+9968eLFq1evltbFingYdn8AaIAGaEbQAG13/vznP//kJz853hOxIh5KzzOCJgDtojz11FNBNeinn34aoOPhF58zZ05xcfHvf/97saLcH95++22ABmiAdkWko/bbt28/duzYu+++K9bFMwAdJ00/adKkhx9+WG5x6cl77rln27Zt0iyOBQsWADRAA7ST2bJly0MPPXTLLbeI/4p16clPPvnk1ltvBWh/Z0pPgp6U50E/8MADvp/RAccA7b0cP3789ddff/TRRwGaADRAA7S7cvPNN0+YMKG8vBygCUADNEATgCYADdAATQCaADRAE4AmAA3QAE0AmgA0QBOAJgAN0ABNAJoANEADNF2U1qf1CUATgCYADdDG02xZLl68eOHChWb3xZ0bZvVW0frxvGFwDND0BICm9QEaoAEaoAGaDQNogKYnADStD9AA7VhaLMulS5c6Ojpa3Bd3bpjVW0Xrx/OGwbFXgW61LJ2dnWJQ0Oq+uHPDrN4qWj+e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" />
|
357
356
|
|
358
357
|
</div>
|
359
358
|
<p>This plot is an alternative to the original boxplot. For the final presentation, it is important to think which graphics will be best understood by our audience. A violin plot is a less known plot and could add mental overhead, yet, in my opinion, it does look a lit bit better than the boxplot and provides even more information than the boxplot with jitter.</p>
|
360
359
|
</div>
|
361
360
|
<div id="adding-decoration" class="section level2">
|
362
361
|
<h2>Adding Decoration</h2>
|
363
|
-
<p>Our final plot is starting to take shape, but a presentation plot should have at least a title, labels on the
|
364
|
-
<p>The ‘labs’ function adds
|
362
|
+
<p>Our final plot is starting to take shape, but a presentation plot should have at least a title, labels on the axes and maybe some other decorations. Let’s start adding those. Since decoration requires more graph area, this new plot has a ‘width’ and ‘height’ specification. When there is no specification, the default values from R for width and height are 480.</p>
|
363
|
+
<p>The ‘labs’ function adds the required decoration. In this example we use ‘title’, ‘subtitle’, ‘x’ for the <span class="math inline">\(x\)</span> axis label and ‘y’, for the <span class="math inline">\(y\)</span> axis label, and ‘caption’ for information about the plot (for clarity, we defined a caption variable using Ruby’s Here Doc style).</p>
|
365
364
|
<pre class="ruby"><code>R.png("figures/facets_with_decorations.png", width: 540, height: 560)
|
366
365
|
|
367
366
|
caption = <<-EOT
|
@@ -370,8 +369,8 @@ Each animal received one of three dose levels of vitamin C.
|
|
370
369
|
EOT
|
371
370
|
|
372
371
|
@decorations =
|
373
|
-
R.labs(title: "Tooth Growth: Length
|
374
|
-
subtitle: "Faceted by delivery method,
|
372
|
+
R.labs(title: "Tooth Growth: Length vs Vitamin C Dose",
|
373
|
+
subtitle: "Faceted by delivery method, OJ or VC",
|
375
374
|
x: "Dose (mg)", y: "Teeth length",
|
376
375
|
caption: caption)
|
377
376
|
|
@@ -379,14 +378,15 @@ puts @bp + @decorations
|
|
379
378
|
|
380
379
|
R.dev__off</code></pre>
|
381
380
|
<div class="figure">
|
382
|
-
<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAhwAAAIwCAIAAABC8iVmAABK0UlEQVR42u3dC1wUdd///xVQ5CAioZcn8IiiIGJqaaRgKSoqmke0bo+dvbvLKyWvvL0eev0rN/PqZHea1oVaIp08XCGmWXbSNNPSzLIjloWaEoooCNLvE/NvrmHZw+yBXXZ5vR88eMzOzs5+d+b7nefM7Mx3Db8TQgghLoqBRUAIIQRUCCGEgAohhBBQIYQQQkCFEEIIqBBCCAEVQgghoEIIIYSACiGEEFDxvsVUFT5aPfyw9Wr5EFJfUDHoSK1udxx7i5KSkqeeeio5Ofmqq64KCAgICwtLTEz87//+771799adTWotbTQ9vi121YetjQ+irbeNGjVq06bN0KFDpaqcP3+eTRIBFVAxn2+++aZr1661XVpQ8XZUtGnVqtX+/fvZKhFQ8YKTGG7eGMkxiiJKly5d1q1b99NPP12+fPnChQtHjhx59tln+/XrByqgogyXlpb+8MMPa9asiY2NlZEtWrQ4c+YMGyYCKnUFlbKyMqPR2LNnz6CqyMDSpUtlg65zAkuHFMrw+fPn/+u//is4OPiqq6564IEHKisrLZXwqaeekum7det27tw5nR+nuLj4jjvuiIiI8Pf311PUS5cuNWrUyM/PT16ojJEJZD6JiYnKQxkvzwYGBsqULvxortoWv/jii8nJyU2bNpVP0alTp3nz5hUVFZm83Eqpvv3221GjRoWEhISFhc2cOVOmrPmhXPJh1ZfMmDFD3is0NHTMmDHCgDx17NgxWcIyHxMGfvvtNymYPPXVV1/pXziyz5GQkCDjFy1apLO6yiq+//77O3To0LBhQynb4MGD33jjDZ1LmBBQsb3Bkp2+gQMH1tygDBo0SGmHNiewvjGSrYn2qeXLl1sqofIuL7/8sv6Pk56ern1Tm0WVJCUlyZhdu3bJcGFhoWzF5KH8V7Yd7777rjy8/vrr9WxnrXw0x3bVrbxKNuJTpkypWZ64uDjVYOul+vXXX1u1aqV9SoDRj4r+9Wh27Ujatm179uxZeXbChAny8KGHHtK+RLb7yrvYu3Bef/11GX/ttdfqrM/Ku9f8pHqWMCGgYrtNyj6djG/WrNmGDRuKq5KdnR0eHi4jpZ3rmcD6aRNp7d98801JSck999wjD/v06WOphHLAIROcPn3aZA5mv1NRxkRHR7/99tuyZ6rzs0j+9re/qQ+3bNkiwx07dpT/ubm5Muaxxx6T4QcffFDPGSErH83lqKxevVqekv3rzZs3i3+yffzkk08UIOW4QU+p5s6dKw87d+68b98+WWLyX/bETd7RJetRfYnMX3mvvXv3SsllTGZmpjx74MAB5bsQdcWVl5dHRUXJyD179ti7cKTCKCtdZx1o3LixgqJQoSyHsWPH6lzChICK7TapnD3IycnRjly/fr16UsjmBNY3Rp9++qny8NSpU/IwJCTEUgkDAgJkAtm+6EclLy/Prs8ikZfIw/Hjx8vwnDlzZFg2Our2buLEiTK8bds2PdtZ/R/NeVRkmy5Pffzxx9qRJ06ckJExMTF6SqV8X7Vjxw715du3b9ePil0fVnmJzF8dI4tUObepPBw6dKg8zMrKUh7KKtMeINq1cKTCyHipPDrrgOyIyPCIESMWLVr03nvvXblyRf8SJgRUbLdJZcftwoUL2pGyfycjg4KC9ExgfWNUUVGhc/9d9i7l2V9//VVP4ZUxsuNs12eRyP6pv79/u3btZPjqq69u3bp1ZWWl7DUr50/kqEWe1V6l6pKP5jwqwcHBli5/atiwoZ5SBQYGyvDFixfVZ2Xp6UfFrg+rTFDzvWQFKQ+V04wCgPKwX79+8vDf//63AwtHQU4Oc3XWAdmrUGqaEjl0++yzz3QuYUJAxfOo6Nxo/v7ntx1btmzRj4q9n0WJWCJjvv76az8/v2nTpsmYqVOnyobj+PHjMl6etflG9n4051GR8tu8NNx6qZxExa4PaxMVyXXXXSdj3nrrrY8++kgGunfvrufL/5rjX3vtNRmvXhyopw5IYTZv3izHqW3btlVP5elZwoSAit7TX6+88op25IYNG0xOf1mZQNKgQQN5aLJRsHdjpHyfcc0112gvPLNrVnqKKrn33ntlzB133CH/X3rppd+rrvmRYeVbh/vuu0/7cpd8NOdRkQ2fPPX555/b9XLtGOX0l2zE1Wd37Nhh8hJXfVibp78kb7zxhowZNmyYcsrxX//6lwMLR/Do0aOHjF+8eLFddUBJQUGBjJdjU/nIepYwIaBie0OgfLF51VVXSTu8UJWcnBzl/ID2i3orE0jkWXn4zjvvaLdH9m6Mzp8/365dO5mgf//+sg367bffKioqTpw4sXLlSp2z0lPU3/+8Xkh2aWUbeurUKRlz8uRJGW7atKmM37hxo3aeLvlozqMi21zlwoS1a9f++OOP5eXlpaWlx44dW7VqlSwuPaW6//77la8H9u/fL2zLfxk2eYmrPqx6Zmnfvn3yXnv37lWuhlC+uFIibyEeyGKXbXqbNm3UL+31LByZOD8/XxZFzftUbNYBYUw0lfFy+CJLTz1+0rOECQEV2xsCaTkDBgyoebyfkpKitHObE0jGjx9v79kYszl8+LByFVDNk9orVqywOSs9Rf39z+uFJD179jQ5yjG5/Mzhj+bM1V+Wzr0ol105fPpL+GzZsqX2VSNHjtR+xe3C9WhyybLJJcVqlO/PTci3d+EIA9o76m3WgZpPTZkyRecSJgRUdG0IpB3K/p1sVWWXLSgoSAYeffRR7VbY5gQ///zzuHHjIiIilPMnzuzOFxUVPfTQQ3369AkLC5N9WNlkzJw58+uvv9ZvpPWiKlH2cOfNm6eOUc59ac/POPPRagMVyc6dO2W7L/v1oqx8uri4uLvvvluOBnSWShbjiBEjgoODZdnOmDHju+++k2ebN2/u8vWoTHDu3DlZd3KUEBISMnr06O+//95kMimPTCYHiPpvd1Uin12ISktLe/bZZ9X7WHXWgV27dslnVHqW69Chw/z587Xf/VhfwoSACiEWo5zwkV14zxZAOGddEFAhxPsihwu7d++WHXk5HHzppZeUWwKt3xtfeyksLFTuVvniiy9YNQRUCPHCilsjvXv3tvkNea2WJC0tjfVCCKgQr8zWrVuHDBmi7S3RU71aKRcIDBo06Oeff2a9EAIqhBBCQIUQQgioEEIIARVCCCEEVAghhIAKIYQQUCGEEAIqhBBCCKgQQggBFUIIIaBCCCGEgAohhBBQqdsLztwvO7nqZ/Vszserf7/PycLrefnDDz88evRou2abnp6+ZMkSF35MB8pQ20UiBFRAxcYE3qhLbaNy4cKF5s2bf/PNN3bN9tixY/Iq7S8nOhPHylCrRSIEVEw3JbX0O9uOzY0jFYc/Tm2jsm7durFjx2rHfP7558OHDw+tigwcPnzY7NzkyGDDhg0u+chqGQSGli1bXrp0yWSC3377rUePHoWFhTL85ZdfysQRERGNGjXq06fPq6++WhtFIgRU3LQZBRUfQ2XChAkvvvii+lAOF1q0aLFy5cpzVZEBeageQ2jntn79+smTJ7vkI2vLMH78+GeffdZkgiVLltx6662/V/24vagjE5w5c6a0tHTv3r3jxo2rjSIRAiq2NyXffffdqFGjZPczMDBw2LBhp06dUsZfvnx5zpw5kZGR4eHhy5YtU0ZWVFTMnz+/efPmQUFBkyZNOn/+vMkBkJXJJNLgp0+fHhwc/Je//GXp0qWWUHn00UdlmyWTzZgxQ14iIwcMGKDd2Tx+/HirVq2Kioq0L7Q0c0uF0Z7+Onv2rHxSZZ9XiYyRMsgYKy9//PHH27Zt26BBAz3Fk+llq9ehQwfZlY6Li/vggw+ysrJiYmIaNmyYmJio7vjrXMIysGLFinbt2ikv//TTT5Xxsjsv29mwqtx2223q3r2eJa+NlPPbb79VH958882yUrQTyMNbbrmlZr2S6tSpU6eaM7RUMO1itFKGAwcOdO7c+cqVK+qzZWVl8io5iJHhKVOmPPHEE5Y+i6UiEQIqtYJK9+7d33777YsXL8pG8N5775XNhzL+wQcfTE1N/emnn3777bf77rtPGfmPf/xjyJAhMlI2drKRuuuuu8zO2dJk8+bNGzFihLh18uRJAcwSKso0krS0tMzMTBn55ptvduvWTd2mzJo1y2g0mrzQ0sxtllkZuPPOO7XzlL1g5VNbebls9E+fPq2zeDL92LFjf/zxx5KSkocffrhJkyayJ64+7Nevn11LWHn3EydOXLhwYfHixX379lXG33///bLQlIUwdOjQuXPn6l/y2ghpUjD1oVAk76WdQB7KwUHNssm+iLy25gwtFUy7GK2XQWrjK6+8oj5cs2aNeoJOivfLL79Y+iyWikQIqLgAFevfqUgbln1kZVjdDdRGdo2/+uorZVi2DtKYzW7yLE3Wpk0b9ZyJzNwSKuo0X3/9tRRDGZbt5vr169WR2s2N9ZnbLLMy8OWXX0ZHR5eXl8uw/G/fvr0ccFh/ufa3b20WT6Y/c+aMupxNHgYEBNi1hJWjq5ovb926tRRAXQiyTPQveW0aN24s22L1ob+/v7Jk1MhD9U31oGKpYCaL0UoZdu3apdop6dGjx759+5RhKYlJ8UCFgIrHjlR27959/fXXh4SEKNKoZyFqbkeU1qtlSZ3YZM6WJpN5VlRUqFslS6hop1G3XJs3b+7atas8NXny5KeffrrmCy3N3GaZ1YHhw4fn5OTIwIYNG6ZMmWLXR7ZZPOtfiugvrfWHJgtBXXp6lrzJqafvv/9efdiiRQudRyrfffddx44dba4dsyBZL4NEjufeeecd5dAwJSVFeyBl5UjFUpEIAZVaQUX2GWVLWlRUVFlZee7cOXUas0cqUVFRJhsXs3O2NJl2f1n2W20eqciAuksrxZOd03nz5skxRFlZmf6Z2yyzOrB9+/b+/fsrG6+DBw/a9ZFtFk+nCjrfztJDOSDQHpHIQ/1LXpsJEyZkZ2erD0XKmt+pqGdKTb6oz8jIMHukYrZgVkpiUgbJli1bhg0bJgODBw/etm2bOl72AJ566ilL87FUJEJApVZQiYiIkL3s0tJS2aGbNGmSOs2CBQtqfqfy8MMPp6Wlffvtt7KzefjwYZleGR8eHq6etLEy2dy5c0eNGnX69Gnl+xJLqCjTSEaOHCmbafUpwU+eff75581+Okszt1QYs/epxMXFLV++XLZZNj9LzcJbL55OFXQuYUsvnzNnjvqNlGx///rXv9pc8mbXwrp168aMGaM+lLdu3ry5evXXc889Jw/VfQ7tHORVymlAk1gqmBVUTMqgyB0fHy/je/bsqR0vTLZq1UpKdfbsWanJ+/bt0179ZalIhIBKraCyadOmjh07+vv7R0dHP/300+o0ly9fvvfee4WcZs2aPf7448rIK1euPPLII8pFR9K8lZNFkoceeig0NFR9raXJLl26NHXq1KCgoBYtWui5+mvatGnauxNeffXVmJgYS2fPLc3cUmHMorJ69Wo/Pz85ZFHH2Hy5zuLpREXnErb08osXL86cObNJVWRAvenP0sL58MMPk5KSapZW+XZNe+PhoUOHBIOQqgwdOvSzzz6r+e6ycZf5m73T0FLBrKBSswySF198MSAg4KWXXjKZ+OjRozfddJPQ26hRo759+6r3qVgpEiGgUt+Tnp5ucj6E4jmZQYMGKd9S1IzYpqeLlOLiYmFGGZbpXdsnis4yWInLi0QIqPhCZP991apV3bt3196pQPE8noqKiieffHLAgAFUUUJAxasWscHQvn179RJSildH4ufnFxcXd+DAAaooIaBCCCEEVAghhIAKIYQQAiqEEEJAhRBCCKgQQggBFUIIIQRUCCGEgIoDOUaIc6FeEbfVK1ABFQIqhIAKqBACKgRUQAVUCKgQUAEVUCGgQgiogAohoEJABVRo/ARUCKiACqgQUCGgAiqgQkCFEFABlfqcNWvWJCUlRUdHy/+1a9eq41u3bs3CARX9WbZs2ZQpU2qOnzx5sjwlA+vWrRswYIDUtD59+jz11FMsMVABFR/Mpk2b4uPjc3Jyjhw5Iv9lePPmzaACKg7k888/l/rz3nvvaUfKQxkpT23cuFEGXnrppS+++GLXrl0zZ85kiYEKqPhgJkyY8OSTT6oPZXjixImgAiqOZcGCBf/zP/+jHXPPPffISBkYP378008/zSICFVDx8XTr1m3v3r3qw48++qh79+6gAiqO5eOPP5bDkYMHDyoPDxw4EBcXJyNlODY2dt++fSwiUAEVH09UVNTRo0fVhzIsY0AFVBzOnXfeuXjxYmVYBuSh2ZpGQAVUOFIhoGI777zzTq9evY5WRQbkoTKeIxVQAZV6kfHjx5t8pzJhwgRQARVnMmnSpP/7v/975plnZEBb05YvX87CARVQ8fEo1+Tk5OR88cUXL7/8sgzLGFABFScrVXJy8sCBA9W6pIzs0aPH+vXrlau/Zs2axYICFVDxzWRlZV133XVRUVHyX4aVkZ9//nm7du1YOKDiWIZUxWSkep9K3759uRIMVEClHuXo0aPLli274YYbWBSgQkAFVEDF2bRt27Zfv36bNm1iUYAKARVQARUCKgRUQAVUCKgQ6hUBFQIqhIAKqBACKgRUQAVUCKgQUAEVUCGgQgiogAohoEJABVRo/ARUCKiACqgQUCHUK+IdqPzqrly+fPnSpUu/elu8sdhuLjP1inrltnoFKqBC4wcVVhD1ClRAhVZE4wcVig0qoOJAityV8vLysrKyIm+LNxbbzWWmXlGv3FavQMULct5dqaiokD2d894Wbyy2m8tMvaJeua1egQqnvzhNwekvVhD1itNfoEIrovGDCsUGFVABFYoNKqwjUAEVUKEhgQr1ijKDCqjQ+CkzqFCvQAVUaPw0flChXoEKqIAKjR9UqFegAiqgQuMHFVYQ9QpUQIVWROMHFYoNKqACKjR+UGEdgQqogAoNCVSoV3UyBQUFq1evTk5OTkhIMBqNoAIqoAIqoEK9cjyzZ882aJKdnQ0qoAIqoAIq1CsH07RpUy0qqampoAIqoAIqoEK9cjBRUVFaVGJiYkAFVEAFVECFeuVgFi5cqEUlMzMTVEAFVEAFVKhXDiY/Pz8jI8Pf3z8sLMxoNBYUFIAKqIAKqIAK9cqpJCcnjx492rP1ClRAhcYPKqwgUAEVUKEVgQqoUGxQARVQodigwjoCFVABFRo/qFCvQAVUQIXGT5lBBVRABVRo/KACKtQrUAEVUKHxgwr1ClRABVRo/KDCCgIVUAEVWhGogArFBhVQARVQARXWkSuj/J5KeHh406ZN+T0VUAEVUAEV6pVT4fdUQAVUQAVUWEcuC7+nAiqgAiqgwjpyWfg9FVABFVABFdaRy8LvqYAKqIAKqLCOXBZ+TwVUQAVUQIV15OJwSTGogAqogArrCFRABVRo/KBCvQIVAio0flChXoEKqIAKrQhUQIV6BSqgAioUG1SoV6ACKqBC4wcV6hWogAqo0PgpM6iACqiACqiACqhQr0AFVECFxg8q1CtQIaBC4wcV6hWogAqo0IpABVSoV6ACKqBCsUGFegUqoAIqNH5QoV6BCqiACo2/buf48eMTJ04MDw8PCQkZNGgQqFCvQAVUQIXG73hiY2O1P6Z02223gQr1ClRABVRo/A7G399fi0pkZCSoUK9ABVRAhcbvYAIDA7WoBAUFgQr1ClRABVRo/A7m2muv1aLSq1cvUKFegQqogAqN38F8+umnUVFRfn5+wcHBgwYNOn78OKhQr0AFVECFxu9NZaZegQqogAqNH1RAhXoFKqBiLvv3758/f/7YsWOnTJmydOnSM2fOKOMrKyuzsrIyMjImT568du1aeUjjBxVQoV6BCqjYyIMPPrhnz54LFy5cvHjx5ZdfnjdvnjJ+27Ztc+fOPVsVGdi+fTuNH1RAhXoFKqBiR8rKysaNG6cMiy6HDh1ShmUgMzOTxg8qoEK9AhVQ0Rupo6+++urixYuVh5MmTSopKVGGZSAjI4PGDyqgQr0CFVDRlVFVueWWW3755RdlTHp6uvo9igxIbdBOv+jPXHJXrly5UlFRccnb4o3FdnOZLe3isIJ8rNiCypgxYzxbr0DFrZHDkZycnPnz5+s5Urn9z1x2VwQ2aUiXvS3eWGw3l9lsbWQF+V6xU1JSBBXP1itQ8cB3KmPHjuU7FU5/cfqLdcTpL1BxMI8//viPP/4oh9KFhYUvvPDCgw8+qIzPy8sTV5Srv2SAq79ABVSoV6ACKrbz4Ycf3nPPPXJYessttzzxxBNFRUUm96lI1qxZw30qoAIq1CvHUlBQsHr16vDw8KZNmxqNRlCpR6e/HAitCFRAhXplPbNnz9Z2VJqdnQ0qoAIq9WiPMjk5OSEhwbN7lKwgXyq2HKBoUUlNTQUVUAEV9ihBhXrlYKKiorT1KiYmBlRABVTYowQV6pWDWbhwobZeZWZmggqogAp7lKBCvXIw+fn5GRkZ/v7+YWFhRqOxoKAAVEAFVNijBBXqlVPhkmJQARX2KD22R8kKAhVQARVaEY0fVCg2qIAKqFBsUKFegQqogAqNH1SoV+5JVlbWKKfTt2/fa6+91smZ5OXlgQqo0PhBBVS8u9gDBw5M6JfUJWW4Z/8Sr+0vroAKqND4QQVUvB6V9kPHG+58zLN/4gqogAqNH1RABVRABVRABVRAhXoFKqACKqACKtQrUAEVUKHxgwr1ClRABVRo/KACKqACKqACKhQbVKhXoAIqoELjBxVWEKiACqjQ+EEFVEAFVEAFVEAFVKhXoAIqoAIqoEK9AhUCKjR+UKFegQqogAqNH1RABVRABVRAhWKDCvUKVEAFVGj8oEK9AhVQAZX61vgLCgpWr14tG+iEhASj0ehFZQ4PD2/atKnbyky9AhVQARUav+3Mnj3boEl2djZlBhVQARVQARUHIzv72g10amoqZQYVUAEVUAEVBxMVFaXdQMfExFBmUAEVUAEVUHEwCxcu1G6gMzMz3fCmWVlZo5xIt27dtGXu2rWrw7PKy8sDFVABFVABFZclPz8/IyPD398/LCzMaDQWFBS4p/En9EuStufYX+cBqWEt2/j5+weGNGkR0z0meZhj80m8tr+TjZ96BSqgAio0fjNx8+W5PtP4qVegAiqgQuMHFVABFXN///W/hp7JhoiWhj6phhn/ABVQARVQARVQcaJede3zn2/qxBVQARVQARVQARXHq0TDwP+gEt4CVEAFVEAFVEDFiXrVMeE/qPRMBhVQARVH4pEuT5xt/LcuMfQYYAgMMgQ0NHTqCSqg4pp6NX6O4S/RhgZ+hsbBhr7DQAVUQMWReKTLE2cbf/NqNz8a+gwBFVBxQb2SoxNths8EFVABFbvjkS5PnG38hgbVGn9QKKiAigvqlRz7atOuG6iACqjYHY90eeJs4/fzq9b4/f1BBVRcUK+aNKtWrxz9rh5UQKVeN36PdNPibOOP6lqt8bfuBCqg4oJ6dW1a9dOqqaACKqBidzzVTYtTjX/q3w1NI6uOUQL++KL+1iWgAiouqFezHvrjVpWGgX/c/3j9TYbbHwUVUAEVB+P+S4q7pgy7avzdnv2LSxoEKj6Gim/UK1ABFS9u/J66pLh33Qio+BgqvlGvQAVUvLjxe+qSYlABFeoVqICKDzZ+T11S3G3Aja1GTfPsX3z/gaDiY6j4Rr0CFVDxZON38gevgoODtaiEhoa64Qev6KYFVOriF/V0fQ8qoKI0pISU1C4Tb3fsLzLhGi0qV8X1dmw+iden6G9Izjb+2x81DLnljyuJI1v/cZUOqICKb9UrUAEVD6PS/s5Fhl2/O/iXV2wYNv2Pm9I7xBvufcaws9yx+Ygr7kOlznSnASo+hQrdtIAKqLgAFRf9uRWVOtOdBqj4FCp00wIqoOICVOTQ5O85hsQUQ+fEP45UvAKVOtOdBqj4FCp00wIqoOICVCbNrdaQluR6ASp1pjsNUPEpVOimBVRAxQWohIZXa0j9R3oBKnWmOw1Q8SlU6KYFVEDFBai0bF8NlehYL0CFS4pBxafrFah4QYrclfLy8rKysiI3Jjk52SlUbjdWQ2X6IodRSU9Pt6PMdaPx6y9zfatX3lhsn6lXoOIFOe+uVFRUyN7ZeTfGWVRcd0mxNCQ7ylw37ifQX+b6Vq+8sdh1ChVn6hWocPqLS4q5T4XTX5z+4vQXqIAK96mACqiACqiASn1HhftUQAVUQAVUQEVb5vikFGn/jv01i4mvZkrn7o7NJ6FfEqiACqiACqh4PSpGo3GgE2nTpo0Wlbi4OIdnlZWVBSqgAiqgAirejYqT8chvwIAKqIAKqICKb6ISFRWlRSUmJgZUQAVUQAVUQMXBLFy4UItKZmYmqIAKqIAKqICKg8nPz8/IyPD39w8LCzMajQUFBaACKqACKqACKk4lOTl59OjRbns7UAEVUAEVUAEVUAEVUAEVUAEVUAEVUAEVUAEVUAEVUAEVUKnfqHji54RBBVTqIiqu6/0aVEClHqPiiZ8TBhVQqYuo1Jner0EFVLwZFU/8nDCogEpdRKXO9H7tmk2zwQAqoOJgQ+o6ftZVj73h2J9fsxbaduTfoq1j84kbPg5UQMW7UakzvV+DCqh4GJXeTsSkc8bWrVs7PCtQARXvRqXXDdVQ6ZMKKqACKnanRYtqRyqdOnUCFVDxXlSc+UmFkNbRakMIbt6qXeo4T/2kgmP517/+1bFjx4YNG3bu3HnlypVaVOShNG15Sv6vWrVKHX/06NHhw4eHhYU1atTo6quvzsnJUZ/asmVLYmKijG/Xrt3zzz8PKvULlW6jJrf623OO/fk1DtaiEtg5wbH5xA8eCSqg4tliO/mTCv7+/v9BJTjYmVk5+ZMKDmTjxo0Cxr59+8rKyj766KMOHTqoqKxbt659+/YyUp7as2ePILF+/XrlqdjY2OXLl587d06ekteOHTtWGf/mm282a9ZM5llaWnro0KEuXbps3rwZVPiiXt9fy/bVDvmjY/miHlTqZ7GlAqvtYPbs2R6sVw6kX79+27dvVx9u27ZNRaV37955eXnqU1u3bu3bt68y3Lhx4xMnTtSc24ABA0QU9eH+/fsTEhJABVT0/d1urIbK9EV1H5WCgoLVq1eHh4c3bdpUdk5BBVRckvfff1/qsByvREdHy+65d6ESFBR08eJF9WFJSYmKishh8pSMUYbnzJnTokWLu+66a82aNT/99JM6jRyoGarHz88PVEBF319esWHYdENQqKFD/B83P+4sr/uoyF6ktrpnZ2eDCqj40hGw21CRHDhwYOnSpRMnToyIiFiyZIn6kuLiYr6oBxV++RFUQKWeomL99Jc8VJ/Ky8tTT39p8/3338sBijKclJT07rvvggqo8MuPoAIq9RSVV199tXPnzvv27ZNlvnfvXpMv6jt27Cgj1afUL+qHDRu2Y8eOCxcuyHHJqlWr4uLilPE7d+7s06fPnj17SktL5Vl5mJaWBiqgwi8/ggqo1BdUJM8//3z79u3NXlK8YsWKTp06BQQEmFxSvHXrVvm8gYGBYWFhI0aMOHbsmPqUHKkMGjQoJCQkKCgoJSUlNzcXVECFX34EFVCpR6j4TEAFVLikmK2zaY4fPz5x4sTw8HDZ1ZUdXlABFVABFS4pBhXHExsbqz1Fedttt4EKqIAKqHBJMag4GO3d6ZLIyEhQARVQARUuKQYVBxMYGKhdR0FBQaACKqACKlxSDCoO5tprr9Wuo169eoEKqIAKqHBJMag4mE8//VTs9/PzCw4OHjRo0PHjx0EFVGoRlZMnT8pqCwkJMeleBlRARU+US4pDQ0Pj4uK4pLguh0uKQcVNqNx000233nprYWEhRyqg4i2LGlRABVTqLiqyj+nmpQkqoAIqoAIqPotKYGCg1DZQARVQARVQIS5AJTExcc+ePaACKqACKqBCXIDK+vXrxZWjR49WVlaCCqiACqiAijORDWlF7cRtm2gHUTHYirejUlBQIF7KVj4+Pt5t3YeACqiAiqvabx3p/sfeyHI+XzsRV7hPxZOoeKT7EFABFVDx3vbrZlR279595MgRH0TF7EGJDxypeKT7EFABFVDx3vbrZlRmzZq1YMGCeoFKZWVlgwYNvB0Vj3Qf4iwqO8sNf88xJKYYOif+8Rv1oAIq9bXYdaf7H1BxFhUR5Z133mnbtq23o+KR7kOcRWXS3Grfay3JBRVQqZ/Frjvd/4CKfZzUjByjyD5Cdna2t6OSn5/fsmXLgICAbt26ua37EGdRCQ2vtjL6jwQVUKmfxa47vyjqMCq7d+9eYDVDhgxJT09fYCvq9y7e/Z2Kb1xS7ObrEV2ASsv21VCJjgUVUKnPxfbGS4pVVORAJKFfUpeU4c78JV7bXz2a8SZUaqZRo0ayg79s2bIrV66AivtQud1YbTVMXwQqoAIq3otK+6HjDXc+5syfuOJ9qKxcuTImJmbHjh0lVdm+fXunTp2eeeaZAwcO9O7d+6GHHgIV96GSV2wYNt0QFGroEP/HF/U7y0EFVEAFVLwMlc6dO+/fv187Zt++fTJSBg4ePNi+fXtQcR8qXFIMKhQbVPShsm3bthtuuKFx48YRERE333zzqVOn6goqDRs2NOlQsqysTEYqS0cZABVQARVQAZU6hcqQIUPy8vKKi4uFk7vvvluAqSuotGvXruaRinKA8tVXX3Xt2hVUQAVUQAVU6vLpr5KSksDAwLr1ncpbb711sSo7duzo3Lnzc889J0/JIdW6detABVRABVRApS6jsnnz5v79+9ehvr9ycnKuueaaxlWRAXnIJcWgAiqgAirOoJKRkRGflCKuOPMXOzDVJiqffvpp27Zt5X8dQoX7VEAFVEAFVFyLyvjx452/T6XbgMHWUdm1a5eI8t5779Whq79Onjwpqy0kJER/1/cHDhyQzzlu3LgpU6b885//LCoqUrt4ycrKEp8nT568du1aS73/gwqogAqocPrL+dNfOTk5rVu33rdvX926pPimm2669dZbCwsL9b9k4cKFn3zyiVRQ4WTFihXymdVL3ObOnXu2KjKwffv2eohK/NAx4opn/xJSUkGFrTOo+DYqskMfHR199OjROnefSmhoqDNLs7S0dOzYscrwvHnzDh06pAzLQGZmZn1DxWg0DnQ6ffr06du3r5MzkUNGUGHrDCo+jErNnlCKi4vrBCqBgYEm96nYlb1794olyvCkSZNKSkrUS9wyMjLqGypOxiO/dgcqoAIqXnr6q47eUZ+YmLhnzx7H3u+7776bMWOG/Fcepqenq9+jyIDUBu3Ei/7MJXdFauSYMWMueU/uu+8+7X7Hxo0bvaXkV65ckRrvtrczWxt99cPW52K7uQmDimtQWb9+vbhy9OhRS9+rW8rhw4dFlCNHjqhjrB+p3P5nLrsrKSkpUiMve0/kGEWLyogRI7yl5FJ5ZJvltrez1Jh98sPW52K7uQmDimtQMViI9Ve9//7706ZNO3bsmHYk36k4GY/82h2nvzj9xemvWjr95fx9Kgn9krwPFQeyadOmmTNn/vjjjybj8/LyxBXl6i8ZqIdXfzmZ/v37a1EZN24cGyxQARUvRSU3N3eW1cinGzJkyCxb2b17t/ehsnHjxh49evj5+SkP09LStm7damX6UTWinI5U71ORrFmzph7ep+JkwsLCtKhIhWODBSqg4qWo1N/fqF+1alWXLl3279+vnvJ66623brzxRu6o5/QXqIAKqICK3YmOjla+CFFRKS4uDg4OBhX3Z+HChVpUMjMz2WCBCqiAipeh0rBhw9LSUi0qUvNCQ0NBxf3Jz8/PyMjw9/cPCwszGo0FBQVssEAFVHwVldzcXPX7Ep9CpWfPnlu2bNGi8uGHH9bS772Aiq8WG1RYR6BiLyr2xmtQ2bhxY0RExKZNm5S7/Hft2tW7d+93330XVEAFVEAFVOxN7d0MZO+thJ68+isvL2/AgAHBwcGNGzdOSkrauXNnrZaSrTOogAqo+CoqsumvqJ14EypuDltnUAEVUOH0l6+d/jLYCqiACqiACqjUHiq7d+8+cuSID36nwpEKqICKb2+dDx06NHv27Li4uP/93//99ttvaQt1BBWfvaQYVEAFVHwblYyMDG+8+QlUQAVUQAVU6mK0PxbuRd00gAqogAqogEpdzKhRo1RUZs+eTVsAFVABFVABFcfz/vvviyv+/v5Kn0xeUWaP/Aqqa1HZvXv3AqsZMmRIenr6AltRv8z3GlROnjwpmzDtATJXf4EKqPgSKt5Yr+SISrs5ys7O9jpU5EAkISW1y8TbnflLvD7F+35P5aabbrr11lsLCws5UqHxgwqo1JHIAYoWldTUVG9Epf2diwy7fnfmT1zxPlRCQ0NdtTRBBVRAhXrlknjkZyBAxTWoBAYGuurHmUEFVECFeuWSeORnILwLFTd8VeEgKomJiXv27AEVGj+ogErdifIzEKGhoXFxcW77GQhvPFKpi6isX79eXDl69KjbeiujFYEKqFCvvKVegYruSen7i8YPKqBCvQIV7lMBFRo/qFCv6j4qGRkZ8UPHiCvO/MXeNNX7UDFbJo5UaPygAirUK2dQGT9+vPP3qXRLn+ILqFRWVjZo0ABUaPygAirUK05/OYuKiPLOO++0bdvW21EpKCjo3r17ZGRkfHy827p5oPGDCvUKVOovKma/n5djlKioqOzsbG9HxSPdPND4QYV6BSpuvk+lVi+tctl3Kj7wRb1Hunmg8YMK9QpU6vsd9ZKNGzf26NHDz89PeZiWlrZ161ZvR8Uj3TzQ+EGlDmbHjh29evWSBh4ZGXnw4EHqFajULiqrVq3q0qXL/v371UOWt95668Ybb/R2VDzSzQOogEodTIcOHdSGkJSURL0CldpFRfmJBe15sOLi4uDgYG9HJT8/v2XLlgEBAd26dXNbNw+gAiq1kaysrFFORLt3JccrzswqLy8PVPSj4vx9Kgkpqd6HSsOGDUtLS7WoyFoMDQ3lkmJQAZU6gsrAgQOdueMhIOg/v5bUOKK5M7/tIa6Aik5UcnNzZ1mNtPQhQ4bMspXdu3d7GSo9e/bcsmWLFpUPP/zwhhtuABVQAZW6g4pTJ1L+v02G5m0NhgaGNp0NKz525lQMqOhHpf7+nPDGjRsjIiI2bdokqBQXF+/atat3797vvvsuqIAKqPgIKi76AxVQ0Zu8vLwBAwYEBwc3btw4KSlp586d9P0FKqACKqACKnQoCSqgAiqg4h2o5Obmqt+X+BoqPnmfCqiACqiASl1Gxd5wnwqogAqogEq9Q6WysvJK7cQjJ5a4T+U/oUNJUPElVLqOn3XVY284+Lfk9aAB6Q2CQho0bNSo5/UOzydu+DhQ0YNKRe3EbT/Oy30q5kOHkqDiS6j0diKyj6htC61atXJ4VqDC6a/6e58KHUqCCqgoMenONiAgAFTqAiq7d+8+cuQI96l4DSp0KAkqvoRKt1GTW/3tOcf+DH5+1X7ewj/AsfnEDx4JKlxSXH/vU6FDSVDxJVSc+qL+muHVDlUSU/iiHlRcj4r7f0bF3sbvZCd6w4cPj4yM9Pf3b9KkSY8ePUaOHOktneiBCqi4GJXXT/7RQYuhgaFRY0PKRMP2S6ACKvURlT860UtN7XL77Z79S0xxdyd6oAIqLkaFS4pBBVT+/4a0aJGh6lN58E9cARVQARVQsReV3bt3L7CaIUOGpKenL7AV9ct8UAEVUAEVUKm/qMiBiPPnWhJTUrzm91QMtgIqoAIqoAIqzqDi/BZMtj/ehApHKqACKqACKl6KSmVlZWZmZnh4eLNmzebPn2/2fnvnDxVABVRABVRApV6gsnLlyn79+v1cFRlYvXp1bWznQQVUQAVUavztLDf8PeeP21M6JxrufQZUfAOV/v37v/3228qwDCQlJYEKqIAKqLgFlUlzq50EWZILKj6ASlhY2Llz55ThoqKi8PBws9v5iIiIhg0bdunS5ZFHHnHgWxmf+pEuUAEVUHENKqHh1VDpPxJU3IBKRkZG/JgxshFz5i926lRLqPj5+an94cuAv7+/pSLJCw8dOjRo0KD77rsPVJxApbzckJNjSEkxJCYannkGVECl/qLSsl01VKJjQcUNqIwfP975S4q7TZnizJGKNgUFBTanARWrf3OrH/Ln5oIKqHgvKvFDx4grjv01blUNldCYHo7NJyElFVS86zsVbU6dOiUOgYoTqyS8+iH/yJGgAipeiorRaBzoRAICArRNISIiwuFZZWVlgUodQWXFihXiinL1lwyoV39pvy/PyMj4/PPPy8vLv/3227S0tJkzZ4KKE6ukfftqqMTGggqoeCkqTsZ7fwYCVKzfpzJv3rzwqjzwwAPqfSpaVF555ZWEhATZq2jTps2cOXMuXrzom6gU6YtsW51aJUZjNVQcnZWs1PT09CI3RkGlyKsiu0JlZWVueztn6pXXfVjns0gqvybz58+nXumvV9xR7wXR2SWns6gUFxumTzeEhhri4//4or683BlUzrsxCirnvSpS3WvvV1Rrxpl65XUf1vkUFBTcfPPN/v7+YWFhy5YtKywspF7pr1egwukvLinm9Benv6hXvn/6C1RAhcYPKqACKqACKqACKqACKg6h4vzNjwmpqaDCzY+Op6CgYPXq1eHh4U2bNjUajTR+UKFeeS8qubm5s6xGmB8yZMgsW9m9ezeocPOjg5k9e7a2yNnZ2TR+UKFeeSkq9e7nhLn5sQ6iIjuS2iKnpqbS+EGFegUqoMLNjw6Gm9RAhXpVf1DJzc1VT22Bijeg4rqbH92GysKFC7VFzszMpPGDCvXKV1Fx4K4dUPEoKq67+dFtqOTn52dkZISGhsbFxRmNxoKCAho/qLiqXik3P1KvQAVU6t0lxd54xSqo1P1wSbF7ULly5crl2onZX6EHFVABFVABFV9GxccCKqACKqwgUAEVUAEVUAEVUAEVUAEVtlmgAiqgAiqgAiqgUo9WEN20gAqogAqogIrLQjctoAIqoAIqoOKy0E0LqIAKqIAKqLgsdNMCKqACKqACKi4L3bSACqiACqiAistC9z+gAiqgAiqgQrFBBVRAhcYPKqwjUAEVUAEVUAEVygwhoAIqNH5QoV6BCqiACo0fVEAFVEAFVGj8oAIqoAIqoAIqoAIq1CtQARVQofGDCvUKVEAFVGj8oMI6AhVQARVQARVQoV4RUAEVGj+oUK9ABVT0oNJ11qyr3njDs39x48aBCqiACqiAii+g0rtuBFRABVRABVRABVRAhRVEvQIVUNGg0m3y5FbPPefZv/iRI0EFVEAFVECFL+r5oh5UWEHUK1ABFVCh8YMKxQYVUAEVGj+osI5ABVRABVRABVQoM6iACqjQ+D2BSkFBwfr166VyxsfHG41G1hGogAqogAqoOJ7Zs2cbNMnOzmYdgQqogAqogIqDadq0qRaV1NRU1hGogAqogAqoOJioqCgtKjExMawjUAEVUAEVUHEwf/vb37SoZGZmso5ABVRABVRAxcEkJCRoUbn//vtZR6ACKqACKqDiYBo0aKBFpXnz5qwjUAEVUAEVUHEwAQEBWlQaNWrEOgIVUAEVUAEVB3PjjTdqUUlKSmIdgQqogAqo1F9UsrKyRjmR1NTUxo0bCyd+fn6tW7ceMWKEw7PKy8ujXoEKqIAKjd+7UZF6lZCaKqvVs3+JKSnUK1ABFVCh8fsCKtQr6hWogAqNn8YPKtQrUAEVGj+NH1SoV6ACKqBC4wcV6hX1ioAKjR9UqFfUK1DxNlTUayJNxldWVmZlZWVkZEyePHnt2rXykMZP4wcV6hWogIpeWkzGbNu2be7cuWerIgPbt2+n8dP4QYV6BSqg4iAq8+bNO3TokDIsA5mZmZ5s/OXlhpwcQ0qKITHR8MwzNH5QoV5Rr0DFy1CZNGlSSUmJMiwDGRkZnmz8c+dqu9Mw5ObS+EGFekW9AhVvQiU9PV39HkUGRo8erX120Z+5pC/JyclONf7w8GqNf+RIhxu/fJBLbsyVK1cqKioueVXcXGazFZJ6Rb2qjXoFKnX3SOX2P3NZX5xt/O3bV2v8sbHONP7Lbox4LG3pslfFzWU2WyGpV9Sr2qhXoMJ3Kn/+PfRQtcbv6Kw4TcHpr2p/RiP1itNfoOImVPLy8sQV5eovGXD+6q/4MWOk/Tv216hVK23bD6/aP3XgLyE1lcYPKv/5Ky42TJ9uCA01xMf/8UV9eTmogAqouOw+FZO7VdT7VCRr1qxx8j4Vo9E40IkYqqdhw4YOz0o+FI0fVLikGFRApY7GPfWDX+gDFVChXoEKqLgs0dHRWlS6d+9OQwIVUKFegQqoOJgmTZpoURk8eDANCVRAhXoFKqDiYKKiorSoxMTE0JBABVSoV6ACKg5m4cKFWlQyMzNpSKACKtQrUAEVB5Ofn9+yZcuAgIBu3boZjcaCggIaEqiACvUKVEDF8SQnJ48ePfpXbwuNH1SoV6ACKqBC4wcVUAEVUAEVUAEVUKFegQqogAqNH1SoV6ACKqBC4wcVUAEVUAEVGj+ogAqogAqogAqogAr1ClRABVRo/KBCvQIVUAEVGj+ogAqogIpPolJQUNC9e/fIyMj4+Hij0UhDAhVQoV6BCqg4ntmzZ2v7/srOzqYhgQqoUK9ABVQcTNOmTbWopKam0pBABVSoV6ACKg6Gru9BBVSoV6ACKi4LXd+DCqhQr0AFVFyW/Pz8qVOnhoaG0vU9qIAK9QpUQKWetiIaP6hQr0AFVECFxg8qoAIqoAIqNCRQARXqFaiACqjQ+EGFegUqoAIqNH7vR6W83JCTY0hJMSQmGp55BlRABVRAhYYEKk6gMneu9lJ1Q24uqIAKqIAKDQlUHEUlPLwaKiNHggqogAqo0JDqNSpdZ8266o03HPvza9FCa4p/27aOzSdu3DhQARVQARWK7Quo9HYibdq00aLSunVrh2cFKqACKqBCses7Ki2qH6l06tQJVEAFVECFhlSvUek2eXKr555z7M8vOFiLSmBCgmPziR85ElRABVRAhWL7AipOfVHfvn21L+pjY/miHlRABVRoSKDiKCpGYzVUHJ0VqIAKqIAKxQaV3w3FxYbp0w2hoYb4+D9ufiwvBxVQARVQoSGBCt20UK9ABVRAhTJ7HBW6aQEVUAEVGhKouAwVumkBFVABFRoSqLgMFbppARVQARUaEqi4DBUuKQYVUAEVGhKouAwVLikGFVABFRoSqLgMFS4pBhVQARUaEqi4DBUuKQYVUAEVGhKoaFGJHzNGXPHsX0JqKqiACqiACsX2elSMRuNAJzJgwICOHTs2adIkNDS0c+fOzswqKyuLegUqoAIqFNu7UXEys2fP1n5Pn52dzToCFVABFRoSqDiYpk2balFJTU1lHYEKqIAKDQlUHExUVJQWlZiYGNYRqIAKqNCQQMXBLFy4UItKZmYm6whUQAVUaEig4mDy8/NbtmwZEBDQrVs3o9FYUFDAOgIVUAEVGhKoOJ7k5OTRo0dTr0AFVECFhgQqzkYOTbp37x4ZGRkfHy9HKqwjUAEVUKEhgYrj4ZJiUAEVUAEVUHFZuKQYVEAFVEAFVFwWLikGFVCpcylyV8rLy8vKyoq8Ld5YbDeX2YP1atGiRVpU5s+fzzry7XoFKl6Q8+5KRUWF7Omc97Z4Y7HdXGYP1quCggLlkuLu3bsvW7assLCQdeTb9QpUOP3F6S9Of9VuuKSY01+gAio0JFABFeoVqIAKqFBmUKFegQqogAqNH1SoV6ACKqBC4wcVUKFeEVABFRo/qFCvQAVUaEU0fq9Dhb6/QAVUQAVUQMVloe8vUAEVUAEVUHFZ6PsLVEAFVEAFVFwW+v4CFVABFVABFZeFnxMGFVABFVABFZclPz9/6tSpoaGh/JwwqIAKqNCQQIV6RZlBBVRo/JQZVKhXoAIqoELjBxXqFaiACqjQ+EGFekW9IqBC4wcVVhD1ClRAhVZE4wcVig0qoAIqFBtUWEegAiqgQkMCFeoVZQYVUKHxU2ZQoV6BCqjQ+Gn8oEK9AhVQARUaP6hQr6hXoAIqNH5QYQVRr0AFVGhFNH5QodigAiqgQrFBhXUEKqBST3L77bcvWrSIYlNmPiz1ioAKjZ8y82GpV6ACKtRIGj/1imJTr0CFxk+xafzUK8pMQIUQQgioEEIIARVCCCGgQgghhIAKIYQQUHFzKisrs7KyMjIyJk+evHbtWnlYc5pR1VM3P0gdL57ZHDhwYMGCBePGjZsyZco///nPoqIi6hX1inoFKt6dbdu2zZ0792xVZGD79u1m25W3fBzvavwLFy785JNPLl26JM1+xYoVsiGgXlGvqFeg4t2ZN2/eoUOHlGEZyMzMpPF7JKWlpWPHjqVeUa+oV6Di3Zk0aVJJSYkyLAMZGRlmW5QcR48ZM+bOO+989dVXr1y5QuN3efbu3SsbYuoV9Yp6BSrenfT0dPV8twyMHj3a0pTS5n/44YcHH3xw9erVNH7X5rvvvpsxY4b8p15Rr6hXoOL7e5TaFBYW2pyGxm9XDh8+LC3/yJEj1CvqFfUKVLw+es59a1NUVCTbCxq/q/L+++9Pmzbt2LFj1CvqFfUKVHwheXl50v6Vq3RkQL1KR9uKli5dmp+fX1FRUVBQsHjx4qeeeorG75Js2rRp5syZP/74I/WKekW9AhUfiXo/gWTNmjXqeXBtK/rwww/vueeeMWPGTJ8+/fnnny8rK6ubzb7u3/RgvcySS5cuUa+oV9QrUCGEEEJAhRBCCKgQQggBFUIIIaBCCCGEgAohhBBQIYQQAiqEEEIIqBBCCAEVQgghoEIIIQRUCCGEEFAhhBACKqQeVsE/Exwc3LFjx4kTJ+bl5bm5DEuXLk1LS3PtPIcNG7Zs2TLWLwEVQtyNijJQWlr6ww8/rFmzJjY2dtasWW4rwOXLl1u3bv3ZZ5+5drYHDhxo06ZNeXk5q5iACiEeQEXNhQsXEhISXnzxRfcUIDc3Nzk5uTbmfN1116m/00UIqBDiGVQkr7/++g033KA+XLlyZadOnRo2bCj/V61apY4/evTo8OHDw8LCGjVqdPXVV+fk5KhPbdmyJTExUca3a9fu+eeft1KA22+/Xfvzi1Ke9evX9+nTJygoKCQkZPDgwZ9//nleXp4IERwcLGNuuumm06dPq9M/99xz7du3l7J17txZyqn9OE8++eTdd9/NKiagQoiHUZGtdkREhDK8bt062Wp/9NFHZWVle/bsESRko688FRsbu3z58nPnzslT+/btGzt2rDL+zTffbNas2caNG0tLSw8dOtSlS5fNmzdbKkCvXr0++eQTbXni4+M/+OADmeeZM2fuuOMOKUnPnj3ff/99mZsyRn0jYUwskbdWCiDmaT/OgQMHevfuzSomoEKIh1EpLy8PCAhQhmW7rP3qfuvWrX379lWGGzdufOLEiZovHzBggIiiPty/f39CQoKlAoSHh589e1ZbniNHjqgPCwsLZcwXX3yhHRMaGqoMX3PNNTt27FCf2r59u/bjiHYqjYSACiEeQ+XUqVORkZGqHBcvXlSfKikpkTHK8Jw5c1q0aHHXXXetWbPmp59+UqcJDg42VI+fn5+lAvj7+1dUVGjLo/62vJUxlsqm/ThXrlxRaSQEVAjxGCqvvfba4MGDbaLye9UppqVLl06cOFGOCZYsWaK+pLi4WGcB5Ejl/PnzVspjZYx1VDhSIaBCiOdRuXDhQo8ePTZs2KA87N2797Zt29Rn8/Ly1NNf2nz//fdygKIMJyUlvfvuuzoLkJiYePDgQcdQueaaa9566y11/I4dO0y+U7n66qtZxQRUCPEAKmVlZfn5+WvXro2Njb3jjjvUCdatW9exY8e9e/devnxZ/nfo0EH9on7YsGGyHReE5Lhk1apVcXFxyvidO3f26dNnz549paWl8qw8tHJv42233WZy9Zd+VHJycmJiYvbv3y9lk/8yrJ1YZnvXXXexigmoEOJWVJQEBQUJGBMnTtQelyhZsWJFp06dAgICTC4p3rp1a3JycmBgYFhY2IgRI44dO6Y+JUcqgwYNCgkJkdmmpKTk5uZaKoA8NWDAAMdQ+b3qcud27doplxQ/88wzjRo1Up+6/vrr33zzTVYxARVC6lGUO+o//fRT52d14MABOcxShg8ePCiz5Y56AiqE1Ls89thjw4cPd+y1t9xyy9dffy14CEu9e/deunSpMl5mKLNl2RJQIYTYkTVr1nTu3DkgIKBdu3aLFy++cuUKy4SACiGEEAIqhBBCQIUQQgioEEIIIaBCCCEEVAghhIAKIYQQUCGEEEJAhRBCCKgQQggBFUJqrzoaHK+Q7777blRUlMNzcOatnZl/bb8vIaBCQMWR9O3bd8uWLR5567qPSp2lyyMFA3JQIT7b7E1m7sx7NW7c+PLly+7/mDpf6FpUanuz+Nlnn6WmpoaEhLRu3fqFF15QRlZWVmZmZoaHhzdr1mz+/PnykNZBQIX4LCpOlhNU1Bw7diw6Ovr1118vKSk5fvz4jBkzlPErV67s16/fz1WRgdWrV9M6CKgQ12y/KioqZF+1efPmQUFBkyZNOn/+vDrxihUrlF9CTExMVH/56uLFi1OnTg0ODv7LX/7y6KOPKvM0aGL95dpcunTp1ltvDavKbbfdJg/Nzsr69JLS0tLp06crRVq6dKn6QkvTmy1bzfe18nL54C1atJB3lM20vLvJ4v3uu+9GjRoVGhoaGBg4bNiwU6dOKePz8vLi4uLkTeWtle14zTetOY2llahnCU+ePFk9OtGmf//+b7/9tjIsA0lJSTWnMbuirew92CyYpZpmaXGZvIv1ZW6ptDaXJwEV4mJU/vGPfwwZMuSnn36SRi6bZvWX2GViafknTpy4cOHC4sWL+/btq4y///77R48efboqsi2wsq0x+3JtZFZpaWmyETl58uTQoUPnzp1rfefd0vTz5s0bMWKEMl62SurLrczfbNlM3tfKy5W3k8gEmZmZJi/v3r27bKllM1dUVHTvvffefPPNyvjIyMjXXntNNohy0DBr1iyzb2p2GksbcZtLWLawDz/8cKtWrWRrO2HChMLCQmW8MHnu3DllWAoZHh5udmnrXNE6C2appllaXCbvYn2ZWyqtzeVJQIW4GBXZg/vqq6+UYdl6ymZInfjs2bPKcElJSUBAgDLcpk0b2bVUhr/55hsr2xqzL9emdevWX3/9tXqiRuZsHRVL08uAlEQdr77cyvzNls3kfa28XH07maBt27ZWii3zl31zZTgqKmr58uWyVbWyUsxOY2kjbnMJ+/v7y5b0bFWmTZsm23plvJ+fn/oTZDIgk9V8rf4VrbNglmqapcVl8i7Wl7ml0tpcngRUiItRkTavPQnToEED69sO2QBVVFQow+Xl5Ta3NVbe2mRWljbuNqe3VCSd87f0Eay83Ppsd+/eff3114eEhJgs0o8//lh2oq+66qqOHTv++9//NvumZqfRU1qzC02OSNSjE9nQh4aG6j9SsXdF25zAUk2ztLhMZmJ9mVsqrc3lSUCFuBgV2ZU7ceKEzYm1u/927cBaeWuZlfYIQx7aPFIxO732SEV2Y7VF1TN/Sx/BysvV8TJQ8wBLxuTk5MjGurKyUrbdJrOVkVu3bm3ZsqWVD2syjcOoyMZai0qTJk2UYT3fqVha0bJBl+MJZfjMmTP6UbFU06wvLp3L3FJpbS5PAirExag8/PDDaWlp3377rezfHT58WD1DYmnT8Ne//nXMmDG/VkV78lr2dtWTGzo3eXPmzFFPlA8bNkzmbB0VS9PPnTtXSnL69GnlhLv6cp3zt/QRrLxceTvJyJEj582bZzKfiIiIzZs3l5aWymZOlqc6PiMj44svvigrK8vNzY2MjDT7pmancRiVF154YebMmYVVmTZt2uTJk5XxK1asEFeUq79kwOw32JZWdO/evRcvXiyuiBDjx4/Xj4qlmmZpcZnMxPoyt1RaS8uTG1xAhbgGFZP8XnVK/ZFHHlGu1YmPj5d9RuubBtma3HLLLUFBQS1atJDNhLxKGf/QQw+Fhobatcm7ePGibPKaVEUG5KH1Bm9p+kuXLk2dOlUpkvbqL53zVx+afAQrL1evRJIttfaqMGVg06ZNHTt29Pf3j46Ofvrpp9XxGzZs6Nq1q+zpx8XFvfnmm2bf1Ow0DqMi+fvf/y4bUymqAKAetcieu2yXw6vywAMPmL1PxdKKPnjwYK9evaSEUmeeffZZ/ahYqmmWFpfJTKwvc0ultbQ8QQVUSF3Ml19+2aFDB5YDK9ojB9lUS1D53VsqJWWzXtr77rtP9nkLCgrS0tLmzJnj5gLo7BnM/Uu19t7RtXPWPzdLK9rJztlqqcyerZagAip1aJ5ua5wueSOZyZNPPhkZGRkaGjplypTi4mI3r0qdPYOBivNzs7Si7eqczVW1zuYYz1ZLUPEyD2p+E8CRSr0traWewVzYTwyoOLYK6nLN+fLLL8eOHRsREdGoUaM+ffq8+uqrmFGvUfHtDTeouKQAoOK2uXndjt3XX3/dsmXLZ5999syZM6WlpXv37h03bhxmgIppLHUZJPtQc+bMkQPh8PDwZcuWqTOx2VGSpRlaeq32cheprx06dJCdoLi4uA8++CArKysmJkaZ/vDhwzbnb/ZTP/74423btlXuBbPUb5LZD2ulO6+zZ8/KxOpVQL9X3b7QokULGWPpVZZ61tLGrl62rJTQ5jwtHbDq73xM54LVU0J7+xwz2w+VnjdS51xzYgdWqP5+sfSvAivFsNQ7nJXmoKc12dUH2pQpU5544gmQABUbqFjqMujBBx9MTU396aeffvvtt/vuu0+dic2OkizN0GZXUTIgR9Y//vhjSUnJww8/3KRJkwkTJqgP+/XrZ3P+Zj+1vOnp06eVh5b6TTL7Ya105yX/77zzTqPRqL7RkiVLlBdaepWlnrW0sbeXLUvvpXOeOo9ULK01PQtWTwnt7XPMbD9Uet5InbPZie1dofr7xbJrFVgqhqVLja00Bz2tyd4+0H755ReQABUzO6GWvlPRdhkkO6HHjh2rORObHSVZmqHNrqJkQA6r1QlMHpp9L5P5m/3UP//8s/rQUr9JZj+sle68lJPL0dHR5eXlv1d1aNG+fXvZplh5laWetbSxt5ctPd1A2dszmM7Ox3QuWD0ltLfPMbP9UOl5I3XOZie2d4Xq7xfLrlVgqRiWULHSHPS0Jrv6QJORSsEIqFiri5a6DPL3969ZgfSccLc0Q4c7OzJ5qHP+Zkda6jfJ7Ie12Z3X8OHDlVvPNmzYMGXKFJtvYbZXJW3s7WXL0ns5ME+dq9jSyrJUEgdKaLPPMbP9UOl5I5vLza4Vqr9fLHtXgdliWFry9jY3x1ofRyqgYgcqlroMsnSkYnOelmboKlR0zt/sSEv9Jpn9sDa789q+fXv//v1loF+/fgcPHrT+Kks9a5ns0trVy5al93Jgnk6iYqkkekpob59jSkz6odLzRjaXm10rVH+/WPauArPFsLTk7W1uzqAiwj311FMgASo2ULHUZdCCBQvMfqdic56WZugqVHTO3+xIS/0mmf2werrziouLW758+eDBg22+haWetbSxt5ctS+/lwDzV6Ox8TOeC1VNCe/scM9sPlZ430rPc9K9Qm/1iObwKzBbDUtdq9jY3Z1AR8lu1avXcc8+dPXtW3nHfvn3aq7/ossVS/h+rIgLnpP+GWgAAAABJRU5ErkJggg==" />
|
381
|
+
<img src="data:image/png;base64,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" />
|
383
382
|
|
384
383
|
</div>
|
385
384
|
</div>
|
386
385
|
<div id="the-corp-theme" class="section level2">
|
387
386
|
<h2>The Corp Theme</h2>
|
388
|
-
<p>We are almost done. But the plot does not yet look nice to the eye. We are still distracted by many aspects of the graph. First, the back font color does not look good. Then plot background, borders, grids all add clutter to the plot.</p>
|
389
|
-
<p>We will now define our corporate theme.
|
387
|
+
<p>We are almost done. But the default plot configuration does not yet look nice to the eye. We are still distracted by many aspects of the graph. First, the back font color does not look good. Then plot background, borders, grids all add clutter to the plot.</p>
|
388
|
+
<p>We will now define our corporate theme. in a module that can be used/loaded for all plots, similar to CSS or any other style definition.</p>
|
389
|
+
<p>In this theme, we remove borders and grids. The background if left for faceted plots but removed for non-faceted plots. Font colors are a shade o blue (color: ‘#00080’). Axis labels are moved near the end of the axis and written in ‘bold’.</p>
|
390
390
|
<pre class="ruby"><code>module CorpTheme
|
391
391
|
|
392
392
|
R.install_and_loads 'RColorBrewer'
|
@@ -439,6 +439,8 @@ end</code></pre>
|
|
439
439
|
</div>
|
440
440
|
<div id="final-box-plot" class="section level2">
|
441
441
|
<h2>Final Box Plot</h2>
|
442
|
+
<p>We can now easily make our final boxplot and violin plot. All the layers for the plot were added in order to expose our understanding of the data and the need to present the result to our audience.</p>
|
443
|
+
<p>The final specification is just the addition of all layers build up to this point (<span class="citation">@bp</span>), plus the decorations (<span class="citation">@decorations</span>), plus the corporate theme.</p>
|
442
444
|
<p>Here is our final boxplot, without jitter.</p>
|
443
445
|
<pre class="ruby"><code>R.png("figures/final_box_plot.png", width: 540, height: 560)
|
444
446
|
|
@@ -446,26 +448,20 @@ puts @bp + @decorations + CorpTheme.global_theme(faceted: true)
|
|
446
448
|
|
447
449
|
R.dev__off</code></pre>
|
448
450
|
<div class="figure">
|
449
|
-
<img src="data:image/png;base64,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" />
|
451
|
+
<img src="data:image/png;base64,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" />
|
450
452
|
|
451
453
|
</div>
|
452
|
-
|
453
|
-
<div id="final-violin-plot" class="section level2">
|
454
|
-
<h2>Final Violin Plot</h2>
|
455
|
-
<p>Here is the final violin plot, with jitter and the same look and feel of the corporate boxplot.</p>
|
454
|
+
<p>And here is the final violin plot, with jitter and the same look and feel of the corporate boxplot.</p>
|
456
455
|
<pre class="ruby"><code>R.png("figures/final_violin_plot.png", width: 540, height: 560)
|
457
456
|
|
458
457
|
puts @violin + @decorations + CorpTheme.global_theme(faceted: true)
|
459
458
|
|
460
459
|
R.dev__off</code></pre>
|
461
|
-
<
|
462
|
-
<img src="data:image/png;base64,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cwwPGFABKkAFRRFUDA2oeHB/eXOOARWgAlSACoouqHif9+WuL2KgH8OwClABKkAFARVfHs/jESoMqwAVoAJUULRAxYIIFQNzw/CAARWgAlRQVEDFmiW/vEWxABWgAlSACooWqFgeSA9UgApQASoIqAAVBFSACqLOhwlUmAAGVIAKUEHRBxWza3wRVw9UgApQQUDl11DxY40vPGBABagAFQRUNFDxb40voAJUgApQQUAFqCCgAlQQdR73FwIqQAWoILtDJWAD9UAFqAAVoIKiEioWhdADFaACVIAKAiqWLfYFVIAKUAEqCKhYsyyx61Zt8+am7dsDFaACVIAKAioWQEW6KUlJSZmZmfx9QAWoABUEVPx1f+H7AipABaggoGLZQD1QASpABaigaIHKzZ06Vdm7l1WKEVABKog67691ZWRktG7dOtALFTd+8kmgAlSAClBBkQ8Vnz1gvkeo1Jw6NTExMT09nf8OqAAVoIKAigURKt27d+ePAypABaigaIGKoWEVsytOMqACVIAKUEFRBBWjwyqEPQIVoAJUEFCx0gNmKkKFsEegAlSACoo6qBidWEyEClABKkAFARVrPGA+bvi+gApQASooGqGSazq0Ht8XUAEqQAUBFb88YMQ8AhWgAlQQUAmyB4yYR6ACVIAKil6oWN5ZIeYRqAAVoIKiGioWdlYYogcqQAWooGiHSq6H4XrfZxIzRA9UgApQQUBFzwPme8wjQ/RABagAFQRUyj1gwhXpryjblRMnli/NcmGTt+pH7raGyckM0QMVoAJUEFAp50oXjdoMGBCTlaUQRXbkbRcDgihABagAFQRU9DVp//5KDodsssP1BypABaggoGIBVyAKUAEqQAUBFYSAClBBCKggoAJUgAoCKgioABWggoAKQkAFqCDqPNaFgApQQQioIKACVIAKAioIqAAVoIKACkJABaggBFQQUAEqQAUBFQRUgApQQUAFIaACVBB1HutCQAWoIARUEFABKkAFARUEVIAKUEFABSGgEmlQCaa6devWp08fykyx+b0UGwEVoEKx+b0UG6gAFWyRao9pUWyKDVSo+ZSZas/fRLERUEEIIQRUEEIIARWEEEJABSGEEAIqCCGEgErwlZdX2K5deuXKqfKan39G56JU6KNu9v3nbF9CXc2dm92kybj4+NTmzSc5HIcwLUwL0wIqYa8XX1zao8fi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" />
|
463
|
-
|
464
|
-
</div>
|
460
|
+
<p>[]<a href="https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/225058450f4e69e5e82a01e22f69725554746893/final_violin_plot.png" class="uri">https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/225058450f4e69e5e82a01e22f69725554746893/final_violin_plot.png</a></p>
|
465
461
|
</div>
|
466
462
|
<div id="another-view" class="section level2">
|
467
463
|
<h2>Another View</h2>
|
468
|
-
<p>
|
464
|
+
<p>We now make another plot, with the same look and feel as before but facetted by dose and not by supplement. This shows how easy it is to create new plots by just changing small statement on the <em>grammar of graphics</em>.</p>
|
469
465
|
<pre class="ruby"><code>R.png("figures/facet_by_dose.png", width: 540, height: 560)
|
470
466
|
|
471
467
|
caption = <<-EOT
|
@@ -492,10 +488,10 @@ R.dev__off</code></pre>
|
|
492
488
|
</div>
|
493
489
|
<div id="conclusion" class="section level1">
|
494
490
|
<h1>Conclusion</h1>
|
495
|
-
<p>Galaaz tightly
|
496
|
-
<p>
|
491
|
+
<p>In this article, we introduce Galaaz and show how to tightly couple Ruby and R in a way that Ruby developers do not need to be aware of the executing R engine. For the Ruby developer the existence of R is of no consequence, she is just coding in Ruby. On the other hand, for the R developer, migration to Ruby is a matter of small syntactic changes with a very gentle learning curve. As the R developer becomes more proficient in Ruby, he can start using ‘classes’, ‘modules’, ‘procs’, ‘lambdas’.</p>
|
492
|
+
<p>Trying to bring to Ruby the power of R starting from scratch is an enourmous endeavour and would probably never be accomplished. Today’s data scientists would certainly stick with either Python or R. Now, both the Ruby and R communities can benefit from this marriage, provided by Galaaz on top of GraalVM and Truffle’s polyglot environment. We presented the process to couple Ruby and R, but this process can also be done to couple Ruby and JavaScript or Ruby and Python. In a polyglot world a <em>uniglot</em> language might be extremely relevant.</p>
|
497
493
|
<p>From the perspective of performance, GraalVM and Truffle promises improvements that could reach over 10 times, both for <a href="https://medium.com/graalvm/faster-r-with-fastr-4b8db0e0dceb">FastR</a> and for <a href="https://rubykaigi.org/2018/presentations/eregontp.html">TruffleRuby</a>.</p>
|
498
|
-
<p>This article has shown how to improve a plot step-by-step. Starting from a very simple boxplot with all default configurations, we moved slowly to our final plot. The important point here is not if the final plot is actually beautiful, but that there is a process of small steps improvements that can be followed to getting a final plot ready for presentation.</p>
|
494
|
+
<p>This article has shown how to improve a plot step-by-step. Starting from a very simple boxplot with all default configurations, we moved slowly to our final plot. The important point here is not if the final plot is actually beautiful (as beauty is in the eye of the beholder), but that there is a process of small steps improvements that can be followed to getting a final plot ready for presentation.</p>
|
499
495
|
<p>Finally, this whole article was written in rmarkdown and compiled to HTML by <em>gknit</em>, an application that wraps <em>knitr</em> and allows documenting Ruby code. This application can be of great help for any Rubyist trying to write articles, blogs or documentation for Ruby.</p>
|
500
496
|
</div>
|
501
497
|
<div id="installing-galaaz" class="section level1">
|
@@ -527,7 +523,6 @@ R.dev__off</code></pre>
|
|
527
523
|
<li>gknit <filename></li>
|
528
524
|
<li>In a scrip add: require ‘galaaz’</li>
|
529
525
|
</ul>
|
530
|
-
<p>And now that you’ve read this far, here’s how to submit your story to the freeCodeCamp publication: send an email to submit at freecodecamp org. Include the URL for your story on Medium (preferably an unpublished draft) and the word “bananas” so that we’ll know that you have read all this. Only send one story URL per email. There’s no need to add anything further to your email — we just read the stories and judge them based on their own merits.</p>
|
531
526
|
</div>
|
532
527
|
</div>
|
533
528
|
|
@@ -1,6 +1,8 @@
|
|
1
1
|
---
|
2
2
|
title: "How to make Beautiful Ruby Plots with Galaaz"
|
3
|
-
author:
|
3
|
+
author:
|
4
|
+
- "Rodrigo Botafogo"
|
5
|
+
- "Daniel Mossé - University of Pittsburgh"
|
4
6
|
tags: [Tech, Data Science, Ruby, R, GraalVM]
|
5
7
|
date: "November 19th, 2018"
|
6
8
|
output:
|
@@ -9,25 +11,27 @@ output:
|
|
9
11
|
keep_md: true
|
10
12
|
pdf_document:
|
11
13
|
includes:
|
12
|
-
in_header:
|
14
|
+
in_header: "../../sty/galaaz.sty"
|
15
|
+
keep_tex: yes
|
13
16
|
number_sections: yes
|
17
|
+
toc: true
|
18
|
+
toc_depth: 2
|
19
|
+
fontsize: 11pt
|
14
20
|
---
|
15
21
|
|
16
22
|
|
17
23
|
|
18
|
-
# Introduction
|
19
|
-
|
20
24
|
According to Wikipedia "Ruby is a dynamic, interpreted, reflective, object-oriented,
|
21
25
|
general-purpose programming language. It was designed and developed in the mid-1990s by Yukihiro
|
22
26
|
"Matz" Matsumoto in Japan." It reached high popularity with the development of Ruby on Rails
|
23
27
|
(RoR) by David Heinemeier Hansson. RoR is a web application framework first released
|
24
28
|
around 2005. It makes extensive use of Ruby's metaprogramming features. With RoR,
|
25
29
|
Ruby became very popular. According to [Ruby's Tiobe index](https://www.tiobe.com/tiobe-index/ruby/)
|
26
|
-
it peeked in popularity around 2008
|
27
|
-
|
28
|
-
|
30
|
+
it peeked in popularity around 2008, then declined until 2015 when it started picking up again.
|
31
|
+
At the time of this writing (November 2018), the Tiobe index puts Ruby in 16th position as
|
32
|
+
most popular language.
|
29
33
|
|
30
|
-
Python, a similar
|
34
|
+
Python, a language similar to Ruby, ranks 4th in the index. Java, C and C++ take the
|
31
35
|
first three positions. Ruby is often criticized for its focus on web applications.
|
32
36
|
But Ruby can do [much more](https://github.com/markets/awesome-ruby) than just web applications.
|
33
37
|
Yet, for scientific computing, Ruby lags way behind Python and R. Python has
|
@@ -37,7 +41,7 @@ of libraries for data analysis.
|
|
37
41
|
|
38
42
|
Until recently, there was no real perspective for Ruby to bridge this gap.
|
39
43
|
Implementing a complete scientific computing infrastructure would take too long.
|
40
|
-
|
44
|
+
Enters [Oracle's GraalVM](https://www.graalvm.org/):
|
41
45
|
|
42
46
|
> GraalVM is a universal virtual machine for running applications written in
|
43
47
|
> JavaScript, Python 3, Ruby, R, JVM-based languages like Java, Scala, Kotlin,
|
@@ -68,38 +72,40 @@ Comes GraalVM into the picture:
|
|
68
72
|
As stated above, GraalVM is a _universal_ virtual machine that allows Ruby and R (and other
|
69
73
|
languages) to run on the same environment. GraalVM allows polyglot applications to
|
70
74
|
_seamlessly_ interact with one another and pass values from one language to the other.
|
71
|
-
|
72
|
-
|
73
|
-
|
75
|
+
Although a great idea, GraalVM still requires application writers to know several languages.
|
76
|
+
To eliminate that requirement, we built Galaaz, a gem for Ruby, to tightly couple
|
77
|
+
Ruby and R and allow those languages to interact in a way that the user will be unaware
|
78
|
+
of such interaction. In other words, a Ruby programmer will be able to use all
|
79
|
+
the capabilities of R without knowing the R syntax.
|
74
80
|
|
75
|
-
Library wrapping is
|
81
|
+
Library wrapping is a usual way of bringing features from one language into another.
|
76
82
|
To improve performance, Python often wraps more efficient C libraries. For the
|
77
|
-
Python developer, the existence of such C libraries is
|
83
|
+
Python developer, the existence of such C libraries is hidden. The problem with
|
78
84
|
library wrapping is that for any new library, there is the need to handcraft a new
|
79
85
|
wrapper.
|
80
86
|
|
81
|
-
Galaaz, instead of wrapping a single C or R library, wraps the whole
|
82
|
-
|
83
|
-
Ruby developers
|
84
|
-
new wrapping effort.
|
87
|
+
Galaaz, instead of wrapping a single C or R library, wraps the whole R language
|
88
|
+
in Ruby. Doing so, all thousands of R libraries are available immediately
|
89
|
+
to Ruby developers without any new wrapping effort.
|
85
90
|
|
86
|
-
|
87
|
-
|
88
|
-
migrating from R to Ruby with Galaaz is a matter of small
|
89
|
-
|
90
|
-
|
91
|
+
To show the power of Galaaz, we show in this article how Ruby can use R's ggplot2
|
92
|
+
library tranparantly bringing to Ruby the power of high quality scientific plotting.
|
93
|
+
We also show that migrating from R to Ruby with Galaaz is a matter of small
|
94
|
+
syntactic changes. By using Ruby, the R developer can use all of Ruby's powerful
|
95
|
+
object-oriented features. Also, with Ruby, it becomes much easier to move code
|
96
|
+
from the analysis phase to the production phase.
|
91
97
|
|
92
|
-
In this article we will explore the R ToothGrowth dataset.
|
98
|
+
In this article we will explore the R ToothGrowth dataset. To illustrate, we will
|
93
99
|
create some boxplots. A primer on boxplot is available in
|
94
100
|
[this article](https://towardsdatascience.com/understanding-boxplots-5e2df7bcbd51).
|
95
101
|
|
96
102
|
We will also create a Corporate Template ensuring that plots will have a consistent
|
97
|
-
visualization. This template is
|
103
|
+
visualization. This template is built using a Ruby module. There is a way of building
|
98
104
|
ggplot themes that will work the same as the Ruby module. Yet, writing a new theme
|
99
|
-
requires specific knowledge. Ruby modules are standard to the
|
100
|
-
need special knowledge.
|
105
|
+
requires specific knowledge on theme writing. Ruby modules are standard to the
|
106
|
+
language and don't need special knowledge.
|
101
107
|
|
102
|
-
|
108
|
+
[Here](https://towardsdatascience.com/ruby-plotting-with-galaaz-an-example-of-tightly-coupling-ruby-and-r-in-graalvm-520b69e21021) we show a scatter plot in Ruby also with Galaaz.
|
103
109
|
|
104
110
|
# gKnit
|
105
111
|
|
@@ -123,18 +129,18 @@ class and instance variables ('@'), are available in all chunks.
|
|
123
129
|
# Exploring the Dataset
|
124
130
|
|
125
131
|
Let's start by exploring our selected dataset. ToothGrowth is an R dataset. A dataset
|
126
|
-
is like
|
132
|
+
is like a simple excel spreadsheet, in which each column has only one type of data.
|
127
133
|
For instance one column can have float, the other integer, and a third strings.
|
128
|
-
This dataset
|
134
|
+
This dataset analyzes the length of odontoblasts (cells responsible for tooth growth)
|
129
135
|
in 60 guinea pigs, where each animal received one of three dose levels of Vitamin C
|
130
|
-
(0.5, 1, and 2 mg/day) by one of two delivery methods, orange juice
|
136
|
+
(0.5, 1, and 2 mg/day) by one of two delivery methods, orange juice OJ or ascorbic acid
|
131
137
|
(a form of vitamin C and coded as VC).
|
132
138
|
|
133
139
|
The ToothGrowth dataset contains three columns: 'len', 'supp' and 'dose'. Let's
|
134
|
-
take a look at a few rows of this dataset. In Galaaz,
|
135
|
-
|
136
|
-
following chunk that
|
137
|
-
|
140
|
+
take a look at a few rows of this dataset. In Galaaz, R variables are accessed
|
141
|
+
by using the corresponding Ruby symbol preceeded by the tilda ('~') function. Note in the
|
142
|
+
following chunk that 'ToothGrowth' is the R variable and Ruby's '@tooth_growth' is
|
143
|
+
assigned the value of '~:ToothGrowth'.
|
138
144
|
|
139
145
|
|
140
146
|
```ruby
|
@@ -172,7 +178,8 @@ puts @tooth_growth.len.head
|
|
172
178
|
## [1] 4.2 11.5 7.3 5.8 6.4 10.0
|
173
179
|
```
|
174
180
|
|
175
|
-
The 'dose' column contains a numeric value
|
181
|
+
The 'dose' column contains a numeric value with either, 0.5, 1 or 2, although the
|
182
|
+
first 6 rows as seen above only contain the 0.5 values. Even though those are
|
176
183
|
number, they are better interpreted as a [factor or cathegory](https://swcarpentry.github.io/r-novice-inflammation/12-supp-factors/). So, let's convert our 'dose' column from numeric to 'factor'.
|
177
184
|
In R, the function 'as.factor' is used to convert data in a vector to factors. To use this
|
178
185
|
function from Galaaz the dot ('.') in the function name is substituted by '__' (double underline).
|
@@ -198,8 +205,9 @@ puts @tooth_growth.dim
|
|
198
205
|
|
199
206
|
This dataset has 60 rows, one for each subject and 3 columns, as we have already seen.
|
200
207
|
|
201
|
-
Note that we do not call 'puts' when using the 'str' function. This
|
202
|
-
return anything and prints the structure of the dataset
|
208
|
+
Note that we do not need to call 'puts' when using the 'str' function. This
|
209
|
+
functions does not return anything and prints the structure of the dataset
|
210
|
+
as a side effect.
|
203
211
|
|
204
212
|
|
205
213
|
```ruby
|
@@ -236,8 +244,9 @@ puts @tooth_growth.summary
|
|
236
244
|
|
237
245
|
## Quick plot for seing the data
|
238
246
|
|
239
|
-
Let's now create our first plot with the given data by accessing ggplot2 from Ruby.
|
240
|
-
that have never seen or used ggplot2, here is the description of ggplot
|
247
|
+
Let's now create our first plot with the given data by accessing ggplot2 from Ruby.
|
248
|
+
For Rubyists that have never seen or used ggplot2, here is the description of ggplot
|
249
|
+
found in its home page:
|
241
250
|
|
242
251
|
> "ggplot2 is a system for declaratively creating graphics, based on _The Grammar of Graphics_.
|
243
252
|
> You provide the data, tell ggplot2 how to map variables to aesthetics, what graphical
|
@@ -249,16 +258,20 @@ axis, data, title, subtitle and also graphical primitives such as _bar plot_, _b
|
|
249
258
|
to form the final graphics.
|
250
259
|
|
251
260
|
In order to make a plot, we use the 'ggplot' function to the dataset. In R, this would be
|
252
|
-
written as ```ggplot(<dataset>, ...)```.
|
253
|
-
or ```<dataset>.ggplot(...)```. In the graph
|
254
|
-
|
255
|
-
|
256
|
-
|
261
|
+
written as ```ggplot(<dataset>, ...)```. Galaaz gives you the flexibility to use
|
262
|
+
either ```R.ggplot(<dataset>, ...)``` or ```<dataset>.ggplot(...)```. In the graph s
|
263
|
+
pecification bellow, we use the second notation
|
264
|
+
that looks more like Ruby. ggplot uses the ‘aes’ method to specify
|
265
|
+
x and y axes; in this case, the 'dose' on the $x$ axis and the 'length' on
|
266
|
+
the $y$ axis: 'E.aes(x: :dose, y: :len)'. To specify the type of plot add a geom to
|
267
|
+
the plot. For a boxplot, the geom is R.geom_boxplot.
|
257
268
|
|
258
269
|
Note also that we have a call to 'R.png' before plotting and 'R.dev__off' after the print
|
259
|
-
statement. 'R.png' opens a 'png
|
260
|
-
|
261
|
-
image gets a default name of 'Rplot\<nnn\>' where \<nnn\> is the number of the plot.
|
270
|
+
statement. 'R.png' opens a 'png device' for outputting the plot. If we do no pass a
|
271
|
+
name to the 'png' function, the
|
272
|
+
image gets a default name of 'Rplot\<nnn\>' where \<nnn\> is the number of the plot.
|
273
|
+
'R.dev__off'
|
274
|
+
closes the device and creates the 'png' file. We can
|
262
275
|
then include the generated 'png' file in the document by adding an rmarkdown directive.
|
263
276
|
|
264
277
|
|
@@ -277,25 +290,29 @@ R.dev__off
|
|
277
290
|
[//]: # (of gKnit, the figures should be automatically saved and the name)
|
278
291
|
[//]: # (taken from the chunk 'label' and possibly chunk parameters)
|
279
292
|
|
280
|
-
![](
|
293
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/96db2729e02ced0f9336216d87d14af141c1e81b/dose_len.png)
|
281
294
|
|
282
295
|
Great! We've just managed to create and save our first plot in Ruby with only
|
283
|
-
four lines of code. We can see with this plot a clear trend: as the
|
296
|
+
four lines of code. We can now easily see with this plot a clear trend: as the
|
297
|
+
dose of the supplement
|
284
298
|
is increased, so is the length of teeth.
|
285
299
|
|
286
300
|
## Facetting the plot
|
287
301
|
|
288
302
|
This first plot shows a trend, but our data has information about two different forms
|
289
|
-
of delivery method, either by Orange Juice
|
290
|
-
Let's then try to create a plot that
|
303
|
+
of delivery method, either by Orange Juice OJ or by Vitamin C VC.
|
304
|
+
Let's then try to create a plot that helps us discern the effect of each
|
305
|
+
delivery method. This next
|
291
306
|
plot is a _facetted_ plot where each delivery method gets is own plot.
|
292
|
-
On the left side, the plot shows the OJ delivery method. On the right side,
|
293
|
-
VC delivery method. To obtain this plot, we use the
|
307
|
+
On the left side, the plot shows the OJ delivery method. On the right side,
|
308
|
+
we see the VC delivery method. To obtain this plot, we use the
|
309
|
+
'R.facet_grid' function, that
|
294
310
|
automatically creates the facets based on the delivery method factors. The parameter to
|
295
311
|
the 'facet_grid' method is a [_formula_](https://thomasleeper.com/Rcourse/Tutorials/formulae.html).
|
296
312
|
|
297
|
-
In Galaaz
|
298
|
-
|
313
|
+
In Galaaz we give programmers the flexibility to use two different ways to write formulas.
|
314
|
+
In the first way, the following changes from writing formulas (for example 'x ~ y')
|
315
|
+
in R are necessary:
|
299
316
|
|
300
317
|
* R symbols are represented by the same Ruby symbol prefixed with the '+' method. The
|
301
318
|
symbol ```x``` in R becomes ```+:x``` in Ruby;
|
@@ -326,7 +343,7 @@ puts @bp
|
|
326
343
|
R.dev__off
|
327
344
|
```
|
328
345
|
|
329
|
-
![](
|
346
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/96db2729e02ced0f9336216d87d14af141c1e81b/facet_by_delivery.png)
|
330
347
|
|
331
348
|
It now becomes clear that although both methods of delivery have a direct
|
332
349
|
impact on tooth growth, method (OJ) is non-linear having a higher impact with smaller
|
@@ -335,9 +352,9 @@ doses of ascorbic acid and reducing it's impact as the dose increases. With the
|
|
335
352
|
|
336
353
|
## Adding Color
|
337
354
|
|
338
|
-
If
|
339
|
-
|
340
|
-
in Ruby. So,
|
355
|
+
If we were writing about data analysis, we would make a better analysis of the trends and
|
356
|
+
improve the statistical analysis. But here we are interested in working with ggplot
|
357
|
+
in Ruby. So, let's add some color to this plot to make the trend and comparison more
|
341
358
|
visible. In the following plot, the boxes are color coded by dose. To add color, it is
|
342
359
|
enough to add ```fill: :dose``` to the aesthetic of boxplot. With this command each 'dose'
|
343
360
|
factor gets its own color.
|
@@ -352,20 +369,20 @@ puts @bp
|
|
352
369
|
R.dev__off
|
353
370
|
```
|
354
371
|
|
355
|
-
![](
|
372
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/96db2729e02ced0f9336216d87d14af141c1e81b/facets_by_delivery_color.png)
|
356
373
|
|
357
|
-
Facetting helps us compare the general trends
|
358
|
-
Adding color allow us to compare specifically how each dosage impacts the
|
359
|
-
It is possible to observe that with smaller doses, up to 1mg,
|
360
|
-
than
|
374
|
+
Facetting helps us compare the general trends for each delivery method.
|
375
|
+
Adding color allow us to compare specifically how each dosage impacts the tooth growth.
|
376
|
+
It is possible to observe that with smaller doses, up to 1mg, OJ performs better
|
377
|
+
than VC (red color). For 2mg, both OJ and VC have the same median, but OJ is
|
361
378
|
less disperse (blue color).
|
362
|
-
For 1mg (green color),
|
363
|
-
it seems that
|
379
|
+
For 1mg (green color), OJ is significantly bettern than VC. By this very quick
|
380
|
+
visual analysis, it seems that OJ is a better delivery method than VC.
|
364
381
|
|
365
382
|
## Clarifying the data
|
366
383
|
|
367
384
|
Boxplots give us a nice idea of the distribution of data, but looking at those plots with
|
368
|
-
large colored boxes leaves us wondering what is going on
|
385
|
+
large colored boxes leaves us wondering what else is going on. According to
|
369
386
|
Edward Tufte in Envisioning Information:
|
370
387
|
|
371
388
|
> Thin data rightly prompts suspicions: "What are they leaving out? Is that really everything
|
@@ -378,7 +395,7 @@ And he states:
|
|
378
395
|
|
379
396
|
> A most unconventional design strategy is revealed: _to clarify, add detail._
|
380
397
|
|
381
|
-
Let's
|
398
|
+
Let's use this wisdom and add yet another layer of data to our plot, so that we clarify
|
382
399
|
it with detail and do not leave large empty boxes. In this next plot, we add data points for
|
383
400
|
each of the 60 pigs in the experiment. For that, add the function 'R.geom_point' to the
|
384
401
|
plot.
|
@@ -395,15 +412,17 @@ puts @bp
|
|
395
412
|
R.dev__off
|
396
413
|
```
|
397
414
|
|
398
|
-
![](
|
415
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/96db2729e02ced0f9336216d87d14af141c1e81b/facets_with_points.png)
|
399
416
|
|
400
|
-
Now we can see the actual distribution of all the 60
|
417
|
+
Now we can see the actual distribution of all the 60 subjects. Actually, this is not
|
401
418
|
totally true. We have a hard time seing all 60 subjects. It seems that some points
|
402
419
|
might be placed one over the other hiding useful information.
|
403
420
|
|
404
421
|
But no sweat! Another layer might solve the problem. In the following plot a new layer
|
405
|
-
called 'geom_jitter' is added to the plot.
|
406
|
-
the
|
422
|
+
called 'geom_jitter' is added to the plot. Jitter adds a small amount of random variation
|
423
|
+
to the location of each point, and is a useful way of handling overplotting caused by
|
424
|
+
discreteness in smaller datasets. This makes it easier to see all of the points and
|
425
|
+
prevents data hiding. We also add
|
407
426
|
color and change the shape of the points, making them even easier to see.
|
408
427
|
|
409
428
|
|
@@ -416,14 +435,14 @@ puts @bp + R.geom_jitter(shape: 23, color: "cyan3", size: 1)
|
|
416
435
|
R.dev__off
|
417
436
|
```
|
418
437
|
|
419
|
-
![](
|
438
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/96db2729e02ced0f9336216d87d14af141c1e81b/facets_with_jitter.png)
|
420
439
|
|
421
440
|
Now we can see all 60 points in the graph. We have here a much higher information density
|
422
441
|
and we can see outliers and subjects distribution.
|
423
442
|
|
424
443
|
# Preparing the Plot for Presentation
|
425
444
|
|
426
|
-
We have come a long way since our first plot. As
|
445
|
+
We have come a long way since our first plot. As we already said, this is not
|
427
446
|
an article about data analysis and the focus is on the
|
428
447
|
integration of Ruby and ggplot. So, let's assume that the analysis is now done. Yet,
|
429
448
|
ending the analysis does not mean that the work is done. On the contrary, the hardest
|
@@ -443,11 +462,12 @@ those colors helped us understand the data, for a final presentation random colo
|
|
443
462
|
can distract the viewer.
|
444
463
|
|
445
464
|
In the following plot we use shades function 'scale_fill_manual' to change
|
446
|
-
the colors of the boxes and order of labels. For colors we use shades of blue for
|
465
|
+
the colors of the boxes and order of labels. For colors, we use shades of blue for
|
447
466
|
each dosage, with light blue ('cyan')
|
448
|
-
representing the lower dose and deep blue ('deepskyblue4') the higher dose.
|
449
|
-
the
|
450
|
-
the botton of the labels and (2) at the top.
|
467
|
+
representing the lower dose and deep blue ('deepskyblue4') the higher dose.
|
468
|
+
Also, the legend could be improved: we use the ‘breaks’ parameter to put
|
469
|
+
the smaller value (0.5) at the botton of the labels and the largest (2) at the top.
|
470
|
+
This ordering seems more natural and
|
451
471
|
matches with the actual order of the colors in the plot.
|
452
472
|
|
453
473
|
|
@@ -463,7 +483,7 @@ puts @bp
|
|
463
483
|
R.dev__off
|
464
484
|
```
|
465
485
|
|
466
|
-
![](
|
486
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/96db2729e02ced0f9336216d87d14af141c1e81b/facets_by_delivery_color2.png)
|
467
487
|
|
468
488
|
|
469
489
|
## Violin Plot and Jitter
|
@@ -498,7 +518,7 @@ puts @violin
|
|
498
518
|
R.dev__off
|
499
519
|
```
|
500
520
|
|
501
|
-
![](
|
521
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/96db2729e02ced0f9336216d87d14af141c1e81b/violin_with_jitter.png)
|
502
522
|
|
503
523
|
This plot is an alternative to the original boxplot. For the final presentation, it is
|
504
524
|
important to think which graphics will be best understood by our audience. A violin plot
|
@@ -508,14 +528,15 @@ bit better than the boxplot and provides even more information than the boxplot
|
|
508
528
|
## Adding Decoration
|
509
529
|
|
510
530
|
Our final plot is starting to take shape, but a presentation plot should have at least a
|
511
|
-
title, labels on the
|
531
|
+
title, labels on the axes and maybe some other decorations. Let's start adding those.
|
512
532
|
Since decoration requires more graph area, this new plot has a 'width' and 'height'
|
513
|
-
specification. When there is no specification, the default values for width and
|
514
|
-
480.
|
533
|
+
specification. When there is no specification, the default values from R for width and
|
534
|
+
height are 480.
|
515
535
|
|
516
|
-
The 'labs' function adds
|
517
|
-
'x' for the $x$ axis label and 'y', for the $y$ axis label, and 'caption'
|
518
|
-
about the plot
|
536
|
+
The 'labs' function adds the required decoration. In this example we use 'title',
|
537
|
+
'subtitle', 'x' for the $x$ axis label and 'y', for the $y$ axis label, and 'caption'
|
538
|
+
for information about the plot (for clarity, we defined a caption variable using Ruby's
|
539
|
+
Here Doc style).
|
519
540
|
|
520
541
|
|
521
542
|
```ruby
|
@@ -527,8 +548,8 @@ Each animal received one of three dose levels of vitamin C.
|
|
527
548
|
EOT
|
528
549
|
|
529
550
|
@decorations =
|
530
|
-
R.labs(title: "Tooth Growth: Length
|
531
|
-
subtitle: "Faceted by delivery method,
|
551
|
+
R.labs(title: "Tooth Growth: Length vs Vitamin C Dose",
|
552
|
+
subtitle: "Faceted by delivery method, OJ or VC",
|
532
553
|
x: "Dose (mg)", y: "Teeth length",
|
533
554
|
caption: caption)
|
534
555
|
|
@@ -537,16 +558,19 @@ puts @bp + @decorations
|
|
537
558
|
R.dev__off
|
538
559
|
```
|
539
560
|
|
540
|
-
![](
|
541
|
-
|
561
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/225058450f4e69e5e82a01e22f69725554746893/facets_with_decorations.png)
|
542
562
|
|
543
563
|
## The Corp Theme
|
544
564
|
|
545
|
-
We are almost done. But the plot does not yet look
|
565
|
+
We are almost done. But the default plot configuration does not yet look
|
566
|
+
nice to the eye. We are still distracted
|
546
567
|
by many aspects of the graph. First, the back font color does not look good. Then
|
547
568
|
plot background, borders, grids all add clutter to the plot.
|
548
569
|
|
549
|
-
We will now define our corporate theme.
|
570
|
+
We will now define our corporate theme. in a module that can be used/loaded for all
|
571
|
+
plots, similar to CSS or any other style definition.
|
572
|
+
|
573
|
+
In this theme, we remove borders and grids. The
|
550
574
|
background if left for faceted plots but removed for non-faceted plots. Font colors are
|
551
575
|
a shade o blue (color: '#00080'). Axis labels are moved near the end of the axis and
|
552
576
|
written in 'bold'.
|
@@ -606,6 +630,13 @@ end
|
|
606
630
|
|
607
631
|
## Final Box Plot
|
608
632
|
|
633
|
+
We can now easily make our final boxplot and violin plot. All the layers for the plot were
|
634
|
+
added in order to expose our understanding of the data and the need to present the result
|
635
|
+
to our audience.
|
636
|
+
|
637
|
+
The final specification is just the addition of all layers build up to this point (@bp), plus
|
638
|
+
the decorations (@decorations), plus the corporate theme.
|
639
|
+
|
609
640
|
Here is our final boxplot, without jitter.
|
610
641
|
|
611
642
|
|
@@ -617,11 +648,9 @@ puts @bp + @decorations + CorpTheme.global_theme(faceted: true)
|
|
617
648
|
R.dev__off
|
618
649
|
```
|
619
650
|
|
620
|
-
![](
|
651
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/225058450f4e69e5e82a01e22f69725554746893/final_box_plot.png)
|
621
652
|
|
622
|
-
|
623
|
-
|
624
|
-
Here is the final violin plot, with jitter and the same look and feel of the corporate
|
653
|
+
And here is the final violin plot, with jitter and the same look and feel of the corporate
|
625
654
|
boxplot.
|
626
655
|
|
627
656
|
|
@@ -633,12 +662,14 @@ puts @violin + @decorations + CorpTheme.global_theme(faceted: true)
|
|
633
662
|
R.dev__off
|
634
663
|
```
|
635
664
|
|
636
|
-
|
665
|
+
|
666
|
+
![]https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/225058450f4e69e5e82a01e22f69725554746893/final_violin_plot.png
|
637
667
|
|
638
668
|
## Another View
|
639
669
|
|
640
|
-
|
641
|
-
dose and not by supplement.
|
670
|
+
We now make another plot, with the same look and feel as before but facetted by
|
671
|
+
dose and not by supplement. This shows how easy it is to create new plots by just
|
672
|
+
changing small statement on the _grammar of graphics_.
|
642
673
|
|
643
674
|
|
644
675
|
```ruby
|
@@ -662,24 +693,26 @@ puts @bp
|
|
662
693
|
R.dev__off
|
663
694
|
```
|
664
695
|
|
665
|
-
![](
|
696
|
+
![](https://gist.githubusercontent.com/rbotafogo/5538d6c679a59f4d56179b2c030e8d28/raw/96db2729e02ced0f9336216d87d14af141c1e81b/facet_by_dose.png)
|
666
697
|
|
667
698
|
# Conclusion
|
668
699
|
|
669
|
-
|
700
|
+
In this article, we introduce Galaaz and show how to tightly couple Ruby and R
|
701
|
+
in a way that Ruby developers do not need to be aware
|
670
702
|
of the executing R engine. For the Ruby developer the existence of R
|
671
|
-
is of no consequence
|
672
|
-
developer, migration to Ruby is a matter of small syntactic changes
|
703
|
+
is of no consequence, she is just coding in Ruby. On the other hand, for the R
|
704
|
+
developer, migration to Ruby is a matter of small syntactic changes with a very gentle
|
673
705
|
learning curve. As the R developer becomes more proficient in Ruby, he can start using
|
674
706
|
'classes', 'modules', 'procs', 'lambdas'.
|
675
707
|
|
676
|
-
|
677
|
-
|
678
|
-
|
679
|
-
|
680
|
-
|
681
|
-
|
682
|
-
|
708
|
+
Trying to bring to Ruby the power of R starting from scratch is an enourmous endeavour
|
709
|
+
and would probably never be accomplished. Today's data scientists would certainly
|
710
|
+
stick with either Python or R. Now, both the Ruby and R communities can benefit
|
711
|
+
from this marriage, provided by Galaaz on top of GraalVM and Truffle's
|
712
|
+
polyglot environment. We presented
|
713
|
+
the process to couple Ruby and R, but this process can also be done to couple Ruby
|
714
|
+
and JavaScript or Ruby and Python. In a polyglot world a *uniglot* language might
|
715
|
+
be extremely relevant.
|
683
716
|
|
684
717
|
From the perspective of performance, GraalVM and Truffle promises improvements that could
|
685
718
|
reach over 10 times, both for [FastR](https://medium.com/graalvm/faster-r-with-fastr-4b8db0e0dceb)
|
@@ -687,15 +720,14 @@ and for [TruffleRuby](https://rubykaigi.org/2018/presentations/eregontp.html).
|
|
687
720
|
|
688
721
|
This article has shown how to improve a plot step-by-step. Starting from a very simple
|
689
722
|
boxplot with all default configurations, we moved slowly to our final plot. The important
|
690
|
-
point here is not if the final plot is actually beautiful
|
691
|
-
of small steps improvements that can be followed
|
692
|
-
presentation.
|
723
|
+
point here is not if the final plot is actually beautiful (as beauty is in the eye of
|
724
|
+
the beholder), but that there is a process of small steps improvements that can be followed
|
725
|
+
to getting a final plot ready for presentation.
|
693
726
|
|
694
727
|
Finally, this whole article was written in rmarkdown and compiled to HTML by _gknit_, an
|
695
728
|
application that wraps _knitr_ and allows documenting Ruby code. This application can
|
696
729
|
be of great help for any Rubyist trying to write articles, blogs or documentation for Ruby.
|
697
730
|
|
698
|
-
|
699
731
|
# Installing Galaaz
|
700
732
|
|
701
733
|
## Prerequisites
|
@@ -722,10 +754,3 @@ the gnu compiler and tools should be enough. I am not sure what is needed on th
|
|
722
754
|
|
723
755
|
* gknit <filename>
|
724
756
|
* In a scrip add: require 'galaaz'
|
725
|
-
|
726
|
-
|
727
|
-
And now that you’ve read this far, here’s how to submit your story to the freeCodeCamp
|
728
|
-
publication: send an email to submit at freecodecamp org. Include the URL for your story on
|
729
|
-
Medium (preferably an unpublished draft) and the word “bananas” so that we’ll know that you
|
730
|
-
have read all this. Only send one story URL per email. There’s no need to add anything
|
731
|
-
further to your email — we just read the stories and judge them based on their own merits.
|