Azzera filtri
Azzera filtri

array generation using logics.

1 visualizzazione (ultimi 30 giorni)
Sathiya S V
Sathiya S V il 29 Mag 2024
Commentato: Voss il 29 Mag 2024
x = [0 10 20 30 0 10 20 30 40 0 10 20 30 40 50 0 10]
'x' is the array to be checked.
checked = [0 10 -10 20 0 10 -10 20 -20 0 10 -10 20 -20 30 0 10]
I want the new array like the above mentioned 'checked' array.
The concept is simple to understand in the above given example, if the numbers are countinously increasing in the order of 10 factors in the x array, I need a checked array of incrementing values containing positive and negative number and next should be a next consecutive number in positive sign.
It is simple for me to understand, but for coding I really finding it difficult..I request someone who is more into finding logics to help me with.

Risposta accettata

Voss
Voss il 29 Mag 2024
x = [0 10 20 30 0 10 20 30 40 0 10 20 30 40 50 0 10];
diffx = diff(x(:));
start = find([true; diffx <= 0; true]);
dx = min(diffx(diffx > 0));
checked = zeros(size(x));
sequence_length = diff(start);
for ii = 1:numel(sequence_length)
n = 1:sequence_length(ii);
checked(start(ii):start(ii+1)-1) = ceil((n-1)/2)*dx.*(-1).^n;
end
disp(checked);
0 10 -10 20 0 10 -10 20 -20 0 10 -10 20 -20 30 0 10
  2 Commenti
Sathiya S V
Sathiya S V il 29 Mag 2024
Thanks, it works:)
Voss
Voss il 29 Mag 2024
You're welcome!

Accedi per commentare.

Più risposte (1)

Dyuman Joshi
Dyuman Joshi il 29 Mag 2024
x = [0 10 20 30 0 10 20 30 40 0 10 20 30 40 50 0 10]
x = 1x17
0 10 20 30 0 10 20 30 40 0 10 20 30 40 50 0 10
<mw-icon class=""></mw-icon>
<mw-icon class=""></mw-icon>
y = x;
idx = [1 find(diff(x)~=10)+1 numel(x)]
idx = 1x5
1 5 10 16 17
<mw-icon class=""></mw-icon>
<mw-icon class=""></mw-icon>
for k=1:numel(idx)-1
vec = (1:idx(k+1)-idx(k)-1);
y(vec+idx(k)) = ceil(vec/2).*10.*(-1).^(vec-1);
end
y
y = 1x17
0 10 -10 20 0 10 -10 20 -20 0 10 -10 20 -20 30 0 10
<mw-icon class=""></mw-icon>
<mw-icon class=""></mw-icon>

Categorie

Scopri di più su Matrices and Arrays 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!

Translated by