view private/EDB1directsound.m @ 18:2d5f50205527 jabuilder_int tip

Escape the trailing backslash as well
author Chris Cannam
date Tue, 30 Sep 2014 16:23:00 +0100
parents 90220f7249fc
children
line wrap: on
line source
function dirsoundok = EDB1directsound(eddatafile,S,R,visplanesfroms,visplanesfromr)
% EDB1directsound - Checks if the direct sound is valid.
% Checks if the direct sound path from a number of source
% points to a number of receiver points are obstructed by any planes.
%
% Input parameters:
%   eddatafile      The name of the file that contains all edge related data.
%                   This file will be loaded.
%   S, R, visplanesfroms, visplanesfromr
%                   Data that should have been passed directly from the
%                   srdatafile.
%
% Global parameter:
%   SHOWTEXT        See EDB1mainISES
%
% Output parameter:
%   dirsoundok      1 or 0, telling if the sound path is unobstructed or not.
%
% ----------------------------------------------------------------------------------------------
%   This file is part of the Edge Diffraction Toolbox by Peter Svensson.                       
%                                                                                              
%   The Edge Diffraction Toolbox is free software: you can redistribute it and/or modify       
%   it under the terms of the GNU General Public License as published by the Free Software     
%   Foundation, either version 3 of the License, or (at your option) any later version.        
%                                                                                              
%   The Edge Diffraction Toolbox is distributed in the hope that it will be useful,       
%   but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS  
%   FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.             
%                                                                                              
%   You should have received a copy of the GNU General Public License along with the           
%   Edge Diffraction Toolbox. If not, see <http://www.gnu.org/licenses/>.                 
% ----------------------------------------------------------------------------------------------
% Peter Svensson (svensson@iet.ntnu.no) 20030929
%
% Uses the function EDB1chkISvisible
%
% dirsoundok = EDB1directsound(eddatafile,S,R,visplanesfroms,visplanesfromr);

global SHOWTEXT

eval(['load ',eddatafile])

[ncorners,slask] = size(corners);
[nplanes,ncornersperplane] = size(planecorners);

%----------------------------------------------------------
% 	Check if the direct sound is obscured
%
%   Pick out the planes that are possible. Only potentially obstructing planes are necessary to check. 
%   Planes that are seen by the source or by the receiver, but not both
%   are potentially obstructing.

planesareseen = full( (double(visplanesfroms)==0 | double(visplanesfromr)==0) & (double(visplanesfroms)+double(visplanesfromr)~=0)  );
planestocheck = find(planesareseen.*canplaneobstruct.');
nplanestocheck = length(planestocheck);
onesvec = ones(nplanestocheck,1);

[hitplanes,reflpoints,edgehits,edgehitpoints,cornerhits,cornerhitpoints] = EDB1chkISvisible(S(onesvec,:),R(onesvec,:),planeeqs(planestocheck,4),planenvecs(planestocheck,:),minvals(planestocheck,:),...
   maxvals(planestocheck,:),planecorners(planestocheck,:),corners,ncornersperplanevec(planestocheck));

if isempty(hitplanes)
	dirsoundok = 1;
	if SHOWTEXT >= 3
		disp('      direct sound OK')
	end
else
	dirsoundok = 0;
	if SHOWTEXT >= 3
        disp('      direct sound obscured')
        if SHOWTEXT >= 4,  
            printvec = int2str(planestocheck(hitplanes(1)));
            for iiprint = 2:length(hitplanes);
   		        printvec = [printvec,' ',int2str(planestocheck(hitplanes(iiprint)))];      
            end
            disp(['          by:'])
  		    disp(['         ',printvec])
        end
   end
end