source: proiecte/pmake3d/make3d_original/Make3dSingleImageStanford_version0.1/LearningCode/Features/OldBatchVersion/AveSupFea.m @ 37

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

Added original make3d

File size: 4.4 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 [AveSupFea ] = AveSupFea(Sup, MedSup, SupFact, MultiScaleSupTable, FeaMax, pick)
40
41% this function generate the AveSupFea for multiScaleSup
42
43global H2;
44
45NuSup = setdiff(unique(Sup)',0);
46NuSupSize = size(NuSup,2);
47%FeaSup = zeros(NuSupSize,size([H2;H4],1)+1);
48%FeaSup = zeros(NuSupSize,size([H2],1)+1);
49FeaSup = zeros(NuSupSize,size([H2],1)*3+1); % add up vertical and horizontal features
50%size(FeaSup)
51l = 1;
52for j = NuSup
53    mask = MedSup ==j;
54    [y x] = find(mask);
55    HRange = min(x):max(x);
56    VRange = min(y):max(y);
57    if sum(mask(:))==0
58       disp(' AveSupFea error');
59    end
60%    FeaSup(l,:) = [j (mean(H2(:,mask)')./FeaMax(1,2:18)) (mean(H4(:,mask)')./FeaMax(1,19:35))];
61    if pick == 1
62       FeaSup(l,:) = [j (mean(H2(:,mask)')./sqrt(FeaMax(1,2:18))) ...
63                        (mean( reshape( H2(:,VRange,:), size(H2,1), [])')./sqrt(FeaMax(1,2:18))) ...
64                        (mean( reshape( H2(:,:,HRange), size(H2,1), [])')./sqrt(FeaMax(1,2:18)))]; % keeping the Sup index at the first column in FeaSup
65    elseif pick == 2
66       FeaSup(l,:) = [j (mean(H2(:,mask)')./FeaMax(1,2:18)) ...
67                        (mean( reshape( H2(:,VRange,:), size(H2,1), [])')./(FeaMax(1,2:18))) ...
68                        (mean( reshape( H2(:,:,HRange), size(H2,1), [])')./(FeaMax(1,2:18)))]; % keeping the Sup index at the first column in FeaSup
69    else
70       FeaSup(l,:) = [j (mean(H2(:,mask)')./FeaMax(1,19:35)) ...
71                        (mean( reshape( H2(:,VRange,:), size(H2,1), [])')./(FeaMax(1,19:35))) ...
72                        (mean( reshape( H2(:,:,HRange), size(H2,1), [])')./(FeaMax(1,19:35)))]; % keeping the Sup index at the first column in FeaSup
73    end   
74    l = l + 1;
75end
76
77disp('go to AveSupFea');
78% calculate the MultiScale Fea of Sup
79FeaSize = (size(H2,1));
80ScaleSize = size(MultiScaleSupTable,2)-1;
81AveSupFea = zeros(NuSupSize,FeaSize*ScaleSize);
82l = 1;
83for j = NuSup
84    row = find(MultiScaleSupTable(:,1) == j);
85    Target = MultiScaleSupTable( row, 2:end);
86    MultiMask = (MultiScaleSupTable(:,2:end) == repmat(Target,[ NuSupSize 1]));
87    ScaleMask = sum(MultiMask,1) > 1; % if Scale have more than one Sup in the save Scale
88    MultiMask(row,ScaleMask) = false; % set the j to zeros
89    Wei = repmat(SupFact(:,2),[1 ScaleSize]).*MultiMask; % get rid of the j sup
90    Wei = Wei ./ repmat(sum(Wei,1),[NuSupSize 1]); % normalize the Wei to have sum to 1
91    AveSupMultScaleFea = sum(repmat(FeaSup(:,2:(FeaSize+1)),[1 1 ScaleSize]).*repmat(permute(Wei,[1 3 2]),[1 FeaSize 1]),1);
92    AveSupFea(l,:) = AveSupMultScaleFea(:)';
93    l = l + 1;
94end
95AveSupFea = [FeaSup AveSupFea];
96
97return;
98
99
Note: See TracBrowser for help on using the repository browser.