-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy path06-documentation.Rmd
59 lines (39 loc) · 3.18 KB
/
06-documentation.Rmd
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
# Document Your Work {#documentation}
(ref:documentation-intro)
**You Must** - (ref:documentation-must)
**You Should** - (ref:documentation-should)
**You Could** - (ref:documentation-could)
|Related Areas: | [Reproducibility](#reproducible) <br> [Comments](#comments) |
|--------------- |------------------------------------------------------------|
## Aqua Book Guidance for Technical Documentation: {#aqua}
Pages 42-43 of the [Aqua book](https://www.gov.uk/government/publications/the-aqua-book-guidance-on-producing-quality-analysis-for-government) contains guidance on documentation that should be in place as part of a quality assurance process for any analysis. The scope of the Aqua book is wider than code, however the definition of technical documentation is useful and repeated here:
All analysis should have documentation for the user, even if that 'user' is just the analyst leading the analysis.
*This is to ensure that they have captured sufficient material to assist them if the analysis is revisited in due course*.
For analysis that is more likely to be revisited or updated in the future, documentation should be provided to assist a future analyst and should be more comprehensive.
This documentation should include:
* a summary of the analysis including the context to the question being asked,
* what analytical methods were considered,
* what analysis was planned and why,
* what challenges were encountered and how they were overcome
* and what verification and validation steps were performed.
In addition, guidance on what should be considered if the analysis is to be revisited or updated is beneficial.
## Document as you Go {#as_you_go}
Don't fall into the trap of assuming documentation is something which is produced at the end.
The best time to put together the documentation is as you are planning or doing the work - while it is fresh in your mind.
This also means that switching projects wont result in undocumented work.
## Use a Documentation Generator {#doxygen}
There are popular tools for generating documentation from your code and comments. These lighten the load of producing and publishing good documentation, and encourage you to produce thorough documentation.
There are [many](https://en.wikipedia.org/wiki/Comparison_of_documentation_generators) documentation generators.
[Doxygen](http://www.doxygen.nl/) or [Roxygen](https://cran.r-project.org/web/packages/roxygen2/)
are recommended.
## `README.md` {#readme}
It is good practice to include a README.md document within your repository.
README files typically include information on:
* What the code does
* Why the code is useful
* How users can get started with the code
* Where users can get help with your code
* Who maintains and contributes to the code
Put the README file in your repository's root (i.e. the top level folder which contains/is the repository). This makes it easy to find. It also means that when you view your repository on github (or other git repository hosting sites), that it will be rendered nicely and prominently displayed.
You can view the README for the repository which produces this book here: [README.md](README.md)
See [About READMEs](https://help.github.com/en/articles/about-readmes) for more.