Matlab期末课程设计《基于BP网络的个人信贷信用评估》

2024-02-23 02:30

本文主要是介绍Matlab期末课程设计《基于BP网络的个人信贷信用评估》,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.目的和意义

  对客户行为模式的分析,对于每一个行业都至关重要。客户信用的评估基于对客户的认知,将客户划分为不同的类别,对应不同的需求,市场规模和重要程度。由此,可以指定差异化的服务策略,从而压缩成本,降低风险,实现利益最大化。

2.算法设计

流程图

在这里插入图片描述

算法理论介绍

(1)读入数据,由于数据保存在二进制文件german.data中,需要使用MATLAB的fid = fopen(‘german.data’, ‘r’);打开文件,再使用MATLAB的读入函数textscan,其中fid作为打开的文件句柄。调用方法如下:

%% 读入数据
% 打开文件
fid = fopen('german.data', 'r');% 按格式读取每一行
% 每行包括21项,包括字符串和数字
C = textscan(fid, '%s %d %s %s %d %s %s %d %s %s %d %s %d %s %s %d %s %d %s %s %d\n');% 关闭文件
fclose(fid);

  为了便于计算,必须使用数值来表示数据中的类别属性。最简单的方式就是使用整数进行编码,如第一个属性的类别字符串为“A12”,“A1”表示该属性为第一个属性,“2”表示属性值为第二个类别。因此,采用数字“2”编码字符串“A12”,具体实现如下:

% 将字符串转换为整数
N = 20;
% 存放整数编码后的数值矩阵
C1=zeros(N+1,1000);
for i=1:N+1% 类别属性if iscell(C{i})for j=1:1000% eg: 'A12' -> 2if i<10d = textscan(C{i}{j}, '%c%c%d');% eg: 'A103'  -> 3elsed = textscan(C{i}{j}, '%c%c%c%d');endC1(i,j) = d{end};end% 数值属性elseC1(i,:) = C{i};end
end

(2)划分训练样本和测试样本

%% 划分训练样本与测试样本% 输入向量
x = C1(1:N, :);
% 目标输出
y = C1(N+1, :);% 正例
posx = x(:,y==1);
% 负例
negx = x(:,y==2);% 训练样本
trainx = [ posx(:,1:350), negx(:,1:150)];
trainy = [ones(1,350), ones(1,150)*2];% 测试样本
testx = [ posx(:,351:700), negx(:,151:300)];
testy = trainy;

(3)样本归一化,使用maominmax函数对输入样本进行归一化

% 训练样本归一化
[trainx, s1] = mapminmax(trainx);% 测试样本归一化
testx = mapminmax('apply', testx, s1);

(4)创建BP网络,训练

% 创建BP网络
net = newff(trainx, trainy);
% 设置最大训练次数
net.trainParam.epochs = 1500;
% 目标误差
net.trainParam.goal = 1e-13;
% 显示级别
net.trainParam.show = 1;% 训练
net = train(net,trainx, trainy);5)测试
y0 = net(testx);% y0为浮点数输出。将y0量化为12。
y00 = y0;
%1.5为临界点,小于1.51,大于1.52
y00(y00<1.5)=1;
y00(y00>1.5)=2;% 显示正确率
fprintf('正确率: \n');
disp(sum(y00==testy)/length(y00));
web -broswer http://www.ilovematlab.cn/forum-222-1.html

3.实验验证

由图可知,结果的正确率为:0.7520,此时较为理想
在这里插入图片描述

同时打开一个网站
在这里插入图片描述

4.实验总结

  随着金融行业的迅猛发展,银行等部门逐渐积累了大量的客户数据,如何根据积累的数据跟踪个人客户的信用记录。如何根据累积的数据跟踪个人客户的信用记录并利用已有客户的数据,分析、判断新客户的信用状况,成为迫切需要解决的问题。个人信用评估对促进消费有极大的帮助。
  通过此次学习,我学到了很多知识,我明白了我要熟练掌握专业知识,做到学以致用,实现学习的价值。同时我也知道了学习的时候要多加练习,才能更牢固的掌握。

5.实验源码

% credit_class.m
% 信贷信用的评估
% 数据取自德国信用数据库%% 清理工作空间
clear,clc% 关闭图形窗口
close all%% 读入数据
% 打开文件
fid = fopen('german.data', 'r');% 按格式读取每一行
% 每行包括21项,包括字符串和数字
C = textscan(fid, '%s %d %s %s %d %s %s %d %s %s %d %s %d %s %s %d %s %d %s %s %d\n');% 关闭文件
fclose(fid);% 将字符串转换为整数
N = 20;
% 存放整数编码后的数值矩阵
C1=zeros(N+1,1000);
for i=1:N+1% 类别属性if iscell(C{i})for j=1:1000% eg: 'A12' -> 2if i<10d = textscan(C{i}{j}, '%c%c%d');% eg: 'A103'  -> 3elsed = textscan(C{i}{j}, '%c%c%c%d');endC1(i,j) = d{end};end% 数值属性elseC1(i,:) = C{i};end
end%% 划分训练样本与测试样本% 输入向量
x = C1(1:N, :);
% 目标输出
y = C1(N+1, :);% 正例
posx = x(:,y==1);
% 负例
negx = x(:,y==2);% 训练样本
trainx = [ posx(:,1:350), negx(:,1:150)];
trainy = [ones(1,350), ones(1,150)*2];% 测试样本
testx = [ posx(:,351:700), negx(:,151:300)];
testy = trainy;
%% 样本归一化
% 训练样本归一化
[trainx, s1] = mapminmax(trainx);% 测试样本归一化
testx = mapminmax('apply', testx, s1);
%% 创建网络,训练% 创建BP网络
net = newff(trainx, trainy);
% 设置最大训练次数
net.trainParam.epochs = 1500;
% 目标误差
net.trainParam.goal = 1e-13;
% 显示级别
net.trainParam.show = 1;% 训练
net = train(net,trainx, trainy);
%% 测试
y0 = net(testx);% y0为浮点数输出。将y0量化为12。
y00 = y0;
%1.5为临界点,小于1.51,大于1.52
y00(y00<1.5)=1;
y00(y00>1.5)=2;% 显示正确率
fprintf('正确率: \n');
disp(sum(y00==testy)/length(y00));
web -broswer http://www.ilovematlab.cn/forum-222-1.html

6.数据集

数据文件

这篇关于Matlab期末课程设计《基于BP网络的个人信贷信用评估》的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/m0_52900946/article/details/125040835
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/737245

相关文章

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Linux网络配置之网桥和虚拟网络的配置指南

《Linux网络配置之网桥和虚拟网络的配置指南》这篇文章主要为大家详细介绍了Linux中配置网桥和虚拟网络的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、网桥的配置在linux系统中配置一个新的网桥主要涉及以下几个步骤:1.为yum仓库做准备,安装组件epel-re

python如何下载网络文件到本地指定文件夹

《python如何下载网络文件到本地指定文件夹》这篇文章主要为大家详细介绍了python如何实现下载网络文件到本地指定文件夹,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...  在python中下载文件到本地指定文件夹可以通过以下步骤实现,使用requests库处理HTTP请求,并结合o

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子