Kubke Lab:Research/ABR/Notebook/2013/10/29: Difference between revisions

From OpenWetWare
Jump to navigationJump to search
(→‎General Entries: feedback from Andy)
(fix raw html notebook nav)
 
(2 intermediate revisions by one other user not shown)
Line 2: Line 2:
|-
|-
|style="background-color: #EEE"|[[Image:owwnotebook_icon.png|128px]]<span style="font-size:22px;"> Hearing development in barn owls</span>
|style="background-color: #EEE"|[[Image:owwnotebook_icon.png|128px]]<span style="font-size:22px;"> Hearing development in barn owls</span>
|style="background-color: #F2F2F2" align="center"|<html><img src="/images/9/94/Report.png" border="0" /></html> [[{{#sub:{{FULLPAGENAME}}|0|-11}}|Main project page]]<br />{{#if:{{#lnpreventry:{{FULLPAGENAME}}}}|<html><img src="/images/c/c3/Resultset_previous.png" border="0" /></html>[[{{#lnpreventry:{{FULLPAGENAME}}}}{{!}}Previous entry]]<html>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</html>}}{{#if:{{#lnnextentry:{{FULLPAGENAME}}}}|[[{{#lnnextentry:{{FULLPAGENAME}}}}{{!}}Next entry]]<html><img src="/images/5/5c/Resultset_next.png" border="0" /></html>}}
|style="background-color: #F2F2F2" align="center"|[[File:Report.png|frameless|link={{#sub:{{FULLPAGENAME}}|0|-11}}]][[{{#sub:{{FULLPAGENAME}}|0|-11}}|Main project page]]<br />{{#if:{{#lnpreventry:{{FULLPAGENAME}}}}|[[File:Resultset_previous.png|frameless|link={{#lnpreventry:{{FULLPAGENAME}}}}]][[{{#lnpreventry:{{FULLPAGENAME}}}}{{!}}Previous entry]]&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}}{{#if:{{#lnnextentry:{{FULLPAGENAME}}}}|[[{{#lnnextentry:{{FULLPAGENAME}}}}{{!}}Next entry]][[File:Resultset_next.png|frameless|link={{#lnnextentry:{{FULLPAGENAME}}}}]]}}
|-
|-
| colspan="2"|
| colspan="2"|
Line 14: Line 14:
== Feedback from Andy ==
== Feedback from Andy ==


* Filter: Higher order is sharper cutoff.
* Filter: Higher order is sharper cutoff. A sharp butterworth would be a 5th or 6th order.  I wouldn't use any higher.


* Try an fft to see where the low pass cutoff should be. If the filter order is too high you get ringing. [ see http://t.co/QfrGaDjvj2 ]
* Try an fft to see where the low pass cutoff should be. If the filter order is too high you get ringing. [ see http://t.co/QfrGaDjvj2 ]
* entered wrong sampling rate - sampling rate is actually 50 kHz - need to recalculate the filters based on that. They are off by a factor of 10, so what says lowpassed at 100 is actually at 1k.


=Personal Entries=
=Personal Entries=

Latest revision as of 23:31, 26 September 2017

Hearing development in barn owls Main project page
Previous entry      Next entry

General Entries

  • Played around with filter() and butter() in library.signal MF Kubke 20:11, 28 October 2013 (EDT)

Feedback from Andy

  • Filter: Higher order is sharper cutoff. A sharp butterworth would be a 5th or 6th order. I wouldn't use any higher.
  • Try an fft to see where the low pass cutoff should be. If the filter order is too high you get ringing. [ see http://t.co/QfrGaDjvj2 ]
  • entered wrong sampling rate - sampling rate is actually 50 kHz - need to recalculate the filters based on that. They are off by a factor of 10, so what says lowpassed at 100 is actually at 1k.

Personal Entries

Fabiana

  • File 2013-10-29-MFK.Rmd

<html>

<body> <h1>Trying to apply a low pass filter to ABR data </h1>

<p>Using package signal</p>

<pre><code class="r">install.packages(&quot;signal&quot;) </code></pre>

<pre><code>## Error: trying to use CRAN without setting a mirror </code></pre>

<pre><code class="r">library(signal) </code></pre>

<pre><code>## Warning: package &#39;signal&#39; was built under R version 3.0.2 </code></pre>

<pre><code>## Loading required package: MASS

    1. Attaching package: &#39;signal&#39;
    2. The following object is masked from &#39;package:stats&#39;:
    3. filter, poly

</code></pre>

<p>Read test file</p>

<pre><code class="r">dir() </code></pre>

<pre><code>## [1] &quot;2013-10-27-MFK.Rmd&quot; &quot;2013-10-27.html&quot; &quot;2013-10-27.R&quot;

    1. [4] &quot;2013-10-27.txt&quot; &quot;2013-10-28-MFK.html&quot; &quot;2013-10-28-MFK.md&quot;
    2. [7] &quot;2013-10-28-MFK.Rmd&quot; &quot;2013-10-29-MFK.Rmd&quot; &quot;Copy189L0A.ABR&quot;
    3. [10] &quot;Copy224l0a.txt&quot; &quot;Copy233L0B.ABR.log&quot; &quot;Copy233L0B.ABR.txt&quot;
    4. [13] &quot;figure&quot; &quot;knitr-testr.html&quot; &quot;knitr-testr.md&quot;
    5. [16] &quot;knitr-testr.Rmd&quot; &quot;kntR2.html&quot; &quot;kntR2.md&quot;
    6. [19] &quot;kntR2.Rmd&quot; &quot;my first knitr.html&quot; &quot;my first knitr.md&quot;
    7. [22] &quot;my first knitr.Rmd&quot; &quot;mydata_new&quot; &quot;mydata_new.txt&quot;
    8. [25] &quot;readrawabr.R&quot; &quot;Sandbox1.R&quot; &quot;Sandbox1.txt&quot;
    9. [28] &quot;signal.pdf&quot; &quot;texput.log&quot;

</code></pre>

<pre><code class="r">mydata &lt;- read.table(&quot;Copy233L0B.ABR.txt&quot;, header = T) head(mydata) #passed test </code></pre>

<pre><code>## msec left right spont bin

    1. 1 0.00 1000 1000 1000 1000
    2. 2 0.02 1000 1000 1000 1000
    3. 3 0.04 1000 1000 1000 1000
    4. 4 0.06 1000 1000 1000 1000
    5. 5 0.08 1000 1000 1000 1000
    6. 6 0.10 1000 1000 1000 1000

</code></pre>

<pre><code class="r">write.table(mydata, &quot;mydata_new.txt&quot;) mydata_new &lt;- read.table(&quot;mydata_new&quot;, header = T) head(mydata_new) #passed test </code></pre>

<pre><code>## msec left right spont bin

    1. 1 0.00 1000 1000 1000 1000
    2. 2 0.02 1000 1000 1000 1000
    3. 3 0.04 1000 1000 1000 1000
    4. 4 0.06 1000 1000 1000 1000
    5. 5 0.08 1000 1000 1000 1000
    6. 6 0.10 1000 1000 1000 1000

</code></pre>

<pre><code class="r">mydata_new$bincomp[1:1000] &lt;- (mydata_new$bin[1:1000] - (mydata_new$left[1:1000] +

   mydata_new$right[1:1000]))

head(mydata_new) </code></pre>

<pre><code>## msec left right spont bin bincomp

    1. 1 0.00 1000 1000 1000 1000 -1000
    2. 2 0.02 1000 1000 1000 1000 -1000
    3. 3 0.04 1000 1000 1000 1000 -1000
    4. 4 0.06 1000 1000 1000 1000 -1000
    5. 5 0.08 1000 1000 1000 1000 -1000
    6. 6 0.10 1000 1000 1000 1000 -1000

</code></pre>

<pre><code class="r">write.table(mydata_new, &quot;mydata_new.txt&quot;) #passed test head(mydata_new) </code></pre>

<pre><code>## msec left right spont bin bincomp

    1. 1 0.00 1000 1000 1000 1000 -1000
    2. 2 0.02 1000 1000 1000 1000 -1000
    3. 3 0.04 1000 1000 1000 1000 -1000
    4. 4 0.06 1000 1000 1000 1000 -1000
    5. 5 0.08 1000 1000 1000 1000 -1000
    6. 6 0.10 1000 1000 1000 1000 -1000

</code></pre>

<p>Test plotting for comparison </p>

<pre><code class="r"> plot(mydata_new[c(1, 2)], type = &quot;l&quot;, main = &quot;original left&quot;) </code></pre>

<p><img src="" alt="plot of chunk unnamed-chunk-3"/> </p>

<p>Now - try to apply a low pass filterusing butter() to determine the properties of the filter. </p>

<pre><code class="r">bf &lt;- butter(3, 0.1) test1 &lt;- filter(bf, mydata_new$left)

par(mfrow = c(1, 2)) plot(mydata_new[c(1, 2)], type = &quot;l&quot;, main = &quot;original left&quot;) plot(test1, main = &quot;butter(3, 0.1)&quot;) </code></pre>

<p><img src="" alt="plot of chunk unnamed-chunk-4"/> </p>

<p>Test type = &ldquo;low&rdquo; vs type = &ldquo;high&rdquo;</p>

<pre><code class="r">bf &lt;- butter(3, 0.1, type = &quot;low&quot;) test1 &lt;- filter(bf, mydata_new$left)

par(mfrow = c(1, 2)) plot(test1, main = &quot;butter type low&quot;)

bf &lt;- butter(3, 0.1, type = &quot;high&quot;) test1 &lt;- filter(bf, mydata_new$left) plot(test1, main = &quot;butter type high&quot;) </code></pre>

<p><img src="" alt="plot of chunk unnamed-chunk-5"/> </p>

<p>(guess default is low then)</p>

<p>Try changing filter properties - change filter order (first argument in function)</p>

<pre><code class="r">par(mfrow = c(2, 2)) plot(mydata_new[c(1, 2)], type = &quot;l&quot;, main = &quot;original left&quot;)

bf &lt;- butter(1, 0.1, type = &quot;low&quot;) test1 &lt;- filter(bf, mydata_new$left) plot(test1, main = &quot;butter(1, 0.1)&quot;)

bf &lt;- butter(3, 0.1, type = &quot;low&quot;) test1 &lt;- filter(bf, mydata_new$left) plot(test1, main = &quot;butter(3, 0.1)&quot;)

bf &lt;- butter(15, 0.1, type = &quot;low&quot;) test1 &lt;- filter(bf, mydata_new$left) plot(test1, main = &quot;butter(30, 0.1)&quot;) </code></pre>

<p><img src="" alt="plot of chunk unnamed-chunk-6"/> </p>

<p>Not really sure what the order is doing - ????</p>

<p>Stick with filter order == 3, change crirical frequency W. W-&gt; [0-1] where 1 is the Nyquist frequency (&frac12; of the sampling rate )</p>

<pre><code class="r">head(mydata_new) </code></pre>

<pre><code>## msec left right spont bin bincomp

    1. 1 0.00 1000 1000 1000 1000 -1000
    2. 2 0.02 1000 1000 1000 1000 -1000
    3. 3 0.04 1000 1000 1000 1000 -1000
    4. 4 0.06 1000 1000 1000 1000 -1000
    5. 5 0.08 1000 1000 1000 1000 -1000
    6. 6 0.10 1000 1000 1000 1000 -1000

</code></pre>

<p>sampling rate =&gt; every 0.2 msec ()</p>

<p>Looks like sampling rate at 5 kHz =&gt; Nyquist = 2.5 KHz</p>

<pre><code class="r">par(mfrow = c(2, 2)) plot(mydata_new[c(1, 2)], type = &quot;l&quot;, main = &quot;original left&quot;)

bf &lt;- butter(3, 0.01, type = &quot;low&quot;) test1 &lt;- filter(bf, mydata_new$left) plot(test1, main = &quot;butter(3, 0.01 (25 Hz)&quot;)

bf &lt;- butter(3, 0.1, type = &quot;low&quot;) test1 &lt;- filter(bf, mydata_new$left) plot(test1, main = &quot;butter(3, 0.1 (250 Hz))&quot;)

bf &lt;- butter(3, 1, type = &quot;low&quot;) test1 &lt;- filter(bf, mydata_new$left) plot(test1, main = &quot;butter(30, 1 (2.5KHz))&quot;) </code></pre>

<p><img src="" alt="plot of chunk unnamed-chunk-8"/> </p>

<p>Try the first derivative on the 250 LP</p>

<pre><code class="r"> bf &lt;- butter(3, 0.1, type = &quot;low&quot;) mydata_new$leftlow &lt;- filter(bf, mydata_new$left)

par(mfrow = c(1, 3)) plot(mydata_new$msec, mydata_new$left, type = &quot;l&quot;, main = &quot;original left&quot;) plot(mydata_new$msec, mydata_new$leftlow, type = &quot;l&quot;, main = &quot;lowpassed left&quot;) mydata_new$diffleft2[2:1000] &lt;- diff(mydata_new$leftlow)/diff(mydata_new$msec) plot(mydata_new$msec, mydata_new$diffleft2, ylim = c(-3000, 3000), type = &quot;l&quot;,

   main = &quot;first diff on lowpassed left&quot;)

</code></pre>

<p><img src="" alt="plot of chunk unnamed-chunk-9"/> </p>

<p>First deriv stil looks noisy - try different filters </p>

<pre><code class="r"> bf &lt;- butter(3, 0.04, type = &quot;low&quot;) mydata_new$leftlow &lt;- filter(bf, mydata_new$left)

par(mfrow = c(1, 3)) plot(mydata_new$msec, mydata_new$left, type = &quot;l&quot;, main = &quot;original left&quot;) plot(mydata_new$msec, mydata_new$leftlow, type = &quot;l&quot;, main = &quot;lowpassed 100 left&quot;) mydata_new$diffleft2[2:1000] &lt;- diff(mydata_new$leftlow)/diff(mydata_new$msec) plot(mydata_new$msec, mydata_new$diffleft2, ylim = c(-3000, 3000), type = &quot;l&quot;,

   main = &quot;first diff on lowpassed left&quot;)

</code></pre>

<p><img src="" alt="plot of chunk unnamed-chunk-10"/> </p>

<pre><code class="r"> par(mfrow = c(1, 1))

plot(mydata_new$msec, mydata_new$diffleft2, ylim = c(-3000, 3000), type = &quot;l&quot;,

   main = &quot;first diff on lowpassed left&quot;)

</code></pre>

<p><img src="" alt="plot of chunk unnamed-chunk-10"/> </p>

<p>Mmmmmmm&hellip;.</p>

</body>

</html>

Andy

  • Enter content here

Oris

  • Enter content here