www.pudn.com > tftb2002toolbox.rar > amtriang.m
function y = amtriang(N,t0,T);
%AMTRIANG Generate triangular amplitude modulation.
% Y = AMTRIANG(N,T0,T) generates a triangular amplitude modulation
% centered on a time T0, and with a spread proportional to T.
% This modulation is scaled such that Y(T0)=1.
%
% N : number of points.
% T0 : time center (default : N/2).
% T : time spreading (default : 2*sqrt(N)).
% Y : signal.
%
% Examples:
% z=amtriang(160);plot(z);
% z=amtriang(160,90,40);plot(z);
% z=amtriang(160,180,50);plot(z);
%
% See also AMEXPO1S, AMEXPO2S, AMGAUSS, AMRECT.
% F. Auger, July 1995.
% Copyright (c) 1996 by CNRS (France).
%
% ------------------- CONFIDENTIAL PROGRAM --------------------
% This program can not be used without the authorization of its
% author(s). For any comment or bug report, please send e-mail to
% f.auger@ieee.org
if (nargin == 0),
error ( 'The number of parameters must be at least 1.' );
elseif (nargin == 1),
t0=N/2; T=2*sqrt(N);
elseif (nargin ==2),
T=2*sqrt(N);
end;
if (N<=0),
error('N must be greater or equal to 1.');
else
tmt0=(1:N)'-t0;
L=sqrt(10.0/pi)*T/2.0;
y = max(0.0,min([L+tmt0';L-tmt0']))'/L;
end;