SAS 学习笔记(四)— SAS编程

结构化编程

控制结构语法 + 数据结构

1.顺序结构

2.选择结构
IF … THEN / ELSE

IF expression THEN
	DO;
		statements ;
	END;
ELSE
	DO;
		statements ;
	END;

SELECT / WHEN

3.循环结构
DO 循环 (标准计数型)

do 计数变量=初值 to 终值 by 步长; /*步长默认为1,也可以取负值*/
	循环体语句;
end;
e.g.
do  i=2  to  10  by  2;
do  i=10  to 2  by2;
do  x=3.6  to 4.8  by  0.05;
do  n=1, 5, 10, 30, 60;
do  n=1, 5  to  10 , 20 , 30 ;
do  month='JAN', 'FEB', 'MAR';
do  z=k  to  n/10 ; 

DO WHILE 循环 (当型)
先判断,再执行循环

do while (循环继续条件);
	循环体语句;
end;

DO UNTIL 循环 (直到型)
先循环,再判断;循环体至少执行一次

do until (循环退出条件); 
	循环体语句;
end;

LEAVE; 退出当前层循环(相当于C语言中的break;)
CONTINUE; 继续下一轮循环(当前轮循环余下的立刻结束)

C / R / Python → for / while 循环
C语言支持整数计数型循环,SAS还支持小数计数型循环、无规律数字循环、文本循环等
计数变量命名规则:I-N规则(i, j, k, l, m, n)


  • 加法的实现
/* pi/4 = 1-1/3+1/5-1/7+..., estimate pi */
/* 计数型循环 */
data;
	s=0; flag=1; /*符号变量,变号器*/
	do n=1 to 10000;
		s=s+flag/(2*n-1);
		flag=-flag; /*每次变号*/
	end;
	pi=4*s;
	file print;put pi=;
run;

/*计算机中,无穷小epsilon一般用10^(-5)或10^(-6)表示
比较两个变量值是否相等:
eps=1e-5 or eps=1e-6;
if abs(a-b)<=eps ...;
*/

/* 当型循环 */
data;
	s=0;flag=1;eps=1e-5;n=1;
	do while(abs(1/n)>1e-5);
		s=s+flag(2*n-1);
		n=n+1;
		flag=-flag;
	end;
	pi=4*s;
	file print; put pi=;
run;

/* LEAVE语句 */
data;
	s=0;flag=1;eps=1e-6;
	do n=1 to 10000000;
		s=s+flag/(2*n-1);
		flag=-flag;
		if abs(1/n)<eps then leave;
	end;
	pi=4*s;
	file print; put pi=;
run;

/* CONTINUE语句 */
/* 求前100个数中奇数之和 */
data;
	do n=1 to 100 /*by 2*/;
		if mod(n,2)=0 then continue;
		s+n;
	end;
	file print; put s=;
run;
  • 数值计算 — 求方程的根
    1、牛顿迭代公式(泰勒展开导出): x n + 1 = x n − f ( x n ) f ′ ( x n ) , 初 值 x 0 x_{n+1}=x_n-\frac{f(x_n)}{f'(x_n)},初值x_0 xn+1=xnf(xn)f(xn)x0收敛条件: ∣ f ( x n + 1 ) ∣ < ϵ , ϵ 任 意 小 |f(x_{n+1})|<\epsilon, \quad \epsilon任意小 f(xn+1)<ϵ,ϵ
/* 求方程 x^2-2x-3=0 的根 */
data;
	x=-3;
	do while(abs(x*x-2*x-3)>1e-5);
		x=x-(x*x-2*x-3)/(2*x-2);
	end;
	put x=;
run;

/* 牛顿迭代公式也可用于求平方根,
采用的判断条件是 x^2-a^2=0,而不是sqrt(x)-a=0 */

2、二分法

data;
	x1=-2;x2=1.8;
	med = (x1+x2)/2;
	do while(abs(med*med-2*med-3)>1e-5);
	if sign((x1*x1-2*x1-3) * (med*med-2*med-3))<0
		then x2=med;
	else x1=med;
		med = (x1+x2)/2;
	end;
	put med=;
run;
  • 数值计算 — 求积分
    F一般是无解析解的函数,利用积分定义和数值计算求解
    ∫ 0 1 e x d x = ? \int_0^1e^xdx = ? 01exdx=?
data;
	area=0; n=1000; a=0; b=1;
	d=(b-a)/n;
	do k=1 to n;
		s=exp(a)*d;
		area+s; /*area=area+s;也可以*/
		a+d;
	end;
	/*
	do k=1 to n;
		area+exp(a+(k-1)*d)*d;
	end;
	*/
	file print; put area=;
run;
  • 6
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值