Department of Computer Engineering2024-11-0920181532-062610.1002/cpe.46912-s2.0-85047664332http://dx.doi.org/10.1002/cpe.4691https://hdl.handle.net/20.500.14288/6138Reduction and broadcast operations are commonly used in machine learning algorithms for different purposes. They widely appear in the calculation of the gradient values of a loss function, which are one of the core structures of neural networks. Both operations are implemented naively in many libraries usually for scalar reduction or broadcast; however, to our knowledge, there are no optimized multidimensional implementations available. This fact limits the performance of machine learning models requiring these operations to be performed on tensors. In this work, we address the problem and propose two new strategies that extend the existing implementations to perform on tensors. We introduce formal definitions of both operations using tensor notations, investigate their mathematical properties, and exploit these properties to provide an efficient solution for each. We implement our parallel strategies and test them on a CUDA enabled Tesla K40m GPU accelerator. Our performant implementations achieve up to 75% of the peak device memory bandwidth on different tensor sizes and dimensions. Significant speedups against the implementations available in the Knet Deep Learning framework are also achieved for both operations.Computer scienceSoftware engineeringComputer scienceTheory methodsFast multidimensional reduction and broadcast operations on GPU for machine learningJournal Article1532-06344472679000042125