我正在寻找一种方法来更新向量 [nx113] 中的某些元素,以便为我的系统的每次完整旋转。
%% # Iterate through timesteps
for tt = 1:nTimeSteps
% # Initialise ink on transfer roller
rollers(2).ink = [zeros(1,98),ones(1,5),zeros(1,113)];
% # Rotate all rollers
for ii = 1:N
rollers(ii).ink(:) = ...
circshift(rollers(ii).ink(:),rollers(ii).rotDirection);
end
% # Update all roller-connections
for ii = 1:N
for jj = 1:nBins(ii)
if(rollers(ii).connections(jj) ~= 0)
index1 = rollers(ii).connections(jj);
index2 = find(ii == rollers(index1).connections);
ink1 = rollers(ii).ink(jj);
ink2 = rollers(index1).ink(index2);
rollers(ii).ink(jj) = (ink1+ink2)/2;
rollers(index1).ink(index2) = (ink1+ink2)/2;
end
end
end
% # Calculate average amount of ink on each roller
for ii = 1:N
averageAmountOfInk(tt,ii) = mean(rollers(ii).ink);
end
rollers(18).TakeOff = averageAmountOfInk*0.6;
end
矢量rollers(2).ink 是我要更新的矢量。目前该向量仅填充一次,因此我有第 98:103 行的向量。我希望为我的系统的每次“旋转”填充这一系列元素,而不仅仅是第一次。原因 - 我试图显示仅从辊子表面的一小部分间歇性添加墨水,因此只需要填充五个单元格。我认为如果我从 1 迭代到时间步数,在循环中以步长 nBins-Max 为单位:
for tt = 1:nBins_max:nTimeSteps
这似乎不是我所追求的。我也希望最后从系统中去除墨水。对于每一转,我希望能够在每次旋转时去除一定百分比的墨水,这样它就不会留在系统中(就像它被打印到一张纸上并被带走一样)。希望有人能理解这一点,并可能就如何处理我的一个或两个问题提供一些建议。