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 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 贴吧问题: 一维序列的卷积神经网络 2021-10-27 -> 正文阅读

[人工智能]贴吧问题: 一维序列的卷积神经网络 2021-10-27

贴吧问题:
题主最近刚接触神经网络的课题,目前想要用Python做一个一维序列的卷积神经网络,需求是将一维序列卷积池化后,再将卷积得到的特征数据序列与另外三个数值数据放入全连接层。
就是卷积和bp的结合,想问问该怎么做

答案:

from tensorflow.keras.layers import Conv1D, MaxPool1D, Flatten, Dense, Input
from tensorflow.keras.models import Model
import numpy as np
import tensorflow

ipt_size=100 #100个样本

ipt_shape=128 #一维128长度数据
ipt2_shape=3 # 三维数据

x1=np.random.randint(0,100,(ipt_size, ipt_shape))
y=np.random.randint(0,100,(ipt_size))
x2=np.random.randint(0,100,(ipt_size, ipt2_shape))


# x  扩维
x1=np.expand_dims(x1, axis=-1)
# 随机样本 x, y
print(x1.shape)
print(y.shape)
print(x2.shape)

ipt1=Input((ipt_shape, 1))
cov1=Conv1D(filters=32, kernel_size=3)(ipt1)
max1=MaxPool1D()(cov1)

cov2=Conv1D(filters=32, kernel_size=3)(max1)
max2=MaxPool1D()(cov2)


f=Flatten()(max2)

ipt2=Input((ipt2_shape))

# 连接层
class Combine_ipt(tensorflow.keras.layers.Layer):
    def __init__(self):
        super(Combine_ipt, self).__init__()

    def call(self, inputs):
        ipt1=inputs[0]
        ipt2=inputs[1]

        res=tensorflow.concat([ipt1, ipt2], -1)


        print("融合前维度为:%s 和 %s, 融合后变成:%s", ipt1.shape, ipt2.shape, res.shape)

        return res

#使用连接层连接 f 和 ipt2
ci=Combine_ipt()([f, ipt2])

d1=Dense(32, activation="relu")(f)

# 回归问题, 单神经元无激活函数
opt=Dense(1)(d1)

model=Model((ipt1, ipt2), opt)

model.summary()

model.compile(loss="mse")

# 训练, 参数自己调 (x=None, y=None, batch_size=None, epochs=1, verbose='auto', callbacks=None, validation_split=0, validation_data=None, shuffle=True, class_weight=None, sample_weight=None, initial_epoch=0, steps_per_epoch=None, validation_steps=None, validation_batch_size=None, validation_freq=1, max_queue_size=10, workers=1, use_multiprocessing=False)
model.fit(x=[x1, x2], y=y)

# 推理
pred=model.predict([x1, x2])

print(pred)
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-10-28 12:23:44  更:2021-10-28 12:25:27 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 8:51:30-

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