source: proiecte/pmake3d/make3d_original/Make3dSingleImageStanford_version0.1/LearningCode/DataProcess/LaserOccluLabel.m @ 37

Last change on this file since 37 was 37, checked in by (none), 14 years ago

Added original make3d

File size: 5.1 KB
Line 
1% *  This code was used in the following articles:
2% *  [1] Learning 3-D Scene Structure from a Single Still Image,
3% *      Ashutosh Saxena, Min Sun, Andrew Y. Ng,
4% *      In ICCV workshop on 3D Representation for Recognition (3dRR-07), 2007.
5% *      (best paper)
6% *  [2] 3-D Reconstruction from Sparse Views using Monocular Vision,
7% *      Ashutosh Saxena, Min Sun, Andrew Y. Ng,
8% *      In ICCV workshop on Virtual Representations and Modeling
9% *      of Large-scale environments (VRML), 2007.
10% *  [3] 3-D Depth Reconstruction from a Single Still Image,
11% *      Ashutosh Saxena, Sung H. Chung, Andrew Y. Ng.
12% *      International Journal of Computer Vision (IJCV), Aug 2007.
13% *  [6] Learning Depth from Single Monocular Images,
14% *      Ashutosh Saxena, Sung H. Chung, Andrew Y. Ng.
15% *      In Neural Information Processing Systems (NIPS) 18, 2005.
16% *
17% *  These articles are available at:
18% *  http://make3d.stanford.edu/publications
19% *
20% *  We request that you cite the papers [1], [3] and [6] in any of
21% *  your reports that uses this code.
22% *  Further, if you use the code in image3dstiching/ (multiple image version),
23% *  then please cite [2].
24% * 
25% *  If you use the code in third_party/, then PLEASE CITE and follow the
26% *  LICENSE OF THE CORRESPONDING THIRD PARTY CODE.
27% *
28% *  Finally, this code is for non-commercial use only.  For further
29% *  information and to obtain a copy of the license, see
30% *
31% *  http://make3d.stanford.edu/publications/code
32% *
33% *  Also, the software distributed under the License is distributed on an
34% * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
35% *  express or implied.   See the License for the specific language governing
36% *  permissions and limitations under the License.
37% *
38% */
39function [OccluList BoundaryLaserOccluHori BoundaryLaserOccluVert]=LaserOccluLabel(k,nList);
40
41
42global GeneralDataFolder ScratchDataFolder LocalFolder ClusterExecutionDirectory...
43    ImgFolder VertYNuPatch VertYNuDepth HoriXNuPatch HoriXNuDepth a_default b_default Ox_default Oy_default...
44    Horizon_default filename batchSize NuRow_default SegVertYSize SegHoriXSize WeiBatchSize PopUpVertY PopUpHoriX taskName;
45
46BpWidthV = ceil(0.01*VertYNuDepth);
47BpWidthH = ceil(0.05*HoriXNuDepth);
48SE = strel('rectangle',[BpWidthV BpWidthH]);
49ThreVert = 0.5;
50ThreHori = 0.5;
51ThreFar = 15;
52% load data
53depthfile = strrep(filename{k},'img','depth_sph_corr'); % the depth filename
54load([ScratchDataFolder '/Gridlaserdata/' depthfile '.mat']);
55LaserDepth = Position3DGrid(:,:,4);
56
57load([ScratchDataFolder '/data/CleanSup/CleanSup' num2str(k) '.mat']);
58Sup = double(Sup);
59MaxSup = max( Sup(:));
60MaskSky = Sup ==0;
61
62BoundaryPVert = conv2(Sup,[1 MaxSup],'valid').*( conv2(Sup,[1 -1],'valid') >0)...
63                .* ~MaskSky(:,1:(end-1)) .* ~MaskSky(:,2:end); % two step build up hash index 1) Left > Righ index
64BoundaryPVert = BoundaryPVert + conv2(Sup,[MaxSup 1],'valid').* (conv2(Sup,[-1 1],'valid') >0)...
65                .* ~MaskSky(:,1:(end-1)) .* ~MaskSky(:,2:end); % 2) Left < Righ index
66BoundaryPHori = conv2(Sup,[1; MaxSup],'valid').* (conv2(Sup,[1; -1],'valid') >0)...
67                .* ~MaskSky(1:(end-1),:) .* ~MaskSky(2:end,:); % two step build up hash index 1) Top > bottom index
68BoundaryPHori = BoundaryPHori + conv2(Sup,[MaxSup; 1],'valid').*( conv2(Sup,[-1; 1],'valid') >0)...
69                .* ~MaskSky(1:(end-1),:) .* ~MaskSky(2:end,:); % 2) Top < Bottom index
70
71% detect occlusion in both vertical and horizontal direction
72DiffDepthVert = abs(conv2(LaserDepth,[1; -1],'valid'));
73DiffDepthHori = abs(conv2(LaserDepth,[1 -1],'valid'));
74FraDiffDepthVert = DiffDepthVert./ sqrt(LaserDepth(1:(end-1),:) .* LaserDepth(2:end,:) );
75%FraDiffDepthVert = DiffDepthVert./ min(LaserDepth(1:(end-1),:) , LaserDepth(2:end,:) );
76OccFraDiffDepthVert = FraDiffDepthVert > ThreVert;
77OccFraDiffDepthVert(LaserDepth(1:(end-1),:) > ThreFar & LaserDepth(2:end,:) > ThreFar) = 0;
78FraDiffDepthHori = DiffDepthHori./ sqrt( LaserDepth(:,1:(end-1)) .* LaserDepth(:,2:end) );
79%FraDiffDepthHori = DiffDepthHori./ min( LaserDepth(:,1:(end-1)) , LaserDepth(:,2:end) );
80OccFraDiffDepthHori = FraDiffDepthHori > ThreHori;
81OccFraDiffDepthHori(LaserDepth(:,1:(end-1)) > ThreFar & LaserDepth(:,2:end) > ThreFar) = 0;
82
83BoundaryLaserOccluHori = (imdilate(OccFraDiffDepthVert, SE).*(BoundaryPHori ~= 0));
84BoundaryLaserOccluVert = (imdilate(OccFraDiffDepthHori, SE).*(BoundaryPVert ~= 0));
85OccluMap = zeros(size(LaserDepth));
86OccluMap(:,1:(end-1)) = imdilate(OccFraDiffDepthHori, SE);
87OccluMap(1:(end-1),:) = imdilate(OccFraDiffDepthVert, SE);
88%figure(200);subplot(1,2,1);
89%figure;
90%disp('plot');
91%Img = imresize(imread([GeneralDataFolder '/' ImgFolder '/' filename{k} ],'jpg'), [SegVertYSize SegHoriXSize]);
92%Img(:,:,1) = 255*imresize(OccluMap, [ SegVertYSize, SegHoriXSize]);
93%image(Img);
94
95OccluHash = setdiff(unique([BoundaryPHori(BoundaryLaserOccluHori ~= 0); BoundaryPVert(BoundaryLaserOccluVert ~= 0)]),0);
96List = nList(:,1)*MaxSup + nList(:,2);
97OccluList = false*ones(size(List));
98if isempty(OccluHash)
99   return;
100end
101mask = sum(repmat(List,[1 size(OccluHash,1)]) == repmat(OccluHash',[size(List,1) 1]),2) > 0;
102OccluList(mask) = true;
103return;
Note: See TracBrowser for help on using the repository browser.