BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
michokwu
Quartz | Level 8

Hello,

I'd like to see how a program's pre- and post-implementation trends compare. I've having difficulties correctly creating the positive and negative values. Please see sample data below (Trend should be 0, if the program was implemented in 2012, +1 for every year after, -1 for every year before)

data biz_trend;
set biz_data;
by business adoption_year;
retain Trend;
if first.business and first.adoption_year then Trend=0;
else Trend=Trend+1;
run;

 

YearBusinessProductsAdoption_year
2010Company A  
2011Company A  
2012Company Aconvenience 2012
2013Company A  
2014Company Ashopping2014
2014Company Araw materials2014
2015Company A  
2016Company A  
2017Company Amajor equipment2017
2010Company B  
2011Company B  
2012Company B  
2013Company B  
2014Company B  
2015Company B  
2016Company Braw materials2016
2017Company Bconvenience 2017
2010Company C  
2011Company C  
2012Company C  
2013Company C  
2014Company Cconvenience 2014
2015Company C  
2016Company Cmajor equipment2016
2017Company Cconvenience 2017

 

What I want

YearBusinessAdoption_yearTrend
2010Company A -2
2011Company A -1
2012Company A20120
2013Company A 1
2014Company A20142
2014Company A20143
2015Company A 4
2016Company A 5
2017Company A20176
2010Company B -6
2011Company B -5
2012Company B -4
2013Company B -3
2014Company B -2
2015Company B -1
2016Company B20160
2017Company B20171
2010Company C -4
2011Company C -3
2012Company C -2
2013Company C -1
2014Company C20140
2015Company C 1
2016Company C20162
2017Company C20173
1 ACCEPTED SOLUTION

Accepted Solutions
maguiremq
SAS Super FREQ

I feel like you have a typo in your 'want' data set. I think this is what you meant, but I may have missed a key detail in your post. I'm mainly wondering about Company A's two values for 2014--is this intentionally incremented by 1 even though it's the same distance from the adoption year?

 

proc sql;
	select
				a.year,
				a.business,
				a.adoption_year,
				a.year - b.first_year as trend
	from
				have as a
					left join
				(select
							business,
							min(adoption_year) as first_year
				 from
				 			have
				 where
				 			adoption_year is not null
				 group by
				 			business) as b
				 		on a.business = b.business
	order by
				a.business, a.year;
quit;
Year 	Business 	Adoption_year 	trend
2010 	Company A 	. 	-2
2011 	Company A 	. 	-1
2012 	Company A 	2012 	0
2013 	Company A 	. 	1
2014 	Company A 	2014 	2
2014 	Company A 	2014 	2
2015 	Company A 	. 	3
2016 	Company A 	. 	4
2017 	Company A 	2017 	5
2010 	Company B 	. 	-6
2011 	Company B 	. 	-5
2012 	Company B 	. 	-4
2013 	Company B 	. 	-3
2014 	Company B 	. 	-2
2015 	Company B 	. 	-1
2016 	Company B 	2016 	0
2017 	Company B 	2017 	1
2010 	Company C 	. 	-4
2011 	Company C 	. 	-3
2012 	Company C 	. 	-2
2013 	Company C 	. 	-1
2014 	Company C 	2014 	0
2015 	Company C 	. 	1
2016 	Company C 	2016 	2
2017 	Company C 	2017 	3

 

View solution in original post

6 REPLIES 6
ballardw
Super User

What role does the Products variable play in this process? Since Company A shows 4 different adoption years depending on the Products then you need to show what you expect as the actual output of the process.

michokwu
Quartz | Level 8
The Product variable is not relevant for this purpose. Thank you.
ballardw
Super User

@michokwu wrote:
The Product variable is not relevant for this purpose. Thank you.

So which adoption year is supposed to be used for each Company? We need a rule to select the correct one when there are multiple adoptions years.

michokwu
Quartz | Level 8

The first year the company adopted the program, regardless of the product. I updated my post with the expected outcome. Thank you.

maguiremq
SAS Super FREQ

I feel like you have a typo in your 'want' data set. I think this is what you meant, but I may have missed a key detail in your post. I'm mainly wondering about Company A's two values for 2014--is this intentionally incremented by 1 even though it's the same distance from the adoption year?

 

proc sql;
	select
				a.year,
				a.business,
				a.adoption_year,
				a.year - b.first_year as trend
	from
				have as a
					left join
				(select
							business,
							min(adoption_year) as first_year
				 from
				 			have
				 where
				 			adoption_year is not null
				 group by
				 			business) as b
				 		on a.business = b.business
	order by
				a.business, a.year;
quit;
Year 	Business 	Adoption_year 	trend
2010 	Company A 	. 	-2
2011 	Company A 	. 	-1
2012 	Company A 	2012 	0
2013 	Company A 	. 	1
2014 	Company A 	2014 	2
2014 	Company A 	2014 	2
2015 	Company A 	. 	3
2016 	Company A 	. 	4
2017 	Company A 	2017 	5
2010 	Company B 	. 	-6
2011 	Company B 	. 	-5
2012 	Company B 	. 	-4
2013 	Company B 	. 	-3
2014 	Company B 	. 	-2
2015 	Company B 	. 	-1
2016 	Company B 	2016 	0
2017 	Company B 	2017 	1
2010 	Company C 	. 	-4
2011 	Company C 	. 	-3
2012 	Company C 	. 	-2
2013 	Company C 	. 	-1
2014 	Company C 	2014 	0
2015 	Company C 	. 	1
2016 	Company C 	2016 	2
2017 	Company C 	2017 	3

 

michokwu
Quartz | Level 8
You're right. Its a typo. Thank you very much!

SAS Innovate 2025: Save the Date

 SAS Innovate 2025 is scheduled for May 6-9 in Orlando, FL. Sign up to be first to learn about the agenda and registration!

Save the date!

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 6 replies
  • 889 views
  • 1 like
  • 3 in conversation