Esempio n. 1
0
def group_velocity(soln):

    coils = np.array([-0.63, 0.63])
    p = Plasma(0.3, coils)

    for i in range(0, 582):
        #soln[:,1].size,10):

        print i
        z = soln[i, 0]
        x = soln[i, 1]
        #p = Plasma(1)
        X = p.X([z, x])

        Y = p.Yabs([z, x])
        gamma = p.gamma(1)
        Nz = soln[i, 2]
        Nx = soln[i, 3]

        localN = Local_N(p.Yvec([z, x]), p.gradY([z, x]), np.array([Nz, Nx]))

        dNz_dN = localN.dNz_dN()
        dNx_dN = localN.dNx_dN()
        localNz = localN.Nz()
        localNx = localN.Nx()
        vgz.append((dD_dN(X, Y, gamma, localNz, localNx, dNz_dN, dNx_dN)[0] /
                    dD_dw(X, Y, gamma, localNz, localNx)))
        vgx.append((dD_dN(X, Y, gamma, localNz, localNx, dNz_dN, dNx_dN)[1] /
                    dD_dw(X, Y, gamma, localNz, localNx)))
        lNz.append(localN.Nz())
        #print z,x,X,Y,Nz,Nx#dD_dN( X,Y,gamma,localNz,localNx,dNz_dN,dNx_dN   )[0] , dD_dw(  X,Y,gamma,localNz,localNx   )
    return np.array(vgz), np.array(vgx)
Esempio n. 2
0
def checkNx(soln):

    p = Plasma(0.5, np.array([-1, 1]))
    i = 0
    for x in soln[10345:10370, 1]:

        r = np.array([soln[i, 0], soln[i, 1]])

        locN = Local_N(p.Yvec(r), p.gradY(r),
                       np.array([soln[i, 2], soln[i, 3]]))
        print locN.Nx(), locN.Nz()
        plt.scatter(x, locN.Nx())
        plt.scatter(x, locN.Nz())

        i += 1