⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 lfcomp3.m

📁 电力系统电压稳定研究的图形化软件
💻 M
字号:
% LFCOMP	Conventional Newton-Raphson method for load Flow analysis
%		LFCOMP provides load flow results.
%

%lfcntrup;
n=length(x);
v=zeros(n,1);

OldFigNumber=watchon;
param;
k_temp=no_gen+no_pv-1;
for i=1:k_temp
   paramx(i)=param(i);
end
for i=1:no_pq
   ii=k_temp+i;
   jj=k_temp+1+2*(i-1);
   paramx(ii)=param(jj);
   paramx(ii+no_pq)=param(jj+1);
end
param=paramx';
param;
ConvergenceFlag=0;
for j=1:round(MaxIterations/ReportCycle)
    OldFigNumber=watchon;

    t0=clock;
    for i=1:ReportCycle
        x0=x;
        [f,J]=eval([CurrentSystem,'(data,x,[0;param],v)']);
        delta_x=-sparse(J(2:n+1,1:n))\f(2:n+1);
        x=x0+delta_x;
        
    end

    AbsError=max(abs(x-x0));
    if x0==0
        RelError='NA';
    else
        RelError=AbsError/max(abs(x0));
    end

    lfsetsta;

    % set LF control control errors
    %set(AbsErrorDisp,'String',num2str(AbsError,3));
    %if isstr(RelError)
        %set(RelErrorDisp,'String',RelError);
    %else
        %set(RelErrorDisp,'String',num2str(RelError,3));
    %end
    %set(NumIterations,'String',num2str(j*ReportCycle));
   % set(IterationTime,'String',num2str(etime(clock,t0)/ReportCycle));

    if ((AbsError<=LFAbsTol*0.001) & ((~isstr(RelError)) & ...
          (RelError<=LFRelTol*0.01) | isstr(RelError)))
       ConvergenceFlag=1;
        break;
    end
 end
  if ConvergenceFlag==0
        'NR Failed to Converge'
        break;
    end


for i=1:k_temp
   paramx(i)=param(i);
end
for i=1:no_pq
   ii=k_temp+i;
   jj=k_temp+1+2*(i-1);
   paramx(jj)=param(ii);
   paramx(jj+1)=param(ii+no_pq);
end
param=paramx;
param;
watchoff;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -