50 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			50 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
|  | #include <lazyvec.hpp>
 | ||
|  | 
 | ||
|  | constexpr std::string_view _funcs = R"text( | ||
|  |   double Len() const {{ return std::sqrt(SqLen()); }} | ||
|  |   double SqLen() const {{ return {1}; }} | ||
|  | 
 | ||
|  |   template <typename T1> | ||
|  |   double Distance(const vec{0}<T1>& v) const {{ | ||
|  |     return (*this - v).Len(); | ||
|  |   }} | ||
|  |      | ||
|  |   vec{0}<T> Normalize() const {{ | ||
|  |     double l = Len(); | ||
|  |     if(l == 0) {{ | ||
|  |       return *this; | ||
|  |     }} | ||
|  |     return *this / (T)l; | ||
|  |   }} | ||
|  | 
 | ||
|  |   template <typename T1> | ||
|  |   T Dot(const vec{0}<T1>&v) const {{ | ||
|  |     return {2}; | ||
|  |   }} | ||
|  | )text"; | ||
|  | 
 | ||
|  | constexpr std::string_view _cross = R"text( | ||
|  |   template <typename T1> | ||
|  |   vec3<T> Cross(const vec3<T1>& v) const { | ||
|  |     return vec3<T>(y * v.z - z * v.y, z * v.x - x * v.z, x * v.y - y * v.x); | ||
|  |   } | ||
|  | )text"; | ||
|  | 
 | ||
|  | namespace LVec { | ||
|  | std::string MakeFunctions(int n) { | ||
|  |   std::stringstream s1, s2; | ||
|  |   for (int i = 0; i < n; i++) { | ||
|  |     s1 << elems[i] << " * " << elems[i]; | ||
|  |     s2 << elems[i] << " * (T)v." << elems[i]; | ||
|  |     if (i != n - 1) { | ||
|  |       s1 << " + "; | ||
|  |       s2 << " + "; | ||
|  |     } | ||
|  |   } | ||
|  |   std::string ret = std::format(_funcs, n, s1.str(), s2.str()); | ||
|  |   if (n == 3) { | ||
|  |     ret += _cross; | ||
|  |   } | ||
|  |   return ret; | ||
|  | } | ||
|  | }  // namespace LVec
 |