-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path06b_create-report.qmd
582 lines (402 loc) · 13.7 KB
/
06b_create-report.qmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
---
title: "Front Matter & Markdown Basics"
subtitle: "Creating a Scientific Report"
---
In this part of the course, we will use `Quarto` to create a reproducible presentation document for our analysis, combining our code and it's output with text in the form of markdown!
## Create your first `.qmd`!
### Create new `.qmd` file
Let's start by creating a new `.qmd` file in RStudio.
::: {.callout-info appearance="minimal"}
**File \> New File \> Quarto Document... \> Document**
:::
data:image/s3,"s3://crabby-images/6018d/6018d9168c5f9e8b60d5047da1b2bfa8061bc7e0" alt=""
The new document default content **demonstrates the 3 main elements that make up a Quarto document**:
1. At the top, the YAML header where we specify front matter metadata about the document.
2. The main body of the document where we write our text in markdown.
3. The code chunks where we write our executable R code.
### Save as `report.qmd`
Let's **save the file as `report.qmd`** in the root of our project directory.
## Quarto Editing Modes
Quarto documents can be edited in two modes: Source and Visual.
To switch between the two modes, you can use the buttons in the top left of the editor.
### Source Vs Visual Editing
::: panel-tabset
## Visual
The Quarto Visual Editor is a `WhatYouSeeIsWhatYouGet` editor that allows you to edit your document in a more visual way and is normally the mode launched by default in Rstudio.
Find out more about the [Visual Editor](https://quarto.org/docs/visual-editor/).
data:image/s3,"s3://crabby-images/4f10b/4f10ba7f5658cd7fc8dbaef5dfde255af57a5b58" alt=""
## Source
The Source editor is a text editor that allows you to edit the raw markdown and code that makes up your document. It is more stable and is the mode we will be using more often for this course.
data:image/s3,"s3://crabby-images/6d236/6d236b52c8784aaf8821e7f27f0811d3b14865cf" alt=""
:::
## Render `report.qmd`
Render the document by clicking on the **Render** button.
data:image/s3,"s3://crabby-images/4595b/4595b36c4daf1e9cf006ef8981ef053bab5a0e8c" alt=""{fig-align="left" width="120"}
Quarto will the Knit the document by running all the computations and rendering any markdown to an `.html` document:
data:image/s3,"s3://crabby-images/6dd79/6dd79465b601b7f0520f8f188353a8b3bcf019e3" alt=""
## Edit Front matter YAML header
The **yaml** header contains metadata about the document.
It is contained between the `---` separators at the top of the file and is encoded as [YAML](https://yaml.org/), *a human friendly data serialization standard for all programming languages*.
The key thing to know about YAML is that **indentation is extremely important!**. So make sure you copy any example YAML code exactly, ensuring correct indentation. If you get errors, check your indentation.
The default YAML header contains the following metadata:
``` yaml
---
title: "Untitled"
format: html
editor: visual
---
```
- `title`: A field to specify a title of the document.
- `format`: The format of the document. We will be using the default `html` for this course.
- `editor`: The default editor mode the document will be opened with.
Let's go ahead and update the title and add some more metadata to the header.
``` yaml
---
title: "Analysis of NEON Woody plant vegetation structure data"
subtitle: "ACCE DTP course"
author: "Anna Krystalli"
date: "2024-03-19"
format: html
editor: visual
---
```
Let's re-render and have a look at our updated document:
data:image/s3,"s3://crabby-images/60ce9/60ce9f3767f686a751c49bf71d5ffd0dcd03ad00" alt=""
### Add a floating table of contents
We can add a table of contents (TOC) using the `toc` option and specify a floating toc using the `toc_float` option. For example:
``` yaml
---
title: "Analysis of NEON Woody plant vegetation structure data"
subtitle: "ACCE DTP course"
author: "Anna Krystalli"
date: "2024-03-19"
format:
html:
toc: true
editor: visual
---
```
data:image/s3,"s3://crabby-images/35402/35402c34b0004003525b89c50c19147e0169257c" alt=""
### Choose a theme
There are several options that control the appearance of HTML documents:
- `theme` specifies the Bootstrap theme to use for the page (themes are drawn from the [Bootswatch](https://bootswatch.com/4/) theme library). Valid themes include `r knitr::combine_words(rmarkdown:::themes(), before='\x60')`.
```{r}
#| echo: false
knitr::include_url("https://bootswatch.com/4/")
```
I'm going to go ahead and choose the `minty` theme but feel free to experiment and choose a theme that you like.
``` yaml
---
title: "Analysis of NEON Woody plant vegetation structure data"
subtitle: "ACCE DTP course"
author: "Anna Krystalli"
date: "2024-03-19"
format:
html:
toc: true
theme: minty
editor: visual
---
```
Once rendered, my theme of choice looks like this:
data:image/s3,"s3://crabby-images/96faa/96faac8fd506de81d351b9288532ba2b62dd290b" alt=""
#### Choose code highlights
Field `highlight-style` specifies the code syntax highlighting style.
Supported styles include `r knitr::combine_words(rmarkdown:::html_highlighters(), before='\x60')` as well as a bunch of new styles which can be found [here](https://quarto.org/docs/output-formats/html-code.html#highlighting):
I'm picking one of the extended themes called `dracula`!
``` yaml
---
title: "Analysis of NEON Woody plant vegetation structure data"
subtitle: "ACCE DTP course"
author: "Anna Krystalli"
date: "2024-03-19"
format:
html:
toc: true
theme: minty
highlight-style: dracula
editor: visual
---
```
data:image/s3,"s3://crabby-images/ae197/ae19749e13e45f2aaaa04dc59c7c18098bf904f0" alt=""
Before moving on to adding content to our document, let's have a look at some Markdown basics.
# Markdown basics
The text in an [Quarto document is written with the Markdown syntax](https://quarto.org/docs/authoring/markdown-basics.html). Precisely speaking, it is Pandoc’s Markdown.
We use a small number of notations to **markup** our text with some common html tags
## Text
```
normal text
```
normal text
```
*italic text*
```
*italic text*
```
**bold text**
```
**bold text**
```
***bold italic text***
```
***bold italic text***
```
superscript^2^
```
superscript^2^
```
~~strikethrough~~
```
~~strikethrough~~
<br>
## Headers
::: grid
::: g-col-6
**markdown**
```
# Header 1
## Header 2
### Header 3
#### Header 4
##### Header 5
###### Header 6
```
:::
::: g-col-6
**rendered html**
```{r, out.width="80%", echo=FALSE}
knitr::include_graphics("assets/img/headers.png")
```
:::
:::
## Unordered lists
::: grid
::: g-col-6
**markdown**
```
- first item in the list
- second item in list
- third item in list
```
:::
::: g-col-6
**rendered html**
- first item in the list
- second item in list
- third item in list
:::
:::
## Ordered lists
::: grid
::: g-col-6
**markdown**
```
1. first item in the list
1. second item in list
1. third item in list
```
:::
::: g-col-6
**rendered html**
1. first item in the list
2. second item in list
3. third item in list
:::
:::
## Blockquotes
::: grid
::: g-col-6
**markdown**
```
> this text will be quoted
```
:::
::: g-col-6
**rendered html**
> **this text will be quoted**
:::
:::
## Code
### Annotate code inline
::: grid
::: g-col-6
**markdown**
```
`this text will appear as code` inline
```
:::
::: g-col-6
**rendered html**
`this text will appear as code` inline
:::
:::
### Evaluate r code inline
::: grid
::: g-col-6
```{r}
a <- 10
```
```{r, echo = F}
a <- "`r a`"
```
**markdown**
```
the value of parameter *a* is `{{r}} a`
```
```{r, echo = F}
a <- 10
```
:::
::: g-col-6
**rendered html**
the value of parameter *a* is `{r} a`
:::
:::
## Images
Provide either a path to a local image file or the URL of an image.
::: grid
::: g-col-6
**markdown**
``` md
data:image/s3,"s3://crabby-images/2a493/2a4935d9b8b7a0683ffbcb135685233948b9a9f3" alt=""
```
:::
::: g-col-6
**rendered html**
data:image/s3,"s3://crabby-images/2a493/2a4935d9b8b7a0683ffbcb135685233948b9a9f3" alt=""
:::
:::
## Basic tables in markdown
::: grid
::: g-col-6
**markdown**
```
Table Header | Second Header
- | -
Cell 1 | Cell 2
Cell 3 | Cell 4
```
:::
::: g-col-6
**rendered html**
| Table Header | Second Header |
|--------------|---------------|
| Cell 1 | Cell 2 |
| Cell 3 | Cell 4 |
:::
:::
Check out handy [**online .md table converter**](http://www.tablesgenerator.com/markdown_tables)
## Hyperlinks
::: grid
::: g-col-6
**markdown**
```
[Download R](http://www.r-project.org/)
[RStudio](http://www.rstudio.com/)
```
:::
::: g-col-6
**rendered html**
[Download R](http://www.r-project.org/)
[RStudio](http://www.rstudio.com/)
:::
:::
## Mathematical expressions
Quarto supports mathematical notations through [MathJax](http://www.onemathematicalcat.org/MathJaxDocumentation/TeXSyntax.htm).
You can write LaTeX math expressions inside a pair of dollar signs, e.g. `$\alpha+\beta$` renders $\alpha+\beta$. You can use the display style with double dollar signs:
::: grid
::: g-col-6
```
$$\bar{X}=\frac{1}{n}\sum_{i=1}^nX_i$$
```
:::
::: g-col-6
$$\bar{X}=\frac{1}{n}\sum_{i=1}^nX_i$$
:::
:::
## Visual Editor
Much of the markdown syntax can be added to documents via the visual editor.
The editor toolbar includes buttons for the most commonly used formatting commands, e.g:
- Formatting text to appear as bold, italic, or code
- Creating headers
- Creating lists
data:image/s3,"s3://crabby-images/7bcc5/7bcc50c6d41fb683386ced8131ea8d6a45c4701b" alt=""
::: grid
::: g-col-4
**Format**
data:image/s3,"s3://crabby-images/5ac47/5ac47531d1cb30b2ad8fa9297000629a1373c26a" alt=""
:::
::: g-col-4
**Insert** data:image/s3,"s3://crabby-images/61023/6102379919d977b6899d9560e8155b570e3690be" alt=""
:::
::: g-col-4
**Table** data:image/s3,"s3://crabby-images/9f265/9f26588c0ab3e55b01eae5c356c424bc7fb048d9" alt=""
:::
:::
### Add images with the Visual Editor
To add an image via the visual editor, click on the picture button in the toolbar.
data:image/s3,"s3://crabby-images/d265f/d265fabf56985289010e7cb6f8d02d41e1e1ca74" alt=""
This opens up a file dialog box where you can select the image you want to insert by clicking on **Browse...**.
You can also add a add a caption and a link to the image
data:image/s3,"s3://crabby-images/72036/720367fffc247c045653a45e02e34fabbdf4fd78" alt="" Click OK and the image is now inserted.
data:image/s3,"s3://crabby-images/19404/1940400943514e26f6e723c4be5ce3f0260d15b5" alt=""
### Resize images with Visual Editor
The Visual editor allows to resize images via the user interface.
To change any attributes of an image, click on the round `...` button in the image toolbar.
data:image/s3,"s3://crabby-images/adfa8/adfa8e7a63ec76b08422c03ad95fb55384eb8c95" alt=""
This opens up a image dialog box where you can change the image size, alignment and more.
You can reduce the size by editing the width and or height fields.
data:image/s3,"s3://crabby-images/ba2eb/ba2eb3be9585a3fd21d59cf124003c85f4d2bb65" alt=""
Click ok and the image is now resized.
data:image/s3,"s3://crabby-images/727b0/727b0ce0a3051861ec8cbe1e19fa020b02147299" alt=""
# Edit Content
Next let's start adding content related to our analysis.
To do so, let's first remove all the default content in the document **EXCEPT FOR THE YAML HEADER** and start with a clean slate.
## TASK: Create a `"Background"` section using headers
- **Create a `Background` Header**: Create a new level 2 header section called `"Background"` using the appropriate number of the `#` symbol followed by the header text.
- **Write a short description of the data set and analysis**: Write a short description of the NEON Vegetation structure dataset and the objective of the analysis.
**Have a look at the project README in `data-raw/wood-survey-data-master`** which contains some useful information you might be able to copy. \_Note: You'll likely need to switch to the Source editor to paste raw markdown\_
- **Make use of markdown annotation to**:
- *highlight* **important** ***information***
- include links to sources or further information. The NEON Data Portal Vegetation Structure URL might come in handy here: <https://data.neonscience.org/data-products/DP1.10098.001>
- **Add an image related to the data**.
- perhaps a logo or a relevant image to the organisms in question (see `data-raw/wood-survey-data-master` for a NEON logo).
- have a look online, especially on sites like [unsplash](https://unsplash.com/) that offer free to use images. *Note: To upload images to your project, use the **Upload files to server button** in the File pane on the bottom right of Posit Cloud interface.*
- include the source underneath for attribution.
- see if you can resize it.
- Include a brief data preparation section:
- Use a list to describe a couple of steps in our data preparation process.
- Mention the script that contains the data preparation code.
::: {.callout-note appearance="minimal" collapse="true" title="Here's what my document now looks like:"}
::: grid
::: g-col-6
```
---
title: "Analysis of NEON Woody plant vegetation structure data"
subtitle: "ACCE DTP course"
author: "Anna Krystalli"
date: "2024-03-19"
format:
html:
toc: true
theme: minty
highlight-style: dracula
editor: visual
---
## Background
data:image/s3,"s3://crabby-images/70fcb/70fcbce318b4b6aecab5f5f3f4d82f350a247ecf" alt=""{width="200"}
The [NEON Woody plant vegetation structure dataset](https://data.neonscience.org/data-products/DP1.10098.001) contains **structure measurements, including height, canopy diameter, and stem diameter, as well as mapped position of individual woody plants across the survey area.**
This data product contains the quality-controlled, native sampling resolution data from in-situ measurements of live and standing dead woody individuals and shrub groups, from all terrestrial NEON sites with qualifying woody vegetation. With some modifications, this protocol adopts guidelines established by the U.S. Forest Service (2012) for measuring tree species. The exact measurements collected per individual depend on growth form, and these measurements are focused on enabling biomass and productivity estimation, estimation of shrub volume and biomass, and calibration / validation of multiple NEON airborne remote-sensing data products.
Our analyses focus on the **relationship between individual stem height and diameter** and how that relationship **varies across growth forms**.
### Data Preparation
Data was prepared for analysis by:
- Compiling all individual raw data files into a single table.
- Merging individual data with plot level data and geolocating individuals.
The data preparation steps are contained in the `data-raw/individuals.R` script.
```
:::
::: g-col-6
data:image/s3,"s3://crabby-images/72c20/72c20949f3dd8767f3cc6e01350591a521ed9b39" alt=""
:::
:::
:::