📄 icavar.m
字号:
% icavar() - project ICA component activations through the ICA weight matrices % to reconstitute the observed data using selected ICA components. % Returns time course of variance on scalp for each component.%% Usage: >> [srcvar] = icavar(data,weights,sphere,compnums);%% Inputs:% data - data matrix returned by runica()% weights - weight matrix returned by runica()% sphere - sphere matrix returned by runica() (default|0 -> eye(ncomps))% compnums - list of component numbers (default|0 -> all)%% Author: Scott Makeig, SCCN/INC/UCSD, La Jolla, 11-30-1996 %% See also: runica()% Copyright (C) 11-30-1996 Scott Makeig, SCCN/INC/UCSD, scott@sccn.ucsd.edu%% This program is free software; you can redistribute it and/or modify% it under the terms of the GNU General Public License as published by% the Free Software Foundation; either version 2 of the License, or% (at your option) any later version.%% This program is distributed in the hope that it will be useful,% but WITHOUT ANY WARRANTY; without even the implied warranty of% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the% GNU General Public License for more details.%% You should have received a copy of the GNU General Public License% along with this program; if not, write to the Free Software% Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA% $Log: icavar.m,v $% Revision 1.1 2002/04/05 17:36:45 jorn% Initial revision%% 04-03-97 made more efficient -sm% 05-20-97 debugged variance calculation and made it more efficient -sm% 06-07-97 changed order of args to conform to runica -sm% 07-23-97 do not add back datamean to projections -sm% 12-23-97 added compnums -sm% 02-25-98 changed activations input to data -sm% 07-20-98 use pinv() for inverting non-square weights -sm% 01-25-02 reformated help & license, added links -ad function [srcvar] = icavar(data,weights,sphere,compnums)if nargin<2 help icavar returnendif size(weights,2) ~= size(sphere,1) | size(sphere,2) ~= size(data,1) fprintf('icavar() - sizes of weights, sphere, and data incompatible.\n') whos data weights sphere returnendactivations = weights*sphere*data;[ncomps,frames] = size(activations);[wr,chans] = size(weights); % Note: ncomps may < data chansif nargin<4 compnums = 0;endif compnums == 0, compnums = 1:ncomps;endsrcvar = zeros(length(compnums),frames);if nargin < 3 sphere = 0;endif sphere == 0, sphere = eye(ncomps);endproject = weights*sphere;if wr~=ncomps, fprintf('icavar: Number of rows in activations and weights must be equal.\n'); returnend% if wr<chans, % fprintf('Filling out a square projection matrix with small noise.\n'); % for r=1:chans-wr, % project = [project;0.00001*randn(1,chans)]; % end% end% project = inv(project); % invert projection matrixif wr<chans project = pinv(project);else project = inv(project);endfprintf('Projecting ICA component ');nout = length(compnums);for i=1:nout % for each component comp = compnums(i); fprintf('%d ',comp); projdata = project(:,comp)*activations(comp,:); % reproject eeg data srcvar(i,:) = sum(projdata.*projdata)/(chans-1);% compute variance at each time pointendfprintf('\n');
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -