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
@@ -373,7 +373,7 @@ $(document).ready(function () {
373
373
  <h1 class="title toc-ignore">How to do reproducible research in Ruby with gKnit</h1>
374
374
  <h4 class="author"><em>Rodrigo Botafogo</em></h4>
375
375
  <h4 class="author"><em>Daniel Mossé - University of Pittsburgh</em></h4>
376
- <h4 class="date"><em>20/02/2019</em></h4>
376
+ <h4 class="date"><em>29/04/2019</em></h4>
377
377
 
378
378
  </div>
379
379
 
@@ -401,9 +401,9 @@ puts lst</code></pre>
401
401
  ## [1] 3</code></pre>
402
402
  <p>Now, any single code has dozens of variables that we might want to use and reuse between chunks. Clearly, such an approach becomes quickly unmanageable. Probably, because of this problem, it is very rare to see any <strong>R markdown</strong> document in the Ruby community.</p>
403
403
  <p>When variables can be used accross chunks, then no overhead is needed:</p>
404
- <pre class="ruby"><code>@lst = R.list(a: 1, b: 2, c: 3)
404
+ <pre class="ruby"><code>lst = R.list(a: 1, b: 2, c: 3)
405
405
  # any other code can be added here</code></pre>
406
- <pre class="ruby"><code>puts @lst</code></pre>
406
+ <pre class="ruby"><code>puts lst</code></pre>
407
407
  <pre><code>## $a
408
408
  ## [1] 1
409
409
  ##
@@ -544,7 +544,7 @@ g &lt;- ggplot(mpg_select, aes(displ, cty)) +
544
544
 
545
545
  g + geom_jitter(aes(col=manufacturer, size=hwy)) +
546
546
  geom_smooth(aes(col=manufacturer), method=&quot;lm&quot;, se=F)</code></pre>
547
- <p><img src="" /><!-- --></p>
547
+ <p><img src="" /><!-- --></p>
548
548
  </div>
549
549
  <div id="ruby-chunks" class="section level3">
550
550
  <h3>Ruby chunks</h3>
@@ -552,21 +552,23 @@ g + geom_jitter(aes(col=manufacturer, size=hwy)) +
552
552
  <pre><code>```{ruby first_ruby_chunk}
553
553
  ```</code></pre>
554
554
  <p>In this example, the ruby chunk is called ‘first_ruby_chunk’. One important aspect of chunk labels is that they cannot be duplicated. If a chunk label is duplicated, gKnit will stop with an error.</p>
555
- <p>Another important point with Ruby chunks is that they are evaluated in the scope of a class called RubyChunk. To make sure that variables are available between chunks, they should be made as instance variables of the RubyChunk class. In the following chunk, variable ‘@a’, ‘@b’ and ‘@c’ are standard Ruby variables and ‘@vec’ and ‘@vec2’ are two vectors created by calling the ‘c’ method on the R module.</p>
555
+ <p>In the following chunk, variable a’, b’ and c’ are standard Ruby variables and vec’ and vec2’ are two vectors created by calling the ‘c’ method on the R module.</p>
556
556
  <p>In Galaaz, the R module allows us to access R functions transparently. The ‘c’ function in R, is a function that concatenates its arguments making a vector.</p>
557
557
  <p>It should be clear that there is no requirement in gknit to call or use any R functions. gKnit will knit standard Ruby code, or even general text without any code.</p>
558
- <pre class="ruby"><code>@a = [1, 2, 3]
559
- @b = &quot;US$ 250.000&quot;
560
- @c = &quot;The 'outputs' function&quot;
561
-
562
- @vec = R.c(1, 2, 3)
563
- @vec2 = R.c(10, 20, 30)</code></pre>
564
- <p>In this next block, variables ‘@a’, ‘@vec’ and ‘@vec2’ are used and printed.</p>
565
- <pre class="ruby"><code>puts @a
566
- puts @vec * @vec2</code></pre>
567
- <pre><code>## [1, 2, 3]
558
+ <pre class="ruby"><code>a = [1, 2, 3]
559
+ b = &quot;US$ 250.000&quot;
560
+ c = &quot;The 'outputs' function&quot;
561
+
562
+ vec = R.c(1, 2, 3)
563
+ vec2 = R.c(10, 20, 30)</code></pre>
564
+ <p>In the next block, variables a’, vec’ and vec2’ are used and printed.</p>
565
+ <pre class="ruby"><code>puts a
566
+ puts vec * vec2</code></pre>
567
+ <pre><code>## 1
568
+ ## 2
569
+ ## 3
568
570
  ## [1] 10 40 90</code></pre>
569
- <p>Note that @a is a standard Ruby Array and @vec and @vec2 are vectors that behave accordingly, where multiplication works as expected.</p>
571
+ <p>Note that a is a standard Ruby Array and vec and vec2 are vectors that behave accordingly, where multiplication works as expected.</p>
570
572
  </div>
571
573
  <div id="accessing-r-from-ruby" class="section level3">
572
574
  <h3>Accessing R from Ruby</h3>
@@ -594,32 +596,32 @@ puts @vec * @vec2</code></pre>
594
596
  <li>carb: Number of carburetors</li>
595
597
  </ul>
596
598
  <pre class="ruby"><code># copy the R variable :mtcars to the Ruby mtcars variable
597
- @mtcars = ~:mtcars
599
+ mtcars = ~:mtcars
598
600
 
599
601
  # create a new column 'car_name' to store the car names so that it can be
600
602
  # used for plotting. The 'rownames' of the data frame cannot be used as
601
603
  # data for plotting
602
- @mtcars.car_name = R.rownames(:mtcars)
604
+ mtcars.car_name = R.rownames(:mtcars)
603
605
 
604
606
  # compute normalized mpg and add it to a new column called mpg_z
605
607
  # Note that the mean value for mpg can be obtained by calling the 'mean'
606
608
  # function on the vector 'mtcars.mpg'. The same with the standard
607
609
  # deviation 'sd'. The vector is then rounded to two digits with 'round 2'
608
- @mtcars.mpg_z = ((@mtcars.mpg - @mtcars.mpg.mean)/@mtcars.mpg.sd).round 2
610
+ mtcars.mpg_z = ((mtcars.mpg - mtcars.mpg.mean)/mtcars.mpg.sd).round 2
609
611
 
610
612
  # create a new column 'mpg_type'. Function 'ifelse' is a vectorized function
611
613
  # that looks at every element of the mpg_z vector and if the value is below
612
614
  # 0, returns 'below', otherwise returns 'above'
613
- @mtcars.mpg_type = (@mtcars.mpg_z &lt; 0).ifelse(&quot;below&quot;, &quot;above&quot;)
615
+ mtcars.mpg_type = (mtcars.mpg_z &lt; 0).ifelse(&quot;below&quot;, &quot;above&quot;)
614
616
 
615
617
  # order the mtcar data set by the mpg_z vector from smaler to larger values
616
- @mtcars = @mtcars[@mtcars.mpg_z.order, :all]
618
+ mtcars = mtcars[mtcars.mpg_z.order, :all]
617
619
 
618
620
  # convert the car_name column to a factor to retain sorted order in plot
619
- @mtcars.car_name = @mtcars.car_name.factor levels: @mtcars.car_name
621
+ mtcars.car_name = mtcars.car_name.factor levels: mtcars.car_name
620
622
 
621
623
  # let's look at the first records of the final data frame
622
- puts @mtcars.head</code></pre>
624
+ puts mtcars.head</code></pre>
623
625
  <pre><code>## mpg cyl disp hp drat wt qsec vs am gear carb
624
626
  ## Cadillac Fleetwood 10.4 8 472 205 2.93 5.250 17.98 0 0 3 4
625
627
  ## Lincoln Continental 10.4 8 460 215 3.00 5.424 17.82 0 0 3 4
@@ -636,7 +638,7 @@ puts @mtcars.head</code></pre>
636
638
  ## Maserati Bora Maserati Bora -0.84 below</code></pre>
637
639
  <pre class="ruby"><code>require 'ggplot'
638
640
 
639
- puts @mtcars.ggplot(E.aes(x: :car_name, y: :mpg_z, label: :mpg_z)) +
641
+ puts mtcars.ggplot(E.aes(x: :car_name, y: :mpg_z, label: :mpg_z)) +
640
642
  R.geom_bar(E.aes(fill: :mpg_type), stat: 'identity', width: 0.5) +
641
643
  R.scale_fill_manual(name: 'Mileage',
642
644
  labels: R.c('Above Average', 'Below Average'),
@@ -649,14 +651,14 @@ puts @mtcars.ggplot(E.aes(x: :car_name, y: :mpg_z, label: :mpg_z)) +
649
651
  <div id="inline-ruby-code" class="section level3">
650
652
  <h3>Inline Ruby code</h3>
651
653
  <p>When using a Ruby chunk, the code and the output are formatted in blocks as seen above. This formatting is not always desired. Sometimes, we want to have the results of the Ruby evaluation included in the middle of a phrase. gKnit allows adding inline Ruby code with the ‘rb’ engine. The following chunk specification will create and inline Ruby text:</p>
652
- <pre><code>This is some text with inline Ruby accessing variable \@b which has value:
653
- ```{rb puts @b}
654
+ <pre><code>This is some text with inline Ruby accessing variable 'b' which has value:
655
+ ```{rb puts b}
654
656
  ```
655
657
  and is followed by some other text!</code></pre>
656
658
  <div style="margin-bottom:30px;">
657
659
 
658
660
  </div>
659
- <p>This is some text with inline Ruby accessing variable @b which has value: US$ 250.000 and is followed by some other text!</p>
661
+ <p>This is some text with inline Ruby accessing variable b which has value: US$ 250.000 and is followed by some other text!</p>
660
662
  <div style="margin-bottom:30px;">
661
663
 
662
664
  </div>
@@ -666,10 +668,10 @@ and is followed by some other text!</code></pre>
666
668
  <h3>The ‘outputs’ function</h3>
667
669
  <p>He have previously used the standard ‘puts’ method in Ruby chunks in order produce output. The result of a ‘puts’, as seen in all previous chunks that use it, is formatted inside a white box that follows the code block. Many times however, we would like to do some processing in the Ruby chunk and have the result of this processing generate and output that is “included” in the document as if we had typed it in <strong>R markdown</strong> document.</p>
668
670
  <p>For example, suppose we want to create a new heading in our document, but the heading phrase is the result of some code processing: maybe it’s the first line of a file we are going to read. Method ‘outputs’ adds its output as if typed in the <strong>R markdown</strong> document.</p>
669
- <p>Take now a look at variable ‘@c’ (it was defined in a previous block above) as ‘@c = “The ‘outputs’ function”. “The ‘outputs’ function” is actually the name of this section and it was created using the ’outputs’ function inside a Ruby chunk.</p>
671
+ <p>Take now a look at variable c’ (it was defined in a previous block above) as c = “The ‘outputs’ function”. “The ‘outputs’ function” is actually the name of this section and it was created using the ’outputs’ function inside a Ruby chunk.</p>
670
672
  <p>The ruby chunk to generate this heading is:</p>
671
673
  <pre><code>```{ruby heading}
672
- outputs &quot;### #{@c}&quot;
674
+ outputs &quot;### #{c}&quot;
673
675
  ```</code></pre>
674
676
  <p>The three ‘###’ is the way we add a Heading 3 in <strong>R markdown</strong>.</p>
675
677
  </div>
@@ -2177,7 +2179,7 @@ author: &quot;Rodrigo Botafogo&quot;
2177
2179
  tags: [Galaaz, Ruby, R, TruffleRuby, FastR, GraalVM, knitr, gknit]
2178
2180
  date: &quot;29 October 2018&quot;
2179
2181
  output:
2180
- pdf_document:
2182
+ pdf\_document:
2181
2183
  includes:
2182
2184
  in\_header: [&quot;../../sty/galaaz.sty&quot;]
2183
2185
  number\_sections: yes
@@ -4,7 +4,7 @@ author:
4
4
  - "Rodrigo Botafogo"
5
5
  - "Daniel Mossé - University of Pittsburgh"
6
6
  tags: [Tech, Data Science, Ruby, R, GraalVM]
7
- date: "20/02/2019"
7
+ date: "29/04/2019"
8
8
  bibliography: stats.bib
9
9
  output:
10
10
  html_document:
@@ -38,9 +38,8 @@ the same output and reports.
38
38
 
39
39
  The R community has put a great deal of effort in reproducible research. In 2002, Sweave was
40
40
  introduced and it allowed mixing R code with Latex generating high quality PDF documents. A
41
- Sweave
42
- document could include code, the results of executing the code, graphics and text such that it
43
- contained the whole narrative to reproduce the research. In
41
+ Sweave document could include code, the results of executing the code, graphics and text
42
+ such that it contained the whole narrative to reproduce the research. In
44
43
  2012, Knitr, developed by Yihui Xie from RStudio was released to replace Sweave and to
45
44
  consolidate in one single package the many extensions and add-on packages that
46
45
  were necessary for Sweave.
@@ -99,13 +98,13 @@ When variables can be used accross chunks, then no overhead is needed:
99
98
 
100
99
 
101
100
  ```ruby
102
- @lst = R.list(a: 1, b: 2, c: 3)
101
+ lst = R.list(a: 1, b: 2, c: 3)
103
102
  # any other code can be added here
104
103
  ```
105
104
 
106
105
 
107
106
  ```ruby
108
- puts @lst
107
+ puts lst
109
108
  ```
110
109
 
111
110
  ```
@@ -379,12 +378,9 @@ In this example, the ruby chunk is called 'first_ruby_chunk'. One important
379
378
  aspect of chunk labels is that they cannot be duplicated. If a chunk label is
380
379
  duplicated, gKnit will stop with an error.
381
380
 
382
- Another important point with Ruby chunks is that they are evaluated in the scope
383
- of a class called RubyChunk. To make sure that variables are
384
- available between chunks, they should be made as instance variables of the
385
- RubyChunk class. In the following chunk, variable '\@a', '\@b' and '\@c'
386
- are standard Ruby variables and '\@vec' and '\@vec2' are two vectors created
387
- by calling the 'c' method on the R module.
381
+ In the following chunk, variable 'a', 'b' and 'c' are standard Ruby variables
382
+ and 'vec' and 'vec2' are two vectors created by calling the 'c' method on the
383
+ R module.
388
384
 
389
385
  In Galaaz, the R module allows us to access R functions transparently. The 'c'
390
386
  function in R, is a function that concatenates its arguments making a vector.
@@ -396,28 +392,30 @@ any code.
396
392
 
397
393
 
398
394
  ```ruby
399
- @a = [1, 2, 3]
400
- @b = "US$ 250.000"
401
- @c = "The 'outputs' function"
395
+ a = [1, 2, 3]
396
+ b = "US$ 250.000"
397
+ c = "The 'outputs' function"
402
398
 
403
- @vec = R.c(1, 2, 3)
404
- @vec2 = R.c(10, 20, 30)
399
+ vec = R.c(1, 2, 3)
400
+ vec2 = R.c(10, 20, 30)
405
401
  ```
406
402
 
407
- In this next block, variables '\@a', '\@vec' and '\@vec2' are used and printed.
403
+ In the next block, variables 'a', 'vec' and 'vec2' are used and printed.
408
404
 
409
405
 
410
406
  ```ruby
411
- puts @a
412
- puts @vec * @vec2
407
+ puts a
408
+ puts vec * vec2
413
409
  ```
414
410
 
415
411
  ```
416
- ## [1, 2, 3]
412
+ ## 1
413
+ ## 2
414
+ ## 3
417
415
  ## [1] 10 40 90
418
416
  ```
419
417
 
420
- Note that \@a is a standard Ruby Array and \@vec and \@vec2 are vectors that behave accordingly,
418
+ Note that 'a' is a standard Ruby Array and 'vec' and 'vec2' are vectors that behave accordingly,
421
419
  where multiplication works as expected.
422
420
 
423
421
 
@@ -475,32 +473,32 @@ ten aspects are:
475
473
 
476
474
  ```ruby
477
475
  # copy the R variable :mtcars to the Ruby mtcars variable
478
- @mtcars = ~:mtcars
476
+ mtcars = ~:mtcars
479
477
 
480
478
  # create a new column 'car_name' to store the car names so that it can be
481
479
  # used for plotting. The 'rownames' of the data frame cannot be used as
482
480
  # data for plotting
483
- @mtcars.car_name = R.rownames(:mtcars)
481
+ mtcars.car_name = R.rownames(:mtcars)
484
482
 
485
483
  # compute normalized mpg and add it to a new column called mpg_z
486
484
  # Note that the mean value for mpg can be obtained by calling the 'mean'
487
485
  # function on the vector 'mtcars.mpg'. The same with the standard
488
486
  # deviation 'sd'. The vector is then rounded to two digits with 'round 2'
489
- @mtcars.mpg_z = ((@mtcars.mpg - @mtcars.mpg.mean)/@mtcars.mpg.sd).round 2
487
+ mtcars.mpg_z = ((mtcars.mpg - mtcars.mpg.mean)/mtcars.mpg.sd).round 2
490
488
 
491
489
  # create a new column 'mpg_type'. Function 'ifelse' is a vectorized function
492
490
  # that looks at every element of the mpg_z vector and if the value is below
493
491
  # 0, returns 'below', otherwise returns 'above'
494
- @mtcars.mpg_type = (@mtcars.mpg_z < 0).ifelse("below", "above")
492
+ mtcars.mpg_type = (mtcars.mpg_z < 0).ifelse("below", "above")
495
493
 
496
494
  # order the mtcar data set by the mpg_z vector from smaler to larger values
497
- @mtcars = @mtcars[@mtcars.mpg_z.order, :all]
495
+ mtcars = mtcars[mtcars.mpg_z.order, :all]
498
496
 
499
497
  # convert the car_name column to a factor to retain sorted order in plot
500
- @mtcars.car_name = @mtcars.car_name.factor levels: @mtcars.car_name
498
+ mtcars.car_name = mtcars.car_name.factor levels: mtcars.car_name
501
499
 
502
500
  # let's look at the first records of the final data frame
503
- puts @mtcars.head
501
+ puts mtcars.head
504
502
  ```
505
503
 
506
504
  ```
@@ -524,7 +522,7 @@ puts @mtcars.head
524
522
  ```ruby
525
523
  require 'ggplot'
526
524
 
527
- puts @mtcars.ggplot(E.aes(x: :car_name, y: :mpg_z, label: :mpg_z)) +
525
+ puts mtcars.ggplot(E.aes(x: :car_name, y: :mpg_z, label: :mpg_z)) +
528
526
  R.geom_bar(E.aes(fill: :mpg_type), stat: 'identity', width: 0.5) +
529
527
  R.scale_fill_manual(name: 'Mileage',
530
528
  labels: R.c('Above Average', 'Below Average'),
@@ -546,8 +544,8 @@ with the 'rb' engine. The following chunk specification will
546
544
  create and inline Ruby text:
547
545
 
548
546
  ````
549
- This is some text with inline Ruby accessing variable \@b which has value:
550
- ```{rb puts @b}
547
+ This is some text with inline Ruby accessing variable 'b' which has value:
548
+ ```{rb puts b}
551
549
  ```
552
550
  and is followed by some other text!
553
551
  ````
@@ -555,7 +553,7 @@ and is followed by some other text!
555
553
  <div style="margin-bottom:30px;">
556
554
  </div>
557
555
 
558
- This is some text with inline Ruby accessing variable \@b which has value:
556
+ This is some text with inline Ruby accessing variable 'b' which has value:
559
557
  US$ 250.000
560
558
  and is followed by some other text!
561
559
 
@@ -580,15 +578,15 @@ For example, suppose we want to create a new heading in our document, but the he
580
578
  phrase is the result of some code processing: maybe it's the first line of a file we are
581
579
  going to read. Method 'outputs' adds its output as if typed in the __R markdown__ document.
582
580
 
583
- Take now a look at variable '\@c' (it was defined in a previous block above) as
584
- '\@c = "The 'outputs' function". "The 'outputs' function" is actually the name of this
581
+ Take now a look at variable 'c' (it was defined in a previous block above) as
582
+ 'c = "The 'outputs' function". "The 'outputs' function" is actually the name of this
585
583
  section and it was created using the 'outputs' function inside a Ruby chunk.
586
584
 
587
585
  The ruby chunk to generate this heading is:
588
586
 
589
587
  ````
590
588
  ```{ruby heading}
591
- outputs "### #{@c}"
589
+ outputs "### #{c}"
592
590
  ```
593
591
  ````
594
592
 
@@ -1364,13 +1362,14 @@ author: "Rodrigo Botafogo"
1364
1362
  tags: [Galaaz, Ruby, R, TruffleRuby, FastR, GraalVM, knitr, gknit]
1365
1363
  date: "29 October 2018"
1366
1364
  output:
1367
- pdf_document:
1365
+ pdf\_document:
1368
1366
  includes:
1369
1367
  in\_header: ["../../sty/galaaz.sty"]
1370
1368
  number\_sections: yes
1371
1369
  ---
1372
1370
  ```
1373
1371
 
1372
+
1374
1373
  # Conclusion
1375
1374
 
1376
1375
  In order to do reproducible research, one of the main basic tools needed is a systhem that
Binary file
@@ -122,7 +122,7 @@
122
122
  \postauthor{\par}
123
123
  \predate{\centering\large\emph}
124
124
  \postdate{\par}
125
- \date{20/02/2019}
125
+ \date{29/04/2019}
126
126
 
127
127
  % usar portugues do Brasil
128
128
  % \usepackage[brazilian]{babel}
@@ -304,14 +304,14 @@ When variables can be used accross chunks, then no overhead is needed:
304
304
 
305
305
  \begin{Shaded}
306
306
  \begin{Highlighting}[]
307
- \OtherTok{@lst}\NormalTok{ = R.list(}\StringTok{a: }\DecValTok{1}\NormalTok{, }\StringTok{b: }\DecValTok{2}\NormalTok{, }\StringTok{c: }\DecValTok{3}\NormalTok{)}
307
+ \NormalTok{lst = R.list(}\StringTok{a: }\DecValTok{1}\NormalTok{, }\StringTok{b: }\DecValTok{2}\NormalTok{, }\StringTok{c: }\DecValTok{3}\NormalTok{)}
308
308
  \CommentTok{# any other code can be added here}
309
309
  \end{Highlighting}
310
310
  \end{Shaded}
311
311
 
312
312
  \begin{Shaded}
313
313
  \begin{Highlighting}[]
314
- \NormalTok{puts }\OtherTok{@lst}
314
+ \NormalTok{puts lst}
315
315
  \end{Highlighting}
316
316
  \end{Shaded}
317
317
 
@@ -630,12 +630,9 @@ In this example, the ruby chunk is called `first\_ruby\_chunk'. One
630
630
  important aspect of chunk labels is that they cannot be duplicated. If a
631
631
  chunk label is duplicated, gKnit will stop with an error.
632
632
 
633
- Another important point with Ruby chunks is that they are evaluated in
634
- the scope of a class called RubyChunk. To make sure that variables are
635
- available between chunks, they should be made as instance variables of
636
- the RubyChunk class. In the following chunk, variable `@a', `@b' and
637
- `@c' are standard Ruby variables and `@vec' and `@vec2' are two vectors
638
- created by calling the `c' method on the R module.
633
+ In the following chunk, variable `a', `b' and `c' are standard Ruby
634
+ variables and `vec' and `vec2' are two vectors created by calling the
635
+ `c' method on the R module.
639
636
 
640
637
  In Galaaz, the R module allows us to access R functions transparently.
641
638
  The `c' function in R, is a function that concatenates its arguments
@@ -647,31 +644,32 @@ text without any code.
647
644
 
648
645
  \begin{Shaded}
649
646
  \begin{Highlighting}[]
650
- \OtherTok{@a}\NormalTok{ = [}\DecValTok{1}\NormalTok{, }\DecValTok{2}\NormalTok{, }\DecValTok{3}\NormalTok{]}
651
- \OtherTok{@b}\NormalTok{ = }\StringTok{"US$ 250.000"}
652
- \OtherTok{@c}\NormalTok{ = }\StringTok{"The 'outputs' function"}
647
+ \NormalTok{a = [}\DecValTok{1}\NormalTok{, }\DecValTok{2}\NormalTok{, }\DecValTok{3}\NormalTok{]}
648
+ \NormalTok{b = }\StringTok{"US$ 250.000"}
649
+ \NormalTok{c = }\StringTok{"The 'outputs' function"}
653
650
 
654
- \OtherTok{@vec}\NormalTok{ = R.c(}\DecValTok{1}\NormalTok{, }\DecValTok{2}\NormalTok{, }\DecValTok{3}\NormalTok{)}
655
- \OtherTok{@vec2}\NormalTok{ = R.c(}\DecValTok{10}\NormalTok{, }\DecValTok{20}\NormalTok{, }\DecValTok{30}\NormalTok{)}
651
+ \NormalTok{vec = R.c(}\DecValTok{1}\NormalTok{, }\DecValTok{2}\NormalTok{, }\DecValTok{3}\NormalTok{)}
652
+ \NormalTok{vec2 = R.c(}\DecValTok{10}\NormalTok{, }\DecValTok{20}\NormalTok{, }\DecValTok{30}\NormalTok{)}
656
653
  \end{Highlighting}
657
654
  \end{Shaded}
658
655
 
659
- In this next block, variables `@a', `@vec' and `@vec2' are used and
660
- printed.
656
+ In the next block, variables `a', `vec' and `vec2' are used and printed.
661
657
 
662
658
  \begin{Shaded}
663
659
  \begin{Highlighting}[]
664
- \NormalTok{puts }\OtherTok{@a}
665
- \NormalTok{puts }\OtherTok{@vec}\NormalTok{ * }\OtherTok{@vec2}
660
+ \NormalTok{puts a}
661
+ \NormalTok{puts vec * vec2}
666
662
  \end{Highlighting}
667
663
  \end{Shaded}
668
664
 
669
665
  \begin{verbatim}
670
- ## [1, 2, 3]
666
+ ## 1
667
+ ## 2
668
+ ## 3
671
669
  ## [1] 10 40 90
672
670
  \end{verbatim}
673
671
 
674
- Note that @a is a standard Ruby Array and @vec and @vec2 are vectors
672
+ Note that `a' is a standard Ruby Array and `vec' and `vec2' are vectors
675
673
  that behave accordingly, where multiplication works as expected.
676
674
 
677
675
  \hypertarget{accessing-r-from-ruby}{%
@@ -747,32 +745,32 @@ performance for 32 automobiles (1973--74 models). The ten aspects are:
747
745
  \begin{Shaded}
748
746
  \begin{Highlighting}[]
749
747
  \CommentTok{# copy the R variable :mtcars to the Ruby mtcars variable}
750
- \OtherTok{@mtcars}\NormalTok{ = ~}\StringTok{:mtcars}
748
+ \NormalTok{mtcars = ~}\StringTok{:mtcars}
751
749
 
752
750
  \CommentTok{# create a new column 'car_name' to store the car names so that it can be}
753
751
  \CommentTok{# used for plotting. The 'rownames' of the data frame cannot be used as}
754
752
  \CommentTok{# data for plotting}
755
- \OtherTok{@mtcars}\NormalTok{.car_name = R.rownames(}\StringTok{:mtcars}\NormalTok{)}
753
+ \NormalTok{mtcars.car_name = R.rownames(}\StringTok{:mtcars}\NormalTok{)}
756
754
 
757
755
  \CommentTok{# compute normalized mpg and add it to a new column called mpg_z}
758
756
  \CommentTok{# Note that the mean value for mpg can be obtained by calling the 'mean'}
759
757
  \CommentTok{# function on the vector 'mtcars.mpg'. The same with the standard}
760
758
  \CommentTok{# deviation 'sd'. The vector is then rounded to two digits with 'round 2'}
761
- \OtherTok{@mtcars}\NormalTok{.mpg_z = ((}\OtherTok{@mtcars}\NormalTok{.mpg - }\OtherTok{@mtcars}\NormalTok{.mpg.mean)/}\OtherTok{@mtcars}\NormalTok{.mpg.sd).round }\DecValTok{2}
759
+ \NormalTok{mtcars.mpg_z = ((mtcars.mpg - mtcars.mpg.mean)/mtcars.mpg.sd).round }\DecValTok{2}
762
760
 
763
761
  \CommentTok{# create a new column 'mpg_type'. Function 'ifelse' is a vectorized function}
764
762
  \CommentTok{# that looks at every element of the mpg_z vector and if the value is below}
765
763
  \CommentTok{# 0, returns 'below', otherwise returns 'above'}
766
- \OtherTok{@mtcars}\NormalTok{.mpg_type = (}\OtherTok{@mtcars}\NormalTok{.mpg_z < }\DecValTok{0}\NormalTok{).ifelse(}\StringTok{"below"}\NormalTok{, }\StringTok{"above"}\NormalTok{)}
764
+ \NormalTok{mtcars.mpg_type = (mtcars.mpg_z < }\DecValTok{0}\NormalTok{).ifelse(}\StringTok{"below"}\NormalTok{, }\StringTok{"above"}\NormalTok{)}
767
765
 
768
766
  \CommentTok{# order the mtcar data set by the mpg_z vector from smaler to larger values}
769
- \OtherTok{@mtcars}\NormalTok{ = }\OtherTok{@mtcars}\NormalTok{[}\OtherTok{@mtcars}\NormalTok{.mpg_z.order, }\StringTok{:all}\NormalTok{]}
767
+ \NormalTok{mtcars = mtcars[mtcars.mpg_z.order, }\StringTok{:all}\NormalTok{]}
770
768
 
771
769
  \CommentTok{# convert the car_name column to a factor to retain sorted order in plot}
772
- \OtherTok{@mtcars}\NormalTok{.car_name = }\OtherTok{@mtcars}\NormalTok{.car_name.factor }\StringTok{levels: }\OtherTok{@mtcars}\NormalTok{.car_name}
770
+ \NormalTok{mtcars.car_name = mtcars.car_name.factor }\StringTok{levels: }\NormalTok{mtcars.car_name}
773
771
 
774
772
  \CommentTok{# let's look at the first records of the final data frame}
775
- \NormalTok{puts }\OtherTok{@mtcars}\NormalTok{.head}
773
+ \NormalTok{puts mtcars.head}
776
774
  \end{Highlighting}
777
775
  \end{Shaded}
778
776
 
@@ -797,7 +795,7 @@ performance for 32 automobiles (1973--74 models). The ten aspects are:
797
795
  \begin{Highlighting}[]
798
796
  \NormalTok{require }\StringTok{'ggplot'}
799
797
 
800
- \NormalTok{puts }\OtherTok{@mtcars}\NormalTok{.ggplot(E.aes(}\StringTok{x: :car_name}\NormalTok{, }\StringTok{y: :mpg_z}\NormalTok{, }\StringTok{label: :mpg_z}\NormalTok{)) +}
798
+ \NormalTok{puts mtcars.ggplot(E.aes(}\StringTok{x: :car_name}\NormalTok{, }\StringTok{y: :mpg_z}\NormalTok{, }\StringTok{label: :mpg_z}\NormalTok{)) +}
801
799
  \NormalTok{ R.geom_bar(E.aes(}\StringTok{fill: :mpg_type}\NormalTok{), }\StringTok{stat: 'identity'}\NormalTok{, }\StringTok{width: }\FloatTok{0.5}\NormalTok{) +}
802
800
  \NormalTok{ R.scale_fill_manual(}\StringTok{name: 'Mileage'}\NormalTok{,}
803
801
  \StringTok{labels: }\NormalTok{R.c(}\StringTok{'Above Average'}\NormalTok{, }\StringTok{'Below Average'}\NormalTok{),}
@@ -820,13 +818,13 @@ phrase. gKnit allows adding inline Ruby code with the `rb' engine. The
820
818
  following chunk specification will create and inline Ruby text:
821
819
 
822
820
  \begin{verbatim}
823
- This is some text with inline Ruby accessing variable \@b which has value:
824
- ```{rb puts @b}
821
+ This is some text with inline Ruby accessing variable 'b' which has value:
822
+ ```{rb puts b}
825
823
  ```
826
824
  and is followed by some other text!
827
825
  \end{verbatim}
828
826
 
829
- This is some text with inline Ruby accessing variable @b which has
827
+ This is some text with inline Ruby accessing variable `b' which has
830
828
  value: US\$ 250.000 and is followed by some other text!
831
829
 
832
830
  Note that it is important not to add any new line before of after the
@@ -849,16 +847,16 @@ but the heading phrase is the result of some code processing: maybe it's
849
847
  the first line of a file we are going to read. Method `outputs' adds its
850
848
  output as if typed in the \textbf{R markdown} document.
851
849
 
852
- Take now a look at variable `@c' (it was defined in a previous block
853
- above) as `@c = ``The `outputs' function''. ``The `outputs' function''
854
- is actually the name of this section and it was created using the
855
- 'outputs' function inside a Ruby chunk.
850
+ Take now a look at variable `c' (it was defined in a previous block
851
+ above) as `c = ``The `outputs' function''. ``The `outputs' function'' is
852
+ actually the name of this section and it was created using the 'outputs'
853
+ function inside a Ruby chunk.
856
854
 
857
855
  The ruby chunk to generate this heading is:
858
856
 
859
857
  \begin{verbatim}
860
858
  ```{ruby heading}
861
- outputs "### #{@c}"
859
+ outputs "### #{c}"
862
860
  ```
863
861
  \end{verbatim}
864
862
 
@@ -1248,7 +1246,7 @@ author: "Rodrigo Botafogo"
1248
1246
  tags: [Galaaz, Ruby, R, TruffleRuby, FastR, GraalVM, knitr, gknit]
1249
1247
  date: "29 October 2018"
1250
1248
  output:
1251
- pdf_document:
1249
+ pdf\_document:
1252
1250
  includes:
1253
1251
  in\_header: ["../../sty/galaaz.sty"]
1254
1252
  number\_sections: yes