focal_volume.cpp
This is an example of how to generate the focal field distribution.
#include "focal_volume.h"
int main(int argc, char** argv)
{
if(argc < 3)
{
cerr << "Usage: " << argv[0] << " <parameters file> <output directory>\n";
exit(-1);
}
string param_file = argv[1];
string outputdir = argv[2];
focus3d_parameters p;
if(!p.load(param_file)) {exit (-1);}
p.print();
Array<complex<double>,3> E_focus1_x, E_focus1_y, E_focus1_z;
Array<complex<double>,2> E_inc_x, E_inc_y, E_inc_z;
E_focus1_x.resize(p.Nx,p.Ny,p.Nz); E_focus1_x = 0;
E_focus1_y.resize(p.Nx,p.Ny,p.Nz); E_focus1_y = 0;
E_focus1_z.resize(p.Nx,p.Ny,p.Nz); E_focus1_z = 0;
E_inc_x.resize(p.Ntheta,p.Nphi);
E_inc_y.resize(p.Ntheta,p.Nphi);
E_inc_z.resize(p.Ntheta,p.Nphi);
E_inc_x = 1.0;
E_inc_y = 0.0;
E_inc_z = 0.0;
focus3d focus1(p);
focus1.set_incident_field(E_inc_x,E_inc_y,E_inc_z);
focus1.calculate_focus(E_focus1_x,E_focus1_y,E_focus1_z);
focus1.save_results(outputdir);
return(0);
}