BackEnd.E_calculation.java Source code

Java tutorial

Introduction

Here is the source code for BackEnd.E_calculation.java

Source

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package BackEnd;

import static InternalFrame.InternalFrameproject.Rozptie;
import emft_vol2.constants;
import java.util.ArrayList;
import org.apache.commons.math.complex.Complex;
import org.apache.commons.math.linear.RealMatrix;
import org.jdelaunay.delaunay.error.DelaunayError;
import org.jdelaunay.delaunay.geometries.DPoint;
import tools.help;

/**vypocita E v mieste Rp od jedneho lana
 * matrmatika vpo?tu je ale ZLA PONECHAVAM LEN KOLI ALGORITMOM 3D PKK a PKJ koeficienty
 * @author Jozef
 */
public class E_calculation {

    double epsi0;
    double epsiR;

    DPoint Rp;
    DPoint R0;
    DPoint deltaL;
    double R0_bundleY = 0;
    double R0_bundleZ = 0;
    double beta = 0;

    ArrayList<DPoint> RP_vectors;
    ArrayList<DPoint> R0_vectors;
    ArrayList<DPoint> R0m_vectors;
    ArrayList<DPoint> deltaL_vectors;
    RealMatrix Tau_real; // tau pre kazdy element
    RealMatrix Tau_image;
    ArrayList<Integer> polohy_lan;
    int Lano;
    FazorVektor E;

    public E_calculation() {
    }

    /**
     * 
     * @param epsi0  mu0
     * @param epsiR MUR
     * @param U  prud
     * @param phase faza
     * @param RP poloha pozorovatela
     * @param R0_vectors arralist vsetkch RP vektorov jednho lana
     * @param R0m_vectors arralist vsetkch RP vektorov jednho lana
     * @param deltaL_vectors arraylist vsetkch DL vektorov jedneho lana
     * @param R0_Y korekcia bundke vodi?a smer Y podla retazovky class
     * @param R0_Z korekcia bundke vodi?a smer Z podla retazovky class 
     * @throws DelaunayError 
     */
    public E_calculation(double epsi0, double epsiR, RealMatrix Tau_real, RealMatrix Tau_image,
            ArrayList<Integer> polohy_lan, int Lano, DPoint RP, ArrayList<DPoint> R0_vectors,
            ArrayList<DPoint> R0m_vectors, ArrayList<DPoint> deltaL_vectors, double R0_Z, double R0_Y, double beta)
            throws DelaunayError {
        this.epsi0 = epsi0;
        this.epsiR = epsiR;
        this.Tau_real = Tau_real;
        this.Tau_image = Tau_image;
        this.polohy_lan = polohy_lan;
        this.Lano = Lano;
        this.Rp = RP;
        this.R0_vectors = R0_vectors;
        this.R0m_vectors = R0m_vectors;
        this.deltaL_vectors = deltaL_vectors;
        this.R0_bundleY = R0_Y;
        this.R0_bundleZ = R0_Z;
        this.beta = beta; // 
        //System.out.println( " this.R0_bundleY " + this.R0_bundleY );
        //System.out.println( " this.R0_bundleZ " + this.R0_bundleZ );
        //korektura bundle

    }

    public void run() throws DelaunayError {
        Complex NULA = new Complex(0, 0);
        FazorVektor E_v_miesteRp = new FazorVektor(NULA, NULA, NULA);

        //cyklus od kazdeho elementu
        for (int cl1 = 0; cl1 < this.R0_vectors.size(); cl1++) {

            E_v_miesteRp.AddToFazorVektor(calc_DE(Tau_real.getEntry(polohy_lan.get(Lano) + cl1, 0),
                    Tau_image.getEntry(polohy_lan.get(Lano) + cl1, 0), Rp, R0_vectors.get(cl1),
                    R0m_vectors.get(cl1), deltaL_vectors.get(cl1)));

        }

        this.E = E_v_miesteRp;
    }

