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

相关文章

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

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

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor