DATA Step, Macro, Functions and more

Calculated a weighted Average Interest Rate

Reply
Contributor
Posts: 29

Calculated a weighted Average Interest Rate

Dear Sas Community:

I am trying to calculate a a weighted Average Interest Rate for a company that may have several subsidiaries that borrow at different interest rates.

I have the following table:

CompanyNumSubsidiaryNumAmountRate
12345000000355
12435000000405

 

I want the following table:

CompanyNumTotal AmountWeighted Average Rate
180000000376.875

 

How can I do that using SAS Proc SQL. Any suggestions. Basically I would like to have my analysis at the company level.

Contributor
Posts: 42

Re: Calculated a weighted Average Interest Rate

data watch;
input CompanyNum SubsidiaryNum Amount Rate;
datalines;
1 23 45000000 355
1 24 35000000 405
;

run;

 

 

proc sql;
select
CompanyNum,
sum(Amount) as Total_Amount,
sum(Amount*Rate)/sum(Amount) as wRate
from watch
group by CompanyNum;
quit;

Valued Guide
Posts: 797

Re: Calculated a weighted Average Interest Rate

[ Edited ]

Why not use the procedure that SAS intended for this purpose?  It would be easy to expand the number of vars, or request other statistics (std, var, min, max, median, various percentiles etc.)

 

proc summary data=have noprint nway ;

  class companynum;

  var rate;

  weight amount;

  output out=want (drop=_type_ _freq_) sumwgt(rate)=total_amount mean(rate)=wrate ;

run;

Ask a Question
Discussion stats
  • 2 replies
  • 290 views
  • 9 likes
  • 3 in conversation