unet预测图片全黑/全灰解决方案(keras)

几个注意点
载入模型

model = load_model("unet_person_128_" + str(n) + ".hdf5")

预测前图片处理:

def testGenerator(test_path, num_image, target_size):
    for pngfile in glob.glob(test_path + "/*.png"):#查找有关目录下的所有文件,pngfile为路径
        img = cv.imread(pngfile)#在OpenCV第一个参数是指定需要读取的图片的路径和图片名,另一个参数,常用的就是"IMREAD_UNCHANGED"、"IMREAD_GRAYSCALE"、"IMREAD_COLOR"三个属性
        img = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
        img = img / 255.0
        img = np.reshape(img, img.shape + (1,))
        img = np.reshape(img, (1,) + img.shape)#将测试图片扩展一个维度,与训练时的输入[2,256,256]保持一致
        yield img

保存结果:

def saveResult(save_path, result, flag_multi_class=False, num_class=2):
    for i, item in enumerate(result):
        img = item[:, :, 0]
        #img = (img * 255).astype(np.uint8)
        #io.imsave(os.path.join(save_path,"%d_predict.png"%i),img)     #使用该函数保存时不用做归一化
        cv.normalize(img, img, 0, 255, cv.NORM_MINMAX)  # 使用opencvimwrite保存图片时,需做归一化,将原先归一化至0-1的图片复原出来,否则结果全黑
        img = np.array(img)
        cv.imwrite(save_path + "/" + str(i+1) + "_predict.png", img)
  • 0
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
以下是一个基于Keras实现UNet的示例代码: ```python from keras.models import Model from keras.layers import Input, Conv2D, MaxPooling2D, Dropout, UpSampling2D, concatenate def unet(input_size=(256,256,1)): inputs = Input(input_size) # Contracting Path conv1 = Conv2D(64, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(inputs) conv1 = Conv2D(64, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv1) pool1 = MaxPooling2D(pool_size=(2, 2))(conv1) conv2 = Conv2D(128, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(pool1) conv2 = Conv2D(128, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv2) pool2 = MaxPooling2D(pool_size=(2, 2))(conv2) conv3 = Conv2D(256, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(pool2) conv3 = Conv2D(256, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv3) pool3 = MaxPooling2D(pool_size=(2, 2))(conv3) conv4 = Conv2D(512, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(pool3) conv4 = Conv2D(512, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv4) drop4 = Dropout(0.5)(conv4) pool4 = MaxPooling2D(pool_size=(2, 2))(drop4) # Bottom conv5 = Conv2D(1024, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(pool4) conv5 = Conv2D(1024, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv5) drop5 = Dropout(0.5)(conv5) # Expansive Path up6 = UpSampling2D(size = (2,2))(drop5) up6 = Conv2D(512, 2, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(up6) merge6 = concatenate([drop4,up6], axis = 3) conv6 = Conv2D(512, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(merge6) conv6 = Conv2D(512, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv6) up7 = UpSampling2D(size = (2,2))(conv6) up7 = Conv2D(256, 2, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(up7) merge7 = concatenate([conv3,up7], axis = 3) conv7 = Conv2D(256, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(merge7) conv7 = Conv2D(256, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv7) up8 = UpSampling2D(size = (2,2))(conv7) up8 = Conv2D(128, 2, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(up8) merge8 = concatenate([conv2,up8], axis = 3) conv8 = Conv2D(128, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(merge8) conv8 = Conv2D(128, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv8) up9 = UpSampling2D(size = (2,2))(conv8) up9 = Conv2D(64, 2, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(up9) merge9 = concatenate([conv1,up9], axis = 3) conv9 = Conv2D(64, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(merge9) conv9 = Conv2D(64, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv9) conv9 = Conv2D(2, 3, activation = 'relu', padding = 'same', kernel_initializer = 'he_normal')(conv9) # Output conv10 = Conv2D(1, 1, activation = 'sigmoid')(conv9) model = Model(inputs = inputs, outputs = conv10) return model ``` 使用方法: ```python model = unet() model.compile(optimizer = 'adam', loss = 'binary_crossentropy', metrics = ['accuracy']) model.summary() ``` 这个代码实现了一个基本的UNet模型,输入大小为256*256*1,输出大小为256*256*1,使用了`sigmoid`作为激活函数。可以根据实际需求进行修改。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值