function [u_bry,v_bry,ubar_bry,vbar_bry,...
          temp_bry,salt_bry]=oct_vinterp_OGCM_bry(zr_bry,zu_bry,zv_bry,...
                                              dzr_bry,dzu_bry,dzv_bry,...
                                              u_bry,v_bry,ubar_bry,vbar_bry,...
                                              temp_bry,salt_bry,...
                                              N,Z,conserv);
%
%
%
%
% Perform the vertical interpolations for the bry_file with OGCM for each boundary
%
%
%
%
zr_bry=squeeze(zr_bry);
zu_bry=squeeze(zu_bry);
zv_bry=squeeze(zv_bry);
dzr_bry=squeeze(dzr_bry);
dzu_bry=squeeze(dzu_bry);
dzv_bry=squeeze(dzv_bry);
%
% Add a level on top and bottom with no-gradient
%
u_bry=cat(1,u_bry(1,:),u_bry);
u_bry=cat(1,u_bry,u_bry(end,:));
v_bry=cat(1,v_bry(1,:),v_bry);
v_bry=cat(1,v_bry,v_bry(end,:));
temp_bry=cat(1,temp_bry(1,:),temp_bry);
temp_bry=cat(1,temp_bry,temp_bry(end,:));
salt_bry=cat(1,salt_bry,salt_bry(end,:));
salt_bry=cat(1,salt_bry(1,:),salt_bry);
% 
% Perform the vertical interpolations 
%
u_bry=squeeze(oct_ztosigma_1d(flipdim(u_bry,1),zu_bry,flipud(Z)));
v_bry=squeeze(oct_ztosigma_1d(flipdim(v_bry,1),zv_bry,flipud(Z)));
temp_bry=squeeze(oct_ztosigma_1d(flipdim(temp_bry,1),zr_bry,flipud(Z)));
salt_bry=squeeze(oct_ztosigma_1d(flipdim(salt_bry,1),zr_bry,flipud(Z)));
%
% Correct the horizontal transport 
% i.e. remove the interpolated tranport and add 
%      the OGCM transport
%
if conserv==1
  u_bry=u_bry-squeeze(oct_tridim(squeeze(sum(u_bry.*dzu_bry)./sum(dzu_bry)),N));
  v_bry=v_bry-squeeze(oct_tridim(squeeze(sum(v_bry.*dzv_bry)./sum(dzv_bry)),N));
  u_bry =u_bry + squeeze(oct_tridim(ubar_bry,N));
  v_bry = v_bry + squeeze(oct_tridim(vbar_bry,N));
end
%
% Barotropic velocities
%
ubar_bry=squeeze(sum(u_bry.*dzu_bry)./sum(dzu_bry));
vbar_bry=squeeze(sum(v_bry.*dzv_bry)./sum(dzv_bry));
%
return
