How to add time from 2 arrays

1 view (last 30 days)
SS
SS on 16 Oct 2014
Answered: Andrei Bobrov on 16 Oct 2014
Hi, I am a new user of Matlab. I have the following problem:
I have two columns like this way.
  • a =102 sec
  • a =135
  • a =157
  • b =189
  • b =201
  • a =222
  • a =245
  • b =290
Here the values are in seconds. I want to write a formula, which show the total duration of seconds of a and b.
For example: here total duration of a is = (157-102) + (245-222) = 78 seconds.
Please suggest me how to do it.
Thanks
  6 Comments
José-Luis
José-Luis on 16 Oct 2014
So is your variable a table or do you have two column vectors: one with strings and the other with numbers?
SS
SS on 16 Oct 2014
It's two column vectors: one with string and other with number.

Sign in to comment.

Accepted Answer

Andrei Bobrov
Andrei Bobrov on 16 Oct 2014
C = {'a' 102
'a' 135
'a' 157
'b' 189
'b' 201
'a' 222
'a' 245
'b' 290}
cn = [C{:,2}]';
[~,~,c1] = unique(C(:,1));
t = [true;diff(c1)~=0];
s1 = accumarray(cumsum(t),cn,[],@(x)x(end)-x(1));
out = accumarray(c1(t),s1);

More Answers (1)

Rainer
Rainer on 16 Oct 2014
I don't see the two columns and I don't understand what a and b are.
  1 Comment
SS
SS on 16 Oct 2014
sorry..i corrected it:
  • a =102 sec
  • a =135
  • a =157
  • b =189
  • b =201
  • a =222
  • a =245
  • b =290

Sign in to comment.

Categories

Find more on Characters and Strings in Help Center and File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!