preserve. set printback=on. * SIMPLE AND COMPLEX RANDOM ASSIGNMENT IN EXPERIMENTAL DESIGNS Valentim R. Alferes, University of Coimbra (Portugal), 2009. * SimpleRand3.sps - Simple Random Assignment (Forced unequal sizes). set printback=off. set ovars labels onumbers values tvars labels tnumbers values. set errors=none. data list list/Treatment(f8.0) ntreat(f8.0). * Enter Treatment number and number of units per treatment. begin data 1 8 2 9 3 6 end data. loop cases=1 to ntreat. xsave outfile='%temp%\outf1'/keep=Treatment. end loop. execute. get file='%temp%\outf1'. set rng=mt mtindex=random. compute random=uniform(1). sort cases by random(a). compute Unit=$casenum. formats all(f8.0). oms/select tables/if commands=["summarize"] subtypes=["case processing summary"]/destination viewer=no. oms/select tables/if commands=["crosstabs"] subtypes=["case processing summary"]/destination viewer=no. summarize/tables=unit treatment/format=validlist nocasenum nototal /title='Simple Random Assignment \n Sorted by Unit'/cells=none. sort cases by treatment(a) unit(a). summarize/tables=unit treatment/format=validlist nocasenum nototal /title='Simple Random Assignment \n Sorted by Treatment'/cells=none. summarize/tables=unit by treatment/format=nolist total /title='Number of Units per Treatment'/cells=count npct. restore.