京公网安备 11010802034615号
经营许可证编号:京B2-20210330
你知道SAS也可以实现神经网络吗
神经网络的理论太长了,我就不写上来了,本次的代码是根据这本书《数据挖掘与应用》--张俊妮中神经网络这一章我做了思路的改动以及在原本代码的基础上,我把它封装好变成一个完整的宏。如果后面你们需要去了解sas神经网络这个proc neural过程也可以去购买这本来读,这本书没有配套的代码,所以代码也是我一个一个照着书敲来之后更改的。
说下这个代码的思路。
1、宏的第一步是采用神经网络建立广义线性模型,没有隐藏层,对数据做第一次的训练。这里的数据宏里面已经自动拆分成测试和训练了,你自己不用拆了。
2、算出神经网络建立广义线性模型的结果算出原始数据(训练集以及测试集)中每一个,客户的违约概率,之后算其ks值。
3、接下来就是循环隐藏层,从1循环到3,当然你要是觉得3层太少,你可以再设置,使用的是早停止(张俊妮的《数据挖掘与应用》的114页种有详细解释这个算法)法建立多层感知模型,那么这里第一次当然循环就是1层啦,那就是1层感知模型。
4、在当隐藏层为一层的时候,我们会拟合两次神经网络,第一次不输出结果,只是产出在隐藏层为一层的时候,挑选出最优的变量权重,拟合一个使用早停止法拟合出来的一个隐藏层为一层的神经网络模型,利用出来的变量规则,算出客户的概率之后算出模型的ks值。
5、到这里并不是要循环隐藏层为两层,还有呢,别着急,这时候隐藏层为一层的前提下,再使用,规则化法建模一层感知器模型,刚才的一层隐藏层使用的早停止法,现在使用的是规则化法,这时候规则化法去的权衰减常数的四种取值(规则化法也可以在书里的115页看到。)四种取值是:0.1 、0.01、0.001、0.0001然后循环之后算出,每个模型的ks记录。
6、所以循环一次隐藏层的层数,是得到4个模型的,早停止法一个,规则化法四个。
7、再一次循环隐藏层的2、3层。最终你可以在ks的汇总跑那个表中,选出训练数据以及测试数据ks都高的模型,作为你最终的模型。
%macromlps(dir,data,list_varname,y_var);
proc datasets lib=work;
delete alltrainfit allvalidfit vaild_ks_total train_ks_total;
run;
data M_CALL_DAY_TOTAL4_t;
set &data.;
indic=_n_;
run;
Proc sort data=M_CALL_DAY_TOTAL4_t; by &y_var.;run;
proc surveyselect data =M_CALL_DAY_TOTAL4_t method = srs rate=0.8
out = traindata;
strata &y_var.;
run;
proc sql;
create table validdata as
select * from
M_CALL_DAY_TOTAL4_t where indic not in (select indic from traindata);
quit;
data traindata;
set traindata;
drop SelectionProb SamplingWeight indic;
run;
data validdata;
set validdata;
drop indic;
run;
proc dmdb data=traindata dmdbcat=dmcdata;
class &y_var.;
var &list_varname.;
run;
proc dmdb data=validdata dmdbcat=dmcdata;
class &y_var.;
var &list_varname.;
run;
data decisionmatrix;
&y_var.=1;
to_1=0;
to_2=1;
output;
&y_var.=0;
to_1=1;
to_2=0;
output;
run;
proc neural data=traindata validdata=validdata dmdbcat=dmcdata ranscale=0.1random=0;
input &list_varname./level=int;
target &y_var./level=nom;
decision decdata=decisionmatrix(type=loss) decvars=TO_1 TO_2;
archi glim;
nloptions maxiter=300;
train ;
code file="&dir.nncode_germancredit_glim.sas";
score data=traindata nodmdb out=traindata_GLIM outfit=trainfit_GLIM role=TRAIN;
score data=validdata nodmdb out=validdata_GLIM outfit=validfit_GLIM role=valid;
run;
data test_train(keep=appl_id &y_var.point);
set traindata;
%include"&dir.nncode_germancredit_glim.sas";
rename P_&y_var.0=point;
run;
proc npar1way data=test_train noprint;
class &y_var.;
var point;
output out=ks_t(keep=_d_ p_ksa rename=(_d_=KS p_ksa=P_value));
run;
data test_train_ks;
set ks_t;
length model$50.;
model="glim";
run;
proc append base=train_ks_total data=test_train_ks force;
run;
data vaild_train(keep=appl_id &y_var.point);
set validdata;
%include"&dir.nncode_germancredit_glim.sas";
rename P_&y_var.0=point;
run;
proc npar1way data=vaild_train noprint;
class &y_var.;
var point;
output out=ks_v(keep=_d_ p_ksa rename=(_d_=KS p_ksa=P_value));
run;
data test_vaild_ks;
set ks_v;
length model$50.;
model="glim";
run;
proc append base=vaild_ks_total data=test_vaild_ks force;
run;
%letnhidden=1;
%do%until(&nhidden.>3);
proc neural data=traindata validdata=validdata dmdbcat=dmcdata graph;
input &list_varname./level=int;
target &y_var./level=nom;
decision decdata=decisionmatrix(type=loss) decvars=TO_1 TO_2;
archi MLP hidden=&nhidden.;
nloptions maxiter=300;
train estiter=1outest=weights_MLP&nhidden._ES outfit=assessment_MLP&&nhidden._ES;
/*code file="&dir.nncode_germancredit_glim.sas";*/
/*score data=traindata nodmdb out=traindata_GLIM outfit=trainfit_GLIM role=TRAIN;*/
/*score data=validdata nodmdb out=validdata_GLIM outfit=validfit_GLIM role=valid;*/
run;
proc sort data=assessment_MLP&&nhidden._ES;
by _VALOSS_;
RUN;
DATA BESTITER;
SET assessment_MLP&&nhidden._ES;
IF _N_=1;
RUN;
proc sql;
select _iter_ into:BESTITER from BESTITER;
quit;
data bestweights;
set weights_MLP&nhidden._ES;
if _type_="PARMS"AND _iter_=&bestiter.;
drop _tech_ _type_ _name_ _decay_ _seed_ _nobj_ _obj_ _objerr_
_averr_ _vnobj_ _vobj_ _vobjerr_ _vaverr_ _p_num_ _iter_;
run;
proc neural data=traindata validdata=validdata dmdbcat=dmcdata graph;
input &list_varname./level=int;
target &y_var./level=nom;
decision decdata=decisionmatrix(type=loss) decvars=TO_1 TO_2;
archi MLP hidden=&nhidden.;
initial inest=bestweights;
train tech=none;
code file="&dir.nncode_germancredit_MLP&nhidden._ES.sas";
score data=traindata nodmdb out=traindata_MLP&Nhidden._ES outfit=trainfit_MLP&Nhidden._ES role=TRAIN;
score data=validdata nodmdb out=validdata_MLP&Nhidden._ES outfit=validfit_MLP&Nhidden._ES role=valid;
run;
data test_train(keep=appl_id &y_var.point);
set traindata;
%include"&dir.nncode_germancredit_MLP&nhidden._ES.sas";
rename P_&y_var.0=point;
run;
proc npar1way data=test_train noprint;
class &y_var.;
var point;
output out=ks_t(keep=_d_ p_ksa rename=(_d_=KS p_ksa=P_value));
run;
data test_train_ks;
set ks_t;
length model$50.;
model="ES";
run;
proc append base=train_ks_total data=test_train_ks force;
run;
data vaild_train(keep=appl_id &y_var.point);
set validdata;
%include"&dir.nncode_germancredit_MLP&nhidden._ES.sas";
rename P_&y_var.0=point;
run;
proc npar1way data=vaild_train noprint;
class &y_var.;
var point;
output out=ks_v(keep=_d_ p_ksa rename=(_d_=KS
p_ksa=P_value));
run;
data test_vaild_ks;
set ks_v;
length model$50.;
model="ES";
run;
proc append base=vaild_ks_total data=test_vaild_ks force;
run;
%letidecay=1;
%do%until(&idecay.>4);
%if&idecay.=1%then%letcedcay=0.1;
%else%if&idecay.=2%then%letcedcay=0.01;
%else%if&idecay.=3%then%letcedcay=0.001;
%else%if&idecay.=4%then%letcedcay=0.0001;
%put&cedcay.;
proc neural data=traindata validdata=validdata dmdbcat=dmcdata graph;
input &list_varname./level=int;
target &y_var./level=nom;
decision decdata=decisionmatrix(type=loss) decvars=TO_1 TO_2;
archi MLP hidden=&nhidden.;
netoptions decay=&cedcay.;
nloptions maxiter=300;
prelim5maxiter=10;
train ;
code file="&dir.nncode_germancredit_MLP&nhidden._WD&idecay..sas";
score data=traindata nodmdb out=traindata_MLP&Nhidden._WD&idecay.outfit=trainfit_MLP&Nhidden._WD&idecay.role=TRAIN;
score data=validdata nodmdb out=validdata__MLP&Nhidden._WD&idecay.outfit=validfit_MLP&Nhidden._WD&idecay.role=valid;
run;
data test_train(keep=appl_id &y_var.point);
set traindata;
%include"&dir.nncode_germancredit_MLP&nhidden._WD&idecay..sas";
rename P_&y_var.0=point;
run;
proc npar1way data=test_train noprint;
class &y_var.;
var point;
output out=ks_t(keep=_d_ p_ksa rename=(_d_=KS p_ksa=P_value));
run;
data test_train_ks;
set ks_t;
length model$50.;
model="&nhidden._WD&idecay.";
run;
proc append base=train_ks_total data=test_train_ks force;
run;
data vaild_train(keep=appl_id &y_var.point);
set validdata;
%include"&dir.nncode_germancredit_MLP&nhidden._WD&idecay..sas";
rename P_&y_var.0=point;
run;
proc npar1way data=vaild_train noprint;
class &y_var.;
var point;
output out=ks_v(keep=_d_ p_ksa rename=(_d_=KS
p_ksa=P_value));
run;
data test_vaild_ks;
set ks_v;
length model$50.;
model="&nhidden._WD&idecay.";
run;
proc append base=vaild_ks_total data=test_vaild_ks force;
run;
%letidecay=%eval(&idecay.+1);
%end;
%letnhidden=%eval(&nhidden.+1);
%end;
%mend;
/*%mlps();*/
%letlist_varname=%str(N_M5_T09_CONRT N_M6_T09_CINRT N_N5_T82_COC_RC N_M5_T03_CONRT N_M3_T10_CONRC N_M3_T83_COC_RC
N_M3_T09_CINRTN_M6_T83_COT_RC N_M3_T83_CIT_RC N_M2_T10_CONRC N_M5_T03_CINRM N_M5_T10_CONRC N_M4_T02_CONRC N_M1_T08_CONRM
N_M3_T06_CINRM N_M2_T09_CONRT N_M6_T03_CONRT N_M5_T07_CINR );
%mlps(dir=F:data_1,data=raw.CALL_HOUR2_total7_woe,list_varname=&list_varname.,y_var=y);
最终的宏里面的list_vaname就不用填了,让他引用上面的宏list_vaname就可以了,list_vaname填的是你要去建立神经网络的变量,这里提醒一句哈,就是我尝试了不分组,分20组,分10组,分5组的效果,我建议是将变量分组好之后再丢进去比较好,但是我说不准到底是几组好,毕竟我和你的数据不一样。
data填的原始数据集。dir,填一个路径,这个路径存放的是最终的模型输出的规则,跟决策树那个score一个道理的。y_var填的是你的因变量。
最后看下你们最终要看的结果图长什么样子:
主要是要看这两个数据集的,这两个数据集长这样子:
ks值每个模型的ks值,p值是ks的p值,model对应的是哪个模型,GLIM是哪个广义线性模型,1_WD1代表的是隐藏层为1,权衰减为0.1对应的模型,在1_WD1,代表的隐藏层为1的时候对应的早停止发的模型,在2_WD1,代表的隐藏层为2的时候对应的早停止发的模型,找出你喜欢模型之后,去路径下面找规则代码就可以了。如果实在是这个代码格式跟你的sas不符的,可以在后台跟我要下txt的格式的代码。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
【核心关键词】贷款、报表、课程、专业、建模、缺失值、营销、互联网、银行、办公自动化、数据分析、数据预处理、特征工程、贷 ...
2026-06-05在数据库数据查询、业务报表统计、多表关联分析中,LEFT JOIN左连接是使用率最高的SQL关联查询语句。其核心特性是保留左表全部数 ...
2026-06-05 很多数据分析师能熟练地写SQL、做透视表、算描述性统计,但当被问到“如何预测用户流失概率”“如何归因销量下滑的关键因素 ...
2026-06-05任何一款产品从诞生、普及到最终退出市场,都会遵循一套固定的发展规律,这就是产品生命周期理论。在市场竞争日益激烈、产品迭代 ...
2026-06-04在Excel数据分析、办公统计、业务报表制作场景中,数据透视表是数据汇总、分类统计、快速复盘的核心工具,能够高效完成海量原始 ...
2026-06-04 很多数据分析师拿到数据就开始清洗、建模,但当被问到“这批数据属于什么类型——结构化还是非结构化?分类变量还是数值变量 ...
2026-06-04在问卷调查与社会科学数据分析中,卡方检验是最常用、最基础的非参数检验方法,广泛应用于市场调研、用户分析、行为统计、满意度 ...
2026-06-03【核心关键词】贷款、报表、课程、专业、建模、缺失值、营销、互联网、银行、办公自动化、数据分析、数据预处理、特征工程、贷 ...
2026-06-03 很多数据分析师画过趋势图、做过业绩预测,但当被问到“这个月销售额增长20%,到底是长期趋势自然增长,还是促销活动的短期 ...
2026-06-03逻辑回归是数据分析、机器学习、统计建模中应用最广泛的二分类预测模型,常用于风险判断、行为预测、归因分析等场景。在SPSS、Py ...
2026-06-02数字经济时代,市场竞争日趋同质化,用户消费需求愈发个性化、多元化,传统依托经验、粗放式、广撒网的营销模式弊端日益凸显。长 ...
2026-06-02 很多数据分析师做过按月份的销售额趋势图,画过按天的流量折线图,但当被问到“时间序列和普通数据有什么本质区别”“季节性 ...
2026-06-02在市场竞争日趋饱和、用户需求不断细分的当下,企业创业创新、产品迭代与市场拓展不再依赖经验决策,而是需要系统化、工具化的商 ...
2026-06-01【核心关键词】调度、岗位、数据库、企业、报表、培训、程序、数据分析、数据加工、业务部门、企业数据、调度工具、业务指标、 ...
2026-06-01 很多数据分析师能熟练地计算指标、搭建标签体系,但当被问到“画像到底在解决什么问题”“画像和标签是什么关系”“画像如何 ...
2026-06-01在数据统计分析、数据清洗、异常值识别与数据分布研究中,箱型图是最直观、高效、专业的可视化分析工具。相较于柱状图、折线图仅 ...
2026-05-29Tkinter是Python内置的标准GUI图形界面库,具备无需额外安装、调用简单、兼容性强、轻量化高效等优势,是Python快速开发桌面小程 ...
2026-05-29 很多分析师在设计标签时思路清晰,但真到落地环节却面临“数据在手,不知如何转化为可用标签”的困境:或因加工方式选择不当 ...
2026-05-29【核心关键词】大数据、经理、专业、金融、客户、传统、建模、数据产品、互联网金融、产品经理、数据分析、金融行业、数据模型 ...
2026-05-28 很多分析师每天和数据打交道,但当被问到“标签是什么”“标签和指标有什么区别”“标签体系如何设计”时,却常常答不上来。 ...
2026-05-28