How to replace values?
Mostra commenti meno recenti
How can I replace values? I've a matrix of 3653x337 Let's consider I've
- dates values
- 0101 0
- 0102 0
- 0103 0
- 0104 1
- 0105 0
- 0106 0
- 0107 0 ....
I need a function to find all these "1"'s in my matrix and to replace it for two days before and after I've a "1".
Thanks!
4 Commenti
Azzi Abdelmalek
il 16 Lug 2013
This is not clear
Ugur
il 16 Lug 2013
Cedric
il 16 Lug 2013
And why not to 0101 and 0107?
the cyclist
il 16 Lug 2013
I think he means that if there is a 1 in the second column, put two more 1's before and two more after (all in the second column).
Risposta accettata
Più risposte (1)
Jos (10584)
il 17 Lug 2013
Here's a one-liner:
values = [0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 0 0 1]
values(max(min(bsxfun(@plus,reshape(find(values==1),[],1),-2:2),numel(values)),1))=1
or in more readable format:
values = [0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 0 0 1]
oldIndex = find(values==1)
newIndex = bsxfun(@plus, oldIndex(:), -2:2)
newIndex = max(newIndex,1)
newIndex = min(newIndex,numel(values))
values2 = values % work on a copy
values2(newIndex) = 1
Note that you do not need unique numbers for right-hand indexing
B = [0 0 0]
B([2 2 2 2 2 2]) = 1
3 Commenti
Ugur
il 17 Lug 2013
Jos (10584)
il 17 Lug 2013
you should type numel with an lower case L instead of the digit 1 ...
Ugur
il 20 Lug 2013
Categorie
Scopri di più su Library Development in Centro assistenza e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!