mirror of
				https://github.com/ml-explore/mlx.git
				synced 2025-10-25 20:58:13 +08:00 
			
		
		
		
	Implements divide for integer types and adds floor_divide op (#228)
* Add floor_divide * Add floor_divide to the tests * Add floor_divide to the docs
This commit is contained in:
		 Angelos Katharopoulos
					Angelos Katharopoulos
				
			
				
					committed by
					
						 GitHub
						GitHub
					
				
			
			
				
	
			
			
			 GitHub
						GitHub
					
				
			
						parent
						
							de892cb66c
						
					
				
				
					commit
					2807c6aff0
				
			| @@ -357,7 +357,7 @@ template <typename T, typename U, typename Op> | ||||
|   instantiate_binary_all(name, complex64, complex64_t, bool, op) | ||||
|  | ||||
| instantiate_binary_types(add, Add) | ||||
| instantiate_binary_float(div, Divide) | ||||
| instantiate_binary_types(div, Divide) | ||||
| instantiate_binary_types_bool(eq, Equal) | ||||
| instantiate_binary_types_bool(ge, Greater) | ||||
| instantiate_binary_types_bool(geq, GreaterEqual) | ||||
|   | ||||
| @@ -111,6 +111,13 @@ constexpr complex64_t operator*(complex64_t a, complex64_t b) { | ||||
|   return {a.real * b.real - a.imag * b.imag, a.real * b.imag + a.imag * b.real}; | ||||
| } | ||||
|  | ||||
| constexpr complex64_t operator/(complex64_t a, complex64_t b) { | ||||
|   auto denom = b.real * b.real + b.imag * b.imag; | ||||
|   auto x = a.real * b.real + a.imag * b.imag; | ||||
|   auto y = a.imag * b.real - a.real * b.imag; | ||||
|   return {x / denom, y / denom}; | ||||
| } | ||||
|  | ||||
| constexpr complex64_t operator%(complex64_t a, complex64_t b) { | ||||
|   auto real = a.real - (b.real * static_cast<int64_t>(a.real / b.real)); | ||||
|   auto imag = a.imag - (b.imag * static_cast<int64_t>(a.imag / b.imag)); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user