galaaz 0.4.9 → 0.4.10

Sign up to get free protection for your applications and to get access to all the features.
Files changed (76) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +798 -285
  3. data/blogs/galaaz_ggplot/galaaz_ggplot.Rmd +3 -12
  4. data/blogs/galaaz_ggplot/galaaz_ggplot.aux +5 -7
  5. data/blogs/galaaz_ggplot/galaaz_ggplot.html +69 -29
  6. data/blogs/galaaz_ggplot/galaaz_ggplot.pdf +0 -0
  7. data/blogs/galaaz_ggplot/galaaz_ggplot_files/figure-html/midwest_rb.png +0 -0
  8. data/blogs/galaaz_ggplot/galaaz_ggplot_files/figure-html/scatter_plot_rb.png +0 -0
  9. data/blogs/galaaz_ggplot/galaaz_ggplot_files/figure-latex/midwest_rb.pdf +0 -0
  10. data/blogs/galaaz_ggplot/galaaz_ggplot_files/figure-latex/scatter_plot_rb.pdf +0 -0
  11. data/blogs/galaaz_ggplot/midwest.Rmd +1 -9
  12. data/blogs/gknit/gknit.Rmd +37 -40
  13. data/blogs/gknit/gknit.html +32 -30
  14. data/blogs/gknit/gknit.md +36 -37
  15. data/blogs/gknit/gknit.pdf +0 -0
  16. data/blogs/gknit/gknit.tex +35 -37
  17. data/blogs/manual/manual.Rmd +548 -125
  18. data/blogs/manual/manual.html +509 -286
  19. data/blogs/manual/manual.md +798 -285
  20. data/blogs/manual/manual.pdf +0 -0
  21. data/blogs/manual/manual.tex +2816 -0
  22. data/blogs/manual/manual_files/figure-latex/diverging_bar.pdf +0 -0
  23. data/blogs/nse_dplyr/nse_dplyr.Rmd +240 -74
  24. data/blogs/nse_dplyr/nse_dplyr.html +191 -87
  25. data/blogs/nse_dplyr/nse_dplyr.md +361 -107
  26. data/blogs/nse_dplyr/nse_dplyr.pdf +0 -0
  27. data/blogs/nse_dplyr/nse_dplyr.tex +1373 -0
  28. data/blogs/ruby_plot/ruby_plot.Rmd +61 -81
  29. data/blogs/ruby_plot/ruby_plot.html +54 -57
  30. data/blogs/ruby_plot/ruby_plot.md +48 -67
  31. data/blogs/ruby_plot/ruby_plot.pdf +0 -0
  32. data/blogs/ruby_plot/ruby_plot_files/figure-html/dose_len.png +0 -0
  33. data/blogs/ruby_plot/ruby_plot_files/figure-html/facet_by_delivery.png +0 -0
  34. data/blogs/ruby_plot/ruby_plot_files/figure-html/facet_by_dose.png +0 -0
  35. data/blogs/ruby_plot/ruby_plot_files/figure-html/facets_by_delivery_color.png +0 -0
  36. data/blogs/ruby_plot/ruby_plot_files/figure-html/facets_by_delivery_color2.png +0 -0
  37. data/blogs/ruby_plot/ruby_plot_files/figure-html/facets_with_jitter.png +0 -0
  38. data/blogs/ruby_plot/ruby_plot_files/figure-html/facets_with_points.png +0 -0
  39. data/blogs/ruby_plot/ruby_plot_files/figure-html/final_box_plot.png +0 -0
  40. data/blogs/ruby_plot/ruby_plot_files/figure-html/final_violin_plot.png +0 -0
  41. data/blogs/ruby_plot/ruby_plot_files/figure-html/violin_with_jitter.png +0 -0
  42. data/blogs/ruby_plot/ruby_plot_files/figure-latex/dose_len.png +0 -0
  43. data/blogs/ruby_plot/ruby_plot_files/figure-latex/facet_by_delivery.png +0 -0
  44. data/blogs/ruby_plot/ruby_plot_files/figure-latex/facet_by_dose.png +0 -0
  45. data/blogs/ruby_plot/ruby_plot_files/figure-latex/facets_by_delivery_color.png +0 -0
  46. data/blogs/ruby_plot/ruby_plot_files/figure-latex/facets_by_delivery_color2.png +0 -0
  47. data/blogs/ruby_plot/ruby_plot_files/figure-latex/facets_with_decorations.png +0 -0
  48. data/blogs/ruby_plot/ruby_plot_files/figure-latex/facets_with_jitter.png +0 -0
  49. data/blogs/ruby_plot/ruby_plot_files/figure-latex/facets_with_points.png +0 -0
  50. data/blogs/ruby_plot/ruby_plot_files/figure-latex/final_box_plot.png +0 -0
  51. data/blogs/ruby_plot/ruby_plot_files/figure-latex/final_violin_plot.png +0 -0
  52. data/blogs/ruby_plot/ruby_plot_files/figure-latex/violin_with_jitter.png +0 -0
  53. data/lib/R_interface/rdata_frame.rb +0 -12
  54. data/lib/R_interface/robject.rb +14 -14
  55. data/lib/R_interface/ruby_extensions.rb +3 -31
  56. data/lib/R_interface/rvector.rb +0 -12
  57. data/lib/gknit/knitr_engine.rb +5 -3
  58. data/lib/util/exec_ruby.rb +22 -61
  59. data/specs/tmp.rb +26 -12
  60. data/version.rb +1 -1
  61. metadata +22 -17
  62. data/bin/gknit_old_r +0 -236
  63. data/blogs/dev/dev.Rmd +0 -23
  64. data/blogs/dev/dev.md +0 -58
  65. data/blogs/dev/dev2.Rmd +0 -65
  66. data/blogs/dev/model.rb +0 -41
  67. data/blogs/dplyr/dplyr.Rmd +0 -29
  68. data/blogs/dplyr/dplyr.html +0 -433
  69. data/blogs/dplyr/dplyr.md +0 -58
  70. data/blogs/dplyr/dplyr.rb +0 -63
  71. data/blogs/galaaz_ggplot/galaaz_ggplot.log +0 -640
  72. data/blogs/galaaz_ggplot/galaaz_ggplot.md +0 -431
  73. data/blogs/galaaz_ggplot/galaaz_ggplot.tex +0 -481
  74. data/blogs/galaaz_ggplot/midwest.png +0 -0
  75. data/blogs/galaaz_ggplot/scatter_plot.png +0 -0
  76. data/blogs/ruby_plot/ruby_plot.tex +0 -1077
