function [Plosskw,Qlosskw,vbp]=backwardforward (linedata,busdata,MVAb,KVb )
%global linedata busdata MVAb KVb
br=length(linedata);
no=length(busdata);
Zb=(KVb^2)/MVAb;
% Per unit Values
for i=1:br
R(i,1)=(linedata(i,4))/Zb;
X(i,1)=(linedata(i,5))/Zb;
end
for i=1:no
P(i,1)=((busdata(i,2))/(1000*MVAb));
Q(i,1)=((busdata(i,3))/(1000*MVAb));
end
R;
X;
P;
Q;
C=zeros(br,no);
for i=1:br
a=linedata(i,2);
b=linedata(i,3);
for j=1:no
if a==j
C(i,j)=-1;
end
if b==j
C(i,j)=1;
end
end
end
C;
e=1;
for i=1:no
d=0;
for j=1:br
if C(j,i)==-1
d=1;
end
end
if d==0
endnode(e,1)=i;
e=e+1;
end
end
endnode';
h=length(endnode);
for j=1:h
e=2;
f=endnode(j,1);
% while (f~=1)
for s=1:no
if (f~=1)
k=1;
for i=1:br
if ((C(i,f)==1)&&(k==1))
f=i;
k=2;
end
end
k=1;
for i=1:no
if ((C(f,i)==-1)&&(k==1));
f=i;
g(j,e)=i;
e=e+1;
k=3;
end
end
end
end
end
for i=1:h
g(i,1)=endnode(i,1);
end
g;
w=length(g(1,:));
for i=1:h
j=1;
for k=1:no
for t=1:w
if g(i,t)==k
g(i,t)=g(i,j);
g(i,j)=k;
j=j+1;
end
end
end
end
g;
for k=1:br
e=1;
for i=1:h
for j=1:w-1
if (g(i,j)==k)
if g(i,j+1)~=0
adjb(k,e)=g(i,j+1);
e=e+1;
else
adjb(k,1)=0;
end
end
end
end
end
adjb;
for i=1:br-1
for j=h:-1:1
for k=j:-1:2
if adjb(i,j)==adjb(i,k-1)
adjb(i,j)=0;
end
end
end
end
adjb;
x=length(adjb(:,1));
ab=length(adjb(1,:));
for i=1:x
for j=1:ab
if adjb(i,j)==0 && j~=ab
if adjb(i,j+1)~=0
adjb(i,j)=adjb(i,j+1);
adjb(i,j+1)=0;
end
end
if adjb(i,j)~=0
adjb(i,j)=adjb(i,j)-1;
end
end
end
adjb;
for i=1:x-1
for j=1:ab
adjcb(i,j)=adjb(i+1,j);
end
end
b=length(adjcb);
% voltage current program
for i=1:no
vb(i,1)=1;
end
for s=1:10
for i=1:no
nlc(i,1)=conj(complex(P(i,1),Q(i,1)))/(vb(i,1));
end
nlc;
for i=1:br
Ibr(i,1)=nlc(i+1,1);
end
Ibr;
xy=length(adjcb(1,:));
for i=br-1:-1:1
for k=1:xy
if adjcb(i,k)~=0
u=adjcb(i,k);
%Ibr(i,1)=nlc(i+1,1)+Ibr(k,1);
Ibr(i,1)=Ibr(i,1)+Ibr(u,1);
end
end
end
Ibr;
for i=2:no
g=0;
for a=1:b
if xy>1
if adjcb(a,2)==i-1
u=adjcb(a,1);
vb(i,1)=((vb(u,1))-((Ibr(i-1,1))*(complex((R(i-1,1)),X(i-1,1)))));
g=1;
end
if adjcb(a,3)==i-1
u=adjcb(a,1);
vb(i,1)=((vb(u,1))-((Ibr(i-1,1))*(complex((R(i-1,1)),X(i-1,1)))));
g=1;
end
end
end
if g==0
vb(i,1)=((vb(i-1,1))-((Ibr(i-1,1))*(complex((R(i-1,1)),X(i-1,1)))));
end
end
s=s+1;
end
nlc;
Ibr;
vb;
vbp=[abs(vb) angle(vb)*180/pi];
for i=1:no
va(i,2:3)=vbp(i,1:2);
end
for i=1:no
va(i,1)=i;
end
va;
Ibrp=[abs(Ibr) angle(Ibr)*180/pi];
PL(1,1)=0;
QL(1,1)=0;
% losses
for f=1:br
Pl(f,1)=(Ibrp(f,1)^2)*R(f,1);
Ql(f,1)=X(f,1)*(Ibrp(f,1)^2);
PL(1,1)=PL(1,1)+Pl(f,1);
QL(1,1)=QL(1,1)+Ql(f,1);
end
Plosskw=(Pl)*MVAb*1000;
Qlosskw=(Ql)*MVAb*1000;
PL=(PL)*MVAb*1000;
QL=(QL)*MVAb*1000;
voltage = vbp(:,1);
anglle = vbp(:,2);
Vm=num2str(voltage,6);
end
% disp('Vm=');disp(Vm);
% phase=num2str(anglle,6);
% disp('phase');disp(phase);
% Plossline=num2str(Plosskw,6);
% disp('Ploss line=');disp(Plossline);
% Qlossline=num2str(Qlosskw,6);
% disp('Qloss line=');disp(Qlossline);
% Plosstotal=num2str(PL,6);
% disp('Ploss total=');disp(Plosstotal);
% Qlosstotal=num2str(QL,6);
% disp('Qloss tatal=');disp(Qlosstotal);
% plot(voltage);
我虽横行却不霸道
- 粉丝: 95
- 资源: 1万+
最新资源
- 大英赛冲奖必备资料,包含作文,单词等等
- 一种估算光伏功率测量全局水平辐照度的无监督方法
- Multisim更新:振幅调制器+解调器(含仿真程序+文档+原理图+PCB)
- 基于PLC的立体车库的设计,西门子S7-1200PLC程序及组态仿真,电路图,IO表,博途15.1
- Java毕设项目:基于spring+mybatis+maven+mysql实现的资源共享平台【含源码+数据库+毕业论文】
- 基于WebRTC的P2P在线媒体流传输与监控设计源码
- 基于Python的pygtide模块:地球引力潮计算设计源码
- 基于JavaScript的物流管理系统设计与源码分享
- 基于Qt5框架的LinpopLanIM局域网即时通讯软件设计源码
- UFS 3.0相关原文档
- 基于Vue框架的服装商店网页设计源码
- 基于Java语言开发的CRM项目源码设计
- IMG_20250105_001134.jpg
- 计算机前端后端数据库八股文笔记,涵盖编程语言、数据结构、算法、设计模式等基础知识
- 基于微信小程序的4S店服务预约与管理小程序设计源码
- IMG_20250105_001151.jpg
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