필터 지우기
필터 지우기

Adding available capacity at the hourly time increment

조회 수: 1 (최근 30일)
Banjo
Banjo 2018년 11월 15일
답변: per isakson 2019년 12월 23일
Hello,
Could you please help me how to cumulate available capacity that is second column of G matrix (10,10,15,15,15) at the hourly time increment. When random number is larger or equal to number from third column of G matrix, these capacities should be cumulated for every time iteration of 1 to 500.
For example, if i=1 => Sum=10+0+15+15+0=40; i=2 => Sum=0+10+15+0+0=25; i=3 => Sum=10+10+0+15+15=50 and so on until 500 iteration. I hope it is clear enough what I want to do.
G=[1,10,0.05;2,10,0.05;3,15,0.03;4,15,0.03;5,15,0.03];
for i=1:500
for j=1:length(G)
X=rand(1);
if X>=G(j,3)
K=G(j,2);
else
K=0;
end
end
end
  댓글 수: 3
Banjo
Banjo 2018년 11월 15일
Basically I just want that every of 500 hourly iterations represent a summation of available capacity for 5 generators. Generator capacity is available if X>=G(j,3). Regards
Guillaume
Guillaume 2018년 11월 15일
What is X? What is capacity? What is a generator? Where is time so we understand what an hourly iteration is?
We have absolutely no idea what your data represent and you don't explain it. Your basically doesn't give us the basics I'm afraid.

댓글을 달려면 로그인하십시오.

답변 (2개)

madhan ravi
madhan ravi 2018년 11월 15일
have you seen cumsum?
  댓글 수: 1
Banjo
Banjo 2018년 11월 15일
When I put cumsum(K)
G=[1,10,0.05;2,10,0.05;3,15,0.03;4,15,0.03;5,15,0.03];
for i=1:500
for j=1:length(G)
X=rand(1);
if X>=G(j,3)
K=G(j,2);
else
K=0;
end
end
cumsum(K)
end
I get for example
K = 10
K = 10
K = 0
K = 15
K = 15
ans = 15
but as an answer I should get
ans = 50

댓글을 달려면 로그인하십시오.


per isakson
per isakson 2019년 12월 23일
This answer is a variation of my answer to your recent question, "Storing and passing all iterations to an array outside the nested for loops"
>> clearvars
>> cssm
>> h = plot(sum(K,2),'.');
>> h.Parent.YLim = [33,67];
Produces 500 realizations of whatever your code represents. The results range from 35 to 65.
Capture.PNG
where the script, cssm, is your script with a few modifications
%%
G=[1,10,0.05;2,10,0.05;3,15,0.03;4,15,0.03;5,15,0.03];
K = nan( 500, length(G) ); % pre-allocate
for ii=1:500
for jj=1:length(G)
X=rand(1);
if X>=G(jj,3)
K(ii,jj)=G(jj,2);
else
K(ii,jj)=0;
end
end
end

카테고리

Help CenterFile Exchange에서 Logical에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by