*! 1.1.0 NJC 24 May 2007 
*! 1.0.0 NJC 5 December 2000 
program define _gsemean 
	version 6
	syntax newvarname =/exp [if] [in] [, BY(varlist)]
	tempvar touse mean n 
	quietly {
		gen byte `touse' = 1 `if' `in'
		sort `touse' `by'
		by `touse' `by': gen double `mean' = /*
			*/ sum(`exp')/sum((`exp') < .) if `touse' == 1
		by `touse' `by': gen long `n' = sum((`exp') < .) if `touse' == 1 
		by `touse' `by': replace `n' = `n'[_N] 
		by `touse' `by': gen `typlist' `varlist' = /*
		*/ sqrt(sum(((`exp')-`mean'[_N])^2)/(sum((`exp') < .) - 1)) /*
		*/ if `touse'==1 & sum(`exp' < .)
		by `touse' `by': replace `varlist' = `varlist'[_N] / sqrt(`n') 
	}
end