Professional Documents
Culture Documents
Oleh
SRI ASNI WINDA
1010952043
b[i][j] = xl [l]/aa;
b[j][i] = b [i][j];
g[i][i]+=rl[l]/aa;
g[j][j]+=rl[l]/aa;
b[i][i]+=-xl[l]/aa+bl[l]/2;
b[j][j]+=-xl[l]/aa+bl[l]/2;
}
//Print Ybus
for (i=1;i<=nb;i++)
{
for (j=1;j<=nb;j++)
{
cout<<"G["<<i<<"]["<<j<<"]= "<<g[i][j]<<endl;
cout<<"B["<<i<<"]["<<j<<"]= "<<b[i][j]<<endl;
}
}
for (i=1;i<=nb;i++)
{
for (j=1;j<=nb;j++)
{
B1[i][j]=0;
}
}
//Build B1
for (l=1;l<=nl;l++)
{
i=sl[l];
j=el[l];
B1[i][j]=1.0/xl[l];
B1[j][i]=B1[i][j];
B1[i][i]+= -1.0/xl[l];
B1[j][j]+= -1.0/xl[l];
}
for (k=1;k<=nb;++k)
if (type[k]==slack)
B1[k][k]=10e70;
cout<<"\nPrint B1:"<<endl;
for (i=1;i<=nb;i++)
{
for (j=1;j<=nb;j++)
{
cout<<"B1["<<i<<"]["<<j<<"]="<<B1[i][j]<<endl;
a[i][j]=B1[i][j];
}
}
invers(a, nb);
cout<<"\nPrint invers B1 : "<<endl;
for (i=1;i<=nb;i++)
{
for (j=1;j<=nb;j++)
{
cout<<"B1Invers["<<i<<"]["<<j<<"]="<<a[i][j]<<endl;
B1Invers[i][j]=a[i][j];
}
}
//Build B2
for (i=1;i<=nb;++i)
{
for (i=1;i<=nb;i++)
theta[i] = theta[i]+delta_theta[i];
//Hitung delta Q
for (i=1;i<=nb;++i)
{
qs[i]=0.0;
if (type[i]==PQ)
{
qsch[i]=Qg[i]-Ql[i];
for (k=1; k<=nb; ++k)
qs[i]=qs[i]+(g[i][k]*sin(theta[i]-theta[k])b[i][k]*cos(theta[i]-theta[k]))*v[k]*v[i];
deltaq[i]=qsch[i]-qs[i];
}
}
//Calculate delta V = -[B2]'(delta_Q/|v|)
for (i=1;i<=nb;i++)
{
delta_v[i]=0;
for (j=1;j<=nb;j++)
{
delta_v[i]= delta_v[i]-B2Invers[i][j]*(deltaq[j]/v[i]);
}
}
//Up date theta v
for (i=1;i<=nb;i++)
v[i]=v[i]+ delta_v[i];
Selisih=0.0;
DelPmax=0.0;
DelQmax=0.0;
for(i=1;i<=nb;i++)
{
if (type[i]==PV||type[i]==PQ)
{
if (fabs(deltap[i]) >= DelPmax)
DelPmax = fabs(deltap[i]);
if (type[i]==PQ)
{
if (fabs(deltaq[i]) >= DelQmax)
DelQmax = fabs(deltaq[i]);
}
}
}
if (DelPmax >= DelQmax)
Selisih=DelPmax;
else
Selisih=DelQmax;
cout <<fixed <<setw(18) << right << setprecision(6) <<Selisih;
cout <<fixed <<setw(15) << right << setprecision(6) <<DelPmax;
cout <<fixed <<setw(15) << right << setprecision(6) <<DelQmax<<endl;
Iter=Iter+1;
}
//Calculate (p and q) slack bus and (q) pv bus
for (i=1;i<=nb;++i)
{
if (type[i]==slack)
{
ps[i]=0.0;
qs[i]=0.0;
for (k=1;k<=nb;++k)
{
if (k==i)
{
ps[i]+=g[i][k]*v[k]*v[i];
qs[i]+=-b[i][k]*v[k]*v[i];
}
else
{
ps[i]+=(g[i][k]*cos(theta[i]theta[k])+b[i][k]*sin(theta[i]-theta[k]))*v[k]*v[i];
qs[i]+=(g[i][k]*sin(theta[i]-theta[k])b[i][k]*cos(theta[i]-theta[k]))*v[k]*v[i];
}
}
Pg[i]=ps[i]+Pl[i];
Qg[i]=qs[i]+Ql[i];
}
if (type[i]==PV)
{
qs[i]=0.0;
for (k=1;k<=nb;++k)
{
qs[i]+=(g[i][k]*sin(theta[i]-theta[k])-b[i][k]*cos(theta[i]theta[k]))*v[k]*v[i];
}
Qg[i]=qs[i]+Ql[i];
}
}
//Print hasil
cout<<"\n -------------------------------------------------------------------";
cout<<"\n
Load Flow Solution using Fast Decoupled Method
";
cout<<"\n -------------------------------------------------------------------";
cout<<"\n
Bus.
Volts
Angle
PG(Mw)
QG(Mvar)
PL(Mw)
QL(Mvar)";
cout<<"\n
pu
deg.
";
cout<<"\n -------------------------------------------------------------------\n";
for (i=1;i<=nb;++i)
{
cout <<fixed <<setw(5) << right <<no[i];
cout <<fixed <<setw(10) << right << setprecision(4) << v[i];
cout <<fixed <<setw(10) << right << setprecision(4) << theta[i]*180/3.14;
cout <<fixed <<setw(11) << right << setprecision(4) << Pg[i]*base;
cout <<fixed <<setw(11) << right << setprecision(4) << Qg[i]*base;
cout <<fixed <<setw(11) << right << setprecision(4) << Pl[i]*base;
cout <<fixed <<setw(11) << right << setprecision(4) << Ql[i]*base<<endl;
}
cout<<" -------------------------------------------------------------------"<<endl;
system("pause");
return 0;
}
void invers (double a[20][20],int n)
{
int i,j,k,l;
//<< a[1][2] << a[1][3];
for (i=1;i<=n;i++)
{
a[i][i] = 1.0/a[i][i];
for (j=1;j<=n;j++)
{
if (j!=i)
{
a[j][i] = a[j][i] * a[i][i];
for (k=1;k<=n;k++)
{
if (k!=i)
{
a[j][k] = a[j][k] - a[j][i]*a[i][k];
if (j==n)
{
a[i][k] = -a[i][i]* a[i][k];
}
}
}
}
}
}
k = n-1;
for (l=1;l<=k;l++)
{
a[n][l] = -a[n][n]*a[n][l];
}
}