    //TOTO JE SRDCE VYPOCTU
    private FazorVektor calc_DE(double tau_real, double tau_image, DPoint Rp, DPoint R0, DPoint R0m, DPoint deltaL)
            throws DelaunayError {
        DPoint R_0 = new DPoint(R0.getX(), R0.getY(), R0.getZ());
        DPoint R_0m = new DPoint(R0.getX(), R0.getY(), R0.getZ());
        R_0.setY(R0.getY() + R0_bundleY); //  bundle korektura pre jeden druhy SMER 
        R_0.setZ(R0.getZ() + Math.cos(beta) * R0_bundleZ); // priemety
        R_0.setX(R0.getX() + Math.sin(beta) * R0_bundleZ);

        R_0m.setY(R0m.getY() - R0_bundleY); //  bundle korektura pre jeden druhy SMER 
        R_0m.setZ(R0m.getZ() + Math.cos(beta) * R0_bundleZ); // priemety
        R_0m.setX(R0m.getX() + Math.sin(beta) * R0_bundleZ);

        //  System.out.println( "R_0= " + R_0 );
        //  System.out.println( "Rp= " + Rp );
        // System.out.println( "deltal= " + deltaL );
        double K = 1 / (4 * Math.PI * constants.getEpsi0() * constants.getEpsi1()); // kontanta

        DPoint R_r = help.substract(Rp, R_0); // rozdiel vektorov Rp a RO
        DPoint R_m = help.substract(Rp, R_0m); // rozdiel vektorov RP a RO mirror
        DPoint R_r_unit = new DPoint(R_r);
        DPoint R_m_unit = new DPoint(R_m);

        R_r_unit.setX(R_r_unit.getX() / get_ABS(R_r));
        R_r_unit.setY(R_r_unit.getY() / get_ABS(R_r));
        R_r_unit.setZ(R_r_unit.getZ() / get_ABS(R_r));

        R_m_unit.setX(R_m_unit.getX() / get_ABS(R_m));
        R_m_unit.setY(R_m_unit.getY() / get_ABS(R_m));
        R_m_unit.setZ(R_m_unit.getZ() / get_ABS(R_m));

        double menovatel_r = Math.pow(get_ABS(R_r), 2);
        double menovatel_m = Math.pow(get_ABS(R_m), 2);
        double DELTA_l = get_ABS(deltaL);
        //
        //double DELTA_l = 1; //Rozptie.getKrok();

        FazorVektor deltaE = new FazorVektor(new Complex(0, 0), new Complex(0, 0), new Complex(0, 0));

        deltaE.setX_Real(K * (((tau_real * DELTA_l * R_r_unit.getX()) / menovatel_r)
                - ((tau_real * DELTA_l * R_m_unit.getX()) / menovatel_m)));
        deltaE.setY_Real(K * (((tau_real * DELTA_l * R_r_unit.getY()) / menovatel_r)
                - ((tau_real * DELTA_l * R_m_unit.getY()) / menovatel_m)));
        deltaE.setZ_Real(K * (((tau_real * DELTA_l * R_r_unit.getZ()) / menovatel_r)
                - ((tau_real * DELTA_l * R_m_unit.getZ()) / menovatel_m)));

        deltaE.setX_Imaginary(K * (((tau_image * DELTA_l * R_r_unit.getX()) / menovatel_r)
                - ((tau_image * DELTA_l * R_m_unit.getX()) / menovatel_m)));
        deltaE.setY_Imaginary(K * (((tau_image * DELTA_l * R_r_unit.getY()) / menovatel_r)
                - ((tau_image * DELTA_l * R_m_unit.getY()) / menovatel_m)));
        deltaE.setZ_Imaginary(K * (((tau_image * DELTA_l * R_r_unit.getZ()) / menovatel_r)
                - ((tau_image * DELTA_l * R_m_unit.getZ()) / menovatel_m)));

        return deltaE;
    }

    private double get_ABS(DPoint X) {
        double ABS = Math.sqrt(Math.pow(X.getX(), 2) + Math.pow(X.getY(), 2) + Math.pow(X.getZ(), 2));
        return ABS;
    }

    public FazorVektor getE() {
        return E;
    }

    public void setE(FazorVektor B) {
        this.E = E;
    }

}