tensorflow实现非线性回归实例

2024-06-17 13:58

本文主要是介绍tensorflow实现非线性回归实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

import tensorflow as tf
import numpy as np
import os
import matplotlib.pyplot as plt
os.environ['TF_CPP_MIN_LOG_LEVEL']='2'# R25=10k B25/50=3470 NTC热敏电阻特性数据表# 加载样本数据 格式:电阻值(K)   温度值(℃)
dat = np.loadtxt('trainData.txt')# 数据归一化处理
R = dat[:,0]
T = dat[:,1]R_K = R.max()-R.min()
R_B = R.min()T_K = T.max()-T.min()
T_B = T.min()R = (R - R_B)/R_K
T = (T - T_B)/T_KR = R.reshape(141,1)
T = T.reshape(141,1)X = tf.placeholder(tf.float32, shape = [None, 1])
Y = tf.placeholder(tf.float32, shape = [None, 1])# 定义层
def add_layer(input,in_size,out_size,activation_fun):""":param input: 输入数据:param in_size: 输入矩阵列数:param out_size: 输出矩阵列数:param activation_fun:激活函数:return:输出矩阵"""weights = tf.Variable(tf.random_normal([in_size, out_size]))bias = tf.Variable(tf.zeros([1, out_size]))z_i = tf.matmul(input, weights) + biasreturn activation_fun(z_i)# 正向传播#  添加隐藏层 该层10个神经元
out_h = add_layer(X,1,10,tf.nn.sigmoid)# 输出层
out = add_layer(out_h,10,1,tf.nn.sigmoid)# 定义损失函数
loss = tf.reduce_mean(tf.reduce_sum(tf.square(out - Y), reduction_indices=[1]))# 学习率为
learning_rate = 20.2# 梯度下降优化器,让损失最小化
train_step = tf.train.GradientDescentOptimizer(learning_rate).minimize(loss)# 初始化tensor flow中的变量
init = tf.global_variables_initializer()with tf.Session() as sess:sess.run(init)for i in range(10000):sess.run(train_step, feed_dict={X: R, Y: T})if i % 100== 0:# 打印损失值e = sess.run(loss, feed_dict={X: R, Y: T})print(e)# 预测值y = sess.run(out, feed_dict={X: R, Y: T})y = y*T_K+T_Bdat_R = dat[:,0]dat_T = dat[:,1]plt.rcParams['font.sans-serif']=['SimHei']plt.rcParams['axes.unicode_minus'] = Falseplt.xlabel("电阻")plt.ylabel("温度")plt.plot(dat_R ,dat_T,'r',label='R-T特性曲线')plt.plot(dat_R,y,label='拟合曲线')plt.legend()plt.grid()plt.show()

运行结果:

在这里插入图片描述

这篇关于tensorflow实现非线性回归实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1069634

相关文章

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu