tensorflow2.0 rc版使用教程 常用操作集合系列1——Layer自定义层的设计add.weight(w,b权重设置)

推荐:
【tensorflow2.0最新建模教程】,如下:
tensorflow2.0教程 常用操作集合1—Layer自定义层的设计

常用操作集合系列2—Model自定义模型的设计

常用操作集合系列3—Model自定义模型的训练和参数调优loss gradient optimizer
常用操作集合系列4—损失函数正则化解决模型过拟合
常用操作集合系列5:tf2.0基于keras构建深度学习模型
常用操作集合系列6.案例-tf2.0如何构建交通标识识别CNN
今天分享的是如何使用tensorflow2.0展开自定义层Layer的设计。
注意点1权重初始化如下:
w_initial=tf.random_normal_initializer()
b_initial=tf.zeros_initializer()

Class Mydense(Layers.layer):
#例如Linear层  y=wa+b
  def _init_(self,input_dim,units):
      super(Mydense,self)._init_()
      w_initial=tf.random_normal_initializer()
      b_initial=tf.zeros_initializer()
      self.w=tf.variable(w_initial(shape=input_dim,units),dtype='float32')
      self.b=tf.variable(b_initial(shape=(units,)),dtype='float32')
  def call(self,inputs):
  return tf.matmul(inputs,self.w)+self.b
      

w和b的权重设置也可以单独在build中实现,调用add_weight来做权重设置,代码如下:

Class Mydense(Layers.layer):
   def _init_(self,units):
       super(Mydense,self)._init_
       self.units=units
   def build(self,input_shape):
       self.w=self.add_weight(shape=(input_shape[-1],units),initializer='random_normal',trainable=True)
       self.b=self.add_weight(shape=(self.units,),initializer='random_normal',trainable=True)
   def call(self,inputs):
       return tf.matmul(inputs,self.w) + self.b
       
  • 5
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
好的,以下是使用最新本的Tensorflow实现自定义Tensorflow的k-means示例: ```python import tensorflow as tf class KMeans(tf.keras.layers.Layer): def __init__(self, k, **kwargs): self.k = k super(KMeans, self).__init__(**kwargs) def build(self, input_shape): # 初始化聚类中心 self.centers = self.add_weight(name='centers', shape=(self.k, input_shape[-1]), initializer='random_normal', trainable=True) def call(self, inputs): # 计算输入与聚类中心的欧式距离 distances = tf.reduce_sum(tf.square(tf.expand_dims(inputs, axis=1) - self.centers), axis=2) # 找到距离最近的聚类中心 cluster_indices = tf.argmin(distances, axis=1) # 返回聚类中心和聚类结果 return [self.centers, cluster_indices] def compute_output_shape(self, input_shape): return [(self.k, input_shape[-1]), (input_shape[0],)] # 创建模型 inputs = tf.keras.layers.Input(shape=(10,)) kmeans = KMeans(4) centers, cluster_indices = kmeans(inputs) outputs = tf.keras.layers.Concatenate()([centers, tf.one_hot(cluster_indices, 4)]) model = tf.keras.models.Model(inputs=inputs, outputs=outputs) # 编译模型 model.compile(optimizer='adam', loss='kld', metrics=['accuracy']) # 训练模型 model.fit(x_train, y_train, epochs=10, validation_data=(x_test, y_test)) ``` 在这个例子中,我们定义了一个名为KMeans的自定义。在build方法中,我们使用随机正态分布初始化了聚类中心,并将其设置为可训练的权重。在call方法中,我们计算了输入数据与聚类中心之间的欧式距离,并返回了聚类中心和每个输入数据所属的聚类结果。在compute_output_shape方法中,我们指定了输出的形状。 然后,我们将KMeans应用于一个输入数据,将聚类中心和聚类结果连接在一起,并构建了一个包含输入和输出的完整模型。最后,我们编译了模型并训练了它。 请注意,此代码中的参数和数据需要根据您的具体情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI深度学习算法实战代码解读

离下一篇原创,还差5个打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值