John Gallagher (Committee Member), Michael Raymer (Committee Member), Mateen Rizki (Advisor), Andres Rodriguez (Committee Member)
Master of Science (MS)
Convolutional neural networks (CNNs) are currently state-of-the-art for various classification tasks, but are computationally expensive. Propagating through the convolutional layers is very slow, as each kernel in each layer must sequentially calculate many inner products for a single forward and backward propagation which equates to O(N^2 n^2) per kernel per layer where the inputs are N x N arrays and the kernels are n x n arrays. Convolution can be efficiently performed as a Hadamard product in the frequency domain. The bottleneck is the transformation which has a cost of O(N^2 log_2 N) using the fast Fourier transform (FFT). However, the increase in efficiency is less significant when N >> n as is the case in CNNs. We mitigate this by using the ``overlap-and-add'' technique reducing the computational complexity to O(N^2 log_2 n) per kernel. This method increases the algorithm's efficiency in both the forward and backward propagation, significantly reducing the training and testing time for CNNs. Our empirical results show our method reduces computational time by a factor of up to 50.4 times the traditional convolution implementation.
Department or Program
Department of Computer Science
Year Degree Awarded
Copyright 2015, some rights reserved. My ETD may be copied and distributed only for non-commercial purposes and may not be modified. All use must give me credit as the original author.
Creative Commons License
This work is licensed under a Creative Commons Attribution-Noncommercial-No Derivative Works 3.0 License.