// // This confidential and proprietary software may be used only as // authorised by a licensing agreement from ARM Limited // (C) COPYRIGHT 2020-2024 ARM Limited // ALL RIGHTS RESERVED // The entire notice above must be reproduced on all authorised // copies and copies may only be made to the extent permitted // by a licensing agreement from ARM Limited. ERROR_IF(shape != broadcast_shape(shape1, shape2)); for_each(index in shape) { shape_t index1 = apply_broadcast(shape, shape1, index); shape_t index2 = apply_broadcast(shape, shape2, index); in_out_t value1 = tensor_read(input1, shape1, index1); in_out_t value2 = tensor_read(input2, shape2, index2); REQUIRE(value2 != 0); // This catches the case where we divide minimum by -1 // which is not representable in two's complement REQUIRE(static_cast(value1) / static_cast(value2) <= maximum_s); in_out_t result = apply_intdiv_s(value1, value2); tensor_write(output, shape, index, result); }