IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> tensorflow 2.x 学习笔记 -> 正文阅读

[Python知识库]tensorflow 2.x 学习笔记

tensorflow 2.x 的特点:

  • tensorflow 2.x 默认使用Eager execution模式,简化了运行和调试。在tensorflow 1.x 中需要先构建完整的静态计算图,然后打开Session运行。
  • tensorflow 2.x 合并了Keras,简化了模型的构建。
  • 删除了冗余的API。placeholder, session, tf.layers, tf.contrib。

构建模型的三种方式

  • tf.keras.Sequential()
  • API构建模型
  • Model子类

保存模型

  • model.save() 或?tf.keras.models.save_model() 保存完整的模型
  • model.save_weights() 只保存网络模型的权重

常用的激活函数

  • tf.nn.relu
  • tf.nn.tanh
  • tf.nn.sigmoid
  • tf.nn.softmax

参数初始化

  • tf.keras.initializers.glorot_uniform (默认方法)
  • tf.keras.initializers.glorot_normal
  • tf.keras.initializers.he_uniform
  • tf.keras.initializers.he_normal
  • tf.keras.initializers.lecun_uniform
  • tf.keras.initializers.lecun_normal

优化器

  • tf.keras.optimizers.SGD
    • 不带动量
    • 带动量
    • Nesterov动量
  • tf.keras.optimizers.Adagrad
  • tf.keras.optimizers.RMSprop
  • tf.keras.optimizers.Adam

正则化

  • 参数范数惩罚
    • tf.keras.regularizers.l1
    • tf.keras.regularizers.l2
  • dropout
  • 噪声鲁棒性
  • 提前终止
  • 数据集增强

示例:tensorflow实现MLP

import os
import tensorflow as tf
from sklearn.datasets import load_boston
from sklearn.model_selection import train_test_split

tf.random.set_seed(2)

def load_data():
    data = load_boston()
    X_data, y_data = data.data, data.target
    y_data = y_data.reshape(y_data.shape[0], 1)
    X_train, X_test, y_train, y_test = train_test_split(X_data, y_data, test_size=0.2)
    return tf.cast(X_train, tf.float32), \
           tf.cast(X_test, tf.float32), \
           tf.cast(y_train, tf.float32), \
           tf.cast(y_test, tf.float32)

def load_weights(model, filepath):
    dirname = os.path.dirname(filepath)
    if not os.path.exists(dirname):
        os.mkdir(dirname)
        print("load weights failed")
        return False
    else:
        model.load_weights(filepath)
        print("load weights successfully")
        return True

class MLP(tf.keras.Model):
    def __init__(self):
        super(MLP, self).__init__()
        self.dense1 = tf.keras.layers.Dense(units=30, activation='relu', kernel_regularizer='l2')
        self.dropout1 = tf.keras.layers.Dropout(rate=0.5)
        self.dense2 = tf.keras.layers.Dense(units=20, activation='relu', kernel_regularizer='l2')
        self.dropout2 = tf.keras.layers.Dropout(rate=0.5)
        self.dense3 = tf.keras.layers.Dense(units=1, kernel_regularizer='l2')
    def call(self, inputs, training=False):
        x = self.dense1(inputs)
        if training:
            x = self.dropout1(x, training=training)
        x = self.dense2(x)
        if training:
            x = self.dropout2(x, training=training)
        outputs = self.dense3(x)
        return outputs

# 加载数据
X_train, X_test, y_train, y_test = load_data()
# 创建模型
model = MLP()
# 加载网络模型的权重
filepath = os.path.join(os.getcwd(), 'saved_models', 'mlp')
skip_train = load_weights(model, filepath)
# 优化器
optimizer = tf.keras.optimizers.Adam()
"""
======================================
train
======================================
"""
if skip_train:
    steps = 0
else:
    steps = 10000
    # tensorboard
    logdir = os.path.join(os.getcwd(), 'logs')
    writer = tf.summary.create_file_writer(logdir=logdir)
for step in range(1,steps+1):
    # 注意tape的作用域
    with tf.GradientTape() as tape:
        y_pred = model(X_train, training=True)
        loss = tf.reduce_mean(tf.square(y_pred - y_train))
        print('step: {}/{}, loss: {}'.format(step, steps, loss))
        with writer.as_default():
            tf.summary.scalar('loss', loss, step=step)
            writer.flush()
    grads = tape.gradient(loss, model.variables)
    optimizer.apply_gradients(zip(grads, model.variables))
"""
======================================
test
======================================
"""
y_pred = model(X_test)
loss = tf.reduce_mean(tf.square(y_pred-y_test))
print(loss)
"""
======================================
save weights
======================================
"""
model.save_weights(filepath, save_format="tf")

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-08-06 10:40:12  更:2022-08-06 10:42:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 10:09:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码