资源算法pytorch-toolbelt

pytorch-toolbelt

2019-10-10 | |  209 |   0 |   0

Pytorch-toolbelt

Build Status Documentation Status

pytorch-toolbelt is a Python library with a set of bells and whistles for PyTorch for fast R&D prototyping and Kaggle farming:

What's inside

  • Easy model building using flexible encoder-decoder architecture.

  • Modules: CoordConv, SCSE, Hypercolumn, Depthwise separable convolution and more.

  • GPU-friendly test-time augmentation TTA for segmentation and classification

  • GPU-friendly inference on huge (5000x5000) images

  • Every-day common routines (fix/restore random seed, filesystem utils, metrics)

  • Losses: BinaryFocalLoss, Focal, ReducedFocal, Lovasz, Jaccard and Dice losses, Wing Loss and more.

  • Extras for Catalyst library (Visualization of batch predictions, additional metrics)

Showcase: Catalyst, Albumentations, Pytorch Toolbelt example: Semantic Segmentation @ CamVid

Why

Honest answer is "I needed a convenient way to re-use code for my Kaggle career". During 2018 I achieved a Kaggle Master badge and this been a long path. Very often I found myself re-using most of the old pipelines over and over again. At some point it crystallized into this repository.

This lib is not meant to replace catalyst / ignite / fast.ai. Instead it's designed to complement them.

Installation

pip install pytorch_toolbelt

Showcase

Encoder-decoder models construction

from pytorch_toolbelt.modules import encoders as Efrom pytorch_toolbelt.modules import decoders as Dclass FPNSegmentationModel(nn.Module):    def __init__(self, encoder:E.EncoderModule, num_classes, fpn_features=128):        self.encoder = encoder        self.decoder = D.FPNDecoder(encoder.output_filters, fpn_features=fpn_features)        self.fuse = D.FPNFuse()
        input_channels = sum(self.decoder.output_filters)        self.logits = nn.Conv2d(input_channels, num_classes,kernel_size=1)        
    def forward(self, input):
        features = self.encoder(input)
        features = self.decoder(features)
        features = self.fuse(features)
        logits = self.logits(features)        return logits        
def fpn_resnext50(num_classes):
  encoder = E.SEResNeXt50Encoder()  return FPNSegmentationModel(encoder, num_classes)  
def fpn_mobilenet(num_classes):
  encoder = E.MobilenetV2Encoder()  return FPNSegmentationModel(encoder, num_classes)

Compose multiple losses

from pytorch_toolbelt import losses as L

loss = L.JointLoss(L.FocalLoss(), 1.0, L.LovaszLoss(), 0.5)

Test-time augmentation

from pytorch_toolbelt.inference import tta# Truly functional TTA for image classification using horizontal flips:logits = tta.fliplr_image2label(model, input)# Truly functional TTA for image segmentation using D4 augmentation:logits = tta.d4_image2mask(model, input)# TTA using wrapper module:tta_model = tta.TTAWrapper(model, tta.fivecrop_image2label, crop_size=512)
logits = tta_model(input)

Inference on huge images:

import numpy as npimport torchimport cv2from pytorch_toolbelt.inference.tiles import ImageSlicer, CudaTileMergerfrom pytorch_toolbelt.utils.torch_utils import tensor_from_rgb_image, to_numpy


image = cv2.imread('really_huge_image.jpg')
model = get_model(...)# Cut large image into overlapping tilestiler = ImageSlicer(image.shape, tile_size=(512, 512), tile_step=(256, 256), weight='pyramid')# HCW -> CHW. Optionally, do normalization heretiles = [tensor_from_rgb_image(tile) for tile in tiler.split(image)]# Allocate a CUDA buffer for holding entire maskmerger = CudaTileMerger(tiler.target_shape, 1, tiler.weight)# Run predictions for tiles and accumulate themfor tiles_batch, coords_batch in DataLoader(list(zip(tiles, tiler.crops)), batch_size=8, pin_memory=True):
    tiles_batch = tiles_batch.float().cuda()
    pred_batch = model(tiles_batch)

    merger.integrate_batch(pred_batch, coords_batch)# Normalize accumulated mask and convert back to numpymerged_mask = np.moveaxis(to_numpy(merger.merge()), 0, -1).astype(np.uint8)
merged_mask = tiler.crop_to_orignal_size(merged_mask)

Advanced examples

  1. Inria Sattelite Segmentation

  2. CamVid Semantic Segmentation

Citation

@misc{Khvedchenya_Eugene_2019_PyTorch_Toolbelt,
  author = {Khvedchenya, Eugene},
  title = {PyTorch Toolbelt},
  year = {2019},
  publisher = {GitHub},
  journal = {GitHub repository},
  howpublished = {url{https://github.com/BloodAxe/pytorch-toolbelt}},
  commit = {cc5e9973cdb0dcbf1c6b6e1401bf44b9c69e13f3}
}


上一篇:pytorch-cpp-rl

下一篇:argus-tensor-stream

用户评价
全部评价

热门资源

  • Keras-ResNeXt

    Keras ResNeXt Implementation of ResNeXt models...

  • seetafaceJNI

    项目介绍 基于中科院seetaface2进行封装的JAVA...

  • spark-corenlp

    This package wraps Stanford CoreNLP annotators ...

  • capsnet-with-caps...

    CapsNet with capsule-wise convolution Project ...

  • inferno-boilerplate

    This is a very basic boilerplate example for pe...