24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1608  |  回复: 5

zlp-lw

木虫 (正式写手)

[交流] svm 预测 已有2人参与

各位大侠:
    您好,我用30个案例分析中的第14章的svm回归预测抑制剂的半浓度,并把其程序进行改写,但是出现了一些意想不到的情况。特向您请教:在第14章的例子中,最后的测试为什么不用测试集,而是用原始训练数据做测试,这样的测试效果很好,但是有什么效果呢?在我做的例子中,我用42个数据作为训练,10个数据作为测试集,对测试集我照着您这个例子中的训练集进行了归一化、反归一化处理,最后用训练模型进行测试,效果非常的差,我不知道这是什么原因?是我程序哪里出了问题,您能帮我看一下吗,我也30个案例分析的忠实读者。谢谢您
xx=xlsread('1.xls');
y=xlsread('1-1.xls');
xx=xx';
sh=[y,xx];

%% 数据的提取和预处理
% 数据是一个52*6的double型的矩阵,每一行表示每一天的负荷数据和影响因素
% 提取数据
[m,n] = size(x);
ts = x(1:m,1);
tsx = x(1:m,2:6);
% 数据预处理,将原始数据进行归一化
ts = ts';
tsx = tsx';
% mapminmax为matlab自带的映射函数
% 对ts进行归一化
[TS,TSps] = mapminmax(ts,1,2);
% 对TS进行转置,以符合libsvm工具箱的数据格式要求
TS = TS';
% mapminmax为matlab自带的映射函数
% 对tsx进行归一化
[TSX,TSXps] = mapminmax(tsx,1,2);
% 对TSX进行转置,以符合libsvm工具箱的数据格式要求
TSX = TSX';
%% 选择回归预测分析最佳的SVM参数c&g
bestc=1;bestg=1.6245;
bestc,cmd = ['-c ', num2str(bestc), ' -g ', num2str(bestg) , ' -s 3 -p 0.01'];
model = svmtrain(TS,TSX,cmd);
%% SVM网络回归预测
[predict,mse] = svmpredict(TS,TSX,model);
predict = mapminmax('reverse',predict',TSps);
predict = predict';
% 打印回归结果
str = sprintf( '均方误差 MSE = %g 相关系数 R = %g%%',mse(2),mse(3)*100);
disp(str);
%% 结果分析
figure;
hold on;
plot(ts,'-o');
plot(predict,'r-^');
legend('原始数据','回归预测数据');
hold off;
xlabel('小时','FontSize',12);
ylabel('/Wh','FontSize',12);
grid on;
figure;
error = predict - ts';
plot(error,'rd');
title('误差图(predicted data - original data)','FontSize',12);
xlabel('小时','FontSize',12);
ylabel('误差量','FontSize',12);
grid on;
figure;
error = (predict - ts')./ts';
plot(error,'rd');
title('相对误差图(predicted data - original data)/original data','FontSize',12);
xlabel('小时)','FontSize',12);
ylabel('相对误差量','FontSize',12);
grid on;
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zlp-lw

木虫 (正式写手)

怎么没有人指点指点啊
2楼2012-11-08 17:19:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

himyou

银虫 (小有名气)

★ ★
小木虫: 金币+0.5, 给个红包,谢谢回帖
csgt0: 金币+1, 欢迎交流 2012-11-13 17:52:18
我也遇到过这样的问题,你用SVMcgForRegress或者gaSVMcgForRegress进行参数寻优

或者你多增加训练集和测试集
3楼2012-11-13 17:06:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zlp-lw

木虫 (正式写手)

引用回帖:
3楼: Originally posted by himyou at 2012-11-13 17:06:13
我也遇到过这样的问题,你用SVMcgForRegress或者gaSVMcgForRegress进行参数寻优

或者你多增加训练集和测试集

我用SVMcgForRegress进行参数寻优,可是数据的输入不一样时预测的结果不一样,下面是我的数据输入的程序,帮我看看是什么原因吧?
%% 数据的提取和预处理

% 载入测试数据上证指数(1990.12.19-2009.08.19)
% 数据是一个4579*6的double型的矩阵,每一行表示每一天的上证指数
% 6列分别表示当天上证指数的开盘指数,指数最高值,指数最低值,收盘指数,当日交易量,当日交易额.
xx=xlsread('TXFZMSHF1.xls');
y=xlsread('ShiyanzhiDuishu1.xls');

xx=xx';
sh=[y,xx];
[m,n] = size(sh);
ts = sh(1:m,1);
tsx = sh(1:m,;


% 画出原始上证指数的每日开盘数
%figure;
%plot(ts,'LineWidth',2);
%title('上证指数的每日开盘数(1990.12.20-2009.08.19)','FontSize',12);
%grid on;

% 数据预处理,将原始数据进行归一化

ts = ts';
tsx = tsx';

% mapminmax为matlab自带的映射函数
[TS,TSps] = mapminmax(ts);       
% 将映射函数的范围参数分别置为1和2
TSps.ymin = 1;
TSps.ymax = 2;
% 对ts进行归一化
[TS,TSps] = mapminmax(ts,TSps);       

% 画出原始上证指数的每日开盘数归一化后的图像
figure;
plot(TS,'LineWidth',2);
title('原始上证指数的每日开盘数归一化后的图像','FontSize',12);
grid on;
% 对TS进行转置,以符合libsvm工具箱的数据格式要求
TS = TS';
TS1 = TS(43:m,1);
TS = TS(1:m-10,1);
% mapminmax为matlab自带的映射函数
[TSX,TSXps] = mapminmax(tsx);       
% 将映射函数的范围参数分别置为1和2
TSXps.ymin = 1;
TSXps.ymax = 2;
% 对tsx进行归一化
[TSX,TSXps] = mapminmax(tsx,TSXps);       
% 对TSX进行转置,以符合libsvm工具箱的数据格式要求
TSX = TSX';
TSX1 = TSX(43:m,1:n);
TSX = TSX(1:m-10,1:n);
这个输入,预测的效果是非常好的,其相关系数都达到了0.9996左右了,而用下面的输入程序,则预测结果不太理想。。

%% 数据的提取和预处理

% 载入测试数据上证指数(1990.12.19-2009.08.19)
% 数据是一个4579*6的double型的矩阵,每一行表示每一天的上证指数
% 6列分别表示当天上证指数的开盘指数,指数最高值,指数最低值,收盘指数,当日交易量,当日交易额.
xx=xlsread('1.xls');
y=xlsread('1-1.xls');
xx=xx';
sh=[y,xx];
[m,n] = size(sh);
ts = sh(1:m,1);
tsx = sh(1:m,;


% 画出原始上证指数的每日开盘数
%figure;
%plot(ts,'LineWidth',2);
%title('上证指数的每日开盘数(1990.12.20-2009.08.19)','FontSize',12);
%grid on;

% 数据预处理,将原始数据进行归一化

ts = ts';
tsx = tsx';

% mapminmax为matlab自带的映射函数
[TS,TSps] = mapminmax(ts);       
% 将映射函数的范围参数分别置为1和2
TSps.ymin = 1;
TSps.ymax = 2;
% 对ts进行归一化
[TS,TSps] = mapminmax(ts,TSps);       

% 画出原始上证指数的每日开盘数归一化后的图像
figure;
plot(TS,'LineWidth',2);
title('原始上证指数的每日开盘数归一化后的图像','FontSize',12);
grid on;
% 对TS进行转置,以符合libsvm工具箱的数据格式要求
TS = TS';
TS1 = TS(43:m,1);
TS = TS(1:m-10,1);
% mapminmax为matlab自带的映射函数
[TSX,TSXps] = mapminmax(tsx);       
% 将映射函数的范围参数分别置为1和2
TSXps.ymin = 1;
TSXps.ymax = 2;
% 对tsx进行归一化
[TSX,TSXps] = mapminmax(tsx,TSXps);       
% 对TSX进行转置,以符合libsvm工具箱的数据格式要求
TSX = TSX';
TSX1 = TSX(43:m,2:n);
TSX = TSX(1:m-10,2:n);
希望您和各位能指点指点。。。
4楼2012-11-14 09:19:27
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zlp-lw

木虫 (正式写手)

真的希望各位帮帮我啦,急啊!!!:sweat:
5楼2012-11-14 11:45:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

qusong007

禁虫 (初入文坛)


小木虫: 金币+0.5, 给个红包,谢谢回帖
本帖内容被屏蔽

6楼2018-05-04 09:34:25
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 zlp-lw 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿北理工298英一数二求调剂 +4 Reframe 2026-04-10 5/250 2026-04-10 08:27 by 紫曦紫棋
[考研] 化学工程与技术324调剂 +17 孙常华 2026-04-09 18/900 2026-04-10 08:17 by Sammy2
[考研] 还有化工二轮调剂的学校吗 5+11 化工人999 2026-04-09 41/2050 2026-04-10 07:37 by chixmc
[考研] 0860004 求调剂 309分 +7 Yin DY 2026-04-08 7/350 2026-04-09 14:06 by ditto77778
[考研] 070300化学279求调剂 +17 哈哈哈^_^ 2026-04-08 18/900 2026-04-09 10:49 by 三七七想上岸
[考研] 求调剂 +15 熊二想上岸 2026-04-04 15/750 2026-04-08 22:52 by 猪会飞
[考研] 材料与化工专硕306分找合适调剂 +27 沧海轻舟e 2026-04-06 28/1400 2026-04-08 22:06 by wdyheheeh
[考研] 专硕310求调剂 +7 捞捞我…. 2026-04-04 8/400 2026-04-08 20:24 by yutian743
[考研] 一志愿郑州大学085600求调剂 +21 吃的不少 2026-04-05 24/1200 2026-04-08 16:47 by sunhuadong
[考研] 一志愿211,化学学硕,310分,本科重点双非,求调剂 +10 努力奋斗112 2026-04-07 10/500 2026-04-08 15:01 by screening
[考研] 283求调剂 +19 A child 2026-04-04 19/950 2026-04-08 14:26 by xingguangj
[考研] 325 调剂 +6 QQ小虾 2026-04-07 6/300 2026-04-07 15:17 by Ccclqqq
[考研] 一志愿北交大材料工程总分358求调剂 +10 cs0106 2026-04-05 12/600 2026-04-06 19:41 by 无际的草原
[考研] 085405软件工程301分求调剂,专硕可跨专业,四六级已过 +3 静静想想 2026-04-05 3/150 2026-04-06 15:23 by nepu_uu
[考研] 319求调剂 +3 handrui 2026-04-05 3/150 2026-04-06 09:33 by jp9609
[考研] 331求调剂 +8 于征yz 2026-04-05 8/400 2026-04-06 00:54 by fmesaito
[考研] 272求调剂 +4 电气李 2026-04-05 4/200 2026-04-05 10:41 by lbsjt
[考研] 353求调剂 +10 MayUxw1 2026-04-03 10/500 2026-04-05 09:23 by 无际的草原
[考研] 本9一志愿2 0854低分专硕286求调剂 +9 芒种111 2026-04-04 9/450 2026-04-04 11:01 by tangruihua
[考研] 400分求调剂 +3 尴尬且挠头 2026-04-04 3/150 2026-04-04 08:41 by jp9609
信息提示
请填处理意见