How can I plot an impulse (sech(x)) consisting of 2002 points, where last 1001 point are zeros?
3 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
So, I've got 2 sech(x) impulses, 1-st consisting of 1001 points, and 2-nd, consisting of 2002 points. For the 2-nd one I need to set last (right) 1001 points as zeros. How can I do that?
Thank you!
0 Commenti
Risposta accettata
Mathieu NOE
il 24 Giu 2025
hello
if you have a recent release (Since R2023b) you can use paddata : here we pad the four first non zero values (your first sech array) with here 2 zeroes
A = [1; 3; 5; 7];
B = paddata(A,6)
6 Commenti
Più risposte (2)
Sam Chak
il 24 Giu 2025
Hi @Anna
Mathieu has shown you how to do that in MATLAB. This is the standard approach in MATLAB computing. However, if you are looking for a math function to include in your thesis or journal paper, you might consider solving the following puzzle:
What input to the hyperbolic secant function will yield
when
and output zero otherwise?


ub = 10; % upper bound
x = linspace(-ub, ub, 2001); % domain
figure(1)
plot(x, sech(x)), grid on
xlabel('x'), ylabel('sech(x)')
title('Standard Hyperbolic Secant function')
ylim([-0.2, 1.2])
From the plot, since we know that
converges to zero at
, or
for
, we can design an intermediate function
for the input to the hyperbolic secant such that
produces the desired output values within the domain. One approach is to use the signum function to create a step at
such that
for
.










f = x + ub/2*sign(x) + ub/2;
y = sech(f);
figure(2)
subplot(211)
plot(x, f), grid on
xlabel('x'), ylabel('f(x)')
title('Intermediate function, f(x)')
subplot(212)
plot(x, y), grid on
xlabel('x'), ylabel('y')
title('Desired Output')
ylim([-0.2, 1.2])
4 Commenti
Sam Chak
il 25 Giu 2025
Hi @Anna_P
@Mathieu NOE indeed has a point. My proposed approach does not give an absolute zero. If you require absolute zero for
, then you should consider using this alternative approach, which also reflects my mathematical interpretation of the MATLAB indexing trick:


Note: You can imagine that
acts like a lowpass filter but allows all
signals pass for
. For your info, "Lowpass" is an engineering term, typically used in E&E Engineering and Audio Engineering.



ub = 10; % upper bound
x = linspace(-ub, ub, 2001); % domain
f1 = 1 - heaviside(x); % function 1: Unit Step down
f2 = sech(x); % function 2: Hyperbolic Secant
y = f1.*f2;
subplot(211)
plot(x, f1), grid on
xlabel('x')
title('Unit Step down function (Heaviside)')
ylim([-0.2, 1.2])
subplot(212)
plot(x, y), grid on
xlabel('x')
title('Semi-Hyperbolic Secant function')
ylim([-0.2, 1.2])
Vedere anche
Categorie
Scopri di più su Startup and Shutdown in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!