mirror of
				https://github.com/zenorogue/hyperrogue.git
				synced 2025-10-25 19:07:40 +00:00 
			
		
		
		
	rug :: partially generalized to 3D (but no interesting results)
This commit is contained in:
		
							
								
								
									
										2
									
								
								hyper.h
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								hyper.h
									
									
									
									
									
								
							| @@ -3739,6 +3739,8 @@ hyperpoint hpxy(ld x, ld y); | |||||||
| hyperpoint hpxy3(ld x, ld y, ld z); | hyperpoint hpxy3(ld x, ld y, ld z); | ||||||
| ld sqhypot_d(int d, const hyperpoint& h); | ld sqhypot_d(int d, const hyperpoint& h); | ||||||
| ld hypot_d(int d, const hyperpoint& h); | ld hypot_d(int d, const hyperpoint& h); | ||||||
|  | ld dsqhypot_d(int d, const hyperpoint& a, const hyperpoint& b); | ||||||
|  | ld dhypot_d(int d, const hyperpoint& a, const hyperpoint& b); | ||||||
| transmatrix pushxto0(const hyperpoint& H); | transmatrix pushxto0(const hyperpoint& H); | ||||||
| transmatrix rpushxto0(const hyperpoint& H); | transmatrix rpushxto0(const hyperpoint& H); | ||||||
| transmatrix spintox(const hyperpoint& H); | transmatrix spintox(const hyperpoint& H); | ||||||
|   | |||||||
| @@ -190,6 +190,16 @@ ld hypot_d(int d, const hyperpoint& h) { | |||||||
|   return sqrt(sqhypot_d(d, h)); |   return sqrt(sqhypot_d(d, h)); | ||||||
|   } |   } | ||||||
|    |    | ||||||
|  | ld sqdhypot_d(int d, const hyperpoint& a, const hyperpoint& b) { | ||||||
|  |   ld sum = 0; | ||||||
|  |   for(int i=0; i<d; i++) sum += (a[i]-b[i])*(a[i]-b[i]); | ||||||
|  |   return sum; | ||||||
|  |   } | ||||||
|  |    | ||||||
|  | ld dhypot_d(int d, const hyperpoint& a, const hyperpoint& b) { | ||||||
|  |   return sqrt(sqdhypot_d(d, a, b)); | ||||||
|  |   } | ||||||
|  |    | ||||||
| ld zlevel(const hyperpoint &h) { | ld zlevel(const hyperpoint &h) { | ||||||
|   if(euclid) return h[GDIM]; |   if(euclid) return h[GDIM]; | ||||||
|   else if(sphere) return sqrt(intval(h, Hypc)); |   else if(sphere) return sqrt(intval(h, Hypc)); | ||||||
|   | |||||||
							
								
								
									
										59
									
								
								rug.cpp
									
									
									
									
									
								
							
							
						
						
									
										59
									
								
								rug.cpp
									
									
									
									
									
								
							| @@ -68,6 +68,8 @@ rugpoint *finger_center; | |||||||
| ld finger_range = .1; | ld finger_range = .1; | ||||||
| ld finger_force = 1; | ld finger_force = 1; | ||||||
|  |  | ||||||
|  | int rugdim; | ||||||
|  |  | ||||||
| bool rug_perspective = ISANDROID; | bool rug_perspective = ISANDROID; | ||||||
|  |  | ||||||
| // extra geometry functions | // extra geometry functions | ||||||
| @@ -273,8 +275,12 @@ rugpoint *addRugpoint(hyperpoint h, double dist) { | |||||||
|     m->flat = hpxyz(hpdist * h[0]/d0 * hpoint[1] / z, hpdist * h[1]/d0 * hpoint[1] / z, -hpdist * hpoint[0] / z);     |     m->flat = hpxyz(hpdist * h[0]/d0 * hpoint[1] / z, hpdist * h[1]/d0 * hpoint[1] / z, -hpdist * hpoint[0] / z);     | ||||||
|     } |     } | ||||||
|    |    | ||||||
|   else m->flat = // hpxyz(h[0], h[1], sin(atan2(h[0], h[1]) * 3 + hyprand) * (h[2]-1) / 1000); |   else { | ||||||
|     hpxyz(h[0], h[1], (h[2] - .99) * (rand() % 1000 - rand() % 1000) / 1000); |     m->flat = h; | ||||||
|  |     ld hd = h[DIM]; | ||||||
|  |     for(int d=DIM; d<rugdim; d++) | ||||||
|  |       m->flat[d] = (hd - .99) * (rand() % 1000 - rand() % 1000) / 1000; | ||||||
|  |     } | ||||||
|  |  | ||||||
|   if(rug_perspective) |   if(rug_perspective) | ||||||
|     push_point(m->flat, 2, -model_distance); |     push_point(m->flat, 2, -model_distance); | ||||||
| @@ -289,7 +295,7 @@ rugpoint *addRugpoint(hyperpoint h, double dist) { | |||||||
| rugpoint *findRugpoint(hyperpoint h) { | rugpoint *findRugpoint(hyperpoint h) { | ||||||
|   using namespace hyperpoint_vec; |   using namespace hyperpoint_vec; | ||||||
|   for(int i=0; i<isize(points); i++)  |   for(int i=0; i<isize(points); i++)  | ||||||
|     if(sqhypot_d(3, points[i]->h - h) < 1e-5) return points[i]; |     if(sqhypot_d(rugdim, points[i]->h - h) < 1e-5) return points[i]; | ||||||
|   return NULL; |   return NULL; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -577,10 +583,15 @@ void verify() { | |||||||
|       auto m2 = e.target; |       auto m2 = e.target; | ||||||
|       ld l = e.len; |       ld l = e.len; | ||||||
|        |        | ||||||
|       normalizer n(m->flat, m2->flat); |       ld l0; | ||||||
|       hyperpoint h1 = n(m->flat); |       if(fast_euclidean) l0 = sqdhypot_d(rugdim, m->flat, m2->flat); | ||||||
|       hyperpoint h2 = n(m2->flat); |       else {       | ||||||
|       ld l0 = hdist(h1, h2); |         normalizer n(m->flat, m2->flat); | ||||||
|  |         hyperpoint h1 = n(m->flat); | ||||||
|  |         hyperpoint h2 = n(m2->flat); | ||||||
|  |         l0 = hdist(h1, h2); | ||||||
|  |         } | ||||||
|  |  | ||||||
|       ratios.push_back(l0 / l); |       ratios.push_back(l0 / l); | ||||||
|       } |       } | ||||||
|      |      | ||||||
| @@ -679,8 +690,7 @@ bool force_euclidean(rugpoint& m1, rugpoint& m2, double rd, bool is_anticusp = f | |||||||
|   if(!m1.valid || !m2.valid) return false; |   if(!m1.valid || !m2.valid) return false; | ||||||
|   // double rd = hdist(m1.h, m2.h) * xd; |   // double rd = hdist(m1.h, m2.h) * xd; | ||||||
|   // if(rd > rdz +1e-6 || rd< rdz-1e-6) printf("%lf %lf\n", rd, rdz); |   // if(rd > rdz +1e-6 || rd< rdz-1e-6) printf("%lf %lf\n", rd, rdz); | ||||||
|   double t = 0; |   double t = sqdhypot_d(rugdim, m1.flat, m2.flat); | ||||||
|   for(int i=0; i<3; i++) t += (m1.flat[i] - m2.flat[i]) * (m1.flat[i] - m2.flat[i]); |  | ||||||
|   if(is_anticusp && t > rd*rd) return false; |   if(is_anticusp && t > rd*rd) return false; | ||||||
|   t = sqrt(t); |   t = sqrt(t); | ||||||
|   /* printf("%s ", display(m1.flat)); |   /* printf("%s ", display(m1.flat)); | ||||||
| @@ -689,7 +699,7 @@ bool force_euclidean(rugpoint& m1, rugpoint& m2, double rd, bool is_anticusp = f | |||||||
|   current_total_error += (t-rd) * (t-rd); |   current_total_error += (t-rd) * (t-rd); | ||||||
|   bool nonzero = abs(t-rd) > err_zero_current; |   bool nonzero = abs(t-rd) > err_zero_current; | ||||||
|   double force = (t - rd) / t / 2; // 20.0; |   double force = (t - rd) / t / 2; // 20.0; | ||||||
|   for(int i=0; i<3; i++) { |   for(int i=0; i<rugdim; i++) { | ||||||
|     double di = (m2.flat[i] - m1.flat[i]) * force; |     double di = (m2.flat[i] - m1.flat[i]) * force; | ||||||
|     m1.flat[i] += di * d1; |     m1.flat[i] += di * d1; | ||||||
|     m2.flat[i] -= di * d2; |     m2.flat[i] -= di * d2; | ||||||
| @@ -739,6 +749,7 @@ bool force(rugpoint& m1, rugpoint& m2, double rd, bool is_anticusp=false, double | |||||||
| vector<pair<ld, rugpoint*> > preset_points; | vector<pair<ld, rugpoint*> > preset_points; | ||||||
|  |  | ||||||
| void preset(rugpoint *m) { | void preset(rugpoint *m) { | ||||||
|  |   if(DIM == 3) return; | ||||||
|   int q = 0; |   int q = 0; | ||||||
|   hyperpoint h; |   hyperpoint h; | ||||||
|   for(int i=0; i<3; i++) h[i] = 0; |   for(int i=0; i<3; i++) h[i] = 0; | ||||||
| @@ -794,14 +805,19 @@ void preset(rugpoint *m) { | |||||||
|     throw rug_exception(); |     throw rug_exception(); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| ld sse(hyperpoint h) { | ld sse(const hyperpoint& h) { | ||||||
|   ld sse = 0; |   ld sse = 0; | ||||||
|   for(auto& p: preset_points) { |   for(auto& p: preset_points) { | ||||||
|     ld l = p.first; |     ld l = p.first; | ||||||
|     normalizer n(h, p.second->flat); |     ld l0; | ||||||
|     hyperpoint h1 = n(h); |     if(fast_euclidean)  | ||||||
|     hyperpoint h2 = n(p.second->flat); |       l0 = dhypot_d(rugdim, h, p.second->flat); | ||||||
|     ld l0 = hdist(h1, h2); |     else { | ||||||
|  |       normalizer n(h, p.second->flat); | ||||||
|  |       hyperpoint h1 = n(h); | ||||||
|  |       hyperpoint h2 = n(p.second->flat); | ||||||
|  |       l0 = hdist(h1, h2); | ||||||
|  |       } | ||||||
|     sse += (l0-l) * (l0-l); |     sse += (l0-l) * (l0-l); | ||||||
|     } |     } | ||||||
|    |    | ||||||
| @@ -815,20 +831,13 @@ void optimize(rugpoint *m, bool do_preset) { | |||||||
|     // int ed0 = isize(preset_points); |     // int ed0 = isize(preset_points); | ||||||
|     for(auto& e: m->edges) if(e.target->valid)  |     for(auto& e: m->edges) if(e.target->valid)  | ||||||
|       preset_points.emplace_back(e.len, e.target); |       preset_points.emplace_back(e.len, e.target); | ||||||
|     if(gwhere >= gSphere) { |     if(gwhere >= gSphere || DIM == 3) { | ||||||
|       ld cur = sse(m->flat); |       ld cur = sse(m->flat); | ||||||
|       for(int it=0; it<500; it++) { |       for(int it=0; it<500; it++) { | ||||||
|         ld ex = exp(-it/60); |         ld ex = exp(-it/60); | ||||||
|         again: |         again: | ||||||
|         hyperpoint last = m->flat; |         hyperpoint last = m->flat; | ||||||
|         switch(it%6) { |         m->flat[(it/2)%rugdim] += ((it&1)?1:-1) * ex; | ||||||
|           case 0: m->flat[0] += ex; break; |  | ||||||
|           case 1: m->flat[0] -= ex; break; |  | ||||||
|           case 2: m->flat[1] += ex; break; |  | ||||||
|           case 3: m->flat[1] -= ex; break; |  | ||||||
|           case 4: m->flat[2] += ex; break; |  | ||||||
|           case 5: m->flat[2] -= ex; break; |  | ||||||
|           } |  | ||||||
|         ld now = sse(m->flat); |         ld now = sse(m->flat); | ||||||
|         if(now < cur) { cur = now; ex *= 1.2; goto again; } |         if(now < cur) { cur = now; ex *= 1.2; goto again; } | ||||||
|         else m->flat = last; |         else m->flat = last; | ||||||
| @@ -846,6 +855,7 @@ bool stop = false; | |||||||
|  |  | ||||||
| bool subdivide_further() { | bool subdivide_further() { | ||||||
|   if(fulltorus) return false; |   if(fulltorus) return false; | ||||||
|  |   if(DIM == 3) return false; | ||||||
|   return isize(points) * 4 < vertex_limit; |   return isize(points) * 4 < vertex_limit; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -1429,6 +1439,7 @@ transmatrix currentrot; | |||||||
|      |      | ||||||
| void reopen() { | void reopen() { | ||||||
|   if(rugged) return; |   if(rugged) return; | ||||||
|  |   rugdim = 2 * DIM - 1; | ||||||
|   when_enabled = ticks; |   when_enabled = ticks; | ||||||
|   GLERR("before init"); |   GLERR("before init"); | ||||||
|   glbuf = new renderbuffer(TEXTURESIZE, TEXTURESIZE, vid.usingGL && !rendernogl); |   glbuf = new renderbuffer(TEXTURESIZE, TEXTURESIZE, vid.usingGL && !rendernogl); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Zeno Rogue
					Zeno Rogue