@@ -139,8 +139,6 @@ cathegory. Some of the examples require 'rspec' do be available. To install 'r
139
139
  ```{r midwest_child, child = 'midwest.Rmd'}
140
140
  ```
141
141
 
142
- ![Midwest Plot](midwest.png){width=70%}
143
-
144
142
  In R, the code to generate this plot is the following
145
143
 
146
144
  ```{r midwest_r, eval=FALSE}
@@ -310,9 +308,7 @@ class ScatterPlot
310
308
  # Plots the scatterplot
311
309
  #---------------------------------------------------------------------------------
312
310
 
313
- def plot(device = 'awt')
314
- device == 'awt' ? R.awt : R.svg
315
-
311
+ def plot
316
312
  gg = @data.ggplot(E.aes(x: @x, y: @y)) +
317
313
  points +
318
314
  R.geom_smooth(method: @method, se: @confidence) +
@@ -325,9 +321,7 @@ class ScatterPlot
325
321
  caption: @caption) +
326
322
  CorpTheme.global_theme
327
323
 
328
- R.png('scatter_plot.png') if !(device == 'awt')
329
324
  puts gg
330
- R.dev__off
331
325
 
332
326
  end
333
327
 
@@ -337,7 +331,7 @@ end
337
331
 
338
332
  And this is the final code for making the scatter plot with the midwest data
339
333
 
340
- ```{ruby scatter_plot_rb}
334
+ ```{ruby scatter_plot_rb, fig.width = 9.1, fig.height = 9.1}
341
335
  require 'galaaz'
342
336
  require 'ggplot'
343
337
 
@@ -350,12 +344,9 @@ sp.y_label = "Population"
350
344
  sp.group_by(color: :state, size: :popdensity) # try sp.group_by(color: :state)
351
345
  # available methods: "lm", "glm", "loess", "gam"
352
346
  sp.add_smoothing_line(method: "glm")
353
- sp.plot('svg')
354
- # puts sp
347
+ sp.plot
355
348
  ```
