- Timestamp:
- 09/26/06 12:42:41 (18 years ago)
- Location:
- GTP/trunk/Lib/Vis
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
GTP/trunk/Lib/Vis/GtpVisibility.sln
r1489 r1492 39 39 {80DECC17-BDDD-4412-8CF8-F7C1C17A7436} = {80DECC17-BDDD-4412-8CF8-F7C1C17A7436} 40 40 {7319E499-473D-4CE5-9983-725D6E68A55D} = {7319E499-473D-4CE5-9983-725D6E68A55D} 41 EndProjectSection42 EndProject43 Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gui", "Preprocessing\gui\gui.vcproj", "{8E28F667-63A7-4F41-81D0-233B971BF247}"44 ProjectSection(ProjectDependencies) = postProject45 EndProjectSection46 EndProject47 Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "fractal", "Preprocessing\fractal\fractal.vcproj", "{00ED6D39-0F68-405F-AE02-B8886BACA7E2}"48 ProjectSection(ProjectDependencies) = postProject49 41 EndProjectSection 50 42 EndProject … … 393 385 {17F2C6F9-6101-430E-ABF4-71383868EF24}.Universal Unicode Release.ActiveCfg = Release|Win32 394 386 {17F2C6F9-6101-430E-ABF4-71383868EF24}.Universal Unicode Release.Build.0 = Release|Win32 395 {8E28F667-63A7-4F41-81D0-233B971BF247}.Debug.ActiveCfg = Debug|Win32396 {8E28F667-63A7-4F41-81D0-233B971BF247}.Debug.Build.0 = Debug|Win32397 {8E28F667-63A7-4F41-81D0-233B971BF247}.Debug Static.ActiveCfg = Debug|Win32398 {8E28F667-63A7-4F41-81D0-233B971BF247}.Debug Static.Build.0 = Debug|Win32399 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Debug.ActiveCfg = Debug|Win32400 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Debug.Build.0 = Debug|Win32401 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Release.ActiveCfg = Release|Win32402 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Release.Build.0 = Release|Win32403 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Unicode Debug.ActiveCfg = Debug|Win32404 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Unicode Debug.Build.0 = Debug|Win32405 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Unicode Release.ActiveCfg = Release|Win32406 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Unicode Release.Build.0 = Release|Win32407 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Universal Debug.ActiveCfg = Debug|Win32408 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Universal Debug.Build.0 = Debug|Win32409 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Universal Release.ActiveCfg = Release|Win32410 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Universal Release.Build.0 = Release|Win32411 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Universal Unicode Debug.ActiveCfg = Debug|Win32412 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Universal Unicode Debug.Build.0 = Debug|Win32413 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Universal Unicode Release.ActiveCfg = Release|Win32414 {8E28F667-63A7-4F41-81D0-233B971BF247}.DLL Universal Unicode Release.Build.0 = Release|Win32415 {8E28F667-63A7-4F41-81D0-233B971BF247}.mlrt.ActiveCfg = Release|Win32416 {8E28F667-63A7-4F41-81D0-233B971BF247}.mlrt.Build.0 = Release|Win32417 {8E28F667-63A7-4F41-81D0-233B971BF247}.Release.ActiveCfg = Release|Win32418 {8E28F667-63A7-4F41-81D0-233B971BF247}.Release.Build.0 = Release|Win32419 {8E28F667-63A7-4F41-81D0-233B971BF247}.Release Internal.ActiveCfg = Release|Win32420 {8E28F667-63A7-4F41-81D0-233B971BF247}.Release Internal.Build.0 = Release|Win32421 {8E28F667-63A7-4F41-81D0-233B971BF247}.Release Static.ActiveCfg = Release|Win32422 {8E28F667-63A7-4F41-81D0-233B971BF247}.Release Static.Build.0 = Release|Win32423 {8E28F667-63A7-4F41-81D0-233B971BF247}.Unicode Debug.ActiveCfg = Debug|Win32424 {8E28F667-63A7-4F41-81D0-233B971BF247}.Unicode Debug.Build.0 = Debug|Win32425 {8E28F667-63A7-4F41-81D0-233B971BF247}.Unicode Release.ActiveCfg = Release|Win32426 {8E28F667-63A7-4F41-81D0-233B971BF247}.Unicode Release.Build.0 = Release|Win32427 {8E28F667-63A7-4F41-81D0-233B971BF247}.Universal Debug.ActiveCfg = Debug|Win32428 {8E28F667-63A7-4F41-81D0-233B971BF247}.Universal Debug.Build.0 = Debug|Win32429 {8E28F667-63A7-4F41-81D0-233B971BF247}.Universal Release.ActiveCfg = Release|Win32430 {8E28F667-63A7-4F41-81D0-233B971BF247}.Universal Release.Build.0 = Release|Win32431 {8E28F667-63A7-4F41-81D0-233B971BF247}.Universal Unicode Debug.ActiveCfg = Debug|Win32432 {8E28F667-63A7-4F41-81D0-233B971BF247}.Universal Unicode Debug.Build.0 = Debug|Win32433 {8E28F667-63A7-4F41-81D0-233B971BF247}.Universal Unicode Release.ActiveCfg = Release|Win32434 {8E28F667-63A7-4F41-81D0-233B971BF247}.Universal Unicode Release.Build.0 = Release|Win32435 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Debug.ActiveCfg = Debug|Win32436 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Debug.Build.0 = Debug|Win32437 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Debug Static.ActiveCfg = Debug|Win32438 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Debug Static.Build.0 = Debug|Win32439 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Debug.ActiveCfg = DLL Debug|Win32440 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Debug.Build.0 = DLL Debug|Win32441 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Release.ActiveCfg = DLL Release|Win32442 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Release.Build.0 = DLL Release|Win32443 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Unicode Debug.ActiveCfg = DLL Unicode Debug|Win32444 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Unicode Debug.Build.0 = DLL Unicode Debug|Win32445 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Unicode Release.ActiveCfg = DLL Unicode Release|Win32446 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Unicode Release.Build.0 = DLL Unicode Release|Win32447 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Universal Debug.ActiveCfg = DLL Universal Debug|Win32448 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Universal Debug.Build.0 = DLL Universal Debug|Win32449 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Universal Release.ActiveCfg = DLL Universal Release|Win32450 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Universal Release.Build.0 = DLL Universal Release|Win32451 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Universal Unicode Debug.ActiveCfg = DLL Universal Unicode Debug|Win32452 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Universal Unicode Debug.Build.0 = DLL Universal Unicode Debug|Win32453 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Universal Unicode Release.ActiveCfg = DLL Universal Unicode Release|Win32454 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.DLL Universal Unicode Release.Build.0 = DLL Universal Unicode Release|Win32455 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.mlrt.ActiveCfg = DLL Universal Release|Win32456 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.mlrt.Build.0 = DLL Universal Release|Win32457 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Release.ActiveCfg = Release|Win32458 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Release.Build.0 = Release|Win32459 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Release Internal.ActiveCfg = Release|Win32460 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Release Internal.Build.0 = Release|Win32461 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Release Static.ActiveCfg = Release|Win32462 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Release Static.Build.0 = Release|Win32463 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Unicode Debug.ActiveCfg = Unicode Debug|Win32464 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Unicode Debug.Build.0 = Unicode Debug|Win32465 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Unicode Release.ActiveCfg = Unicode Release|Win32466 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Unicode Release.Build.0 = Unicode Release|Win32467 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Universal Debug.ActiveCfg = Universal Debug|Win32468 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Universal Debug.Build.0 = Universal Debug|Win32469 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Universal Release.ActiveCfg = Universal Release|Win32470 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Universal Release.Build.0 = Universal Release|Win32471 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Universal Unicode Debug.ActiveCfg = Universal Unicode Debug|Win32472 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Universal Unicode Debug.Build.0 = Universal Unicode Debug|Win32473 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Universal Unicode Release.ActiveCfg = Universal Unicode Release|Win32474 {00ED6D39-0F68-405F-AE02-B8886BACA7E2}.Universal Unicode Release.Build.0 = Universal Unicode Release|Win32475 387 EndGlobalSection 476 388 GlobalSection(ExtensibilityGlobals) = postSolution -
GTP/trunk/Lib/Vis/OnlineCullingCHC/include/CoherentHierarchicalCullingManager.h
r345 r1492 36 36 bool DecideVisible(HierarchyNode *node) const; 37 37 38 unsigned int mAssumedVisibility; 39 38 40 39 /** Skip query for this node. 41 40 */ 42 41 void SkipQuery(HierarchyNode *node) const; 43 42 43 /** number of steps the visibility is assumed to be valid. 44 */ 45 unsigned int mAssumedVisibility; 44 46 45 47 /** Threshold for rand function to return positive result with respect to -
GTP/trunk/Lib/Vis/Preprocessing/src/GvsPreprocessor.cpp
r1489 r1492 32 32 const VssRay &oldRay) const 33 33 { 34 //|predicted(x)-xp|-|hit(x)-xp| > ?, 34 35 //const Plane3 plane = tri->GetPlane(); 35 36 return false; … … 57 58 new sample points around a triangle in a eps environment 58 59 */ 59 static void CreateNew Samples(VertexContainer &samples,60 61 62 63 60 static void CreateNewRays(SimpleRayContainer &simpleRays, 61 const Triangle3 &hitTriangle, 62 const VssRay &ray, 63 const int index, 64 const float eps) 64 65 { 65 66 const int indexU = (index + 1) % 3; … … 69 70 const Vector3 b = hitTriangle.mVertices[indexU] - hitTriangle.mVertices[index]; 70 71 const Vector3 c = hitTriangle.mVertices[index] - hitTriangle.mVertices[indexL]; 72 71 73 const float len = Magnitude(a); 74 75 const Vector3 dir1 = CrossProd(a, b); //N((pi-xp)×(pi+1- pi)); 76 const Vector3 dir2 = CrossProd(a, c); // N((pi-xp)×(pi- pi-1)) 77 const Vector3 dir3 = DotProd(dir1, dir2) > 0 ? 78 Normalize(dir2 + dir1) : Normalize(CrossProd(a, dir2) + CrossProd(dir1, a)); // N((pi-xp)×di,i-1+di,i+1×(pi-xp)) 72 79 73 80 // compute the new three hit points 74 81 // pi, i + 1 75 const Vector3 dir1 = CrossProd(a, b); //N((pi-xp)×(pi+1- pi));76 82 const Vector3 pt1 = hitTriangle.mVertices[index] + eps * len * dir1; //pi+ e·|pi-xp|·di, j 77 samples.push_back(pt1);78 79 83 // pi, i - 1 80 const Vector3 dir2 = CrossProd(a, c); // N((pi-xp)×(pi- pi-1)) 81 const Vector3 pt2 = hitTriangle.mVertices[index] + eps * len * dir2; //pi+ e·|pi-xp|·di, j 82 samples.push_back(pt2); 83 84 const Vector3 pt2 = hitTriangle.mVertices[index] + eps * len * dir2; //pi+ e·|pi-xp|·di, j 84 85 // pi, i 85 const Vector3 dir3 = DotProd(dir1, dir2) > 0 ?86 Normalize(dir2 + dir1) : Normalize(CrossProd(a, dir2) + CrossProd(dir1, a)); // N((pi-xp)×di,i-1+di,i+1×(pi-xp))87 86 const Vector3 pt3 = hitTriangle.mVertices[index] + eps * len * dir3; //pi+ e·|pi-xp|·di, j 88 samples.push_back(pt3); 89 } 90 91 92 /** Generate rays from sample points. 93 */ 94 static void CreateRays(VssRayContainer &rays, 95 const VertexContainer &samples) 96 { 97 VertexContainer::const_iterator vit, vit_end = samples.end(); 98 99 for (vit = samples.begin(); vit != vit_end; ++ vit) 100 { 101 const Vector3 currentSample = *vit; 102 VssRay *ray;// = new VssRay(ray->mOrigin, currentSample); 103 } 104 } 87 88 /// create simple rays and store them in container 89 Vector3 rayDir; 90 rayDir = Normalize(pt1 - ray.GetOrigin()); 91 simpleRays.push_back(SimpleRay(rayDir, ray.GetOrigin())); 92 rayDir = Normalize(pt2 - ray.GetOrigin()); 93 simpleRays.push_back(SimpleRay(rayDir, ray.GetOrigin())); 94 rayDir = Normalize(pt3 - ray.GetOrigin()); 95 simpleRays.push_back(SimpleRay(rayDir, ray.GetOrigin())); 96 } 97 105 98 106 99 … … 117 110 } 118 111 119 VertexContainer samples;120 s amples.reserve(9);121 122 CreateNew Samples(samples, hitTriangle, prevRay, 0, mEps);123 CreateNew Samples(samples, hitTriangle, prevRay, 1, mEps);124 CreateNew Samples(samples, hitTriangle, prevRay, 2, mEps);112 SimpleRayContainer simpleRays; 113 simpleRays.reserve(9); 114 115 CreateNewRays(simpleRays, hitTriangle, prevRay, 0, mEps); 116 CreateNewRays(simpleRays, hitTriangle, prevRay, 1, mEps); 117 CreateNewRays(simpleRays, hitTriangle, prevRay, 2, mEps); 125 118 126 119 VssRayContainer vssRays; 127 CreateRays(vssRays, samples); 128 129 VssRayContainer::const_iterator rit, rit_end = vssRays.end(); 130 131 for (rit = vssRays.begin(); rit != rit_end; ++ rit) 132 { 133 VssRay *ray = *rit; 134 135 // discontinuity found? 136 // schedule for reverse sampling or adaptive border sampling 137 const bool gap = DiscontinuityFound(*ray, prevRay); 138 mRayQueue.push(GvsRayInfo(ray, gap)); 139 } 140 141 return 9; 142 } 143 144 145 int GvsPreprocessor::ReverseSampling(const VssRay &ray) 120 121 CastRays(simpleRays, vssRays); 122 // add to ray queue 123 EnqueueRays(vssRays); 124 125 return (int)vssRays.size(); 126 } 127 128 129 int GvsPreprocessor::ReverseSampling(const VssRay &oldRay) 146 130 { 147 131 cout << "r" << endl; … … 165 149 166 150 // add to ray queue 167 Enqueue Samples(samples);151 EnqueueRays(samples); 168 152 169 153 Debug << "generated " << numSamples << " samples in " << TimeDiff(startTime, GetTime()) * 1e-3 << " secs" << endl; … … 173 157 174 158 175 void GvsPreprocessor::Enqueue Samples(VssRayContainer &samples, VssRay *oldRay)159 void GvsPreprocessor::EnqueueRays(VssRayContainer &samples, VssRay *oldRay) 176 160 { 177 161 // add samples to ray queue … … 183 167 mRayQueue.push(GvsRayInfo(*vit, gap)); 184 168 } 185 186 169 } 187 170 -
GTP/trunk/Lib/Vis/Preprocessing/src/GvsPreprocessor.h
r1489 r1492 40 40 }; 41 41 42 typedef stack<GvsRayInfo> RayQueue; 42 43 43 typedef stack<GvsRayInfo> RayQueue; 44 struct PendingRay 45 { 46 PendingRay(VssRay *ray, const bool d) 47 : mRay(ray), mFoundDiscontinuity(d) 48 {} 49 50 VssRay *mRay; 51 bool mFoundDiscontinuity; 52 }; 53 54 typedef stack<PendingRay> PendingQueue; 44 55 45 56 /** Runs the adaptive sampling until the ray queue is empty. … … 92 103 with respect to the previous ray. 93 104 */ 94 void Enqueue Samples(VssRayContainer &samples, VssRay *prevRay = NULL);105 void EnqueueRays(VssRayContainer &samples, VssRay *prevRay = NULL); 95 106 96 107 ////////////////////// -
GTP/trunk/Lib/Vis/Preprocessing/src/main.cpp
r1486 r1492 127 127 exit(1); 128 128 } 129 130 129 131 130 string externKdTree = ReplaceSuffix(filename, ".obj", ".kdf");
Note: See TracChangeset
for help on using the changeset viewer.