This is an implementation for paper CASENet: Deep Category-Aware Semantic Edge Detection.
We used the data preprocessing codes provided by the author.sbd-preprocess. Based on this, we generated hdf5 file for data loading. The codes for generating data files are in utils/ folder. We also provided codes to generate png for each class to store the binary value of edge information. (Maybe faster than hdf5 and more efficient in storage. If using this format, need to change the data loader in dataloader/ folder and change the codes for visualization.)
Our implemented model is the ResNet101 version of CASENet. We evaluated the official model provided by the author, got a reasonable result but didn't reproduce the same number as in the paper. (The official model is converted from .caffemodel to PyTorch. About the conversion, we first converted the .caffemodel to numpy array, then based on the layername to load corresponding layer into PyTorch model. Codes for the transformation are in modules/CASENet.py)
Running main.py for training a model.
We modified the visualization codes from CASENet. PLease see vis_features.py.
We used the official benchmark codes for evaluation provided by Semantic Contours from Inverse Detectors. To generate the results image for evaluation, please see get_results_for_benchmark.py.
Original GitHub: https://github.com/merlresearch/CASENet
Original Weights Path: https://drive.google.com/drive/folders/1zxshISZtq0_S6zFB37F-FhE9wT1ZBrGK
- Download the weights from the Google Drive
- Put input image in the path:
predict/input
- Set the input image path on the file predict.py
- Run the script and check the results on the path:
predict/output