Laboratorium EEG/CSP: Różnice pomiędzy wersjami

Z Brain-wiki
 
(Nie pokazano 107 wersji utworzonych przez 4 użytkowników)
Linia 1: Linia 1:
 
[[Laboratorium_EEG]]/BSS
 
[[Laboratorium_EEG]]/BSS
=Ślepa separacja źródeł=
+
 
 +
=Prezentacja=
 +
[https://brain.fuw.edu.pl/edu/images/2/2f/BSS.pdf slajdy z prezentacji]
 +
 
 +
=Ślepa separacja źródeł (BSS)=
 +
{{hidden begin|title=Wstęp teoretyczny do BSS}}
 
Rozważmy ''N''-kanałowy sygnał EEG.
 
Rozważmy ''N''-kanałowy sygnał EEG.
 
Próbkę tego sygnału możemy przedstawić jako punkt w przestrzeni rozpiętej przez osie, z których każda reprezentuje wartość potencjału w jednym kanale. Cały sygnał tworzy w tej przestrzeni chmurę punktów. Rozciągłość tej chmury w danym kierunku mówi nam o wariancji (zmienności) sygnału w tym kierunku.  
 
Próbkę tego sygnału możemy przedstawić jako punkt w przestrzeni rozpiętej przez osie, z których każda reprezentuje wartość potencjału w jednym kanale. Cały sygnał tworzy w tej przestrzeni chmurę punktów. Rozciągłość tej chmury w danym kierunku mówi nam o wariancji (zmienności) sygnału w tym kierunku.  
Linia 34: Linia 39:
 
==Common Spatial Pattern ==
 
==Common Spatial Pattern ==
 
===Koncepcja===
 
===Koncepcja===
Dla ustalenia uwagi możemy myśleć o eksperymencie wywołującym potencjał P300. Mamy w nim dwie sytuacje eksperymentalne. Oznaczmy (<math>T</math> - target) próby, w których pojawił się oczekiwany bodziec, zaś  (<math>NT</math> - non-target) gdy pojawił się bodziec standardowy.
+
Dla ustalenia uwagi możemy myśleć o eksperymencie wywołującym potencjał P300. Mamy w nim dwie sytuacje eksperymentalne. Oznaczmy <math>T</math> (target) próby, w których pojawił się oczekiwany bodziec, zaś  <math>NT</math> (non-target) gdy pojawił się bodziec standardowy.
Chcielibyśmy znaleźć taki montaż, czyli taką kombinację liniową kanałów, które maksymalizuje stosunek mocy (wariancji) sygnałów rejestrowanych w dwóch rożnych warunkach eksperymentalnych.  
+
Chcielibyśmy znaleźć taki montaż (czyli taką kombinację liniową kanałów), który maksymalizuje stosunek mocy (wariancji) sygnałów rejestrowanych w dwóch rożnych warunkach eksperymentalnych.
  
 
===Formalizm===
 
===Formalizm===
Linia 44: Linia 49:
 
Wariancja tego rzutowanego sygnału to:
 
Wariancja tego rzutowanego sygnału to:
 
:<math> \mathrm{var}(s_w) = E[s_w s_w^T] = E[ w^T x (w^T x)^T] = w^T E[x x^T] w = w^T C_x w </math>
 
:<math> \mathrm{var}(s_w) = E[s_w s_w^T] = E[ w^T x (w^T x)^T] = w^T E[x x^T] w = w^T C_x w </math>
Zatem znalezienie właściwego kierunku rzutowania można wyrazić jako szukanie maksimum wyrażenia <math> J(w) </math>(jest to tzw. iloraz Rayleigh'a):
+
Zatem znalezienie właściwego kierunku rzutowania można wyrazić jako szukanie maksimum wyrażenia <math> J(w) </math> (jest to tzw. iloraz Rayleigha):
 
: <math>J(w) = \frac{w^T C_T w}{w^T C_{NT} w}  </math>
 
: <math>J(w) = \frac{w^T C_T w}{w^T C_{NT} w}  </math>
 
Ekstremum tego ilorazu można znaleźć poprzez policzenie gradientu <math>J(w)</math> i przyrównanie go do zera:
 
Ekstremum tego ilorazu można znaleźć poprzez policzenie gradientu <math>J(w)</math> i przyrównanie go do zera:
:<math> \nabla J(w) =  \frac{ C_{T} w+w^T C_{T} 1}{w^T C_{NT} w}-\frac{w^T C_{T} w\left( 1  C_{NT} w+w^T C_{NT} 1\right)}{\left(w^T  C_{NT} w\right)^2}</math>
+
:<math> \nabla J(w) =  \frac{ 2 C_{T} w \left(w^T C_{NT} w\right) -2C_{NT} w \left(w^T C_{T} w \right)}{\left(w^T  C_{NT} w\right)^2} = \frac{  2}{w^T  C_{NT} w}\left[    C_{T}w  -\frac{w^T  C_{T} w}{w^T  C_{NT} w}  C_{NT} w \right]</math>
ponieważ macierze kowariancji są symetryczne
+
Przyrównując to wyrażenie do zera dostajemy do rozwiązania tzw. uogólnione zagadnienie własne:
::<math>\nabla J(w) =  \frac{  1}{w^T  C_{NT} w}\left[    C_{T} w+ C_{T}w  -\frac{w^T  C_{T} w}{w^T  C_{NT} w} \left(  C_{NT} w+ C_{NT}w \right) \right]</math>
 
::<math>= \frac{  2}{w^T  C_{NT} w}\left[    C_{T}w  -\frac{w^T  C_{T} w}{w^T  C_{NT} w}  C_{NT} w \right]</math>
 
Przyrównując to wyrażenie do zera dostajemy:
 
 
:<math>      C_{T}w  =\frac{w^T  C_{T} w}{w^T  C_{NT} w}  C_{NT} w  </math>
 
:<math>      C_{T}w  =\frac{w^T  C_{T} w}{w^T  C_{NT} w}  C_{NT} w  </math>
Liczba <math> \lambda =   \frac{w^T  C_{T} w}{w^T  C_{NT} w}   C_{NT} w </math> jest uogólnioną wartością własną, zaś <math>w</math> jest uogólnionym wektorem własnym odpowiadającym tej wartości.  
+
We wzorze tym liczba <math>\lambda=\frac{w^T  C_{T} w}{w^T  C_{NT} w}</math> spełniająca to równanie jest uogólnioną wartością własną, wtedy <math>w</math> jest uogólnionym wektorem własnym odpowiadającym tej wartości.  
  
Aby znaleźć <math> \lambda</math> i <math>w</math> wystarczy rozwiązać zagadnienie własne. W matlabie możemy w tym celu wykorzystać funkcję <tt>eig</tt>
+
Aby znaleźć <math> \lambda</math> i <math>w</math> możemy wykorzystać w Matlabie funkcję <tt>eig</tt>. Funkcja ta rozwiązuje (również) uogólnione zagadnienia własne postaci ''Aw''=&lambda;''Bw'' dostarczając w wyniku macierz wektorów własnych (w kolumnach) oraz macierz zawierającą na przekątnej odpowiadające im wartości własne.
 +
{{hidden end}}
  
 
<!--
 
<!--
Linia 74: Linia 77:
 
:<math>R^{+}_{CSP} + R^{-}_{CSP} = 1 </math>  (2.5)
 
:<math>R^{+}_{CSP} + R^{-}_{CSP} = 1 </math>  (2.5)
 
Tak więc suma par diagonalnych wartości (<math>k^{+}_{i}</math> i <math>k^{-}_{i}</math>) w macierzach <math>R^{+}_{CSP}</math> i <math>R^{-}_{CSP}</math> musi być równa 1.
 
Tak więc suma par diagonalnych wartości (<math>k^{+}_{i}</math> i <math>k^{-}_{i}</math>) w macierzach <math>R^{+}_{CSP}</math> i <math>R^{-}_{CSP}</math> musi być równa 1.
Korzystając z równania 2.5 wartości na diagonali można również zapisać za pomocą wzoru:
+
Korzystając z równania 2.5 wartości na przekątnej można również zapisać za pomocą wzoru:
  
 
:<math>k^{+}_{i} = \vec{p}^{T}_{i} R^{+} \vec{p}_{i}    </math> (2.6)
 
:<math>k^{+}_{i} = \vec{p}^{T}_{i} R^{+} \vec{p}_{i}    </math> (2.6)
Linia 89: Linia 92:
 
-->
 
-->
  
===Ćwiczenie symulacyjne ===
+
====Ćwiczenie symulacyjne ====
 +
{{hidden begin|title=kod przykładowy}}
 
<source lang  = matlab>
 
<source lang  = matlab>
 
% symulowany eksperyment składa się z sinusoidy udającej alfę spoczynkową i
 
% symulowany eksperyment składa się z sinusoidy udającej alfę spoczynkową i
 
% funkcji Gaussa udającego potencjał wywołany
 
% funkcji Gaussa udającego potencjał wywołany
% źródła te są symulowane niezależnie a potem mieszane przez macierz L
+
% źródła te są symulowane niezależnie a potem mieszane przez macierz A
 
% symulujemy źródła
 
% symulujemy źródła
 
% s1 - symuluje alfę
 
% s1 - symuluje alfę
Linia 147: Linia 151:
 
for r =1:N_rep
 
for r =1:N_rep
 
     B = squeeze(X(r,:,baseline_ind));  
 
     B = squeeze(X(r,:,baseline_ind));  
     R_B = R_B + B*B' ;
+
    tmp =cov(B');
   
+
     R_B = R_B + tmp./trace(tmp);%B*B' ;
 +
 
     E = squeeze(X(r,:,ERP_ind));
 
     E = squeeze(X(r,:,ERP_ind));
     R_E = R_E + E*E' ;
+
    tmp = cov(E');
 +
     R_E = R_E + tmp./trace(tmp);%E*E' ;
 
end
 
end
  
Linia 181: Linia 187:
 
     title('ilustracja sytuacji pomiarowej -\newline znane są potencjały na elektrodach w dwóch warunkach eksperymentalnych')
 
     title('ilustracja sytuacji pomiarowej -\newline znane są potencjały na elektrodach w dwóch warunkach eksperymentalnych')
 
subplot(2,2,3);
 
subplot(2,2,3);
     plot(t(baseline_ind),(squeeze(X(:,1,baseline_ind)))','b'); hold on
+
     plot(t(baseline_ind),(squeeze(X(:,2,baseline_ind)))','b'); hold on
 
     plot(t(ERP_ind),(squeeze(  X(:,2,ERP_ind)))','r'); hold off
 
     plot(t(ERP_ind),(squeeze(  X(:,2,ERP_ind)))','r'); hold off
 
     xlabel('elektroda 2')
 
     xlabel('elektroda 2')
Linia 231: Linia 237:
 
     legend('baseline','ERP')
 
     legend('baseline','ERP')
 
</source>
 
</source>
 +
{{hidden end}}
  
 
==Zastosowanie filtra CSP do detekcji potencjału P300==
 
==Zastosowanie filtra CSP do detekcji potencjału P300==
 +
{{hidden begin|title=Eksperyment}}
 
===Eksperyment===
 
===Eksperyment===
 +
* Proszę zapoznać się z instrukcją: http://laboratorium-eeg.braintech.pl/rozdz10.html
 +
* Proszę wczytać i uruchomić (na sucho) demo Demos->EEG_P300wz
 +
* Wspólne omówienie konstrukcji i potencjalnych modyfikacji tego scenariusza
 +
 
====Przygotowanie do badania:====
 
====Przygotowanie do badania:====
 
* założyć czepek z elektrodami w systemie 10-20;
 
* założyć czepek z elektrodami w systemie 10-20;
 
* elektrody referencyjne: M1 i M2;
 
* elektrody referencyjne: M1 i M2;
 
* elektroda GND w pozycji AFz.
 
* elektroda GND w pozycji AFz.
 
+
<!--
 
====Przygotowanie scenariuszy obci ====
 
====Przygotowanie scenariuszy obci ====
 
* w terminalu uruchomić <tt>obci srv</tt>;
 
* w terminalu uruchomić <tt>obci srv</tt>;
Linia 274: Linia 286:
 
# Po zakończeniu kalibracji uruchamiamy scenariusz &bdquo;Labirynt&rdquo;.
 
# Po zakończeniu kalibracji uruchamiamy scenariusz &bdquo;Labirynt&rdquo;.
 
# Danych z kalibracji potrzebować będziemy kilka zestawów.  Proszę powtórzyć kilkukrotnie scenariusz &bdquo;kalibracjaP300&rdquo;. Przed każdym uruchomieniem trzeba zmienić string w pliku <tt>file_id_name</tt> np. na <tt>test???</tt> gdzie <tt>???</tt> oznacza kolejne numery.
 
# Danych z kalibracji potrzebować będziemy kilka zestawów.  Proszę powtórzyć kilkukrotnie scenariusz &bdquo;kalibracjaP300&rdquo;. Przed każdym uruchomieniem trzeba zmienić string w pliku <tt>file_id_name</tt> np. na <tt>test???</tt> gdzie <tt>???</tt> oznacza kolejne numery.
 
+
-->
 +
{{hidden end}}
 
===Analiza wstępna===
 
===Analiza wstępna===
 +
Poszczególne etapy analizy proszę kodować w osobnych funkcjach. Funkcje te powinny być wywoływane z nadrzędnego skryptu, który powinien umożliwic wykoanie całości analiz.
 +
 
* Wczytać dane kalibracyjne do Matlaba i pociąć je na realizacje typu T &mdash; &bdquo;target&rdquo; (związane z wystąpieniami litery &bdquo;B&rdquo;) i NT &mdash; &bdquo;non-target&rdquo; (pozostałe litery) o długości &minus;200 do +800 ms wokół triggerów. Dla każdej realizacji odjąć trend liniowy.
 
* Wczytać dane kalibracyjne do Matlaba i pociąć je na realizacje typu T &mdash; &bdquo;target&rdquo; (związane z wystąpieniami litery &bdquo;B&rdquo;) i NT &mdash; &bdquo;non-target&rdquo; (pozostałe litery) o długości &minus;200 do +800 ms wokół triggerów. Dla każdej realizacji odjąć trend liniowy.
* Sygnał zmontować wzgl. &bdquo;połączonych uszu&rdquo; i wyświetlić średnie przebiegi dla warunku T i NT w układzie topograficznym &mdash; wykorzystać w tym celu funkcję <tt>topoplot</tt> z pakietu Eeglab.
+
* Sygnał zmontować wzgl. &bdquo;połączonych uszu&rdquo; i wyświetlić średnie przebiegi dla warunku T i NT w układzie topograficznym &mdash; można wykorzystać w tym celu poniższy fragment kodu.
 +
{{hidden begin|title= fragment kodu do rysowania dwóch ERPów -- zamiast funkcji plottopo}}
 +
<source lang = matlab>
 +
%% stworzenie osi
 +
      % zakładam, że dane do rysowania są w dwóch strukturach EEG1 i EEG2 (struktury eeglab),
 +
      % te dane są podzielone na realizacje i mają kształt (kanały , czas, epoki)
 +
      % i że mamy już załadowane położenia elektrod we współrzędnych
 +
      % biegunowych
 +
      w = 0.125;
 +
      h = 0.125;
 +
      sc = 0.8;
 +
      figure()
 +
    for chanNum = 1:length(EEG1.chanlocs)
 +
        r =EEG1.chanlocs(chanNum).radius;
 +
        theta = EEG1.chanlocs(chanNum).theta;
 +
        x = r* sin(theta/180*pi)*sc+0.46;
 +
        y = r* cos(theta/180*pi)*sc+0.46;
 +
        ax(chanNum) = axes('Position', [x, y, w, h]);
 +
    end
 +
%%uśredniam EEG po powtórzeniach aby otrzymać ERP
 +
  ERP1 =squeeze( mean( EEG1.data,3)) ;
 +
  ERP2 =squeeze( mean( EEG2.data,3)) ;
 +
%% rysowanie uśrednionych potencjałów z dwóch struktur EEG
 +
for chanNum = 1:length(EEG1.chanlocs)
 +
    hold(ax(chanNum),'on');
 +
    plot(ax(chanNum), EEG1.times, ERP1(chanNum ,:));
 +
    plot(ax(chanNum), EEG2.times, ERP2(chanNum ,:));
 +
    title(ax(chanNum),EEG1.chanlocs(chanNum).labels );
 +
    hold(ax(chanNum),'off');
 +
end
 +
</source>
 +
{{hidden end}}
  
Poniżej zaprezentowany jest przykładowy skrypt do cięcia danych wokół znaczników. Działa on z plikami zawartymi w archiwum:
+
<small>Poniżej zaprezentowany jest przykładowy skrypt do cięcia danych wokół znaczników. Działa on z plikami zawartymi w archiwum:
 
: [[Plik:KalibracjaP300.tar.gz]]  
 
: [[Plik:KalibracjaP300.tar.gz]]  
 
Korzysta z funkcji pomocniczych dostępnych w dystrybucji obci w katalogu  
 
Korzysta z funkcji pomocniczych dostępnych w dystrybucji obci w katalogu  
 
: /usr/share/openbci/analysis/matlab_obci_signal_processing
 
: /usr/share/openbci/analysis/matlab_obci_signal_processing
Openbci można pobrać z https://github.com/BrainTech/openbci
+
Openbci można pobrać z https://github.com/BrainTech/openbci</small>
  
 +
{{hidden begin|title=przykładowy skrypt}}
 
<source lang = matlab>
 
<source lang = matlab>
 
% ustalamy nzawy plików z danymi
 
% ustalamy nzawy plików z danymi
Linia 372: Linia 419:
 
plot(squeeze(mean(NonTargetSignal,1))','b')
 
plot(squeeze(mean(NonTargetSignal,1))','b')
 
</source>
 
</source>
 +
{{hidden end}}
  
===Analiza CSP===
+
===ZADANIE: Analiza CSP===
* Korzystając z danych kalibracyjnych wykonać analizę CSP wzmacniającą potencjał P300.
+
 
 +
Przegląd badań o P300: https://www.ncbi.nlm.nih.gov/pmc/articles/PMC2715154/
 +
 
 +
Link do Read menager [https://drive.google.com/file/d/1OgOduK5Zn7GgNl5XdCyLWXHJ7wTJIWcC/view?usp=share_link]
 +
<!---
 +
[https://drive.google.com/open?id=0BzwQ_Lscn8yDS3RXNWdBbkxEQ2c]
 +
--->
 +
* Wykonać analizę CSP wzmacniającą potencjał P300.
 
* Zaprezentować średnią ze wszystkich kanałów źródłowych z warunku target (jeden kolor) i non-target (inny kolor) w subplotach ułożonych w prostokątnej siatce. Zaobserwować dla którego kanału średnie różnią się najbardziej. Czy jest związek tego kanału z wartościami własnymi?
 
* Zaprezentować średnią ze wszystkich kanałów źródłowych z warunku target (jeden kolor) i non-target (inny kolor) w subplotach ułożonych w prostokątnej siatce. Zaobserwować dla którego kanału średnie różnią się najbardziej. Czy jest związek tego kanału z wartościami własnymi?
  
* Dla kanału najbardziej różnicującego wykonać mapki topograficzne wektorów odpowiadających:
+
* Dla kanału najbardziej różnicującego wykonać mapki topograficzne (do wykonania tych mapek wykorzystać funkcję <tt>topoplot</tt> z pakietu <tt>eeglab</tt>) wektorów odpowiadających:
 
** filtrowi przestrzennemu  
 
** filtrowi przestrzennemu  
 
** rzutu topograficznego źródła na elektrody.
 
** rzutu topograficznego źródła na elektrody.
* Do wykonania tych mapek wykorzystać funkcję <tt>topoplot</tt> z pakietu <tt>eeglab</tt>
+
<!---
 
* Zbadać powtarzalność topografii pomiędzy plikami konfiguracyjnymi.
 
* Zbadać powtarzalność topografii pomiędzy plikami konfiguracyjnymi.
 +
--->
 +
 +
{{hidden begin|title=Wybór i separacja cech}}
  
 
===Wybór i separacja cech===
 
===Wybór i separacja cech===
 
* Przedstaw na rysunkach nałożone na siebie pojedyncze realizacje z warunków target i non-target po rzutowaniu na wektor <math>w</math> odpowiadający największej i kolejnej wartości  własnej.  
 
* Przedstaw na rysunkach nałożone na siebie pojedyncze realizacje z warunków target i non-target po rzutowaniu na wektor <math>w</math> odpowiadający największej i kolejnej wartości  własnej.  
* Przedstaw wykresy punktowe, takie że na jednej osi jest moc sygnału odpowiadającego największej wartości własnej a na drugiej osi kolejnej wartości własnej; jeden punkt reprezentuje jedno powtórzenie.
+
* Przedstaw wykresy punktowe takie, że na jednej osi jest moc sygnału (suma kwadratów wartości próbek w wybranym zakresie czasu) odpowiadającego największej wartości własnej, a na drugiej osi kolejnej (mniejszej) wartości własnej; jeden punkt reprezentuje jedno powtórzenie.
* Wykonaj serię wykresów jak w poprzednim punkcie dla uśrednień kolejno po 2, 4, 6, 8 i 10 realizacjach. Zaobserwuj jak zmienia się separacja w grupach target i non-target.
+
* Wykonaj serię wykresów jak w poprzednim punkcie dla uśrednień sygnałów kolejno po 2, 4, 6, 8 i 10 realizacjach:
 +
**  Liczymy potencjał wywołany dla danej liczby powtórzeń.
 +
** Następnie podnosimy wartości próbek do kwadratu
 +
**  i sumujemy je w wybranym zakresie czasu.
 +
* Zaobserwuj jak zmienia się separacja w grupach target i non-target.
 +
{{hidden end}}
  
 
==Filtry przestrzenne dla SSEP ==
 
==Filtry przestrzenne dla SSEP ==
 
+
{{hidden begin|title=Filtry przestrzenne dla SSEP}}
 
=== Teoria===
 
=== Teoria===
 
Ciekawa koncepcja filtra przestrzennego dla SSVEP zaprezentowana jest  tu: http://www.eurasip.org/Proceedings/Eusipco/Eusipco2009/contents/papers/1569193209.pdf
 
Ciekawa koncepcja filtra przestrzennego dla SSVEP zaprezentowana jest  tu: http://www.eurasip.org/Proceedings/Eusipco/Eusipco2009/contents/papers/1569193209.pdf
  
Po krótce można ją rozumieć podobnie do tego co robiliśmy rozważając filtry przestrzenne CSP, z tym, że dla SSVEP oraz innych potencjałów wywołanych stanu ustalonego możemy skorzystać z dodatkowych informacji dotyczących poszukiwanych źródeł. Wiemy mianowicie, że powinny one oscylować z częstością bodźca, i być może jej harmonicznych.
+
Pokrótce można ją rozumieć podobnie do tego co robiliśmy rozważając filtry przestrzenne CSP z tym, że dla SSVEP oraz innych potencjałów wywołanych stanu ustalonego możemy skorzystać z dodatkowych informacji dotyczących poszukiwanych źródeł. Wiemy mianowicie, że powinny one oscylować z częstością bodźca, i być może jej harmonicznych.
  
 
Przyda nam się macierz <math>S</math> zbudowana tak, że w kolejnych kolumnach znajdują się sinusy i cosinusy kolejnych częstości harmonicznych. Wektory te unormujemy, żeby miały energię równą 1. Innymi słowy macierz <math>S</math> zbudowana jest z wersorów rozpinających przestrzeń, w której powinien znajdować się sygnał SSVEP.
 
Przyda nam się macierz <math>S</math> zbudowana tak, że w kolejnych kolumnach znajdują się sinusy i cosinusy kolejnych częstości harmonicznych. Wektory te unormujemy, żeby miały energię równą 1. Innymi słowy macierz <math>S</math> zbudowana jest z wersorów rozpinających przestrzeń, w której powinien znajdować się sygnał SSVEP.
Linia 414: Linia 477:
  
  
Aby w badanym sygnale znaleźć składowe odpowiadające SSVEP musimy rzutować sygnał <math>X</math> (macierz sygnałów ''kanały x próbki'')  na przestrzeń rozpiętą przez <math>S</math>:
+
Aby w badanym sygnale znaleźć składowe odpowiadające SSVEP musimy rzutować sygnał <math>X</math> (macierz sygnałów ''kanały &times; próbki'')  na przestrzeń rozpiętą przez <math>S</math>:
 
:<math>A = X*S</math>
 
:<math>A = X*S</math>
Macierz <math>A</math> zawiera współczynniki będące iloczynami skalarnymi sygnałów i wersorów. Mówią one o tym "jak duże" jest sinusa bądź cosinusa o danej częstości w pierwotnym sygnale. Komponenty SSVEP zawarte w sygnale <math>X</math> odzyskujemy tak:
+
Macierz <math>A</math> zawiera współczynniki będące iloczynami skalarnymi sygnałów i wersorów. Mówią one o tym &bdquo;jak dużo&rdquo; jest sinusa bądź cosinusa o danej częstości w pierwotnym sygnale. Komponenty SSVEP zawarte w sygnale <math>X</math> odzyskujemy tak:
 
:<math>\mathrm{SSVEP} = A S^T</math>
 
:<math>\mathrm{SSVEP} = A S^T</math>
  
Linia 425: Linia 488:
 
: to wszystkie komponenty sygnału, które nas nie interesują.
 
: to wszystkie komponenty sygnału, które nas nie interesują.
  
Filtr przestrzenny, który chcemy zbudować powinien maksymalizować stosunek wariancji <math>\mathrm{SSVEP} = A S^T</math> do wariancji <math>Y = X-\mathrm{SSVEP}</math>.
+
Filtr przestrzenny, który chcemy zbudować powinien maksymalizować stosunek wariancji <math>\mathrm{SSVEP} = A S^T</math> do wariancji <math>Y = X-\mathrm{SSVEP}</math>. Macierz kowariancji powinna być uśredniona po powtórzeniach a kowariancja sygnału w każdym powtórzeniu powinna być znormalizowana poprzez podzielenie przez jej ślad (Matlabowa funkcja <tt>cov</tt> już wykonuje tę operację).
Dalej możemy zastosować technikę znaną z konstrukcji filtrów CSP, tzn. maksymalizacji ilorazu Rayleigh'a za pomocą rozwiązania ogólnionego zagadnienia własnego dla macierzy kowariancji <math>\mathrm{SSVEP} </math> i <math>Y </math>.
+
Dalej możemy zastosować technikę znaną z konstrukcji filtrów CSP, tzn. maksymalizacji ilorazu Rayleigha za pomocą rozwiązania uogólnionego zagadnienia własnego dla macierzy kowariancji <math>\mathrm{SSVEP} </math> i <math>Y </math>.
  
===Poniżej prosta demonstracja dla danych zebranych EEG przy stymulacji SSVEP z częstotliwością 38Hz.===
+
===Poniżej prosta demonstracja dla danych zebranych EEG przy stymulacji SSVEP z częstotliwością 38 Hz.===
 
Spakowane dane: [[Plik:PrzykladoweDaneSSVEP.mat.gz]].
 
Spakowane dane: [[Plik:PrzykladoweDaneSSVEP.mat.gz]].
 
W oparciu o powyższy opis proszę zaimplementować  funkcję <tt>cosSinCSP</tt>. Prawidłowo zaimplementowana funkcja wraz z poniższym kodem powinna generować rysunek:
 
W oparciu o powyższy opis proszę zaimplementować  funkcję <tt>cosSinCSP</tt>. Prawidłowo zaimplementowana funkcja wraz z poniższym kodem powinna generować rysunek:
[[Plik:Rys_SSVEP_demo.png|400px|thumb|right|podpis grafiki]]  
+
[[Plik:Rys_SSVEP_demo.png|400px|podpis grafiki]]
 +
Przykładowy skrypt i dane prezentujący konstrukcję i działanie tego typu filtrów przestrzennych dla pełnych danych z eksperymentu SSVEP: [[Plik:SSVEP_demo_csp.tar.gz]]
  
 +
{{hidden begin|title=przykładowy skrypt}}
 
<source lang = matlab>
 
<source lang = matlab>
 
% wczytujemy dane
 
% wczytujemy dane
load('przykladoweDaneSSVEP.mat');
+
load('PrzykladoweDaneSSVEP.mat');
  
 +
[numberOfTrials numberOfChannels numberOfSamples] = size(X.data);
 +
namesOfChannels = X.channels;
 +
 
% numberOfChannels numberOfSamples numberOfTrials
 
% numberOfChannels numberOfSamples numberOfTrials
P = zeros(numberOfChannels,numberOfChannels);
+
W = zeros(numberOfChannels,numberOfChannels);
 
numberOfHarmonics = 3;
 
numberOfHarmonics = 3;
 
signal = X.data; % (  powtórzenie,  kanał, próbki)
 
signal = X.data; % (  powtórzenie,  kanał, próbki)
 
+
 
S = zeros(size(signal));
 
S = zeros(size(signal));
P = cosSinCSP(signal,X.stimulation,numberOfHarmonics,X.sampling);
+
W = cosSinCSP(signal,X.stimulation,numberOfHarmonics,X.sampling);
 
for powt = 1:size(signal,1)
 
for powt = 1:size(signal,1)
     S(powt,:,:) = P'*squeeze(signal(powt,:,:));
+
     S(powt,:,:) = W'*squeeze(signal(powt,:,:));
 
end
 
end
 
+
 
figure('Name',['Stymulacja: ',num2str(X.stimulation),' Hz'])
 
figure('Name',['Stymulacja: ',num2str(X.stimulation),' Hz'])
 
for i =1:numberOfChannels
 
for i =1:numberOfChannels
Linia 454: Linia 522:
 
     subplot(2,8,i)
 
     subplot(2,8,i)
 
     PP=0;
 
     PP=0;
     for rep = 1:freq_trial_count
+
     for rep = 1:numberOfTrials
         x = signal(rep,i,:);
+
         x = squeeze(signal(rep,i,:));
         [Pxx,ff]=pwelch(x, X.sampling, 1, X.sampling, X.sampling);
+
         [Pxx,ff] = pwelch(x, X.sampling, 1, X.sampling, X.sampling);
 
         PP =PP + Pxx;
 
         PP =PP + Pxx;
 
     end
 
     end
 
     plot(ff(ff<60),PP(ff<60))
 
     plot(ff(ff<60),PP(ff<60))
 
     title(namesOfChannels{i})
 
     title(namesOfChannels{i})
   
+
 
     % rysujemy widma uśrednione po realizacjach dla danych  
 
     % rysujemy widma uśrednione po realizacjach dla danych  
 
     % z estymowanych źródeł CSP
 
     % z estymowanych źródeł CSP
 
     subplot(2,8,8+i)
 
     subplot(2,8,8+i)
 
     PP=0;
 
     PP=0;
     for rep = 1:freq_trial_count
+
     for rep = 1:numberOfTrials
         s = S(rep,i,:);
+
         s = squeeze(S(rep,i,:));
 
         [Pss,ff]=pwelch(s, X.sampling, 1, X.sampling, X.sampling);
 
         [Pss,ff]=pwelch(s, X.sampling, 1, X.sampling, X.sampling);
 
         PP =PP + Pss;
 
         PP =PP + Pss;
Linia 475: Linia 543:
 
end
 
end
 
</source>
 
</source>
 +
{{hidden end}}
 +
 +
 +
====ZADANIE: Analiza danych z eksperymentu własnego ====
 +
# Przefiltruj sygnały EEG w paśmie 1-45 Hz za pomocą procedury <tt>filtfilt</tt>.
 +
# Na podstawie sygnału trigger oraz danych zapisanych w pliku wyodrębnij sygnały EEG zarejestrowane w trakcie stymulacji z odpowiednimi częstościami.
 +
# Uśrednij sygnały odpowiadające stymulacji tą samą częstością.
 +
# Obejrzyj uśrednione sygnały. (Zaprezentuj je).
 +
 +
#* Sposób I:
 +
#**Dla każdej realizacji wyestymuj przy pomocy metody Welcha widmo mocy sygnału EEG.
 +
#**Dla każdej częstości stymulacji wyznacz poziom tła na podstawie widm pochodzących ze stymulacji innymi częstościami. Np. dla stymulacji częstością 10 Hz poziom tła można wyznaczyć jako 95 centyl ze zbioru wartości widma w częstości 10 Hz dla stymulacji częstościami {4, 7, 13, 16, 20, 25, 30, 35, 40} Hz.
 +
#**Dla każdej częstości stymulacji wyznacz miarę odpowiedzi SSVEP (amplitudę widma odpowiadającą częstości stymulacji powyżej poziomy tła dla pojedynczej próby).
 +
#**Zaprezentuj widma otrzymane przy stymulacjach różnymi częstościami wraz z korytarzem odpowwiadajacym 95% przedziałowi ufności wyznaczonemu dla widm z pojedynczych realizacji.
 +
#**Sporządź wykres odpowiedzi SSVEP od częstości z zaznaczeniem przedziałów ufności i poziomu tła.
 +
#* Sposób II:
 +
#**Wyestumuj filtr CSP-SSVEP wspólny dla wszystkich częstości stymulacji
 +
#**Powtórz kroki ze sposobu I dla uzyskanych komponentów.
 +
#**Zaprezentuj filtry przestrzenne i topografie dla poszczególnych komponentów
 +
#**Dla przypomnienia:
 +
#***Filtr to zestaw współczynników z jakimi należy zsumować sygnały z poszczególnych kanałów EEG aby dostać komponenty odpowiadające hipotetycznym źródłom nieskorelowanym. Filtr można zilustrować na głowie, przypisując poszczególnym pozycjom elektrod wagi równe współrzędnym wektora w (kolumna macierzy W).
 +
#***Topografia źródła to zestaw współczynników z jakimi docierają one do poszczególnych kanałów EEG. Topografia zawarta jest w wierszach macierzy odwrotnej do W.
 +
#**Można rysunki wykonać jako macierze 5x5 i w pozycji elektrody kolorujemy proporcjonalnie do współczynnika.
 +
 +
===SSVEP-BCI===
 +
W zajęciach tych przydadzą nam się informacje z:
 +
https://brain.fuw.edu.pl/edu/index.php/Laboratorium_EEG/Wprowadzenie_do_syg_online
 +
====Wstęp====
 +
Naszym celem będzie stworzenie prostego interfejsu wykorzystującego zjawisko SSVEP.
 +
Po dwóch stronach monitora zamocujemy diody. Każda będzie migać ze swoją ustaloną częstością (np. 16 i 22 Hz) - warto zadbać aby nie były to częstości powiązane ze sobą harmonicznie, a z drugiej strony aby, biorąc pod uwagę wyniki poprzedniego zadania, dawały dobra odpowiedź SSVEP.
 +
 +
Eksperyment będzie miał dwie cześci: sesję kalibracje i sesję on-line. Pomiędzy tymi sesjami będziemy uczyć kalsyfikator. Na podstawie części kalibracyjnej ustalimy jakie parametry przetwarznego on-line sygnału świadczą o patrzeniu się na diodę z lewej a jakie na tą z prawej strony ekranu.
 +
 +
Potem w sesji online będziemy porównywać (za pomocą predykcji klasyfikatora) rejestrowany sygnał z tymi warościami kalibracyjnymi i na tej podstawie system będzie zwracał informację o wyborze lewej lub prawej diody. To powinno umożliwić prostą komunikację na zasadzie pytanie i odpowiedź TAK/NIE.
  
Przykładowy skrypt i dane prezentujący konstrukcję i działanie tego typu filtrów przestrzennych dla pełnych danych z eksperymentu SSVEP: [[Plik:SSVEP_demo_csp.tar.gz]]
+
==== Sesja kalibracycjna====
 +
* Zakładamy czepek
 +
* Częstość próbkowania ustawiamy na 256Hz
 +
* Na podstawie kodu: https://brain.fuw.edu.pl/edu/index.php/Laboratorium_EEG/Wprowadzenie_do_syg_online#.C4.86wiczenie:_Wykorzystanie_pomiaru_EMG_do_sterowania_on-line
 +
tworzymy programik, który zamiast pętli while tworzy odpowiednie pętle for aby:
 +
* pięciokrotnie zarejestrować sekwencję trzech warunków eksperymentalnych:
 +
** patrz 5s na diodę z lewej (warunek l)
 +
** patrz 5s na środek ekranu (warunek s)
 +
** patrz 5s na diodę z prawej (warunek p)
 +
* w czasie tego patrzenia:
 +
** odbieramy próbki w pakietach o długości 0.5s
 +
** każdy pakiet filtrujem (technika filtrowania on-line) w pasmach dookoła wybranych dwóch częstości (PASMO_LEWE / PASMO_PRAWE)
 +
** przefiltrowany pakiet przeliczamy na RMS
 +
** zbieramy sześć zbiorów wyników -  zestawy RMSów związane z każdym z waunków kalibracyjnych (LEWY/SPOCZYNEK/PRAWY) dla PASMO_LEWE i PASMO_PRAWE.
 +
* Normalizujemy RMSy. Dla pasma lewego obliczamy (RMS_(l/p/s) - np.mean(RMS_s)) / np.sdt(RMS_s) i analogicznie dla pasma prawego. Małe indeksy oznaczaają tu warunki. Zapamiętujemy współczynniki normalizacyjne.
 +
** Ogladamy rozkłady uzyskanych wielkości (znormalizowanych RMSów).
 +
** Uczymy klasyfikator np. regresję logistyczną (https://scikit-learn.org/stable/modules/generated/sklearn.linear_model.LogisticRegression.html) do rozpoznawania, z którym warunkiem patrzenia mamy do czynienia.
  
 +
==== Sesja online====
 +
* wczytujemy wyuczony model i kalibracyjne wartości np.mean(RMS_s)) i np.sdt(RMS_s) dla pasm lewego i prawego
 +
* Odbieramy próbki w pakietach o długości 0.5s
 +
** każdy pakiet filtrujem (technika filtrowania on-line) w pasmach dookoła wybranych dwóch częstości (PASMO_LEWE / PASMO_PRAWE)
 +
** przefiltrowany pakiet przeliczamy na RMS
 +
** Normalizujemy RMSy. Dla pasma lewego obliczamy (RMS_(l/p/s) - np.mean(RMS_s)) / np.sdt(RMS_s) i analogicznie dla pasma prawego. Małe indeksy oznaczaają tu warunki.
 +
** robimy predykcję klasyfikatora, z którym warunkiem patrzenia mamy do czynienia. Wyświetlamy na ekranie komunikat.
 +
* Testujemy czy powyższy schemat analizy pozwala na komunikację.
 +
{{hidden end}}
 
<!--
 
<!--
 
===Eksperyment ASSR===
 
===Eksperyment ASSR===
Linia 515: Linia 642:
  
 
==ICA jako filtr przestrzenny==
 
==ICA jako filtr przestrzenny==
 +
{{hidden begin|title=Wstęp teoretyczny do ICA}}
 
===Definicja ===
 
===Definicja ===
 
Independent Component Analysis (ICA) jest metodą statystycznej analizy sygnałów, która dokonuje dekompozycji wielokanałowych zapisów na składowe niezależne w sensie statystycznym.
 
Independent Component Analysis (ICA) jest metodą statystycznej analizy sygnałów, która dokonuje dekompozycji wielokanałowych zapisów na składowe niezależne w sensie statystycznym.
Dwie składowe <math>s_{1}</math> i <math>s_{2}</math> są niezależne jeżeli wiedza o wartości <math>s_{1}</math> nie daje żadnych informacji o możliwych wartościach <math>s_{2}</math>. ICA może być wyrażona przez prosty model generatywny:
+
Dwie składowe ''s''<sub>1</sub> i ''s''<sub>2</sub> są niezależne jeżeli wiedza o wartości ''s''<sub>1</sub> nie daje żadnych informacji o możliwych wartościach ''s''<sub>2</sub>. ICA może być wyrażona przez prosty model generatywny:
: <math> \mathbf{x} = \mathbf{D}\mathbf{s} </math>
+
: '''x''' = '''Ds'''
: gdzie <math>\mathbf{x}=\{x^{1},x^{2},\dots, x^{n}\}</math> jest zmierzonym <math>n</math> kanałowym sygnałem, <math>\mathbf{D}</math> jest macierzą mieszającą zaś <math>\mathbf{s}=\{s^{1},s^{2},\dots,s^{n} \}</math> jest aktywnością <math>n</math> źródeł. Podstawowym założeniem dotyczącym <math>\mathbf{s}</math> jest to, że <math>s^{i}</math> są statystycznie niezależne.  Aby wyestymować model musimy też założyć, że składowe mają niegaussowskie rozkłady wartości (Hyvarinen, 2000).
+
: gdzie '''x''' = {''x''<sup>1</sup>, ''x''<sup>2</sup>, ..., ''x''<sup>''n''</sup>} jest zmierzonym ''n'' kanałowym sygnałem, '''D''' jest macierzą mieszającą zaś '''s''' = {''s''<sup>1</sup>, ''s''<sup>2</sup>, ..., ''s''<sup>''n''</sup>} jest aktywnością ''n'' źródeł. Podstawowym założeniem dotyczącym '''s''' jest to, że ''s''<sup>''i''</sup> są statystycznie niezależne.  Aby wyestymować model musimy też założyć, że składowe mają niegaussowskie rozkłady wartości (Hyvärinen, 2000).
  
 
Dodatkowo model ten zakłada następujące fakty:
 
Dodatkowo model ten zakłada następujące fakty:
Linia 525: Linia 653:
 
# Sygnały pochodzące z każdego ze źródeł są niezależne od pozostałych
 
# Sygnały pochodzące z każdego ze źródeł są niezależne od pozostałych
 
# Źródła oraz proces ich mieszania są stacjonarne, tzn, ich momenty statystyczne nie zależą od czasu
 
# Źródła oraz proces ich mieszania są stacjonarne, tzn, ich momenty statystyczne nie zależą od czasu
# Energie (wariancje) źródeł nie mogą być wyznaczone jednoznacznie. Dzieje się tak ponieważ pomnożenie amplitudy <math>i-{tego}</math> źródła może być uzyskane poprzez przemnożenie albo <math>s^{i}</math> albo przez przemnożenie <math>i-tej</math> kolumny macierzy <math>\mathbf{D}</math>}.  Naturalnym rozwiązaniem tej niejednoznaczności jest wprowadzenie konwencji, że komponenty są normowane tak aby miały wariancję 1: <math>E[s^{i}]=1</math>.
+
# Energie (wariancje) źródeł nie mogą być wyznaczone jednoznacznie. Dzieje się tak ponieważ pomnożenie amplitudy ''i''-tego źródła może być uzyskane poprzez przemnożenie albo ''s''<sup>''i''</sup> albo przez przemnożenie ''i''-tej kolumny macierzy '''D'''.  Naturalnym rozwiązaniem tej niejednoznaczności jest wprowadzenie konwencji, że komponenty są normowane tak aby miały wariancję 1: E[''s''<sup>''i''</sup>] = 1.
# Kolejność komponentów jest dowolna.  Bo jeśli: w ten sam sposób zmienimy kolejność komponentów w <math>\mathbf{s}</math>, i kolumn w <math>\mathbf{D}</math> to dostaniemy dokładnie ten sam sygnał <math>\mathbf{x}</math>.
+
# Kolejność komponentów jest dowolna.  Bo jeśli w ten sam sposób zmienimy kolejność komponentów w '''s''' i kolumn w '''D''' to dostaniemy dokładnie ten sam sygnał '''x'''.
  
Głównym wyzwaniem w analizie ICA jest estymacja macierzy mieszającej <math>\mathbf{D}</math>. Gdy jest ona znana to komponenty mogą być wyliczone w następujący sposób:
+
Głównym wyzwaniem w analizie ICA jest estymacja macierzy mieszającej '''D'''. Gdy jest ona znana to komponenty mogą być wyliczone w następujący sposób:
: <math> \mathbf{s} = \mathbf{D}^{-1}\mathbf{x} </math>
+
: '''s''' = '''D'''<sup>&minus;1</sup>'''x'''
  
 
=== Estymacja ===
 
=== Estymacja ===
 
Znalezienie niezależnych komponentów może być rozważane w świetle Centralnego Twierdzenia Granicznego jako poszukiwanie komponentów o możliwie nie gaussowskim rozkładzie.
 
Znalezienie niezależnych komponentów może być rozważane w świetle Centralnego Twierdzenia Granicznego jako poszukiwanie komponentów o możliwie nie gaussowskim rozkładzie.
Aby zrozumieć to podejście prześledźmy heurystykę zaproponowaną przez (Hyvarinen, 2000).  
+
Aby zrozumieć to podejście prześledźmy heurystykę zaproponowaną przez (Hyvärinen, 2000).  
 
Dla prostoty załóżmy, że poszukiwane źródła niezależne mają identyczne rozkłady.  
 
Dla prostoty załóżmy, że poszukiwane źródła niezależne mają identyczne rozkłady.  
Zdefiniujmy <math>y = \mathbf{w}^{\mathsf{T}}\mathbf{x}</math>. Zauważmy, że jeśli <math>\mathbf{w}^{\mathsf{T}}</math> jest jedną z kolumn macierzy <math>\mathbf{D}^{-1}</math>, to <math>y</math> jest jednym z poszukiwanych komponentów.
+
Zdefiniujmy  
Zamieniając zmienne <math>\mathbf{z}=\mathbf{D}^{\mathsf{T}}\mathbf{w}</math> możemy napisać <math>y = \mathbf{w}^{\mathsf{T}}\mathbf{x} = \mathbf{w}^{\mathsf{T}} \mathbf{D}\mathbf{s} = \mathbf{z}^{\mathsf{T}}\mathbf{s}</math>. To uwidacznia fakt, że <math>y</math> jest liniową kombinacją składowych <math>s^{i}</math> z wagami danymi przez <math>z_{i}</math>.  
+
 
 +
''y''&nbsp;= '''w'''<sup>T</sup>'''x'''.
 +
 
 +
Zauważmy, że jeśli  
 +
 
 +
'''w'''<sup>T</sup>  
 +
 
 +
jest jedną z kolumn macierzy  
 +
 
 +
'''D'''<sup>&minus;1</sup>,  
 +
 
 +
to ''y'' jest jednym z poszukiwanych komponentów.
 +
Zamieniając zmienne  
 +
 
 +
'''z'''&nbsp;= '''D'''<sup>T</sup>'''w'''
 +
 
 +
możemy napisać  
 +
 
 +
''y''&nbsp;= '''w'''<sup>T</sup>'''x'''&nbsp;= '''w'''<sup>T</sup>'''Ds'''&nbsp;= '''z'''<sup>T</sup>'''s'''.  
 +
 
 +
Uwidacznia to fakt, że ''y'' jest liniową kombinacją składowych s<sup>''i''</sup> z wagami danymi przez z<sub>''i''</sub>.  
 +
 
 
Z centralnego twierdzenia granicznego wynika, że suma niezależnych zmiennych losowych ma  bardziej gaussowski charakter niż każda z tych zmiennych osobno.  
 
Z centralnego twierdzenia granicznego wynika, że suma niezależnych zmiennych losowych ma  bardziej gaussowski charakter niż każda z tych zmiennych osobno.  
Liniowa kombinacja staje się najmniej gaussowska gdy <math>\mathbf{z}</math> ma tylko jeden element niezerowy. W tym przypadku <math>y</math> jest proporcjonalny do <math>s^{i}</math>.  
+
Liniowa kombinacja staje się najmniej gaussowska gdy '''z''' ma tylko jeden element niezerowy. W tym przypadku ''y'' jest proporcjonalny do s<sup>''i''</sup>.  
Zatem problem estymacji modelu ICAmoże być sformułowany jako problem znalezienia takiego <math>\mathbf{w}</math> , który maksymalizuje niegaussowskość <math>y=\mathbf{w}^{\mathsf{T}}\mathbf{x}</math>.  
+
Zatem problem estymacji modelu ICA może być sformułowany jako problem znalezienia takiego wektora '''w''', który maksymalizuje niegaussowskość  
Maksymalizacja niegaussowskości <math>y</math> daje jeden niezależny komponent odpowiadający jednemu z <math>2n</math> maksimów (bo mamy <math>s^{i}</math> i <math>-s^{i}</math>) w krajobrazie optymalizacyjnym. Aby znaleźć wszystkie niezależne komponenty musimy znaleźć wszystkie maksima. Ponieważ komponenty są nieskorelowane, to poszukiwania kolejnych komponentów można kontynuować w podprzestrzeni ortogonalnej do już znalezionych komponentów.
+
 
 +
''y''&nbsp;= '''w'''<sup>T</sup>'''x'''.  
 +
 
 +
Maksymalizacja niegaussowskości ''y'' daje jeden niezależny komponent odpowiadający jednemu z 2''n'' maksimów (bo mamy s<sup>''i''</sup> i &minus;s<sup>''i''</sup>) w krajobrazie optymalizacyjnym. Aby znaleźć wszystkie niezależne komponenty musimy znaleźć wszystkie maksima. Ponieważ komponenty są nieskorelowane, to poszukiwania kolejnych komponentów można kontynuować w podprzestrzeni ortogonalnej do już znalezionych komponentów.
  
 
===Obliczenia===
 
===Obliczenia===
Intuicyjna heurystyka poszukiwania najbardziej niegaussowskich składowych może być użyta do wyprowadzenia różnych funkcji kosztu, których optymalizacja daje model ICA, np. kurtoza. Procedura wykorzystywana w eeglabie (“runica”, Makeig 1996) dąży do minimalizacji informacji wzajemnej. Oba podejścia są w przybliżeniu równoważne (Hyvarinen, 2000), chociaż owo przybliżenie dla  sygnałów elektrofizjologicznych nie zostało to jeszcze w pełni wyeksplorowane.
+
Intuicyjna heurystyka poszukiwania najbardziej niegaussowskich składowych może być użyta do wyprowadzenia różnych funkcji kosztu, których optymalizacja daje model ICA, np. kurtoza.
 +
 
 +
<math>kurt(y) = E\{y^4\} - 3(E{y^2})^2</math>
 +
 
 +
Inną miarą gassowskości jest neg-entropia, którą można wyprowadzić z entropii:
 +
Entropia jest miarą średniego zdziwienia wynikiem obserwacji zmiennej losowej:
 +
<math>H(Y) = - \sum_i P(Y= a_i) \log(P(Y=a_i)) </math>
 +
 
 +
Negentropia jest zdefiniowana:
 +
 
 +
<math> J(y) = H(y_{gauss}) -H(y)</math>
 +
gdzie <math> y_{gauss} </math> jest gassuwską zmienną losową o takiej samej kowaiancji jak <math> y </math>.
 +
 
 +
Negentropia jest skomplikowana obliczeniow, więc w praktyce używana jest formuła przybliżona:
 +
 
 +
<math> J(y) \varpropto  [E\{G (y)\}  - E\{G(\nu)\}]</math>
 +
 
 +
<math>\nu </math> jest zmienną losową ze standardowego rozkładu normalnego , a G są pewnymi niekwadratowymi funkcjami.
 +
 
 +
W algorytmie FastICA extremum negentropii jest znajdowane w procedurze bazującej na optymalizacji Netwona.
 +
(szczegóły np.: sekcja 6 w https://www.cs.helsinki.fi/u/ahyvarin/papers/NN00new.pdf)
 +
 
 +
 
 +
Procedura wykorzystywana w eeglabie (&bdquo;runica&rdquo;, Makeig 1996) dąży do minimalizacji informacji wzajemnej. Oba podejścia są w przybliżeniu równoważne (Hyvärinen, 2000), chociaż owo przybliżenie dla  sygnałów elektrofizjologicznych nie zostało to jeszcze w pełni wyeksplorowane.
 
Dla sygnałów o niskiej wymiarowości i spełniających dokładnie założenia ICA wszystkie powszechnie wykorzystywane algorytmy dają niemal identyczne wyniki.
 
Dla sygnałów o niskiej wymiarowości i spełniających dokładnie założenia ICA wszystkie powszechnie wykorzystywane algorytmy dają niemal identyczne wyniki.
  
;Bardzo ważna uwaga: ogólną zasadą jest, że jeśli estymujemy <math>N</math> stabilnych komponentów  (z <math>N</math>-kanałowych danych) to musimy dysponować <math>k N^2</math> punktami danych w każdym kanale, gdzie <math>N^2</math>jest liczbą elementów w macierzy <math>\mathbf{D}</math>, którą ICA próbuje wyestymować, <math>k</math> jest liczbą całkowitą. Nie ma dobrych oszacowań teoretycznych na wielkość <math>k</math>, z praktycznych obserwacji wynika, że rośnie on z ilością kanałów.
+
;Bardzo ważna uwaga: ogólną zasadą jest, że jeśli estymujemy ''N'' stabilnych komponentów  (z ''N''-kanałowych danych) to musimy dysponować ''kN''<sup>2</sup> punktami danych w każdym kanale, gdzie ''N''<sup>2</sup> jest liczbą elementów w macierzy '''D''', którą ICA próbuje wyestymować, ''k'' jest liczbą całkowitą. Nie ma dobrych oszacowań teoretycznych na wielkość ''k'', z praktycznych obserwacji wynika, że rośnie ona z liczbą kanałów.
  
 
=== Możliwe zastosowania ===
 
=== Możliwe zastosowania ===
Linia 556: Linia 731:
  
 
===Bibliografia===
 
===Bibliografia===
 +
Bazowa praca:
 +
* A. Hyvärinen. Fast and Robust Fixed-Point Algorithms for Independent Component Analysis. IEEE Transactions on Neural Networks 10(3):626-634, 1999 http://www.cs.helsinki.fi/u/ahyvarin/papers/TNN99_reprint.pdf
 +
 +
Nieco prościej opisana wersja z przykładami:
 +
* Hyvärinen, A. and Oja, E. (2000). Independent component analysis: Algorithms and applications. Neural Networks, 13(4-5):411–430.
 +
https://www.cs.helsinki.fi/u/ahyvarin/papers/NN00new.pdf
 +
 
* Grau, C., Fuentemilla, L., Marco-Pallars, J. (2007). Functional neural dynamics underlying auditory event-related n1 and n1 suppression response. Neuroimage, 36(6):522–31.
 
* Grau, C., Fuentemilla, L., Marco-Pallars, J. (2007). Functional neural dynamics underlying auditory event-related n1 and n1 suppression response. Neuroimage, 36(6):522–31.
* Hyvarinen, A. and Oja, E. (2000). Independent component analysis: Algorithms and applications. Neural Networks, 13(4-5):411–430.
+
* Makeig, S., Bell, A., Jung, T.-P., Sejnowski,T. (1996). Independent component analysis of electroencephalographic data. W: Touretzky, D., Mozer, M., and Hasselmo, M., editors, Advances in Neural Information Processing Systems, volume 8, pages 145–151. MIT Press, Cambridge, MA.
* Makeig,S.,Bell,A.,Jung,T.-P., Sejnowski,T.(1996).Independentcomponent analysis of electroencephalographic data. W: Touretzky, D., Mozer, M., and Hasselmo, M., editors, Advances in Neural Information Processing Systems, volume 8, pages 145–151. MIT Press, Cambridge, MA.
+
* Onton, J., Makeig, S. (2006). Information-based modeling of event-related brain dynamics. Prog Brain Res., 159:99–120.
* Onton,J., Makeig,S.(2006).Information-based modeling of event-related brain dynamics. Prog Brain Res., 159:99–120.
 
 
* Tutorial: http://sccn.ucsd.edu/wiki/Chapter_09:_Decomposing_Data_Using_ICA
 
* Tutorial: http://sccn.ucsd.edu/wiki/Chapter_09:_Decomposing_Data_Using_ICA
 
* http://sccn.ucsd.edu/~arno/indexica.html
 
* http://sccn.ucsd.edu/~arno/indexica.html
 +
* http://cis.legacy.ics.tkk.fi/aapo/papers/IJCNN99_tutorialweb/
 +
{{hidden end}}
 +
{{hidden begin|title=Wydobywanie interesujących komponentów}}
  
=== Wydobywanie interesujących komponentów ===
+
=== ZADANIE: Wydobywanie interesujących komponentów ===
 +
 
 +
Dane do tej części ćwiczeń proszę pobrać i rozpakować w swoim katalogu:
 +
http://www.fuw.edu.pl/~jarekz/LabEEG/Dane_do_ICA_alfa.tar.gz
  
Dane do tej części ćwiczeń proszę pobrać i rozpakować w swoim katalogu. [[  ... ]]
 
 
Pochodzą one z eksperymentu, w którym osoba badana siedziała z zamkniętymi oczami słuchając nagrania czytanego spokojnym głosem. Metadane opisujące sygnał znajdują się w pliku Miro.xml, zaś lokalizacje elektrod w pliku Miro-10-20-Cap.locs.
 
Pochodzą one z eksperymentu, w którym osoba badana siedziała z zamkniętymi oczami słuchając nagrania czytanego spokojnym głosem. Metadane opisujące sygnał znajdują się w pliku Miro.xml, zaś lokalizacje elektrod w pliku Miro-10-20-Cap.locs.
  
Linia 581: Linia 767:
 
* usunąć wszystkie komponenty nie zawierające alfy
 
* usunąć wszystkie komponenty nie zawierające alfy
 
* odtworzyć z tych komponentów sygnał na elektrodach
 
* odtworzyć z tych komponentów sygnał na elektrodach
* wykoać dekompozycję ICA kilkukrotnie (co najmniej 3) i porównać wyniki
+
* wykonać dekompozycję ICA kilkukrotnie (co najmniej 3) i porównać wyniki
 
** Czy uzyskiwane komponenty są powtarzalne?  
 
** Czy uzyskiwane komponenty są powtarzalne?  
 
** Swoje wyniki porównać też z sąsiednimi grupami.
 
** Swoje wyniki porównać też z sąsiednimi grupami.
 +
{{hidden end}}
  
=== Usuwanie artefaktów ===
+
===ZADANIE: Identyfikacja artefaktów ===
 +
Proszę pobrać dane:
  
* filtr FIR 0,5Hz
+
*http://www.fuw.edu.pl/~jarekz/LabEEG/Arousal-10-20-Cap.locs
 +
*http://www.fuw.edu.pl/~jarekz/LabEEG/Arousal1.set
 +
*http://www.fuw.edu.pl/~jarekz/LabEEG/Arousal1.fdt
  
 +
Pochodzą one z eksperymentu w którym osoba badana czytała słowa o różnych właściwościach wzbudzania emocji.
 +
 +
* wczytaj je do eeglaba
 +
* wczytaj lokalizację kanałów z pliku Arousal-10-20-Cap.locs
 +
* obejrzyj przebiegi czasowe
 +
* odrzuć kanał z diodą (21) i z GSR (20)
 +
* zrób dekompozycję ICA
 +
* obejrzyj topografię komponentów
 +
* zidentyfikuj komponenty odpowiadające mruganiu i aktywności mięśniowej.
 +
;UWAGA: Aktualnie do wykrywania komponentów artefaktowych warto posłużyć się wtyczkami do eeglaba dostępnymi przez stronę:
 +
 +
https://sccn.ucsd.edu/eeglab/plugin_uploader/plugin_list_all.php
 +
 +
* ICLabel
 +
* MARA
 +
 +
====W raporcie: ====
 +
* zaprezentuj fragmenty sygnału zawierającego artefakty oczne i mięśniowe przed i po zastosowaniu czyszczenia poprzez usuwanie komponentów zdominowanych przez artefakty.
 +
* zaprezentuj topografię i przebiegi czasowe komponentów zidentyfikowanych jako artefakty oczne i mięśniowe.
 +
 +
 +
 +
<!--
 
==Filtry przestrzenne dla większej ilości warunków==
 
==Filtry przestrzenne dla większej ilości warunków==
 
===FFDIAG===
 
===FFDIAG===
 
===Analiza ERD/S z użyciem FFDIAG===
 
===Analiza ERD/S z użyciem FFDIAG===
 +
-->
 +
 +
<!---
 +
==Eksperyment ASSR==
 +
W eksprymencie wykorzystujemy układ do generacji potencjałów słuchowych stanu ustalonego (ASSR). Wejście układu ASSR typu mini-jack wkładamy w wyjście słuchawkowe w laptopie. Drugie wejście układu ASSR wkładamy do wyjścia triggera we wzmacniaczu. Uruchamiamy plik dźwiękowy MM40tr.wav. Można go znalezc w: http://www.fuw.edu.pl/~suffa/LabEEG/MM40tr.wav
 +
 +
Stymulacja dźwiękowa składa sie z fali nośnej o częstości 400 Hz modulowanej z częstością 40 Hz. Plik dźwiękowy zawiera 5 sekund ciszy i 5 sekund stymulacji, powtórzone 40 razy.
 +
 +
===Rejestracja sygnału===
 +
# Zakładamy czepek i elektrody w systemie 10-10, dbamy o to by opory pomiędzy elektrodami były poniżej 5 k&Omega; i różnice pomiędzy oporami różnych elektrod nie przekraczały 20%.
 +
# Oklejamy kwadrat 3&times;3 elektrod na korze słuchowej z lewej strony (elektrody FT7, FC5, FC3, T7, C5, T3, TP7, CP5, CP3), 3&times;3 elektrod na korze słuchowej z prawej strony (elektrody FT8, FC6, FC4, T8, C6, T4, TP8, CP6, CP4), elektrody Fz, Cz, Pz i Oz, elektrody referencyjne A1 i A2. W sumie powinno być 24 elektrody.
 +
# Elektrodę GND mocujemy na pozycji AFz.
 +
# Sygnał rejestrujemy z częstością 2048 Hz.
 +
# Do rejestracji stosujemy scenariusz 'ASSR' w interfejsie obci_gui.
 +
 +
===Analiza===
 +
Początek stymulacji dźwiękowej oznaczymy jako 0. Poniższą analizę zastosuj dla sygnałów w referencji do uśrednionych odprowadzeń usznych A1 i A2.
 +
Wyznaczenie pasma częstości odpowiedzi ASSR
 +
# Z sygnału wycinamy fragmenty od 0 do 5 sek. dla wszystkich elektrod położone nad korą słuchową (odcinki podczas stymulacji oraz bez niej).
 +
# Dla każdej realizacji (odpowiedniego typu) obliczamy widma metodą Welcha.
 +
# Otrzymane zespolone widma uśredniamy po realizacjach.
 +
# Sprawdzamy czy w uśrednionym widmie występuję maksimum w częstości modulacji tj. 40 Hz i czy jest różnica między odcinkami ze stymulacją i bez niej.
 +
 +
===Wyznaczenie przebiegu czasowego ERD i ERS===
 +
# Zaprojektuj filtry pasmowo przepustowe (Czebyszewa 2 rodzaju) zgodne z wyznaczonym pasmem. Zbadaj funkcje przenoszenia i odpowiedzi impulsowej.
 +
# Powycinaj sygnały od &minus;5 do +10 sekund (wszystkie kanały). Przefiltruj każdą realizację.
 +
# Oblicz moc chwilową za pomocą transformaty Hilberta (kwadrat modułu transformaty Hilberta).
 +
# Uśrednij moc chwilową po realizacjach.
 +
# Oblicz względną zmianę mocy chwilowej względem czasu &minus;4 do &minus;2 s. W ten sposób otrzymasz przebieg ERD i ERS w czasie.
 +
# Wykreśl ERD i ERS w układzie topograficznym. (Rozmieść subploty tak, aby z w przybliżeniu odpowiadały pozycjom elektrod).
 +
 +
===Transformacja Hjortha===
 +
Transformacja Hjortha jest przybliżeniem numerycznym transformacji Laplace'a, czyli drugiej pochodnej przestrzennej. Obliczamy ją jako różnicę potencjału pomiędzy daną elektrodą i średnią z czterech sąsiednich elektrod.
 +
Przelicz potencjały z elektrod, w których występuję odpowiedź ASSR na montaż Hjortha i powtórz analizę opisaną powyżej.
 +
--->

Aktualna wersja na dzień 08:47, 14 maj 2024

Laboratorium_EEG/BSS

Prezentacja

slajdy z prezentacji

Ślepa separacja źródeł (BSS)


Ćwiczenie symulacyjne

Zastosowanie filtra CSP do detekcji potencjału P300

Analiza wstępna

Poszczególne etapy analizy proszę kodować w osobnych funkcjach. Funkcje te powinny być wywoływane z nadrzędnego skryptu, który powinien umożliwic wykoanie całości analiz.

  • Wczytać dane kalibracyjne do Matlaba i pociąć je na realizacje typu T — „target” (związane z wystąpieniami litery „B”) i NT — „non-target” (pozostałe litery) o długości −200 do +800 ms wokół triggerów. Dla każdej realizacji odjąć trend liniowy.
  • Sygnał zmontować wzgl. „połączonych uszu” i wyświetlić średnie przebiegi dla warunku T i NT w układzie topograficznym — można wykorzystać w tym celu poniższy fragment kodu.

Poniżej zaprezentowany jest przykładowy skrypt do cięcia danych wokół znaczników. Działa on z plikami zawartymi w archiwum:

Plik:KalibracjaP300.tar.gz

Korzysta z funkcji pomocniczych dostępnych w dystrybucji obci w katalogu

/usr/share/openbci/analysis/matlab_obci_signal_processing

Openbci można pobrać z https://github.com/BrainTech/openbci

ZADANIE: Analiza CSP

Przegląd badań o P300: https://www.ncbi.nlm.nih.gov/pmc/articles/PMC2715154/

Link do Read menager [1]

  • Wykonać analizę CSP wzmacniającą potencjał P300.
  • Zaprezentować średnią ze wszystkich kanałów źródłowych z warunku target (jeden kolor) i non-target (inny kolor) w subplotach ułożonych w prostokątnej siatce. Zaobserwować dla którego kanału średnie różnią się najbardziej. Czy jest związek tego kanału z wartościami własnymi?
  • Dla kanału najbardziej różnicującego wykonać mapki topograficzne (do wykonania tych mapek wykorzystać funkcję topoplot z pakietu eeglab) wektorów odpowiadających:
    • filtrowi przestrzennemu
    • rzutu topograficznego źródła na elektrody.

Filtry przestrzenne dla SSEP

ICA jako filtr przestrzenny

ZADANIE: Identyfikacja artefaktów

Proszę pobrać dane:

Pochodzą one z eksperymentu w którym osoba badana czytała słowa o różnych właściwościach wzbudzania emocji.

  • wczytaj je do eeglaba
  • wczytaj lokalizację kanałów z pliku Arousal-10-20-Cap.locs
  • obejrzyj przebiegi czasowe
  • odrzuć kanał z diodą (21) i z GSR (20)
  • zrób dekompozycję ICA
  • obejrzyj topografię komponentów
  • zidentyfikuj komponenty odpowiadające mruganiu i aktywności mięśniowej.
UWAGA
Aktualnie do wykrywania komponentów artefaktowych warto posłużyć się wtyczkami do eeglaba dostępnymi przez stronę:

https://sccn.ucsd.edu/eeglab/plugin_uploader/plugin_list_all.php

  • ICLabel
  • MARA

W raporcie:

  • zaprezentuj fragmenty sygnału zawierającego artefakty oczne i mięśniowe przed i po zastosowaniu czyszczenia poprzez usuwanie komponentów zdominowanych przez artefakty.
  • zaprezentuj topografię i przebiegi czasowe komponentów zidentyfikowanych jako artefakty oczne i mięśniowe.