356
349
 
357
- ![Midwest Plot with 'glm' function and modified theme](scatter_plot.png){width=70%}
358
-
359
350
  # Conclusion
360
351
 
361
352
  R is a very powerful language for statistical analysis, data analytics, machine learning, plotting
@@ -32,12 +32,10 @@
32
32
  \newlabel{running-other-demos}{{2.4}{3}{Running other demos}{subsection.2.4}{}}
33
33
  \@writefile{toc}{\contentsline {section}{\numberline {3}The demo code}{3}{section.3}}
34
34
  \newlabel{the-demo-code}{{3}{3}{The demo code}{section.3}{}}
35
- \@writefile{lof}{\contentsline {figure}{\numberline {1}{\ignorespaces Midwest Plot}}{4}{figure.1}}
36
35
  \@writefile{toc}{\contentsline {section}{\numberline {4}An extension to the example}{5}{section.4}}
37
36
  \newlabel{an-extension-to-the-example}{{4}{5}{An extension to the example}{section.4}{}}
38
- \@writefile{toc}{\contentsline {section}{\numberline {5}Conclusion}{8}{section.5}}
39
- \newlabel{conclusion}{{5}{8}{Conclusion}{section.5}{}}
40
- \@writefile{lof}{\contentsline {figure}{\numberline {2}{\ignorespaces Midwest Plot with `glm' function and modified theme}}{9}{figure.2}}
41
- \newlabel{LastPage}{{}{9}{}{page.9}{}}
42
- \xdef\lastpage@lastpage{9}
43
- \xdef\lastpage@lastpageHy{9}
37
+ \@writefile{toc}{\contentsline {section}{\numberline {5}Conclusion}{9}{section.5}}
38
+ \newlabel{conclusion}{{5}{9}{Conclusion}{section.5}{}}
39
+ \newlabel{LastPage}{{}{10}{}{page.10}{}}
40
+ \xdef\lastpage@lastpage{10}
41
+ \xdef\lastpage@lastpageHy{10}
@@ -283,6 +283,9 @@ img {
283
283
  button.code-folding-btn:focus {
284
284
  outline: none;
285
285
  }
286
+ summary {
287
+ display: list-item;
288
+ }
286
289
  </style>
287
290
 
288
291
 
@@ -290,10 +293,71 @@ button.code-folding-btn:focus {
290
293
  <div class="container-fluid main-container">
291
294
 
292
295
  <!-- tabsets -->
296
+
297
+ <style type="text/css">
298
+ .tabset-dropdown > .nav-tabs {
299
+ display: inline-table;
300
+ max-height: 500px;
301
+ min-height: 44px;
302
+ overflow-y: auto;
303
+ background: white;
304
+ border: 1px solid #ddd;
305
+ border-radius: 4px;
306
+ }
307
+
308
+ .tabset-dropdown > .nav-tabs > li.active:before {
309
+ content: "";
310
+ font-family: 'Glyphicons Halflings';
311
+ display: inline-block;
312
+ padding: 10px;
313
+ border-right: 1px solid #ddd;
314
+ }
315
+
316
+ .tabset-dropdown > .nav-tabs.nav-tabs-open > li.active:before {
317
+ content: "";
318
+ border: none;
319
+ }
320
+
321
+ .tabset-dropdown > .nav-tabs.nav-tabs-open:before {
322
+ content: "";
323
+ font-family: 'Glyphicons Halflings';
324
+ display: inline-block;
325
+ padding: 10px;
326
+ border-right: 1px solid #ddd;
327
+ }
328
+
329
+ .tabset-dropdown > .nav-tabs > li.active {
330
+ display: block;
331
+ }
332
+
333
+ .tabset-dropdown > .nav-tabs > li > a,
334
+ .tabset-dropdown > .nav-tabs > li > a:focus,
335
+ .tabset-dropdown > .nav-tabs > li > a:hover {
336
+ border: none;
337
+ display: inline-block;
338
+ border-radius: 4px;
339
+ }
340
+
341
+ .tabset-dropdown > .nav-tabs.nav-tabs-open > li {
342
+ display: block;
343
+ float: none;
344
+ }
345
+
346
+ .tabset-dropdown > .nav-tabs > li {
347
+ display: none;
348
+ }
349
+ </style>
350
+
293
351
  <script>
294
352
  $(document).ready(function () {
295
353
  window.buildTabsets("TOC");
296
354
  });
355
+
356
+ $(document).ready(function () {
357
+ $('.tabset-dropdown > .nav-tabs > li').click(function () {
358
+ $(this).parent().toggleClass('nav-tabs-open')
359
+ });
360
+ });
297
361
  </script>
298
362
 
299
363
  <!-- code folding -->
@@ -302,7 +366,6 @@ $(document).ready(function () {
302
366
 
303
367
 
304
368
 
305
-
306
369
  <div class="fluid-row" id="header">
307
370
 
308
371
 
@@ -417,10 +480,6 @@ R.options(scipen: 999) # turn-off scientific notation like 1e+48
417
480
  R.theme_set(R.theme_bw) # pre-set the bw theme.
418
481
 
419
482
  midwest = ~:midwest
420
- # midwest &lt;- read.csv(&quot;http://goo.gl/G1K41K&quot;) # bkup data source
421
-
422
- # R.awt # run the awt device if the plot should show on the screen
423
- R.svg # run the svg device if an image should be generated
424
483
 
425
484
  # Scatterplot
426
485
  gg = midwest.ggplot(E.aes(x: :area, y: :poptotal)) +
@@ -434,16 +493,8 @@ gg = midwest.ggplot(E.aes(x: :area, y: :poptotal)) +
434
493
  title: &quot;Scatterplot&quot;,
435
494
  caption: &quot;Source: midwest&quot;)
436
495
 
437
- R.png('midwest.png') # this line is not necessary with the awt device
438
- puts gg
439
-
440
- R.dev__off # R.dev__off turns off the device. If using awt, the plot
441
- # window will be closed</code></pre>
442
- <pre><code>## This is the fake output</code></pre>
443
- <div class="figure">
444
- <img src="" alt="Midwest Plot" style="width:70.0%" />
445
- <p class="caption">Midwest Plot</p>
446
- </div>
496
+ puts gg</code></pre>
497
+ <p><img src="" /><!-- --></p>
447
498
  <p>In R, the code to generate this plot is the following</p>
448
499
  <pre class="r"><code># install.packages(&quot;ggplot2&quot;)
449
500
  # load package and data
@@ -509,7 +560,6 @@ module CorpTheme
509
560
  end
510
561
 
511
562
  end</code></pre>
512
- <pre><code>## This is the fake output</code></pre>
513
563
  <p>We now define a ScatterPlot class:</p>
514
564
  <pre class="ruby"><code># ScatterPlot.rb
515
565
  # creates a scatter plot and allow some configuration
@@ -582,9 +632,7 @@ class ScatterPlot
582
632
  # Plots the scatterplot
583
633
  #---------------------------------------------------------------------------------
584
634
 
585
- def plot(device = 'awt')
586
- device == 'awt' ? R.awt : R.svg
587
-
635
+ def plot
588
636
  gg = @data.ggplot(E.aes(x: @x, y: @y)) +
589
637
  points +
590
638
  R.geom_smooth(method: @method, se: @confidence) +
@@ -597,14 +645,11 @@ class ScatterPlot
597
645
  caption: @caption) +
598
646
  CorpTheme.global_theme
599
647
 
600
- R.png('scatter_plot.png') if !(device == 'awt')
601
648
  puts gg
602
- R.dev__off
603
649
 
604
650
  end
605
651
 
606
652
  end</code></pre>
607
- <pre><code>## This is the fake output</code></pre>
608
653
  <p>And this is the final code for making the scatter plot with the midwest data</p>
609
654
  <pre class="ruby"><code>require 'galaaz'
610
655
  require 'ggplot'
@@ -618,13 +663,8 @@ sp.y_label = &quot;Population&quot;
618
663
  sp.group_by(color: :state, size: :popdensity) # try sp.group_by(color: :state)
619
664
  # available methods: &quot;lm&quot;, &quot;glm&quot;, &quot;loess&quot;, &quot;gam&quot;
620
665
  sp.add_smoothing_line(method: &quot;glm&quot;)
621
- # sp.plot('svg')
622
- puts sp</code></pre>
623
- <pre><code>## This is the fake output</code></pre>
624
- <div class="figure">
625
- <img src="" alt="Midwest Plot with ‘glm’ function and modified theme" style="width:70.0%" />
626
- <p class="caption">Midwest Plot with ‘glm’ function and modified theme</p>
627
- </div>
666
+ sp.plot</code></pre>
667
+ <p><img src="" /><!-- --></p>
628
668
  </div>
629
669
  <div id="conclusion" class="section level1">
630
670
  <h1>Conclusion</h1>
@@ -4,7 +4,7 @@ screen, bellow, we generate an 'svg' image and then include it in this document.
4
4
  generate and image, the R.svg device is used. To generate the plot on the screen, use the R.awt
5
5
  device, as commented on the code.
6
6
 
7
- ```{ruby midwest_rb, warning=FALSE}
7
+ ```{ruby midwest_rb, warning=FALSE, fig.width = 9.1, fig.height = 9.1}
8
8
  require 'galaaz'
9
9
  require 'ggplot'
10
10
 
@@ -13,10 +13,6 @@ R.options(scipen: 999) # turn-off scientific notation like 1e+48
13
13
  R.theme_set(R.theme_bw) # pre-set the bw theme.
14
14
 
15
15
  midwest = ~:midwest
16
- # midwest <- read.csv("http://goo.gl/G1K41K") # bkup data source
17
-
18
- # R.awt # run the awt device if the plot should show on the screen
19
- R.svg # run the svg device if an image should be generated
20
16
 
21
17
  # Scatterplot
22
18
  gg = midwest.ggplot(E.aes(x: :area, y: :poptotal)) +
@@ -30,10 +26,6 @@ gg = midwest.ggplot(E.aes(x: :area, y: :poptotal)) +
30
26
  title: "Scatterplot",
31
27
  caption: "Source: midwest")
32
28
 
33
- R.png('midwest.png') # this line is not necessary with the awt device
34
29
  puts gg
35
-
36
- R.dev__off # R.dev__off turns off the device. If using awt, the plot
37
- # window will be closed
38
30
  ```
39
31
 
@@ -7,13 +7,13 @@ tags: [Tech, Data Science, Ruby, R, GraalVM]
7
7
  date: "29/04/2019"
8
8
  bibliography: stats.bib
9
9
  output:
10
+ html_document:
11
+ self_contained: true
12
+ keep_md: true
10
13
  pdf_document:
11
14
  includes:
12
15
  in_header: ["../../sty/galaaz.sty"]
13
16
  number_sections: yes
14
- html_document:
15
- self_contained: true
16
- keep_md: true
17
17
  ---
18
18
 
19
19
  ```{r setup, echo=FALSE}
@@ -40,9 +40,8 @@ the same output and reports.
40
40
 
41
41
  The R community has put a great deal of effort in reproducible research. In 2002, Sweave was
42
42
  introduced and it allowed mixing R code with Latex generating high quality PDF documents. A
43
- Sweave
44
- document could include code, the results of executing the code, graphics and text such that it
45
- contained the whole narrative to reproduce the research. In
43
+ Sweave document could include code, the results of executing the code, graphics and text
44
+ such that it contained the whole narrative to reproduce the research. In
46
45
  2012, Knitr, developed by Yihui Xie from RStudio was released to replace Sweave and to
47
46
  consolidate in one single package the many extensions and add-on packages that
48
47
  were necessary for Sweave.
@@ -87,12 +86,12 @@ this problem, it is very rare to see any __R markdown__ document in the Ruby com
87
86
  When variables can be used accross chunks, then no overhead is needed:
88
87
 
89
88
  ```{ruby persistence}
90
- @lst = R.list(a: 1, b: 2, c: 3)
89
+ lst = R.list(a: 1, b: 2, c: 3)
91
90
  # any other code can be added here
92
91
  ```
93
92
 
94
93
  ```{ruby use_var}
95
- puts @lst
94
+ puts lst
96
95
  ```
97
96
 
98
97
  In the Python community, the same effort to have code and text in an integrated environment
@@ -335,12 +334,9 @@ In this example, the ruby chunk is called 'first_ruby_chunk'. One important
335
334
  aspect of chunk labels is that they cannot be duplicated. If a chunk label is
336
335
  duplicated, gKnit will stop with an error.
337
336
 
338
- Another important point with Ruby chunks is that they are evaluated in the scope
339
- of a class called RubyChunk. To make sure that variables are
340
- available between chunks, they should be made as instance variables of the
341
- RubyChunk class. In the following chunk, variable '\@a', '\@b' and '\@c'
342
- are standard Ruby variables and '\@vec' and '\@vec2' are two vectors created
343
- by calling the 'c' method on the R module.
337
+ In the following chunk, variable 'a', 'b' and 'c' are standard Ruby variables
338
+ and 'vec' and 'vec2' are two vectors created by calling the 'c' method on the
339
+ R module.
344
340
 
345
341
  In Galaaz, the R module allows us to access R functions transparently. The 'c'
346
342
  function in R, is a function that concatenates its arguments making a vector.
@@ -351,22 +347,22 @@ functions. gKnit will knit standard Ruby code, or even general text without
351
347
  any code.
352
348
 
353
349
  ```{ruby split_data}
354
- @a = [1, 2, 3]
355
- @b = "US$ 250.000"
356
- @c = "The 'outputs' function"
350
+ a = [1, 2, 3]
351
+ b = "US$ 250.000"
352
+ c = "The 'outputs' function"
357
353
 
358
- @vec = R.c(1, 2, 3)
359
- @vec2 = R.c(10, 20, 30)
354
+ vec = R.c(1, 2, 3)
355
+ vec2 = R.c(10, 20, 30)
360
356
  ```
361
357
 
362
- In this next block, variables '\@a', '\@vec' and '\@vec2' are used and printed.
358
+ In the next block, variables 'a', 'vec' and 'vec2' are used and printed.
363
359
 
364
360
  ```{ruby split2}
365
- puts @a
366
- puts @vec * @vec2
361
+ puts a
362
+ puts vec * vec2
367
363
  ```
368
364
 
369
- Note that \@a is a standard Ruby Array and \@vec and \@vec2 are vectors that behave accordingly,
365
+ Note that 'a' is a standard Ruby Array and 'vec' and 'vec2' are vectors that behave accordingly,
370
366
  where multiplication works as expected.
371
367
 
372
368
 
@@ -413,38 +409,38 @@ ten aspects are:
413
409
 
414
410
  ```{ruby diverging_plot_pre}
415
411
  # copy the R variable :mtcars to the Ruby mtcars variable
416
- @mtcars = ~:mtcars
412
+ mtcars = ~:mtcars
417
413
 
418
414
  # create a new column 'car_name' to store the car names so that it can be
419
415
  # used for plotting. The 'rownames' of the data frame cannot be used as
420
416
  # data for plotting
421
- @mtcars.car_name = R.rownames(:mtcars)
417
+ mtcars.car_name = R.rownames(:mtcars)
422
418
 
423
419
  # compute normalized mpg and add it to a new column called mpg_z
424
420
  # Note that the mean value for mpg can be obtained by calling the 'mean'
425
421
  # function on the vector 'mtcars.mpg'. The same with the standard
426
422
  # deviation 'sd'. The vector is then rounded to two digits with 'round 2'
427
- @mtcars.mpg_z = ((@mtcars.mpg - @mtcars.mpg.mean)/@mtcars.mpg.sd).round 2
423
+ mtcars.mpg_z = ((mtcars.mpg - mtcars.mpg.mean)/mtcars.mpg.sd).round 2
428
424
 
429
425
  # create a new column 'mpg_type'. Function 'ifelse' is a vectorized function
430
426
  # that looks at every element of the mpg_z vector and if the value is below
431
427
  # 0, returns 'below', otherwise returns 'above'
432
- @mtcars.mpg_type = (@mtcars.mpg_z < 0).ifelse("below", "above")
428
+ mtcars.mpg_type = (mtcars.mpg_z < 0).ifelse("below", "above")
433
429
 
434
430
  # order the mtcar data set by the mpg_z vector from smaler to larger values
435
- @mtcars = @mtcars[@mtcars.mpg_z.order, :all]
431
+ mtcars = mtcars[mtcars.mpg_z.order, :all]
436
432
 
437
433
  # convert the car_name column to a factor to retain sorted order in plot
438
- @mtcars.car_name = @mtcars.car_name.factor levels: @mtcars.car_name
434
+ mtcars.car_name = mtcars.car_name.factor levels: mtcars.car_name
439
435
 
440
436
  # let's look at the first records of the final data frame
441
- puts @mtcars.head
437
+ puts mtcars.head
442
438
  ```
443
439
 
444
440
  ```{ruby diverging_bar, fig.width = 9.1, fig.height = 6.5}
445
441
  require 'ggplot'
446
442
 
447
- puts @mtcars.ggplot(E.aes(x: :car_name, y: :mpg_z, label: :mpg_z)) +
443
+ puts mtcars.ggplot(E.aes(x: :car_name, y: :mpg_z, label: :mpg_z)) +
448
444
  R.geom_bar(E.aes(fill: :mpg_type), stat: 'identity', width: 0.5) +
449
445
  R.scale_fill_manual(name: 'Mileage',
450
446
  labels: R.c('Above Average', 'Below Average'),
@@ -463,8 +459,8 @@ with the 'rb' engine. The following chunk specification will
463
459
  create and inline Ruby text:
464
460
 
465
461
  ````
466
- This is some text with inline Ruby accessing variable \@b which has value:
467
- ```{rb puts "```{rb puts @b}\n```"}
462
+ This is some text with inline Ruby accessing variable 'b' which has value:
463
+ ```{rb puts "```{rb puts b}\n```"}
468
464
  ```
469
465
  and is followed by some other text!
470
466
  ````
@@ -472,8 +468,8 @@ and is followed by some other text!
472
468
  <div style="margin-bottom:30px;">
473
469
  </div>
474
470
 
475
- This is some text with inline Ruby accessing variable \@b which has value:
476
- ```{rb puts @b}
471
+ This is some text with inline Ruby accessing variable 'b' which has value:
472
+ ```{rb puts b}
477
473
  ```
478
474
  and is followed by some other text!
479
475
 
@@ -486,7 +482,7 @@ with inline Ruby code.
486
482
 
487
483
 
488
484
  ```{ruby heading, echo = FALSE}
489
- outputs "### #{@c}"
485
+ outputs "### #{c}"
490
486
  ```
491
487
 
492
488
  He have previously used the standard 'puts' method in Ruby chunks in order produce
@@ -500,15 +496,15 @@ For example, suppose we want to create a new heading in our document, but the he
500
496
  phrase is the result of some code processing: maybe it's the first line of a file we are
501
497
  going to read. Method 'outputs' adds its output as if typed in the __R markdown__ document.
502
498
 
503
- Take now a look at variable '\@c' (it was defined in a previous block above) as
504
- '\@c = "The 'outputs' function". "The 'outputs' function" is actually the name of this
499
+ Take now a look at variable 'c' (it was defined in a previous block above) as
500
+ 'c = "The 'outputs' function". "The 'outputs' function" is actually the name of this
505
501
  section and it was created using the 'outputs' function inside a Ruby chunk.
506
502
 
507
503
  The ruby chunk to generate this heading is:
508
504
 
509
505
  ````
510
506
  ```{ruby heading}`r ''`
511
- outputs "### #{@c}"
507
+ outputs "### #{c}"
512
508
  ```
513
509
  ````
514
510
 
@@ -666,13 +662,14 @@ author: "Rodrigo Botafogo"
666
662
  tags: [Galaaz, Ruby, R, TruffleRuby, FastR, GraalVM, knitr, gknit]
667
663
  date: "29 October 2018"
668
664
  output:
669
- pdf_document:
665
+ pdf\_document:
670
666
  includes:
671
667
  in\_header: ["../../sty/galaaz.sty"]
672
668
  number\_sections: yes
673
669
  ---
674
670
  ```
675
671
 
672
+
676
673
  # Conclusion
677
674
 
678
675
  In order to do reproducible research, one of the main basic tools needed is a systhem that