DATA Step, Macro, Functions and more

proc surveyselect

Accepted Solution Solved
Reply
Contributor
Posts: 40
Accepted Solution

proc surveyselect

Hi

 

How can I get the proc survey select to randomly pick cases based upon the criteria that the sum of the variable income should not exceed 0.7 of the (sum of income of selection/ income for total sample)


Accepted Solutions
Solution
‎11-17-2016 09:18 AM
Super User
Posts: 10,035

Re: proc surveyselect

How about this one:

 

proc sql noprint;
select sum(air)*0.7 into : sum
 from sashelp.air;
quit;

data have;
 set sashelp.air;
 rand=rand('uniform');
run;
proc sort data=have;
 by rand;
run;
data want;
 set have;
 temp+air;
 if temp lt ∑
run;

View solution in original post


All Replies
Super User
Posts: 10,035

Re: proc surveyselect

You are looking for variables selection method.
Check SELECT= option of MODEL statement.


Super User
Posts: 10,035

Re: proc surveyselect

Sorry. Ignore my last post. wrong post at wrong place.

Can you post an example to explain what you require ?

Super User
Posts: 11,343

Re: proc surveyselect

Please provide the version of SAS you are using. There may be options to help with this but they may be version dependent.

 

Precalculate what 0.7 of the income for the total sample would be: Example: Suppose the  Total income in your set is 1000000, available from many procs in different ways: means, summary,  univariate or freq to name a few.

Then the target you are looking for is I think 0.7 * 1000000 or 700000.

Use 700000 as the SAMPSIZE with your Income variable as the Size variable.

 

 

Respected Advisor
Posts: 4,925

Re: proc surveyselect

The Size variable in proc SurveySelect is for PPS sampling. PPS means Probability (of selection) Proportional to Size. Use a Size variable only if sampling with PPS.

PG
Respected Advisor
Posts: 4,925

Re: proc surveyselect

Do you want a fixed sample size with at most 70% of incomes, or do you want to randomly pick sampling units until the income reaches 70% of incomes?

PG
Contributor
Posts: 40

Re: proc surveyselect

The latter!

Solution
‎11-17-2016 09:18 AM
Super User
Posts: 10,035

Re: proc surveyselect

How about this one:

 

proc sql noprint;
select sum(air)*0.7 into : sum
 from sashelp.air;
quit;

data have;
 set sashelp.air;
 rand=rand('uniform');
run;
proc sort data=have;
 by rand;
run;
data want;
 set have;
 temp+air;
 if temp lt ∑
run;
☑ This topic is solved.

Need further help from the community? Please ask a new question.

Discussion stats
  • 7 replies
  • 270 views
  • 1 like
  • 4 in conversation