Keras实现U-net

 U-net论文地址:https://arxiv.org/pdf/1505.04597v1.pdf

U-net的网络结构如图

import tensorflow as tf
from keras.layers import *
import numpy as np
import keras
from keras.models import *
from keras.optimizers import *


def unet(pretrained_weight=None, input_size=(512, 512, 3)):
    input = Input(shape=input_size)
    conv1 = Conv2D(64, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv1_1')(input)
    conv1 = Conv2D(64, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv1_2')(conv1)
    maxpool1 = MaxPooling2D((2, 2), name='encoder_maxpool1')(conv1)

    conv2 = Conv2D(128, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv2_1')(maxpool1)
    conv2 = Conv2D(128, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv2_2')(conv2)
    maxpool2 = MaxPooling2D((2, 2), name='encoder_maxpool2')(conv2)

    conv3 = Conv2D(256, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv3_1')(maxpool2)
    conv3 = Conv2D(256, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv3_2')(conv3)
    maxpool3 = MaxPooling2D((2, 2), name='encoder_maxpool3')(conv3)

    conv4 = Conv2D(512, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv4_1')(maxpool3)
    conv4 = Conv2D(512, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv4_2')(conv4)
    maxpool4 = MaxPooling2D((2, 2), name='encoder_maxpool4')(conv4)

    conv5 = Conv2D(1024, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv5_1')(maxpool4)
    conv5 = Conv2D(1024, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='encoder_conv5_2')(conv5)
    # maxpool4=MaxPooling2D((2,2))(conv4)

    up1 = UpSampling2D(size=(2, 2), name='decoder_upsample1')(conv5)
    upconv1 = Conv2D(512, kernel_size=2, padding='same', activation='relu', kernel_initializer='he_normal', name='decoder_upconv1')(up1)
    upconv1 = concatenate([upconv1, conv4], axis=-1)
    upconv1 = Conv2D(512, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='decoder_conv1_1')(upconv1)
    upconv1 = Conv2D(512, kernel_size=3, padding='same', activation='relu', kernel_initializer='he_normal', name='decoder_conv1_2')(upconv1)

    up2 = UpSampling2D(size=(2, 2), name='decoder_upsample2')(upconv1)
    upconv2 = Co
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
U-net是一种深度学习网络,用于图像分割,而不是图像分类。图像分类的任务是将图像分为不同的类别,而图像分割的任务是将图像中的每个像素分为不同的类别。如果你想实现U-net图像分割的代码,我可以给你提供一个Python实现的示例。 ```python import tensorflow as tf from tensorflow.keras import layers def unet(input_size=(256, 256, 1)): inputs = layers.Input(input_size) # Down-sampling layers conv1 = layers.Conv2D(64, 3, activation='relu', padding='same')(inputs) conv1 = layers.Conv2D(64, 3, activation='relu', padding='same')(conv1) pool1 = layers.MaxPooling2D(pool_size=(2, 2))(conv1) conv2 = layers.Conv2D(128, 3, activation='relu', padding='same')(pool1) conv2 = layers.Conv2D(128, 3, activation='relu', padding='same')(conv2) pool2 = layers.MaxPooling2D(pool_size=(2, 2))(conv2) conv3 = layers.Conv2D(256, 3, activation='relu', padding='same')(pool2) conv3 = layers.Conv2D(256, 3, activation='relu', padding='same')(conv3) pool3 = layers.MaxPooling2D(pool_size=(2, 2))(conv3) conv4 = layers.Conv2D(512, 3, activation='relu', padding='same')(pool3) conv4 = layers.Conv2D(512, 3, activation='relu', padding='same')(conv4) drop4 = layers.Dropout(0.5)(conv4) pool4 = layers.MaxPooling2D(pool_size=(2, 2))(drop4) # Bottom layers conv5 = layers.Conv2D(1024, 3, activation='relu', padding='same')(pool4) conv5 = layers.Conv2D(1024, 3, activation='relu', padding='same')(conv5) drop5 = layers.Dropout(0.5)(conv5) # Up-sampling layers up6 = layers.Conv2DTranspose(512, 2, strides=(2, 2), padding='same')(drop5) merge6 = layers.concatenate([drop4, up6], axis=3) conv6 = layers.Conv2D(512, 3, activation='relu', padding='same')(merge6) conv6 = layers.Conv2D(512, 3, activation='relu', padding='same')(conv6) up7 = layers.Conv2DTranspose(256, 2, strides=(2, 2), padding='same')(conv6) merge7 = layers.concatenate([conv3, up7], axis=3) conv7 = layers.Conv2D(256, 3, activation='relu', padding='same')(merge7) conv7 = layers.Conv2D(256, 3, activation='relu', padding='same')(conv7) up8 = layers.Conv2DTranspose(128, 2, strides=(2, 2), padding='same')(conv7) merge8 = layers.concatenate([conv2, up8], axis=3) conv8 = layers.Conv2D(128, 3, activation='relu', padding='same')(merge8) conv8 = layers.Conv2D(128, 3, activation='relu', padding='same')(conv8) up9 = layers.Conv2DTranspose(64, 2, strides=(2, 2), padding='same')(conv8) merge9 = layers.concatenate([conv1, up9], axis=3) conv9 = layers.Conv2D(64, 3, activation='relu', padding='same')(merge9) conv9 = layers.Conv2D(64, 3, activation='relu', padding='same')(conv9) # Output layer outputs = layers.Conv2D(1, 1, activation='sigmoid')(conv9) model = tf.keras.Model(inputs=inputs, outputs=outputs) return model ``` 这是一个简单的U-net实现,可以用于二进制图像分割任务。你可以使用该模型对图像进行分割,然后对分割结果进行分类。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值