function a_stats_db = statsMeanSE(db, tests, props)
% statsMeanSE - Generates a stats_db object with two rows corresponding to
% the mean and standard error (SE) of the tests' distributions.
%
% Usage:
% a_stats_db = statsMeanSE(db, tests, props)
%
% Description:
%
% Parameters:
% db: A tests_db object.
% tests: A selection of tests (see onlyRowsTests).
% props: A structure with any optional properties for stats_db.
%
% Returns:
% a_stats_db: A stats_db object.
%
% See also: tests_db
%
% $Id$
%
% Author: Cengiz Gunay <cgunay@emory.edu>, 2004/10/07
% Copyright (c) 2007 Cengiz Gunay <cengique@users.sf.net>.
% This work is licensed under the Academic Free License ("AFL")
% v. 3.0. To view a copy of this license, please look at the COPYING
% file distributed with this software or visit
% http://opensource.org/licenses/afl-3.0.php.
if ~ exist('props', 'var')
props = struct([]);
end
if ~ exist('tests', 'var')
tests = ':';
end
a_db = onlyRowsTests(db, ':', tests, ':');
[means n] = mean(a_db, 1);
test_results = [means.data; get(std(a_db, 0, 1), 'data') ./ sqrt(n); n];
row_names = {'mean', 'SE', 'n'};
% Original column names
cols = tests2cols(db, tests);
col_name_cell = fieldnames(db.col_idx);
col_names = col_name_cell(cols);
a_stats_db = stats_db(test_results, col_names, row_names, {}, ...
[ 'Mean and SEs of ' db.id ], props);