function b=Schmidt_orthogonalization(a)
[m,n] = size(a);
flag = 0;
if(m<n)
   flag = 1;
   a = a';
   [m,n] = size(a);
end
b=zeros(m,n);

b(:,1)=a(:,1);
for i=2:n
for j=1:i-1
b(:,i)=b(:,i)-dot(a(:,i),b(:,j))/dot(b(:,j),b(:,j))*b(:,j);
end
b(:,i)=b(:,i)+a(:,i);
end


for k=1:n
b(:,k)=b(:,k)/norm(b(:,k));
end
if flag
    b = b';
end

