<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>graphics Archives - Data Analytics</title>
	<atom:link href="https://dataanalytics.org.uk/tag/graphics/feed/" rel="self" type="application/rss+xml" />
	<link>https://dataanalytics.org.uk/tag/graphics/</link>
	<description>Understanding Data</description>
	<lastBuildDate>Thu, 28 Jul 2022 15:43:52 +0000</lastBuildDate>
	<language>en-GB</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.6.1</generator>

<image>
	<url>https://dataanalytics.org.uk/wp-content/uploads/2019/11/cropped-DA-graph-logo-2019-cyan-600-32x32.png</url>
	<title>graphics Archives - Data Analytics</title>
	<link>https://dataanalytics.org.uk/tag/graphics/</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>Association Plots in R</title>
		<link>https://dataanalytics.org.uk/association-plots-in-r/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=association-plots-in-r</link>
		
		<dc:creator><![CDATA[gmark]]></dc:creator>
		<pubDate>Thu, 28 Jul 2022 15:43:52 +0000</pubDate>
				<category><![CDATA[Introduction-to-R]]></category>
		<category><![CDATA[association]]></category>
		<category><![CDATA[association plot]]></category>
		<category><![CDATA[assocplot]]></category>
		<category><![CDATA[chi squared]]></category>
		<category><![CDATA[data visualisation]]></category>
		<category><![CDATA[graphics]]></category>
		<category><![CDATA[plot]]></category>
		<category><![CDATA[R]]></category>
		<category><![CDATA[visualisation]]></category>
		<category><![CDATA[visualization]]></category>
		<guid isPermaLink="false">https://www.dataanalytics.org.uk/?p=39538</guid>

					<description><![CDATA[<p>Association Plots Association plots in R. An association plot draws the results of an association test by charting the Pearson Residuals. Association plots in [&#8230;]</p>
<p>The post <a href="https://dataanalytics.org.uk/association-plots-in-r/">Association Plots in R</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></description>
										<content:encoded><![CDATA[<h1>Association Plots</h1>
<p>Association plots in R. An association plot draws the results of an association test by charting the Pearson Residuals.</p>
<p>Association plots in R are drawn using <code>assocplot()</code></p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">assocplot</span>(x, col = c("black", "red"), space = 0.3,
          main = NULL, xlab = NULL, ylab = NULL)
</code></pre>
<figure>
<table>
<thead>
<tr>
<th>Parameter</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>x</code></td>
<td>the data, usually a <code>numeric</code> <code>matrix</code>.</td>
</tr>
<tr>
<td><code>col</code></td>
<td>colors for positive and negative associations.</td>
</tr>
<tr>
<td><code>space</code></td>
<td>amount of space between the bars, as a fraction of average bar height and width (default = <code>0.3</code>).</td>
</tr>
<tr>
<td><code>main</code>, <code>xlab</code>, <code>ylab</code></td>
<td>title annotations.</td>
</tr>
</tbody>
</table>
<p>&nbsp;</p>
<p>Essentially you need a 2-dimensional <code>matrix</code> to use <code>assocplot()</code>:</figure>
<pre><code class="language-r" lang="r">VADeaths
</code></pre>
<pre><code>      Rural Male Rural Female Urban Male Urban Female
50-54       11.7          8.7       15.4          8.4
55-59       18.1         11.7       24.3         13.6
60-64       26.9         20.3       37.0         19.3
65-69       41.0         30.9       54.6         35.1
70-74       66.0         54.3       71.1         50.0
</code></pre>
<p>Apart from the titles, the only graphical parameter you can alter directly is <code>col</code>, to alter the positive and negative bar colors:</p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">assocplot</span>(VADeaths, col = c(<span style="color: #008000;">"lightblue"</span>, <span style="color: #008000;">"pink"</span>),
	  xlab = <span style="color: #008000;">"Age class"</span>, ylab = <span style="color: #008000;">"Driver actegory"</span>)
</code></pre>
<div id="attachment_39537" style="width: 510px" class="wp-caption aligncenter"><img fetchpriority="high" decoding="async" aria-describedby="caption-attachment-39537" class="wp-image-39537" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-warp-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-warp-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-warp-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-warp-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-warp-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-warp-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-warp.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39537" class="wp-caption-text">Basic association plot using custom color for positive and negative bars</p></div>
<h2>Graphical parameters</h2>
<p>If you want to alter the general appearance of your association plot you&#8217;ll need to set the appropriate graphical parameters using <code>par()</code> before using <code>assocplot()</code>:</p>
<pre><code class="language-r" lang="r">opar &lt;- <span style="color: #0000ff;">par</span>(las = 1, cex = 0.8, mar = c(5,7,2,1))

<span style="color: #0000ff;">assocplot</span>(VADeaths, col = c(<span style="color: #008000;">"blue"</span>, <span style="color: #008000;">"tomato"</span>),
          space = 0.05, xlab = <span style="color: #008000;">"Age class"</span>)
<span style="color: #0000ff;">title</span>(ylab = <span style="color: #008000;">"Driver category"</span>, line = 6)

<span style="color: #0000ff;">par</span>(opar)
</code></pre>
<div id="attachment_39536" style="width: 510px" class="wp-caption aligncenter"><img decoding="async" aria-describedby="caption-attachment-39536" class="wp-image-39536" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-par-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-par-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-par-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-par-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-par-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-par-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-par.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39536" class="wp-caption-text">Custom graphical parameters have to be applied using par() before using assocplot()</p></div>
<p>In the preceding example the margins were widened to allow the labels to &#8220;fit&#8221;. Note also how <code>title()</code> was used to place the y-axis annotation on an outer line.</p>
<h2>Data layout</h2>
<p>Essentially you need a 2D <code>matrix</code> for <code>assocplot()</code> to make an association plot in R. If you have something else you need to coerce it to the correct form.</p>
<p>Here are some options:</p>
<ul>
<li><code>data.frame</code> use <code>as.matrix()</code> to alter the form.</li>
<li><code>table</code> use <code>x[r, c, n, ...]</code> to &#8220;pick out&#8221; the appropriate 2D sub-table or..</li>
<li><code>table</code> use <code>margin.table</code> to &#8220;collapse&#8221; a table and combine across the margins you want.</li>
</ul>
<pre><code class="language-r" lang="r"><span style="color: #808080;"># 3D table</span>
HairEyeColor
</code></pre>
<pre><code>, , Sex = Male

       Eye
Hair    Brown Blue Hazel Green
  Black    32   11    10     3
  Brown    53   50    25    15
  Red      10   10     7     7
  Blond     3   30     5     8

, , Sex = Female

       Eye
Hair    Brown Blue Hazel Green
  Black    36    9     5     2
  Brown    66   34    29    14
  Red      16    7     7     7
  Blond     4   64     5     8
</code></pre>
<pre><code class="language-r" lang="r"><span style="color: #808080;"># Choose "Male"</span>
HairEyeColor[,,1]
</code></pre>
<pre><code>       Eye
Hair    Brown Blue Hazel Green
  Black    32   11    10     3
  Brown    53   50    25    15
  Red      10   10     7     7
  Blond     3   30     5     8
</code></pre>
<pre><code class="language-r" lang="r"><span style="color: #808080;"># Combine "Male" and "Female"</span>
<span style="color: #0000ff;">margin.table</span>(HairEyeColor, margin = c(1,2))
</code></pre>
<pre><code>       Eye
Hair    Brown Blue Hazel Green
  Black    68   20    15     5
  Brown   119   84    54    29
  Red      26   17    14    14
  Blond     7   94    10    16
</code></pre>
<pre><code class="language-r" lang="r"><span style="color: #808080;"># Combine "Eye"</span>
<span style="color: #0000ff;">margin.table</span>(HairEyeColor, margin = c(1,3))
</code></pre>
<pre><code>       Sex
Hair    Male Female
  Black   56     52
  Brown  143    143
  Red     34     37
  Blond   46     81
</code></pre>
<h2>Alternatives to assocplot()</h2>
<p>The <code>assocplot()</code> function is not the only was to draw an association plot using R. You could run a <code>chisq.test()</code> and extract the Pearson residuals <code>$residuals</code>, which you then plot using <code>barplot()</code>.</p>
<pre><code class="language-r" lang="r">X &lt;- <span style="color: #0000ff;">chisq.test</span>(VADeaths)
X$residuals
</code></pre>
<pre><code>         Rural Male Rural Female Urban Male Urban Female
50-54 -0.0001229145  -0.09956533  0.2454344  -0.21106734
55-59  0.0422284686  -0.56107962  0.4550546  -0.06391943
60-64 -0.0951496863  -0.16808112  0.5368919  -0.40335827
65-69 -0.2718462679  -0.34870589  0.2349807   0.36003546
70-74  0.2624133483   0.73510055 -0.8898149   0.09370444
</code></pre>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">barplot</span>(X$residuals, beside = TRUE, col = <span style="color: #0000ff;">cm.colors</span>(5),
        ylim = c(-1,1), legend = TRUE,
	args.legend = <span style="color: #0000ff;">list</span>(x = "top", bty = "n", ncol = 5))
<span style="color: #0000ff;">title</span>(ylab = "Pearson residuals", xlab = "Category")
</code></pre>
<div id="attachment_39535" style="width: 510px" class="wp-caption aligncenter"><img decoding="async" aria-describedby="caption-attachment-39535" class="wp-image-39535" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-bar-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-bar-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-bar-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-bar-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-bar-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-bar-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/assocplot-bar.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39535" class="wp-caption-text">Alternative to assocplot() is to use barplot() on the Pearson residuals</p></div>
<p>To get multiple rows, with a separate mini-plot for each row you would need to set-up <code>par(mfrow = c(rows, cols))</code>.</p>
<p>There are potential advantages to this method, for example you can add horizontal lines at +/- 2 to show the &#8220;significance band&#8221;. However, it is also somewhat more involved!</p>
<hr />
<p>This article is partly in support of my book <em>An Introduction to R</em> see the <a href="https://www.dataanalytics.org.uk/publications">publications page</a> for more information.</p>
<ul>
<li>An Introduction to R will be published by <a href="https://pelagicpublishing.com/">Pelagic Publishing</a>. <a href="https://pelagicpublishing.com/pages/search-results-page?q=Mark%20Gardener">See all my books at Pelagic Publishing</a>.</li>
<li>For more articles look at the <a href="https://www.dataanalytics.org.uk/category/tips-and-tricks/">Tips and Tricks page</a> and look for the various categories or use the search box.</li>
<li>See also the <a href="#https://www.dataanalytics.org.uk/data-analytics-knowledge-base-tips-tricks-r-excel/">Knowledge Base</a> where there are other topics related to R and data science.</li>
<li>Visit our other site at <a href="https://www.gardenersown.co.uk/">GardenersOwn</a> for a more ecological matters.</li>
</ul>
<p>The post <a href="https://dataanalytics.org.uk/association-plots-in-r/">Association Plots in R</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></content:encoded>
					
		
		
			</item>
		<item>
		<title>Conditional density plots in R</title>
		<link>https://dataanalytics.org.uk/conditional-density-plots-in-r/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=conditional-density-plots-in-r</link>
		
		<dc:creator><![CDATA[gmark]]></dc:creator>
		<pubDate>Thu, 28 Jul 2022 15:39:09 +0000</pubDate>
				<category><![CDATA[Introduction-to-R]]></category>
		<category><![CDATA[cdplot]]></category>
		<category><![CDATA[data visualisation]]></category>
		<category><![CDATA[density]]></category>
		<category><![CDATA[density plot]]></category>
		<category><![CDATA[graphics]]></category>
		<category><![CDATA[histogram]]></category>
		<category><![CDATA[plot]]></category>
		<category><![CDATA[R]]></category>
		<category><![CDATA[visualisation]]></category>
		<category><![CDATA[visualization]]></category>
		<guid isPermaLink="false">https://www.dataanalytics.org.uk/?p=39529</guid>

					<description><![CDATA[<p>Conditional density plots Conditional density plots in R &#8212; how to draw a conditional density plot using R. A conditional density plot shows [&#8230;]</p>
<p>The post <a href="https://dataanalytics.org.uk/conditional-density-plots-in-r/">Conditional density plots in R</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></description>
										<content:encoded><![CDATA[<h1>Conditional density plots</h1>
<p>Conditional density plots in R &#8212; how to draw a conditional density plot using R. A conditional density plot shows the density of a sample split into groups.</p>
<p>Use <code>cdplot()</code> to draw a conditional density plot using R.</p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">cdplot</span>(x, y,
       plot = TRUE, tol.ylab = 0.05, ylevels = NULL,
       bw = "nrd0", n = 512, from = NULL, to = NULL,
       col = NULL, border = 1, main = "", xlab = NULL, ylab = NULL,
       yaxlabels = NULL, xlim = NULL, ylim = c(0, 1), ...)
</code></pre>
<p>There are many potential parameters for <code>cdplot()</code> but the most helpful are:</p>
<figure>
<table>
<thead>
<tr>
<th>Parameter</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>x</code>, <code>y</code></td>
<td>the data, specify <code>x</code> and <code>y</code> or use a <code>formula</code>. In any event <code>y</code> should be a <code>factor</code> and <code>x</code> a <code>numeric</code></td>
</tr>
<tr>
<td><code>ylevels</code></td>
<td>the order of the variables to be plotted</td>
</tr>
<tr>
<td><code>yaxlabels</code></td>
<td>labels for axis annotation</td>
</tr>
<tr>
<td><code>bw</code>, <code>n</code>, <code>from</code>, <code>to</code>, <code>...</code></td>
<td>arguments to pass to <code>density</code></td>
</tr>
</tbody>
</table>
</figure>
<p>There are several arguments related to the <code>density()</code> function, which in most cases you&#8217;ll never need to alter.</p>
<p>A basic plot requires a <code>factor</code> variable and a <code>numeric</code>:</p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">cdplot</span>(tension ~ breaks, data = warpbreaks)
</code></pre>
<div id="attachment_39528" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39528" class="wp-image-39528" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39528" class="wp-caption-text">A conditional density plot</p></div>
<p>You can use the <code>ylevels</code> argument to alter the order of the plotting of a <code>cdplot()</code>:</p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">cdplot</span>(tension ~ breaks, data = warpbreaks, ylevels = 3:1)
</code></pre>
<div id="attachment_39527" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39527" class="wp-image-39527" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-rev-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-rev-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-rev-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-rev-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-rev-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-rev-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-warp-rev.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39527" class="wp-caption-text">Use the ylevels argument to change the order of a conditional density plot</p></div>
<p>Give customized names to the <code>factor</code> levels via the <code>yaxlabels</code> argument:</p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">cdplot</span>(group ~ weight, data = PlantGrowth,
       yaxlabels = c("Control", "Treatment-1", "Treatment-2"))
</code></pre>
<div id="attachment_39525" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39525" class="wp-image-39525" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-pg-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-pg-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-pg-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-pg-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-pg-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-pg-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-pg.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39525" class="wp-caption-text">Custom factor labels via yaxlabels argument in cdplot</p></div>
<h2>Altering graphical appearance</h2>
<p>Only some of the general graphical parameters can be changed in <code>cdplot()</code>, as in the following example.</p>
<p>Use graphical parameters <code>col</code> and <code>border</code> to alter the appearance:</p>
<pre><span style="color: #0000ff;">cdplot</span>(spray ~ count, data = InsectSprays,
       col = <span style="color: #0000ff;">cm.colors</span>(6), border = "blue")</pre>
<div id="attachment_39526" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39526" class="wp-image-39526" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-spray-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-spray-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-spray-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-spray-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-spray-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-spray-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-spray.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39526" class="wp-caption-text">Basic graphical parameters col and border used to alter a cdplot</p></div>
<p>If you want to change any other graphical parameters you&#8217;ll need to call <code>par()</code> first:</p>
<pre><code class="language-r" lang="r">opar &lt;- <span style="color: #0000ff;">par</span>(las = 1, cex = 0.8, mar = c(5,7,2,3))

<span style="color: #0000ff;">cdplot</span>(feed ~ weight, data = chickwts, ylab = "")
<span style="color: #0000ff;">title</span>(ylab = "feed", line = 5)

<span style="color: #0000ff;">par</span>(opar)
</code></pre>
<div id="attachment_39524" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39524" class="wp-image-39524" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-chick-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-chick-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-chick-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-chick-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-chick-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-chick-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/cdplot-chick.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39524" class="wp-caption-text">Use par() to set graphical parameters (other than col, border) in a cdplot</p></div>
<p>In the preceding example the margins were altered to allow the annotations to &#8220;fit&#8221;. In the <code>title</code> the annotation was shifted outwards.</p>
<p>This article is partly in support of my book <em>An Introduction to R</em> see the <a href="https://www.dataanalytics.org.uk/publications">publications page</a> for more information.</p>
<ul>
<li>For more articles look at the <a href="https://www.dataanalytics.org.uk/category/tips-and-tricks/">Tips and Tricks page</a> and look for the various categories or use the search box.</li>
<li>See also the <a href="#https://www.dataanalytics.org.uk/data-analytics-knowledge-base-tips-tricks-r-excel/">Knowledge Base</a> where there are other topics related to R and data science.</li>
<li>An Introduction to R will be published by <a href="https://pelagicpublishing.com/">Pelagic Publishing</a>. <a href="https://pelagicpublishing.com/pages/search-results-page?q=Mark%20Gardener">See all my books at Pelagic Publishing</a>.</li>
<li>Visit our other site at <a href="https://www.gardenersown.co.uk/">GardenersOwn</a> for a more ecological matters.</li>
</ul>
<p>The post <a href="https://dataanalytics.org.uk/conditional-density-plots-in-r/">Conditional density plots in R</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></content:encoded>
					
		
		
			</item>
		<item>
		<title>Spine plots using R</title>
		<link>https://dataanalytics.org.uk/spine-plots-using-r/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=spine-plots-using-r</link>
		
		<dc:creator><![CDATA[gmark]]></dc:creator>
		<pubDate>Thu, 28 Jul 2022 09:50:31 +0000</pubDate>
				<category><![CDATA[Introduction-to-R]]></category>
		<category><![CDATA[data visualisation]]></category>
		<category><![CDATA[graphics]]></category>
		<category><![CDATA[plot]]></category>
		<category><![CDATA[plotting]]></category>
		<category><![CDATA[R]]></category>
		<category><![CDATA[spine plot]]></category>
		<category><![CDATA[spineplot]]></category>
		<category><![CDATA[spinogram]]></category>
		<category><![CDATA[visualisation]]></category>
		<category><![CDATA[visualization]]></category>
		<guid isPermaLink="false">https://www.dataanalytics.org.uk/?p=39519</guid>

					<description><![CDATA[<p>Spine Plots using R A spine plot is similar to a mosaic plot and stacked bar chart. Use spineplot()  function to draw spine [&#8230;]</p>
<p>The post <a href="https://dataanalytics.org.uk/spine-plots-using-r/">Spine plots using R</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></description>
										<content:encoded><![CDATA[<h1>Spine Plots using R</h1>
<p>A spine plot is similar to a mosaic plot and stacked bar chart. Use <code>spineplot()</code>  function to draw spine plots using R. There are quite a number of potential arguments you can use:</p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">spineplot</span>(x, y = NULL,
          breaks = NULL, tol.ylab = 0.05, off = NULL,
          ylevels = NULL, col = NULL,
          main = "", xlab = NULL, ylab = NULL,
          xaxlabels = NULL, yaxlabels = NULL,
          xlim = NULL, ylim = c(0, 1), axes = TRUE, ...)
</code></pre>
<p>The major parameters are:</p>
<figure>
<table>
<thead>
<tr>
<th>Parameter</th>
<th>Result</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>x</code></td>
<td>data (x,y) or formula <code>y~x</code></td>
</tr>
<tr>
<td><code>breaks</code></td>
<td>passed to <code>hist()</code></td>
</tr>
<tr>
<td><code>off</code></td>
<td>space between bars</td>
</tr>
<tr>
<td><code>ylevels</code></td>
<td>order of levels in <code>x</code></td>
</tr>
<tr>
<td><code>col</code></td>
<td>colors</td>
</tr>
<tr>
<td><code>xaxlabels</code></td>
<td>labels for x-axis</td>
</tr>
</tbody>
</table>
</figure>
<p>Your data might be in one of two forms, which affects the kind of plot you get:</p>
<ul>
<li><code>category ~ category</code> results in a spine plot (like a 100% stacked bar chart).</li>
<li><code>factor ~ numeric</code> results in a spinogram (like a histogram).</li>
</ul>
<h2>Spine plots</h2>
<p>If your data are <code>category ~ category</code> your <code>spineplot</code> results in a kind of stacked bar chart.</p>
<p>Look at the <code>VADeaths</code> dataset (a <code>matrix</code>) as an example:</p>
<pre><code class="language-r" lang="r">VADeaths
</code></pre>
<pre><code>      Rural Male Rural Female Urban Male Urban Female
50-54       11.7          8.7       15.4          8.4
55-59       18.1         11.7       24.3         13.6
60-64       26.9         20.3       37.0         19.3
65-69       41.0         30.9       54.6         35.1
70-74       66.0         54.3       71.1         50.0
</code></pre>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">spineplot</span>(VADeaths)
</code></pre>
<div id="attachment_39517" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39517" class="wp-image-39517" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39517" class="wp-caption-text">A simple spine plot from a categorical matrix</p></div>
<p>You can tinker with the graphical parameters to make the chart look &#8220;nicer&#8221;:</p>
<pre><code class="language-r" lang="r"># Custom colours, bar space, and axis labels
<span style="color: #0000ff;">spineplot</span>(VADeaths, col = terrain.colors(4),
          off = 5,
          xlab = "Age Class",
          ylab = "Category")
</code></pre>
<div id="attachment_39516" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39516" class="wp-image-39516" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-col-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-col-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-col-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-col-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-col-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-col-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-vad-col.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39516" class="wp-caption-text">Graphical parameters used to prettify a spine plot</p></div>
<p>It is hard to resize name labels, as <code>cex</code>, <code>las</code> and so on do not work! The solution is to set these parameters globally using <code>par()</code> and reset them after drawing your plot.</p>
<p>In the following example custom <code>names</code> are also used to help &#8220;fit&#8221; labels in the plot:</p>
<pre><code class="language-r" lang="r">opar &lt;- <span style="color: #0000ff;">par</span>(cex.axis = 0.6, las = 2)
<span style="color: #0000ff;">spineplot</span>(USPersonalExpenditure,
          xlab = "", ylab = "",
          xaxlabels = c("FT", "HO", "MH", "PC", "PE"))
<span style="color: #0000ff;">par</span>(opar)
</code></pre>
<div id="attachment_39515" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39515" class="wp-image-39515" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/spine-uspe-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-uspe-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-uspe-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-uspe-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-uspe-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-uspe-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-uspe.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39515" class="wp-caption-text">Axis labels are set using par() before drawing a spineplot</p></div>
<h3>Multi-dimensional tables</h3>
<p>The <code>spineplot()</code> function can only deal with 2-dimensional objects. If you have a multi-dimensional <code>table</code> you need to collapse the table to 2D.</p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">spineplot</span>(HairEyeColor)
</code></pre>
<pre><code>Error in spineplot.default(HairEyeColor) :
  a 2-way table has to be specified
</code></pre>
<pre><code class="language-r" lang="r">x &lt;- <span style="color: #0000ff;">margin.table</span>(HairEyeColor, margin = c(1,2))
x
</code></pre>
<pre><code>       Eye
Hair    Brown Blue Hazel Green
  Black    68   20    15     5
  Brown   119   84    54    29
  Red      26   17    14    14
  Blond     7   94    10    16
</code></pre>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">spineplot</span>(x, col = c("brown", "blue", "tan", "green"))
</code></pre>
<div id="attachment_39514" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39514" class="wp-image-39514" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/spine-table-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-table-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-table-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-table-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-table-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-table-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-table.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39514" class="wp-caption-text">A multi-dimensional table needs to be collapsed to 2D for plotting</p></div>
<h2>Spinograms</h2>
<p>A spinogram is a <code>spineplot</code> where the data is in the form <code>factor ~ numeric</code>. A spinogram is analogous to a histogram.</p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">spineplot</span>(tension ~ breaks, data = warpbreaks)
</code></pre>
<div id="attachment_39518" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39518" class="wp-image-39518" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/spine-warp-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-warp-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-warp-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-warp-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-warp-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-warp-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-warp.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39518" class="wp-caption-text">A spinogram is a form of histogram</p></div>
<p>If you have <code>numeric</code> data you can use <code>factor()</code> to convert the data:</p>
<pre><code class="language-r" lang="r"># Use factor(x) to "convert" numeric
<span style="color: #0000ff;">spineplot</span>(<span style="color: #0000ff;">factor</span>(Month) ~ Ozone,
          data = airquality,
          col = <span style="color: #0000ff;">heat.colors</span>(5))
</code></pre>
<div id="attachment_39512" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39512" class="wp-image-39512" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/spine-air-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-air-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-air-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-air-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-air-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-air-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-air.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39512" class="wp-caption-text">A spinogram where numeric data are converted to a factor before plotting</p></div>
<p>caption: : A spinogram where numeric data are converted to a factor before plotting</p>
<p>Use the <code>breaks</code> argument as you would for <code>hist()</code> to change the breakpoints (you can enter a single <code>integer</code> or a <code>numeric vector</code>).</p>
<pre><code class="language-r" lang="r"><span style="color: #0000ff;">spineplot</span>(feed ~ weight, data = chickwts, breaks = 4)
</code></pre>
<div id="attachment_39513" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39513" class="wp-image-39513" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/spine-chick-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-chick-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-chick-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-chick-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-chick-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-chick-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/spine-chick.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39513" class="wp-caption-text">Using the breaks argument to alter the breakpoints in a spinogram</p></div>
<p>It can be tricky to read a spinogram and it is not trivial to add a legend for the colors. See <a href="https://www.dataanalytics.org.uk/legends-on-graphs-and-charts/">Tips and Tricks article about legends here</a>.</p>
<ul>
<li>This article is partly in support of my book <em>An Introduction to R</em> see the <a href="https://www.dataanalytics.org.uk/publications">publications page</a> for more information.</li>
<li>An Introduction to R will be published by <a href="https://pelagicpublishing.com/">Pelagic Publishing</a>. <a href="https://pelagicpublishing.com/pages/search-results-page?q=Mark%20Gardener">See all my books at Pelagic Publishing</a>.</li>
<li>For more articles visit the <a href="https://www.dataanalytics.org.uk/category/tips-and-tricks/">Tips and Tricks page</a> and look for the various categories or use the search box.</li>
<li>Visit our other site at <a href="https://www.gardenersown.co.uk/">GardenersOwn</a> for a more ecological matters.</li>
</ul>
<hr />
<p>This article is partly in support of my book <em>An Introduction to R</em> see the <a href="https://www.dataanalytics.org.uk/publications">publications page</a> for more information.</p>
<p>The post <a href="https://dataanalytics.org.uk/spine-plots-using-r/">Spine plots using R</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></content:encoded>
					
		
		
			</item>
		<item>
		<title>Drawing mathematical curves</title>
		<link>https://dataanalytics.org.uk/drawing-mathematical-curves/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=drawing-mathematical-curves</link>
		
		<dc:creator><![CDATA[gmark]]></dc:creator>
		<pubDate>Thu, 28 Jul 2022 09:48:42 +0000</pubDate>
				<category><![CDATA[Introduction-to-R]]></category>
		<category><![CDATA[curve]]></category>
		<category><![CDATA[data visualisation]]></category>
		<category><![CDATA[graphics]]></category>
		<category><![CDATA[math]]></category>
		<category><![CDATA[math functions]]></category>
		<category><![CDATA[plot]]></category>
		<category><![CDATA[plotting]]></category>
		<category><![CDATA[R]]></category>
		<category><![CDATA[visualisation]]></category>
		<category><![CDATA[visualization]]></category>
		<guid isPermaLink="false">https://www.dataanalytics.org.uk/?p=39424</guid>

					<description><![CDATA[<p>Drawing mathematical curves using R is fairly easy. Here&#8217;s how to plot mathematical functions using R functions curve and plot. The main functions are [&#8230;]</p>
<p>The post <a href="https://dataanalytics.org.uk/drawing-mathematical-curves/">Drawing mathematical curves</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>Drawing mathematical curves using R is fairly easy. Here&#8217;s how to plot mathematical functions using R functions curve and plot.</p>
<p>The main functions are <code>curve()</code> and <code>plot.function()</code> but you can simply use <code>plot()</code>.</p>
<pre><span style="color: #0000ff;">curve</span>(expr, from = NULL, to = NULL, n = 101, add = FALSE,
     type = "l", xname = "x", xlab = xname, ylab = NULL,
     log = NULL, xlim = NULL, ...)

<span style="color: #0000ff;">plot</span>(x, y = 0, to = 1, from = y, xlim = NULL, ylab = NULL, ...)</pre>
<p>Essentially you use (or make) a <code>function</code> that takes values of <code>x</code> and returns a single value. The arguments are largely self-explanatory but:</p>
<ul>
<li><code>expr</code>, <code>x</code> &#8212; an expression or <code>function</code> that returns a single result.</li>
<li><code>from</code>, <code>to</code> &#8212; the limits of the input (default <code>0</code>&#8211;<code>1</code>).</li>
<li><code>n</code> &#8212; the number of &#8220;points&#8221; to draw (these will be evenly spaced between <code>from</code> and <code>to</code>).</li>
<li><code>...</code> &#8212; regular graphical arguments can be used.</li>
</ul>
<h2>Simple Math and Trigonometry</h2>
<p>You can visualize built-in functions. <strong>Note</strong> that you can use regular graphics arguments to augment the basic plot.</p>
<p>Here is a plot of the <code>sqrt</code> function:</p>
<pre><span style="color: #0000ff;">curve</span>(sqrt, from = 0, to = 100, ylab = "Square Root", las = 1)</pre>
<div id="attachment_39482" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39482" class="wp-image-39482" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/crv-sqrt.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-sqrt.png 900w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-sqrt-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-sqrt-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-sqrt-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-sqrt-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-sqrt-100x100.png 100w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39482" class="wp-caption-text">Plot of the square root function sqrt()</p></div>
<p>Here is a simple <code>log</code> plot:</p>
<pre><span style="color: #0000ff;">curve</span>(log, from = 0, to = 100, las = 1, lwd = 2, col = "blue")
</pre>
<div id="attachment_39479" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39479" class="wp-image-39479" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/crv-log-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-log-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-log-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-log-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-log-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-log-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-log.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39479" class="wp-caption-text">Plot of log function using curve()</p></div>
<h3>Adding to plots</h3>
<p>Use the <code>add = TRUE</code> argument to add a <code>curve()</code> to an existing plot.</p>
<pre><span style="color: #0000ff;">curve</span>(sin, -pi*2, pi*2, lty = 2, lwd = 1.5, col = "blue",
      ylab = "Function", ylim = c(-1,1.5))

<span style="color: #0000ff;">curve</span>(cos, -pi*2, pi*2, lty = 3, col = "red", lwd = 2, add = TRUE)

<span style="color: #808080;"># Add legend and title</span>
<span style="color: #0000ff;">legend</span>(x = "topright", legend = c("Sine", "Cosine"),
      lty = c(2, 3), lwd = c(1.5, 2),
      col = c("blue", "red"), bty = "n")

<span style="color: #0000ff;">title</span>(main = "Sine and Cosine functions")</pre>
<div id="attachment_39484" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39484" class="wp-image-39484" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/crv-trig-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-trig-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-trig-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-trig-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-trig-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-trig-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-trig.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39484" class="wp-caption-text">Plot of functions sin and cos using curve()</p></div>
<h2>Custom functions</h2>
<p>You can define your own <code>function</code> to plot. <strong>Remember</strong> that the result should be a single value. In this example we define two functions to convert between Celsius and Fahrenheit:</p>
<pre><span style="color: #808080;"># Conversion of temperature</span>
cels &lt;- <span style="color: #0000ff;">function</span>(x) (x-32) * 5/9
fahr &lt;- <span style="color: #0000ff;">function</span>(x) x*9/5 + 32</pre>
<p>Now you can use <code>from</code> and <code>to</code> arguments to set the limits for the input (the default is <code>0</code>&#8211;<code>1</code>).</p>
<pre><span style="color: #0000ff;">curve</span>(cels, from = 32, to = 100, xname = "Farenheit",
      ylab = "Celsius", las = 1)

<span style="color: #0000ff;">curve</span>(fahr, from = 0, to = 50, xname = "Celsius",
      ylab = "Fahrenheit", las = 1)</pre>
<div id="attachment_39483" style="width: 610px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39483" class="wp-image-39483" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/crv-temperature-300x150.png" alt="" width="600" height="300" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-temperature-300x150.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-temperature-1024x512.png 1024w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-temperature-768x384.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-temperature-1536x768.png 1536w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-temperature-600x300.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-temperature.png 1800w" sizes="(max-width: 600px) 100vw, 600px" /><p id="caption-attachment-39483" class="wp-caption-text">Plots using custom function, temperature conversion</p></div>
<h2>Function arguments</h2>
<p>If your function requires additional arguments you need to do something different. In this example you can see the Manning equation, which is used to estimate speed of fluids in pipes/tubes:</p>
<pre>manning &lt;- <span style="color: #0000ff;">function</span>(r, g, c = 0.1) (r^(2/3) * g^0.5/c)

curve(manning) <span style="color: #808080;"># fails</span></pre>
<pre>Error in manning(x) : argument "g" is missing, with no default</pre>
<p>The plotting fails. You need to pre-define all arguments as you cannot &#8220;pass-through&#8221; additional arguments to your function:</p>
<pre>manning &lt;- <span style="color: #0000ff;">function</span>(r, g = 0.01, c = 0.1) (r^(2/3) * g^0.5/c)

<span style="color: #0000ff;">curve</span>(manning) <span style="color: #808080;"># works</span></pre>
<div id="attachment_39480" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39480" class="wp-image-39480" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/crv-manning-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-manning-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-manning-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-manning-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-manning-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-manning-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-manning.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39480" class="wp-caption-text">Plot of a custom function with parameters</p></div>
<p>In the following example you see a built-in <code>function</code> <code>pt()</code> used to visualize the Student&#8217;s t distribution.</p>
<pre><span style="color: #808080;"># pt needs df and lower.tail arguments</span>
PT &lt;- <span style="color: #0000ff;">function</span>(x) pt(q = x, df = 100, lower.tail = FALSE)

<span style="color: #0000ff;">curve</span>(PT, from = -3, to = 3, las = 1, xname = "t-value",
     n = 20, type = "o", pch = 16, ylab = "probability")</pre>
<div id="attachment_39494" style="width: 510px" class="wp-caption aligncenter"><img loading="lazy" decoding="async" aria-describedby="caption-attachment-39494" class="wp-image-39494" src="https://www.dataanalytics.org.uk/wp-content/uploads/2022/06/crv-pt-300x300.png" alt="" width="500" height="500" srcset="https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-pt-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-pt-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-pt-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-pt-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-pt-100x100.png 100w, https://dataanalytics.org.uk/wp-content/uploads/2022/06/crv-pt.png 900w" sizes="(max-width: 500px) 100vw, 500px" /><p id="caption-attachment-39494" class="wp-caption-text">Plot of Student&#8217;s t distribution using a function &#8220;wrapper&#8221;</p></div>
<p>The workaround is to create a &#8220;wrapper&#8221; <code>function</code> that calls the actual <code>function</code> you want with the appropriate arguments. Note that in this example the <code>n</code> argument was used to plot 20 points, along with <code>type</code> and <code>pch</code> to create a line with over-plotted points.</p>
<p>This post is part of the support for the new book <em>An Introduction to R</em>. See <a href="https://www.dataanalytics.org.uk/publications/">Publications home page</a> for more details.</p>
<ul>
<li>An Introduction to R will be published by <a href="https://pelagicpublishing.com/">Pelagic Publishing</a>. <a href="https://pelagicpublishing.com/pages/search-results-page?q=Mark%20Gardener">See all my books at Pelagic Publishing</a>.</li>
<li>For more articles visit the <a href="https://www.dataanalytics.org.uk/category/tips-and-tricks/">Tips and Tricks page</a> and look for the various categories or use the search box.</li>
<li>See also the <a>Knowledge Base</a> where there are other topics related to R and data science.</li>
<li>Look at our other books on the <a>Publications Page</a>.</li>
<li>Visit our other site at <a href="https://www.gardenersown.co.uk/">GardenersOwn</a> for a more ecological matters.</li>
</ul>
<p>The post <a href="https://dataanalytics.org.uk/drawing-mathematical-curves/">Drawing mathematical curves</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></content:encoded>
					
		
		
			</item>
		<item>
		<title>Add more to a histogram in R</title>
		<link>https://dataanalytics.org.uk/add-more-to-a-histogram-in-r/?utm_source=rss&#038;utm_medium=rss&#038;utm_campaign=add-more-to-a-histogram-in-r</link>
		
		<dc:creator><![CDATA[gmark]]></dc:creator>
		<pubDate>Tue, 19 Nov 2019 10:23:23 +0000</pubDate>
				<category><![CDATA[Tips and Tricks]]></category>
		<category><![CDATA[graphics]]></category>
		<category><![CDATA[histogram]]></category>
		<guid isPermaLink="false">https://www.dataanalytics.org.uk/?p=5189</guid>

					<description><![CDATA[<p>Add more to a histogram in R A histogram is a standard way to present the distribution of a sample of numbers. A [&#8230;]</p>
<p>The post <a href="https://dataanalytics.org.uk/add-more-to-a-histogram-in-r/">Add more to a histogram in R</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></description>
										<content:encoded><![CDATA[<h1 id="section-intro">Add more to a histogram in R</h1>
<p>A histogram is a standard way to present the distribution of a sample of numbers. A basic histogram is useful but it is easy to add more to a histogram in R to produce an even more informative plot. In this article you’ll see how to add a rug and a strip-chart to a basic historgram using simple R commands.</p>
<h2 id="section-basic">A basic histogram</h2>
<p>It is easy to make a histogram using R with the <code>hist()</code> command. For example:</p>
<pre><code><span style="color: #0000ff;">set.seed</span>(123)
x &lt;- <span style="color: #0000ff;">norm</span>(n = 50, mean = 10, sd = 1)
<span style="color: #0000ff;">hist</span>(x, col = "skyblue")
</code></pre>
<p>Produces a histogram resembling this:</p>
<figure><img loading="lazy" decoding="async" class="alignnone wp-image-5191 size-full" src="https://www.dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-basic.png" alt="" width="1000" height="1000" srcset="https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-basic.png 1000w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-basic-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-basic-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-basic-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-basic-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-basic-100x100.png 100w" sizes="(max-width: 1000px) 100vw, 1000px" /></p>
<h2 id="section-rug">Add a rug</h2>
<p>A rug plot can be added to more or less any graphic. The <code>rug()</code> command can add the rug to any side of the plot:</p>
<ul>
<li><code>side = 1</code> is the bottom axis</li>
<li><code>side = 2</code> is the left axis</li>
</ul>
<p>You can alter the colour and width of the rug lines using regular graphical parameters:</p>
<pre><code><span style="color: #0000ff;">rug</span>(x, side = 1, col = "blue")
</code></pre>
<p>Adds the rug like so:</p>
<figure><img loading="lazy" decoding="async" class="alignnone size-full wp-image-5193" src="https://www.dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug.png" alt="" width="1000" height="1000" srcset="https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug.png 1000w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-100x100.png 100w" sizes="(max-width: 1000px) 100vw, 1000px" /></figure>
<h2 id="section-strip">Add a strip chart</h2>
<p>A strip chart can also be added to any chart via the <code>stripchart()</code> command. However, you also need to specify <code>add = TRUE</code> to the command. Giving a bit of <code>jitter</code> helps to separate out points that are coincident:</p>
<pre><code><span style="color: #0000ff;">stripchart</span>(x,
           method = "jitter",
           pch = 23,
           bg = "pink",
           add = TRUE)
</code></pre>
<p>The final plot looks like so:</p>
<p><!-- Use this as the featured image --></p>
<figure><img loading="lazy" decoding="async" class="alignnone size-full wp-image-5192" src="https://www.dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-strip1.png" alt="" width="1000" height="1000" srcset="https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-strip1.png 1000w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-strip1-300x300.png 300w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-strip1-150x150.png 150w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-strip1-768x768.png 768w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-strip1-600x600.png 600w, https://dataanalytics.org.uk/wp-content/uploads/2019/11/rplot-hist-rug-strip1-100x100.png 100w" sizes="(max-width: 1000px) 100vw, 1000px" /></figure>
<p>There are many additional options for the <code>stripchart()</code> command; use <code>help(stripchart)</code> in R to find out more. Look out for other articles in our <a href="https://www.dataanalytics.org.uk/category/tips-and-tricks/">Tips &amp; Tricks</a> pages.</figure>
<p>The post <a href="https://dataanalytics.org.uk/add-more-to-a-histogram-in-r/">Add more to a histogram in R</a> appeared first on <a href="https://dataanalytics.org.uk">Data Analytics</a>.</p>
]]></content:encoded>
					
		
		
			</item>
	</channel>
</rss>
