function dp_3d_new,dat2,ENERGY=en,ERANGE=er,EBINS=ebins,ANGLE=an,ARANGE=ar,BINS=bins,_extra=_extra
p3dxx = 0. & p3dyy = 0. & p3dzz = 0. & p3dxy = 0. & p3dxz = 0. & p3dyz = 0.
if dat2.valid eq 0 then begin
dprint, 'Invalid Data'
return, [p3dxx,p3dyy,p3dzz,p3dxy,p3dxz,p3dyz]
endif
mass = dat2.mass
momen = m_3d_new(dat2,ENERGY=en,ERANGE=er,EBINS=ebins,ANGLE=an,ARANGE=ar,BINS=bins,_extra=_extra)
flux=j_3d_new(dat2,ENERGY=en,ERANGE=er,EBINS=ebins,ANGLE=an,ARANGE=ar,BINS=bins,_extra=_extra)
density=n_3d_new(dat2,ENERGY=en,ERANGE=er,EBINS=ebins,ANGLE=an,ARANGE=ar,BINS=bins,_extra=_extra)
dmomen = dm_3d_new(dat2,ENERGY=en,ERANGE=er,EBINS=ebins,ANGLE=an,ARANGE=ar,BINS=bins,_extra=_extra)
dflux=dj_3d_new(dat2,ENERGY=en,ERANGE=er,EBINS=ebins,ANGLE=an,ARANGE=ar,BINS=bins,_extra=_extra)
ddensity=dn_3d_new(dat2,ENERGY=en,ERANGE=er,EBINS=ebins,ANGLE=an,ARANGE=ar,BINS=bins,_extra=_extra)
p3dxx = (momen(0)-mass*flux(0)*flux(0)/density/1.e10)
p3dyy = (momen(1)-mass*flux(1)*flux(1)/density/1.e10)
p3dzz = (momen(2)-mass*flux(2)*flux(2)/density/1.e10)
p3dxy = (momen(3)-mass*flux(0)*flux(1)/density/1.e10)
p3dxz = (momen(4)-mass*flux(0)*flux(2)/density/1.e10)
p3dyz = (momen(5)-mass*flux(1)*flux(2)/density/1.e10)
dp3dxx = ((dmomen[0])^2 + (2.*mass/1.e10*flux(0)*dflux(0)/density)^2. + (mass/1.e10*flux(0)*flux(0)*ddensity/density^2)^2)^.5
dp3dyy = ((dmomen[1])^2 + (2.*mass/1.e10*flux(1)*dflux(1)/density)^2. + (mass/1.e10*flux(1)*flux(1)*ddensity/density^2)^2)^.5
dp3dzz = ((dmomen[2])^2 + (2.*mass/1.e10*flux(2)*dflux(2)/density)^2. + (mass/1.e10*flux(2)*flux(2)*ddensity/density^2)^2)^.5
dp3dxy = ((dmomen[3])^2 + (2.*mass/1.e10*flux(0)*dflux(1)/density)^2. + (mass/1.e10*flux(0)*flux(1)*ddensity/density^2)^2)^.5
dp3dxz = ((dmomen[4])^2 + (2.*mass/1.e10*flux(0)*dflux(2)/density)^2. + (mass/1.e10*flux(0)*flux(2)*ddensity/density^2)^2)^.5
dp3dyz = ((dmomen[5])^2 + (2.*mass/1.e10*flux(1)*dflux(2)/density)^2. + (mass/1.e10*flux(1)*flux(2)*ddensity/density^2)^2)^.5
p = [[p3dxx,p3dxy,p3dxz],[p3dxy,p3dyy,p3dyz],[p3dxz,p3dyz,p3dzz]]
dp = [[dp3dxx,dp3dxy,dp3dxz],[dp3dxy,dp3dyy,dp3dyz],[dp3dxz,dp3dyz,dp3dzz]]
if finite(total(dat2.magf)) && (total(dat2.magf*dat2.magf) gt 0.) then begin
bx=dat2.magf(0)
by=dat2.magf(1)
bz=dat2.magf(2)
ph=atan(by,bx)
rot_ph=([[cos(ph),-sin(ph),0],[sin(ph),cos(ph),0],[0,0,1]])
p = rot_ph#p#transpose(rot_ph)
dp = rot_ph#dp#transpose(rot_ph)
th=!pi/2.-atan(bz,(bx^2+by^2)^.5)
rot_th=[[cos(th),0,sin(th)],[0,1,0],[-sin(th),0,cos(th)]]
p = rot_th#p#transpose(rot_th)
dp = rot_th#dp#transpose(rot_th)
l1 = (p[0,0]+p[1,1] + (p[0,0]^2+p[1,1]^2-2.*p[0,0]*p[1,1]+4.*p[0,1]^2)^.5)/2.
l2 = (p[0,0]+p[1,1] - (p[0,0]^2+p[1,1]^2-2.*p[0,0]*p[1,1]+4.*p[0,1]^2)^.5)/2.
if l1 ne l2 then ph=acos(((p[0,0]*l1-p[1,1]*l2)/(l1^2-l2^2))^.5) else ph=0.
rot_ph=([[cos(ph),-sin(ph),0.],[sin(ph),cos(ph),0.],[0.,0.,1.]])
dp = rot_ph#dp#transpose(rot_ph)
endif
return, [dp(0,0),dp(1,1),dp(2,2),dp(0,1),dp(0,2),dp(1,2)]
end