Skip to content

Latest commit

 

History

History
175 lines (146 loc) · 8.23 KB

README.md

File metadata and controls

175 lines (146 loc) · 8.23 KB

Viewpoint Estimation for Workpieces with Deep Transfer Learning from Cold to Hot

Build Status Build Status

This repository is the implementation of the paper Viewpoint Estimation for Workpieces with Deep Transfer Learning from Cold to Hot in ICONIP 2018. The code is implemented based on PyTorch.

Requirements

  • PyTorch and Torchvision

    We have tested the compatibility with the following versions of Python and PyTorch based on Travis-CI.

    Python 2.7 Python 3.5 Python 3.6 Python 3.7
    PyTorch 0.3.0 Travis Travis Travis Travis
    PyTorch 0.3.1 Travis Travis Travis Travis
    PyTorch 0.4.0 Travis Travis Travis Travis
    PyTorch 0.4.1 Travis Travis Travis Travis
    PyTorch 1.0.0 Travis Travis Travis Travis
  • TensorboardX and Tensorboard (Optional)

    To visualize the progress of training, we use TensorboardX to plot the loss and the accuracy in Tensorboard. The libaray TensorboardX can be installed by pip.

    pip install tensorboardX

    Also, remember to install Tensorflow and Tensorboard. If you don't want to use Tensorboard, simply set writer = None in train.py.

  • Other Dependencies

    Other dependencies are written in requirements.txt, you can install them by pip.

    cd sources
    pip install -r requirements.txt

Dataset Preparation

The data is read according to the filelists in dataset directory. Your may manually edit these files, or you can also generate the filelists by running our script (dataset/generate.py).

Before running our script, you should prepare your dataset with synthetic images and real images. The directory structure should be like this:

root
├─ wp1
│    ├─ synthetic
│    │    ├─ 1.90_0
│    │    │    ├─ xxx.png
│    │    │    └─ ...
│    │    ├─ 3.45_90
│    │    │    ├─ xxx.png
│    │    │    └─ ...
│    │    └─ ...
│    └─ real
│         ├─ 1.90_0
│         │    ├─ xxx.png
│         │    └─ ...
│         ├─ 3.45_90
│         │    ├─ xxx.png
│         │    └─ ...
│         └─ ...
├─ wp2
│    ├─ ...
│    └─ ...
└─ ...

Then replace the following code in generate.py with your own choices:

# Please edit the root directory of your dataset here
root = '/home/nip/LabDatasets/WorkPieces'
# Please edit your label mapping here
LABEL = {
    '1.90_0': 0,
    '3.45_90': 1,
    '5.45_270': 2,
    '6.0_0': 3,
    '7.0_90': 4,
    '8.0_180': 5,
    '9.0_270': 6
}
# Please edit your workpieces names here
WP = ['wp{}'.format(i) for i in range(1, 9)]

Finally, run the script, and you will get the filelists in dataset folder.

Train

  1. Set the parameters Our paremeters are written in sources/train.py. You can edit it manually.

    • Replace the filelists with your own filelists:

      for wp in ('wp{}'.format(i) for i in range(1, 9)):  # Training from WP1 to WP8
          cadset = MyDataset(
              filelist='../dataset/{}_cad.txt'.format(wp),
              input_transform=transforms.Compose([
                  Resize((300, 300)),
                  transforms.ToTensor(),
                  transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225])
              ])
          )
          realset = MyDataset(
              filelist='../dataset/{}_real.txt'.format(wp),
              input_transform=transforms.Compose([
                  Resize((300, 300)),
                  transforms.ToTensor(),
                  transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225])
              ])
          )
    • Set your own parameters

      parameters = {
          'epoch': 60,
          'batch_size': 128,
          'n_classes': 7,
          'test_steps': 50,
          # Whether to use GPU?
          # None      -- CPU only
          # 0 or (0,) -- Use GPU0
          # (0, 1)    -- Use GPU0 and GPU1
          'GPUs': 0
      }
    • Tensorboard Writer

      If you have installed Tensorboard and TensorboardX, by default, we will use TensorboardX to visualize the training process. Otherwise, we will skip it. The outputs will be written to sources/runs. If you don't want to use Tensorboard, you may set writer = None in your code.

  2. Train your own model

    cd sources
    python train.py

Test

Replace the parameters and the dataset in sources/test.py with our own choice just like Train, and replace the name of the pre-trained model. Then run test.py to test your model.

model.load_state_dict(torch.load('model.pth'))