diff --git a/examples/fokker-planck-1D2V/fokker-planck-1D2V-even_nz-shorttest-nstep200.toml b/examples/fokker-planck-1D2V/fokker-planck-1D2V-even_nz-shorttest-nstep200.toml index 7422ef0b0..9f56e39db 100644 --- a/examples/fokker-planck-1D2V/fokker-planck-1D2V-even_nz-shorttest-nstep200.toml +++ b/examples/fokker-planck-1D2V/fokker-planck-1D2V-even_nz-shorttest-nstep200.toml @@ -1,47 +1,11 @@ -#use_manufactured_solns_for_init = true -#use_manufactured_solns_for_advance = false -n_ion_species = 1 -n_neutral_species = 0 -electron_physics = "boltzmann_electron_response" -#electron_physics = "boltzmann_electron_response_with_simple_sheath" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -#force_Er_zero_at_wall = false #true -#epsilon_offset = 0.1 -#use_vpabar_in_mms_dfni = true -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.0 ionization_frequency = 1.0 constant_ionization_rate = true -nstep = 200 -dt = 1.0e-4 -nwrite = 1000 -nwrite_dfns = 1000 -use_semi_lagrange = false -n_rk_stages = 4 -split_operators = false z_ngrid = 5 z_nelement = 16 #z_nelement_local = 2 @@ -67,31 +31,34 @@ vperp_L = 3.0 #vperp_discretization = "chebyshev_pseudospectral" vperp_discretization = "gausslegendre_pseudospectral" -#vz_ngrid = 17 -#vz_nelement = 4 -#vz_L = 12.0 -#vz_bc = "periodic" -#vz_discretization = "chebyshev_pseudospectral" - -#vr_ngrid = 17 -#vr_nelement = 4 -#vr_L = 12.0 -#vr_bc = "periodic" -#vr_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +#electron_physics = "boltzmann_electron_response_with_simple_sheath" +T_e = 1.0 +T_wall = 1.0 -#vzeta_ngrid = 17 -#vzeta_nelement = 4 -#vzeta_L = 12.0 -#vzeta_bc = "periodic" -#vzeta_discretization = "chebyshev_pseudospectral" +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 -#[ion_numerical_dissipation] -#vpa_dissipation_coefficient = 0.0 -#vperp_dissipation_coefficient = 0.0 -#z_dissipation_coefficient = 0.1 -#r_dissipation_coefficient = 0.0 +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [fokker_planck_collisions] use_fokker_planck = true nuii = 1.0 frequency_option = "manual" + +[timestepping] +nstep = 50 +dt = 1.0e-4 +nwrite = 10 +nwrite_dfns = 10 diff --git a/examples/fokker-planck/fokker-planck-relaxation-report-resolutions.toml b/examples/fokker-planck/fokker-planck-relaxation-report-resolutions.toml index 3c11ac2d6..b79376025 100644 --- a/examples/fokker-planck/fokker-planck-relaxation-report-resolutions.toml +++ b/examples/fokker-planck/fokker-planck-relaxation-report-resolutions.toml @@ -1,31 +1,8 @@ # cheap input file for a 0D2V relaxation to a collisional Maxwellian distribution with self-ion collisions. -n_ion_species = 1 -n_neutral_species = 0 -electron_physics = "boltzmann_electron_response" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.0 ionization_frequency = 0.0 constant_ionization_rate = false @@ -53,6 +30,27 @@ vperp_bc = "zero" # Fokker-Planck operator requires the "gausslegendre_pseudospectral # options for the vpa and vperp grids +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + + [fokker_planck_collisions] use_fokker_planck = true # nuii sets the normalised input C[F,F] Fokker-Planck collision frequency diff --git a/examples/fokker-planck/fokker-planck-relaxation-slowing-down-alphas.toml b/examples/fokker-planck/fokker-planck-relaxation-slowing-down-alphas.toml index 5218fbf4f..81284afba 100644 --- a/examples/fokker-planck/fokker-planck-relaxation-slowing-down-alphas.toml +++ b/examples/fokker-planck/fokker-planck-relaxation-slowing-down-alphas.toml @@ -1,28 +1,9 @@ # cheap input file for a 0D2V relaxation to a collisional Maxwellian distribution with self-ion collisions and collisions with fixed Maxwellian background of cold ions and electrons. -n_ion_species = 1 -n_neutral_species = 0 -electron_physics = "boltzmann_electron_response" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.0 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "isotropic-beam" -vpa_IC_v01 = 1.0 -vpa_IC_vth01 = 0.1 -#vpa_IC_option1 = "directed-beam" -#vpa_IC_vpa01 = -1.5 -#vpa_IC_vperp01 = 0.0 + charge_exchange_frequency = 0.0 ionization_frequency = 0.0 constant_ionization_rate = false @@ -90,3 +71,31 @@ nstep = 50000 dt = 2.5e-4 nwrite = 100 nwrite_dfns = 100 + +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "isotropic-beam" +#initialization_option = "directed-beam" +v0 = 1.0 +vth0 = 0.1 +#vpa0 = -1.5 +#vperp0 = 0.0 diff --git a/examples/fokker-planck/fokker-planck-relaxation-slowing-down-beam.toml b/examples/fokker-planck/fokker-planck-relaxation-slowing-down-beam.toml deleted file mode 100644 index 9f0a16f23..000000000 --- a/examples/fokker-planck/fokker-planck-relaxation-slowing-down-beam.toml +++ /dev/null @@ -1,71 +0,0 @@ -# cheap input file for a 0D2V relaxation to a collisional Maxwellian distribution with self-ion collisions. -n_ion_species = 1 -n_neutral_species = 0 -electron_physics = "boltzmann_electron_response" -evolve_moments_density = false -evolve_moments_parallel_flow = false -evolve_moments_parallel_pressure = false -evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option1 = "isotropic-beam" -#vpa_IC_option1 = "directed-beam" -#vpa_IC_v01 = -#vpa_IC_vth0 = -#vpa_IC_vpa0 = -#vpa_IC_vperp0 = -charge_exchange_frequency = 0.0 -ionization_frequency = 0.0 -constant_ionization_rate = false -z_ngrid = 1 -z_nelement = 1 -z_nelement_local = 1 -z_bc = "wall" -z_discretization = "chebyshev_pseudospectral" -r_ngrid = 1 -r_nelement = 1 -r_nelement_local = 1 -r_bc = "periodic" -r_discretization = "chebyshev_pseudospectral" -vpa_ngrid = 5 -vpa_nelement = 32 -vpa_L = 6.0 -vpa_bc = "zero" -vpa_discretization = "gausslegendre_pseudospectral" -vperp_ngrid = 5 -vperp_nelement = 16 -vperp_L = 3.0 -vperp_discretization = "gausslegendre_pseudospectral" -# Fokker-Planck operator requires the "gausslegendre_pseudospectral -# options for the vpa and vperp grids - -[fokker_planck_collisions] -# nuii sets the normalised input C[F,F] Fokker-Planck collision frequency -nuii = 1.0 -slowing_down_test = true -frequency_option = "manual" -use_fokker_planck = true - -[timestepping] -nstep = 1000 -dt = 1.0e-5 -nwrite = 50 -nwrite_dfns = 50 diff --git a/examples/fokker-planck/fokker-planck-relaxation-slowing-down.toml b/examples/fokker-planck/fokker-planck-relaxation-slowing-down.toml index 9fe59dbe2..f637a06ef 100644 --- a/examples/fokker-planck/fokker-planck-relaxation-slowing-down.toml +++ b/examples/fokker-planck/fokker-planck-relaxation-slowing-down.toml @@ -1,31 +1,8 @@ # cheap input file for a 0D2V relaxation to a collisional Maxwellian distribution with self-ion collisions. -n_ion_species = 1 -n_neutral_species = 0 -electron_physics = "boltzmann_electron_response" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.0 ionization_frequency = 0.0 constant_ionization_rate = false @@ -51,6 +28,27 @@ vperp_discretization = "gausslegendre_pseudospectral" # Fokker-Planck operator requires the "gausslegendre_pseudospectral # options for the vpa and vperp grids +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + + [fokker_planck_collisions] # nuii sets the normalised input C[F,F] Fokker-Planck collision frequency nuii = 1.0 diff --git a/examples/fokker-planck/fokker-planck-relaxation.toml b/examples/fokker-planck/fokker-planck-relaxation.toml index 0f633c12b..9a512fbf8 100644 --- a/examples/fokker-planck/fokker-planck-relaxation.toml +++ b/examples/fokker-planck/fokker-planck-relaxation.toml @@ -1,31 +1,8 @@ # cheap input file for a 0D2V relaxation to a collisional Maxwellian distribution with self-ion collisions. -n_ion_species = 1 -n_neutral_species = 0 -electron_physics = "boltzmann_electron_response" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.0 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.0 ionization_frequency = 0.0 constant_ionization_rate = false @@ -52,6 +29,26 @@ vperp_discretization = "gausslegendre_pseudospectral" # Fokker-Planck operator requires the "gausslegendre_pseudospectral # options for the vpa and vperp grids +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [fokker_planck_collisions] use_fokker_planck = true # nuii sets the normalised input C[F,F] Fokker-Planck collision frequency diff --git a/examples/fokker-planck/fokker-planck-source-sink-slowing-down-alphas-no-self-collisions.toml b/examples/fokker-planck/fokker-planck-source-sink-slowing-down-alphas-no-self-collisions.toml index bb69178fb..44a37a7cf 100644 --- a/examples/fokker-planck/fokker-planck-source-sink-slowing-down-alphas-no-self-collisions.toml +++ b/examples/fokker-planck/fokker-planck-source-sink-slowing-down-alphas-no-self-collisions.toml @@ -1,28 +1,8 @@ # cheap input file for a 0D2V relaxation to a collisional Maxwellian distribution with self-ion collisions and collisions with fixed Maxwellian background of cold ions and electrons. -n_ion_species = 1 -n_neutral_species = 0 -electron_physics = "boltzmann_electron_response" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.0 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "isotropic-beam" -vpa_IC_v01 = 1.0 -vpa_IC_vth01 = 0.1 -#vpa_IC_option1 = "directed-beam" -#vpa_IC_vpa01 = -1.5 -#vpa_IC_vperp01 = 0.0 charge_exchange_frequency = 0.0 ionization_frequency = 0.0 constant_ionization_rate = false @@ -50,6 +30,34 @@ vperp_bc = "zero" # Fokker-Planck operator requires the "gausslegendre_pseudospectral # options for the vpa and vperp grids +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "isotropic-beam" +#initialization_option = "directed-beam" +v0 = 1.0 +vth0 = 0.1 +#vpa0 = -1.5 +#vperp0 = 0.0 + [fokker_planck_collisions] # nuii sets the normalised input C[F,F] Fokker-Planck collision frequency nuii = 1.876334222e-3 #(1/nu_alphae, as computed from input diagnostic) diff --git a/examples/fokker-planck/fokker-planck-source-sink-slowing-down-alphas.toml b/examples/fokker-planck/fokker-planck-source-sink-slowing-down-alphas.toml index fc53ee470..06c6f8d61 100644 --- a/examples/fokker-planck/fokker-planck-source-sink-slowing-down-alphas.toml +++ b/examples/fokker-planck/fokker-planck-source-sink-slowing-down-alphas.toml @@ -1,28 +1,8 @@ # cheap input file for a 0D2V relaxation to a collisional Maxwellian distribution with self-ion collisions and collisions with fixed Maxwellian background of cold ions and electrons. -n_ion_species = 1 -n_neutral_species = 0 -electron_physics = "boltzmann_electron_response" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.0 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "isotropic-beam" -vpa_IC_v01 = 1.0 -vpa_IC_vth01 = 0.1 -#vpa_IC_option1 = "directed-beam" -#vpa_IC_vpa01 = -1.5 -#vpa_IC_vperp01 = 0.0 charge_exchange_frequency = 0.0 ionization_frequency = 0.0 constant_ionization_rate = false @@ -50,6 +30,35 @@ vperp_bc = "zero" # Fokker-Planck operator requires the "gausslegendre_pseudospectral # options for the vpa and vperp grids +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "isotropic-beam" +#initialization_option = "directed-beam" +v0 = 1.0 +vth0 = 0.1 +#vpa0 = -1.5 +#vperp0 = 0.0 + + [fokker_planck_collisions] # nuii sets the normalised input C[F,F] Fokker-Planck collision frequency nuii = 1.876334222e-3 #(1/nu_alphae, as computed from input diagnostic) diff --git a/examples/geometry/1D-mirror.toml b/examples/geometry/1D-mirror.toml index 6a8fe60a3..4b7a954b1 100644 --- a/examples/geometry/1D-mirror.toml +++ b/examples/geometry/1D-mirror.toml @@ -1,50 +1,10 @@ -n_ion_species = 1 -n_neutral_species = 0 -boltzmann_electron_response = true evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.5 ionization_frequency = 0.05 constant_ionization_rate = true -use_semi_lagrange = false -n_rk_stages = 4 -split_operators = false r_ngrid = 1 r_nelement = 1 z_ngrid = 5 @@ -67,6 +27,34 @@ vz_L = 18.0 vz_bc = "both_zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 +[ion_species] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [ion_numerical_dissipation] vpa_dissipation_coefficient = 1.0e-3 #1.0e-2 #1.0e-1 vperp_dissipation_coefficient = 1.0e-3 #1.0e-2 #1.0e-1 diff --git a/examples/gk-ions/2D-periodic-gk.toml b/examples/gk-ions/2D-periodic-gk.toml index 0d27dfb1e..19659aede 100644 --- a/examples/gk-ions/2D-periodic-gk.toml +++ b/examples/gk-ions/2D-periodic-gk.toml @@ -1,51 +1,10 @@ -n_ion_species = 1 -n_neutral_species = 0 -boltzmann_electron_response = true evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -gyrokinetic_ions = true -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 -charge_exchange_frequency = 0.5 +charge_exchange_frequency = 0.0 ionization_frequency = 0.05 constant_ionization_rate = true -use_semi_lagrange = false -n_rk_stages = 4 -split_operators = false r_ngrid = 5 r_nelement = 2 r_bc = "periodic" @@ -69,6 +28,37 @@ vz_L = 18.0 vz_bc = "both_zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +gyrokinetic_ions = true +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + + [geometry] #option="1D-mirror" DeltaB=0.0 diff --git a/examples/kinetic-electrons/periodic_split3_boltzmann.toml b/examples/kinetic-electrons/periodic_split3_boltzmann.toml index 27a3eff33..5ad042d4b 100644 --- a/examples/kinetic-electrons/periodic_split3_boltzmann.toml +++ b/examples/kinetic-electrons/periodic_split3_boltzmann.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -electron_physics = "boltzmann_electron_response" evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.1 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.1 -z_IC_temperature_phase1 = 1.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.0 constant_ionization_rate = false @@ -63,6 +25,58 @@ vz_L = 12.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.1 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.1 +temperature_phase = 1.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] type = "Fekete4(3)" nstep = 1000000 diff --git a/examples/kinetic-electrons/periodic_split3_braginskii-IMEX.toml b/examples/kinetic-electrons/periodic_split3_braginskii-IMEX.toml index 4dfe44807..f359c859d 100644 --- a/examples/kinetic-electrons/periodic_split3_braginskii-IMEX.toml +++ b/examples/kinetic-electrons/periodic_split3_braginskii-IMEX.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -electron_physics = "braginskii_fluid" evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.1 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.1 -z_IC_temperature_phase1 = 1.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.0 constant_ionization_rate = false @@ -63,6 +25,56 @@ vz_L = 12.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "braginskii_fluid" +recycling_fraction = 0.5 +T_e = 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.1 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.1 +temperature_phase = 1.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 + [timestepping] type = "KennedyCarpenterARK324" implicit_ion_advance = false diff --git a/examples/kinetic-electrons/periodic_split3_braginskii.toml b/examples/kinetic-electrons/periodic_split3_braginskii.toml index 31741e462..6f5c8d737 100644 --- a/examples/kinetic-electrons/periodic_split3_braginskii.toml +++ b/examples/kinetic-electrons/periodic_split3_braginskii.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -electron_physics = "braginskii_fluid" evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.1 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.1 -z_IC_temperature_phase1 = 1.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.0 constant_ionization_rate = false @@ -63,6 +25,56 @@ vz_L = 12.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "braginskii_fluid" +recycling_fraction = 0.5 +T_e = 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.1 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.1 +temperature_phase = 1.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 + [timestepping] type = "Fekete4(3)" nstep = 1000000 diff --git a/examples/kinetic-electrons/periodic_split3_kinetic-IMEX.toml b/examples/kinetic-electrons/periodic_split3_kinetic-IMEX.toml index ea91e79fa..e5a02086f 100644 --- a/examples/kinetic-electrons/periodic_split3_kinetic-IMEX.toml +++ b/examples/kinetic-electrons/periodic_split3_kinetic-IMEX.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -electron_physics = "kinetic_electrons" evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.1 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.1 -z_IC_temperature_phase1 = 1.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.0 constant_ionization_rate = false @@ -63,6 +25,56 @@ vz_L = 12.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "kinetic_electrons" +recycling_fraction = 0.5 +T_e = 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.1 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.1 +temperature_phase = 1.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 + [timestepping] type = "KennedyCarpenterARK324" implicit_electron_advance = true diff --git a/examples/kinetic-electrons/periodic_split3_kinetic.toml b/examples/kinetic-electrons/periodic_split3_kinetic.toml index c2c734a78..d4a1140d0 100644 --- a/examples/kinetic-electrons/periodic_split3_kinetic.toml +++ b/examples/kinetic-electrons/periodic_split3_kinetic.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -electron_physics = "kinetic_electrons" evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.1 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.1 -z_IC_temperature_phase1 = 1.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.0 constant_ionization_rate = false @@ -63,6 +25,56 @@ vz_L = 12.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "kinetic_electrons" +recycling_fraction = 0.5 +T_e = 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.1 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.1 +temperature_phase = 1.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 + [timestepping] #type = "KennedyCarpenterARK324" type = "Fekete4(3)" diff --git a/examples/kinetic-electrons/periodic_split3_kinetic_high-collisionality.toml b/examples/kinetic-electrons/periodic_split3_kinetic_high-collisionality.toml index 133d76b16..a0c44f500 100644 --- a/examples/kinetic-electrons/periodic_split3_kinetic_high-collisionality.toml +++ b/examples/kinetic-electrons/periodic_split3_kinetic_high-collisionality.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -electron_physics = "kinetic_electrons" evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.1 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.1 -z_IC_temperature_phase1 = 1.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.0 constant_ionization_rate = false @@ -63,6 +25,56 @@ vz_L = 12.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "kinetic_electrons" +recycling_fraction = 0.5 +T_e = 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.1 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.1 +temperature_phase = 1.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 + [reference_params] Tref = 20.0 diff --git a/examples/kinetic-electrons/wall+sheath-bc_boltzmann_loworder.toml b/examples/kinetic-electrons/wall+sheath-bc_boltzmann_loworder.toml index 35bb42e02..cb1b24116 100644 --- a/examples/kinetic-electrons/wall+sheath-bc_boltzmann_loworder.toml +++ b/examples/kinetic-electrons/wall+sheath-bc_boltzmann_loworder.toml @@ -1,47 +1,9 @@ steady_state_residual = true converged_residual_value = 1.0e-3 -n_ion_species = 1 -n_neutral_species = 1 -#boltzmann_electron_response = false -#electron_physics = "kinetic_electrons" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 2.0 electron_charge_exchange_frequency = 0.0 nu_ei = 0.0 @@ -71,6 +33,57 @@ vz_L = 12.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [output] ascii_output = true diff --git a/examples/kinetic-electrons/wall+sheath-bc_kinetic.toml b/examples/kinetic-electrons/wall+sheath-bc_kinetic.toml index a0a928479..8136e86d0 100644 --- a/examples/kinetic-electrons/wall+sheath-bc_kinetic.toml +++ b/examples/kinetic-electrons/wall+sheath-bc_kinetic.toml @@ -1,45 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -#boltzmann_electron_response = false -electron_physics = "kinetic_electrons" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 2.0 electron_charge_exchange_frequency = 0.0 nu_ei = 0.0 @@ -70,6 +32,57 @@ vz_L = 8.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "kinetic_electrons" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [output] ascii_output = true diff --git a/examples/kinetic-electrons/wall+sheath-bc_kinetic_krook_loworder.toml b/examples/kinetic-electrons/wall+sheath-bc_kinetic_krook_loworder.toml index da7a1bf63..f932d0357 100644 --- a/examples/kinetic-electrons/wall+sheath-bc_kinetic_krook_loworder.toml +++ b/examples/kinetic-electrons/wall+sheath-bc_kinetic_krook_loworder.toml @@ -1,45 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -#boltzmann_electron_response = false -electron_physics = "kinetic_electrons" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 2.0 electron_charge_exchange_frequency = 0.0 nu_ei = 0.0 @@ -69,6 +31,57 @@ vz_L = 8.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "kinetic_electrons" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [output] ascii_output = true diff --git a/examples/kinetic-electrons/wall+sheath-bc_kinetic_loworder.toml b/examples/kinetic-electrons/wall+sheath-bc_kinetic_loworder.toml index c1e8a7637..1b8ca705d 100644 --- a/examples/kinetic-electrons/wall+sheath-bc_kinetic_loworder.toml +++ b/examples/kinetic-electrons/wall+sheath-bc_kinetic_loworder.toml @@ -1,47 +1,9 @@ steady_state_residual = true converged_residual_value = 1.0e-3 -n_ion_species = 1 -n_neutral_species = 1 -#boltzmann_electron_response = false -electron_physics = "kinetic_electrons" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 2.0 electron_charge_exchange_frequency = 0.0 nu_ei = 0.0 @@ -71,6 +33,57 @@ vz_L = 12.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "kinetic_electrons" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [output] #ascii_output = true diff --git a/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_boltzmann-vpadiss0.toml b/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_boltzmann-vpadiss0.toml deleted file mode 100644 index b09ee80c6..000000000 --- a/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_boltzmann-vpadiss0.toml +++ /dev/null @@ -1,97 +0,0 @@ -#runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true -evolve_moments_density = true -evolve_moments_parallel_flow = true -evolve_moments_parallel_pressure = true -evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.05 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 1.0 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 -charge_exchange_frequency = 0.75 -ionization_frequency = 0.5 -constant_ionization_rate = false -r_ngrid = 1 -r_nelement = 1 -z_ngrid = 5 -z_nelement = 32 -z_nelement_local = 16 -z_bc = "wall" -z_discretization = "chebyshev_pseudospectral" -z_element_spacing_option = "sqrt" -vpa_ngrid = 6 -vpa_nelement = 63 -vpa_L = 36.0 -vpa_bc = "zero" -vpa_discretization = "chebyshev_pseudospectral" -vz_ngrid = 6 -vz_nelement = 63 -vz_L = 36.0 -vz_bc = "zero" -vz_discretization = "chebyshev_pseudospectral" - -[timestepping] -type = "Fekete4(3)" -#nstep = 50000 -nstep = 3000000 -dt = 1.0e-6 -minimum_dt = 1.0e-6 -nwrite = 10000 -nwrite_dfns = 100000 -steady_state_residual = true -converged_residual_value = 1.0e-3 - -[ion_source_1] -active = true -z_profile = "gaussian" -z_width = 0.125 -source_strength = 2.0 -source_T = 2.0 - -[ion_numerical_dissipation] -#vpa_dissipation_coefficient = 1.0e-1 -#vpa_dissipation_coefficient = 1.0e-2 -#vpa_dissipation_coefficient = 1.0e-3 -force_minimum_pdf_value = 0.0 - -[neutral_numerical_dissipation] -#vz_dissipation_coefficient = 1.0e-1 -#vz_dissipation_coefficient = 1.0e-2 -#vz_dissipation_coefficient = 1.0e-3 -force_minimum_pdf_value = 0.0 - -[krook_collisions] -use_krook = true diff --git a/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_boltzmann.toml b/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_boltzmann.toml deleted file mode 100644 index f993e7561..000000000 --- a/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_boltzmann.toml +++ /dev/null @@ -1,97 +0,0 @@ -#runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true -evolve_moments_density = true -evolve_moments_parallel_flow = true -evolve_moments_parallel_pressure = true -evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 -charge_exchange_frequency = 0.75 -ionization_frequency = 0.5 -constant_ionization_rate = false -r_ngrid = 1 -r_nelement = 1 -z_ngrid = 5 -z_nelement = 32 -z_nelement_local = 16 -z_bc = "wall" -z_discretization = "chebyshev_pseudospectral" -z_element_spacing_option = "sqrt" -vpa_ngrid = 6 -vpa_nelement = 63 -vpa_L = 36.0 -vpa_bc = "zero" -vpa_discretization = "chebyshev_pseudospectral" -vz_ngrid = 6 -vz_nelement = 63 -vz_L = 36.0 -vz_bc = "zero" -vz_discretization = "chebyshev_pseudospectral" - -[timestepping] -type = "Fekete4(3)" -#nstep = 50000 -nstep = 1000000 -dt = 1.0e-6 -minimum_dt = 1.0e-6 -nwrite = 10000 -nwrite_dfns = 100000 -steady_state_residual = true -converged_residual_value = 1.0e-3 - -[ion_source_1] -active = true -z_profile = "gaussian" -z_width = 0.125 -source_strength = 2.0 -source_T = 2.0 - -[ion_numerical_dissipation] -vpa_dissipation_coefficient = 1.0e-1 -#vpa_dissipation_coefficient = 1.0e-2 -#vpa_dissipation_coefficient = 1.0e-3 -force_minimum_pdf_value = 0.0 - -[neutral_numerical_dissipation] -vz_dissipation_coefficient = 1.0e-1 -#vz_dissipation_coefficient = 1.0e-2 -#vz_dissipation_coefficient = 1.0e-3 -force_minimum_pdf_value = 0.0 - -[krook_collisions] -use_krook = true diff --git a/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_braginskii-vpadiss0-IMEX.toml b/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_braginskii-vpadiss0-IMEX.toml index c6f91785d..34de38208 100644 --- a/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_braginskii-vpadiss0-IMEX.toml +++ b/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_braginskii-vpadiss0-IMEX.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -electron_physics = "braginskii_fluid" evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -64,6 +26,58 @@ vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "braginskii_fluid" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] type = "KennedyCarpenterARK324" #type = "KennedyCarpenterARK324-explicit" diff --git a/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_kinetic-vpadiss0.toml b/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_kinetic-vpadiss0.toml index 9af371c6a..0b14b0eb5 100644 --- a/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_kinetic-vpadiss0.toml +++ b/examples/kinetic-electrons/wall-bc_recyclefraction0.5_split3_kinetic-vpadiss0.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -electron_physics = "kinetic_electrons_with_temperature_equation" evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 0.1 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -63,6 +25,58 @@ vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "kinetic_electrons_with_temperature_equation" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 0.1 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] type = "Fekete4(3)" #nstep = 50000 diff --git a/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split1.toml b/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split1.toml index 7912e9680..c8178024f 100644 --- a/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split1.toml +++ b/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split1.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.5 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.5 -z_IC_temperature_phase1 = 3.14159265359 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.5 -z_IC_density_phase2 = 3.14159265359 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.5 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,40 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 3.14159265359 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 3.14159265359 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 0.0 + + [timestepping] nstep = 2000 dt = 0.001 diff --git a/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split2.toml b/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split2.toml index 8e11356d9..46326e0f4 100644 --- a/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split2.toml +++ b/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split2.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.5 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.5 -z_IC_temperature_phase1 = 3.14159265359 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.5 -z_IC_density_phase2 = 3.14159265359 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.5 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,39 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 3.14159265359 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 3.14159265359 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 0.0 + [timestepping] nstep = 400 dt = 0.001 diff --git a/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split3.toml b/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split3.toml index fc61e6688..fed5d3635 100644 --- a/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split3.toml +++ b/examples/nonlinear-sound-wave/nonlinear-sound-wave_cheb_split3.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.5 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.5 -z_IC_temperature_phase1 = 3.14159265359 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.5 -z_IC_density_phase2 = 3.14159265359 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.5 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,39 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 3.14159265359 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 3.14159265359 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 0.0 + [timestepping] nstep = 200 dt = 0.001 diff --git a/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd.toml b/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd.toml index 6a379b7ce..2d15df95f 100644 --- a/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd.toml +++ b/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.5 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.5 -z_IC_temperature_phase1 = 3.14159265359 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.5 -z_IC_density_phase2 = 3.14159265359 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.5 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,39 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "finite_difference" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 3.14159265359 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 3.14159265359 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 0.0 + [timestepping] nstep = 2000 dt = 0.001 diff --git a/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split1.toml b/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split1.toml index c2f5b1a6f..0de21547e 100644 --- a/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split1.toml +++ b/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split1.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.5 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.5 -z_IC_temperature_phase1 = 3.14159265359 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.5 -z_IC_density_phase2 = 3.14159265359 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.5 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,39 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "finite_difference" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 3.14159265359 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 3.14159265359 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 0.0 + [timestepping] nstep = 2000 dt = 0.001 diff --git a/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split2.toml b/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split2.toml index 8c87a564f..a5322c378 100644 --- a/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split2.toml +++ b/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split2.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.5 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.5 -z_IC_temperature_phase1 = 3.14159265359 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.5 -z_IC_density_phase2 = 3.14159265359 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.5 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,39 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "finite_difference" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 3.14159265359 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 3.14159265359 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 0.0 + [timestepping] nstep = 400 dt = 0.001 diff --git a/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split3.toml b/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split3.toml index 823b932c6..b17c8ff55 100644 --- a/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split3.toml +++ b/examples/nonlinear-sound-wave/nonlinear-sound-wave_fd_split3.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.5 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.5 -z_IC_temperature_phase1 = 3.14159265359 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.5 -z_IC_density_phase2 = 3.14159265359 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.5 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,39 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "finite_difference" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 3.14159265359 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.5 +density_phase = 3.14159265359 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.5 +temperature_phase = 0.0 + [timestepping] nstep = 200 dt = 0.001 diff --git a/examples/numerical-dissipation/num-diss-relaxation.toml b/examples/numerical-dissipation/num-diss-relaxation.toml index 6fb8b0086..3b9e46fe5 100644 --- a/examples/numerical-dissipation/num-diss-relaxation.toml +++ b/examples/numerical-dissipation/num-diss-relaxation.toml @@ -1,31 +1,8 @@ # cheap input file for a 0D2V relaxation with numerical diffusion terms d^2 F / dvpa^2 and d^2 F / vperp^2. -n_ion_species = 1 -n_neutral_species = 0 -electron_physics = "boltzmann_electron_response" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.0 ionization_frequency = 0.0 constant_ionization_rate = false @@ -51,6 +28,27 @@ vperp_L = 3.0 vperp_bc = "zero" vperp_discretization = "gausslegendre_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + + [timestepping] nstep = 2000 dt = 1.0e-3 diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5-init.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5-init.toml index 6c73e7b25..b1e7d80e6 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5-init.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5-init.toml @@ -1,44 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -55,11 +18,64 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 6 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "Fekete4(3)" diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5.toml index 85ab587b9..e8b3e75a1 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5.toml @@ -1,44 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -55,11 +18,64 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 10 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "Fekete4(3)" diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split1.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split1.toml index 60a6b8671..f19d547e4 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split1.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split1.toml @@ -1,44 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 evolve_moments_density = true evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -55,11 +18,64 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 10 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "Fekete4(3)" diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split2.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split2.toml index 770c49197..13f55534b 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split2.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split2.toml @@ -1,44 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = false evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -55,11 +18,65 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 10 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option= "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "Fekete4(3)" diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3-init.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3-init.toml index 4ea030e52..bdf623cb1 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3-init.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3-init.toml @@ -1,44 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -55,19 +18,73 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 6 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option= "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "Fekete4(3)" nstep = 100000 dt = 1.0e-5 minimum_dt = 1.0e-6 -nwrite = 1000 -nwrite_dfns = 1000 +nwrite = 10000 +nwrite_dfns = 10000 split_operators = false steady_state_residual = true converged_residual_value = 1.0e-3 diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3.toml index 96dfe0d41..a337444d9 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3.toml @@ -1,44 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -55,11 +18,65 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 10 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option= "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "Fekete4(3)" diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_SSPRK4.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_SSPRK4.toml index 30f0ab14d..afce660e8 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_SSPRK4.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_SSPRK4.toml @@ -1,44 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -55,11 +18,64 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 10 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] #nstep = 50000 diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete104.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete104.toml index a489cfbd7..ce78514a3 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete104.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete104.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -57,11 +19,65 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 10 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option= "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "Fekete10(4)" diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete42.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete42.toml index f8f00d7e3..e5422637b 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete42.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete42.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -57,11 +19,65 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 10 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option= "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "Fekete4(2)" diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete64.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete64.toml index 5814d393e..86804f900 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete64.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_fekete64.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -57,11 +19,65 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 10 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option= "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "Fekete6(4)" diff --git a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_rkf54.toml b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_rkf54.toml index 5534ffc3d..fa49d590d 100644 --- a/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_rkf54.toml +++ b/examples/recycling-fraction/wall-bc_recyclefraction0.5_split3_rkf54.toml @@ -1,46 +1,8 @@ #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -57,11 +19,65 @@ vpa_nelement = 63 vpa_L = 36.0 vpa_bc = "zero" vpa_discretization = "chebyshev_pseudospectral" +vpa_element_spacing_option = "coarse_tails" vz_ngrid = 10 vz_nelement = 63 vz_L = 36.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +vz_element_spacing_option = "coarse_tails" + +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option= "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 [timestepping] type = "RKF5(4)" diff --git a/examples/sheath+wall-bc_test/sheath-bc_cheb_test.toml b/examples/sheath+wall-bc_test/sheath-bc_cheb_test.toml index c2ac67f3d..4bb5e56a1 100644 --- a/examples/sheath+wall-bc_test/sheath-bc_cheb_test.toml +++ b/examples/sheath+wall-bc_test/sheath-bc_cheb_test.toml @@ -1,46 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -#boltzmann_electron_response = false -electron_physics = "boltzmann_electron_response_with_simple_sheath" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -phi_wall = -2.690 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 2.0 ionization_frequency = 2.0 constant_ionization_rate = false @@ -56,6 +17,58 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response_with_simple_sheath" +T_e = 1.0 +T_wall = 1.0 +phi_wall = -2.690 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option= "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 40000 dt = 0.001 diff --git a/examples/sheath+wall-bc_test/wall-bc_cheb_test.toml b/examples/sheath+wall-bc_test/wall-bc_cheb_test.toml index db9c4b664..b9ed15f46 100644 --- a/examples/sheath+wall-bc_test/wall-bc_cheb_test.toml +++ b/examples/sheath+wall-bc_test/wall-bc_cheb_test.toml @@ -1,45 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -#boltzmann_electron_response = true -electron_physics = "boltzmann_electron_response" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 2.0 ionization_frequency = 2.0 constant_ionization_rate = false @@ -55,6 +17,57 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option= "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 40000 dt = 0.001 diff --git a/examples/sound-wave/sound-wave_cheb.toml b/examples/sound-wave/sound-wave_cheb.toml index 61891bfd6..4c50b1c65 100644 --- a/examples/sound-wave/sound-wave_cheb.toml +++ b/examples/sound-wave/sound-wave_cheb.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -43,6 +21,38 @@ vz_L = 8.0 vz_bc = "periodic" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [output] binary_format = "netcdf" diff --git a/examples/sound-wave/sound-wave_cheb_split1.toml b/examples/sound-wave/sound-wave_cheb_split1.toml index 4df7c7b09..9ef684754 100644 --- a/examples/sound-wave/sound-wave_cheb_split1.toml +++ b/examples/sound-wave/sound-wave_cheb_split1.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,38 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1500 dt = 0.002 diff --git a/examples/sound-wave/sound-wave_cheb_split2.toml b/examples/sound-wave/sound-wave_cheb_split2.toml index a859fbc81..27989f73c 100644 --- a/examples/sound-wave/sound-wave_cheb_split2.toml +++ b/examples/sound-wave/sound-wave_cheb_split2.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,38 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1500 dt = 0.002 diff --git a/examples/sound-wave/sound-wave_cheb_split3.toml b/examples/sound-wave/sound-wave_cheb_split3.toml index 5b7fe80ea..0443db2d4 100644 --- a/examples/sound-wave/sound-wave_cheb_split3.toml +++ b/examples/sound-wave/sound-wave_cheb_split3.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,38 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1500 dt = 0.002 diff --git a/examples/sound-wave/sound-wave_fd.toml b/examples/sound-wave/sound-wave_fd.toml index 8d1f11a0b..5c45c3183 100644 --- a/examples/sound-wave/sound-wave_fd.toml +++ b/examples/sound-wave/sound-wave_fd.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,38 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "finite_difference" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1500 dt = 0.002 diff --git a/examples/sound-wave/sound-wave_fd_split1.toml b/examples/sound-wave/sound-wave_fd_split1.toml index 758b1b387..d25a888d4 100644 --- a/examples/sound-wave/sound-wave_fd_split1.toml +++ b/examples/sound-wave/sound-wave_fd_split1.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,38 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "finite_difference" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1500 dt = 0.002 diff --git a/examples/sound-wave/sound-wave_fd_split2.toml b/examples/sound-wave/sound-wave_fd_split2.toml index abe2ed22a..658572f1f 100644 --- a/examples/sound-wave/sound-wave_fd_split2.toml +++ b/examples/sound-wave/sound-wave_fd_split2.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,38 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "finite_difference" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1500 dt = 0.002 diff --git a/examples/sound-wave/sound-wave_fd_split3.toml b/examples/sound-wave/sound-wave_fd_split3.toml index 15627f0fb..76c205b6a 100644 --- a/examples/sound-wave/sound-wave_fd_split3.toml +++ b/examples/sound-wave/sound-wave_fd_split3.toml @@ -1,29 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -T_e = 1.0 -initial_density1 = 0.5 -initial_temperature1 = 1.0 -initial_density2 = 0.5 -initial_temperature2 = 1.0 -z_IC_option1 = "sinusoid" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 0.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -z_IC_option2 = "sinusoid" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.62831853071 ionization_frequency = 0.0 r_ngrid = 1 @@ -38,6 +16,38 @@ vpa_L = 8.0 vpa_bc = "periodic" vpa_discretization = "finite_difference" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 + +[ion_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[neutral_species_1] +initial_density = 0.5 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[z_IC_neutral_species_1] +initialization_option = "sinusoid" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1500 dt = 0.002 diff --git a/examples/wall-bc/wall+sheath-bc.toml b/examples/wall-bc/wall+sheath-bc.toml index ccfbbde0f..4e582624e 100644 --- a/examples/wall-bc/wall+sheath-bc.toml +++ b/examples/wall-bc/wall+sheath-bc.toml @@ -1,45 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -#boltzmann_electron_response = false -electron_physics = "boltzmann_electron_response_with_simple_sheath" evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = 0.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 2.0 ionization_frequency = 2.0 constant_ionization_rate = false @@ -60,6 +22,57 @@ vz_L = 8.0 vz_bc = "periodic" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response_with_simple_sheath" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_eutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_eutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 10000 dt = 0.001 diff --git a/examples/wall-bc/wall-bc_cheb.toml b/examples/wall-bc/wall-bc_cheb.toml index 4a076b110..d0228533e 100644 --- a/examples/wall-bc/wall-bc_cheb.toml +++ b/examples/wall-bc/wall-bc_cheb.toml @@ -1,44 +1,7 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = false -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.5 ionization_frequency = 0.75 constant_ionization_rate = false @@ -59,6 +22,57 @@ vz_L = 18.0 vz_bc = "both_zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 50000 dt = 1.0e-5 diff --git a/examples/wall-bc/wall-bc_cheb_split1.toml b/examples/wall-bc/wall-bc_cheb_split1.toml index 4c57ebf48..78474d3d0 100644 --- a/examples/wall-bc/wall-bc_cheb_split1.toml +++ b/examples/wall-bc/wall-bc_cheb_split1.toml @@ -1,45 +1,8 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true #runtime_plots = true evolve_moments_density = true evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.5 ionization_frequency = 0.75 constant_ionization_rate = false @@ -60,6 +23,57 @@ vz_L = 18.0 vz_bc = "both_zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 50000 dt = 1.0e-5 diff --git a/examples/wall-bc/wall-bc_cheb_split2.toml b/examples/wall-bc/wall-bc_cheb_split2.toml index 53f29f0ac..81530feec 100644 --- a/examples/wall-bc/wall-bc_cheb_split2.toml +++ b/examples/wall-bc/wall-bc_cheb_split2.toml @@ -1,45 +1,8 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true #runtime_plots = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = false evolve_moments_conservation = true -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.5 ionization_frequency = 0.75 constant_ionization_rate = false @@ -60,6 +23,57 @@ vz_L = 18.0 vz_bc = "both_zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 50000 dt = 1.0e-5 diff --git a/examples/wall-bc/wall-bc_cheb_split3.toml b/examples/wall-bc/wall-bc_cheb_split3.toml index 3db98a2da..7834ba468 100644 --- a/examples/wall-bc/wall-bc_cheb_split3.toml +++ b/examples/wall-bc/wall-bc_cheb_split3.toml @@ -1,45 +1,8 @@ -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true #runtime_plots = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -T_e = 1.0 -T_wall = 1.0 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.5 ionization_frequency = 0.75 constant_ionization_rate = false @@ -60,6 +23,57 @@ vz_L = 18.0 vz_bc = "both_zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +T_e = 1.0 +T_wall = 1.0 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 50000 dt = 1.0e-5 diff --git a/examples/wall-bc/wall-bc_no-neutrals.toml b/examples/wall-bc/wall-bc_no-neutrals.toml index ab5b26595..777c85863 100644 --- a/examples/wall-bc/wall-bc_no-neutrals.toml +++ b/examples/wall-bc/wall-bc_no-neutrals.toml @@ -1,50 +1,10 @@ steady_state_residual = true converged_residual_value = 1.0e-3 runtime_plots = true -n_ion_species = 1 -n_neutral_species = 0 -boltzmann_electron_response = true evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 -#charge_exchange_frequency = 0.75 -#ionization_frequency = 0.5 r_ngrid = 1 r_nelement = 1 z_ngrid = 9 @@ -63,6 +23,36 @@ vz_L = 18.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 100000 dt = 5.0e-4 diff --git a/examples/wall-bc/wall-bc_no-neutrals_split1.toml b/examples/wall-bc/wall-bc_no-neutrals_split1.toml index 0e6086ed0..55c3fece3 100644 --- a/examples/wall-bc/wall-bc_no-neutrals_split1.toml +++ b/examples/wall-bc/wall-bc_no-neutrals_split1.toml @@ -1,50 +1,10 @@ steady_state_residual = true converged_residual_value = 1.0e-3 runtime_plots = true -n_ion_species = 1 -n_neutral_species = 0 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 -#charge_exchange_frequency = 0.75 -#ionization_frequency = 0.5 r_ngrid = 1 r_nelement = 1 z_ngrid = 9 @@ -63,6 +23,36 @@ vz_L = 18.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 100000 dt = 1.0e-4 diff --git a/examples/wall-bc/wall-bc_no-neutrals_split2.toml b/examples/wall-bc/wall-bc_no-neutrals_split2.toml index 2159851d8..3e6a0a8cf 100644 --- a/examples/wall-bc/wall-bc_no-neutrals_split2.toml +++ b/examples/wall-bc/wall-bc_no-neutrals_split2.toml @@ -1,50 +1,10 @@ steady_state_residual = true converged_residual_value = 1.0e-3 runtime_plots = true -n_ion_species = 1 -n_neutral_species = 0 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = false evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 -#charge_exchange_frequency = 0.75 -#ionization_frequency = 0.5 r_ngrid = 1 r_nelement = 1 z_ngrid = 9 @@ -63,6 +23,36 @@ vz_L = 18.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 100000 dt = 1.0e-4 diff --git a/examples/wall-bc/wall-bc_no-neutrals_split3.toml b/examples/wall-bc/wall-bc_no-neutrals_split3.toml index 25664c688..c17ace547 100644 --- a/examples/wall-bc/wall-bc_no-neutrals_split3.toml +++ b/examples/wall-bc/wall-bc_no-neutrals_split3.toml @@ -1,50 +1,10 @@ steady_state_residual = true converged_residual_value = 1.0e-3 runtime_plots = true -n_ion_species = 1 -n_neutral_species = 0 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.5 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 -#charge_exchange_frequency = 0.75 -#ionization_frequency = 0.5 r_ngrid = 1 r_nelement = 1 z_ngrid = 9 @@ -63,6 +23,36 @@ vz_L = 18.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 0 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.5 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 100000 dt = 1.0e-4 diff --git a/examples/wall-bc/wall-bc_volumerecycle.toml b/examples/wall-bc/wall-bc_volumerecycle.toml index ee6a36dd6..14116dcc6 100644 --- a/examples/wall-bc/wall-bc_volumerecycle.toml +++ b/examples/wall-bc/wall-bc_volumerecycle.toml @@ -1,48 +1,10 @@ steady_state_residual = true converged_residual_value = 1.0e-3 #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = false evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -recycling_fraction = 0.25 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -65,6 +27,58 @@ vz_L = 18.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.25 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1000000 dt = 3.0e-5 diff --git a/examples/wall-bc/wall-bc_volumerecycle_split1.toml b/examples/wall-bc/wall-bc_volumerecycle_split1.toml index a2fba2249..574a828e6 100644 --- a/examples/wall-bc/wall-bc_volumerecycle_split1.toml +++ b/examples/wall-bc/wall-bc_volumerecycle_split1.toml @@ -1,48 +1,10 @@ steady_state_residual = true converged_residual_value = 1.0e-3 #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = false evolve_moments_parallel_pressure = false evolve_moments_conservation = true -recycling_fraction = 0.25 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -65,6 +27,58 @@ vz_L = 18.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.25 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1000000 dt = 3.0e-5 diff --git a/examples/wall-bc/wall-bc_volumerecycle_split2.toml b/examples/wall-bc/wall-bc_volumerecycle_split2.toml index 1a5c2e968..ebe6709ce 100644 --- a/examples/wall-bc/wall-bc_volumerecycle_split2.toml +++ b/examples/wall-bc/wall-bc_volumerecycle_split2.toml @@ -1,48 +1,10 @@ steady_state_residual = true converged_residual_value = 1.0e-3 #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = false evolve_moments_conservation = true -recycling_fraction = 0.25 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -65,6 +27,58 @@ vz_L = 18.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.25 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1000000 dt = 3.0e-5 diff --git a/examples/wall-bc/wall-bc_volumerecycle_split3.toml b/examples/wall-bc/wall-bc_volumerecycle_split3.toml index 6b3e03cb9..84c664372 100644 --- a/examples/wall-bc/wall-bc_volumerecycle_split3.toml +++ b/examples/wall-bc/wall-bc_volumerecycle_split3.toml @@ -1,48 +1,10 @@ steady_state_residual = true converged_residual_value = 1.0e-3 #runtime_plots = true -n_ion_species = 1 -n_neutral_species = 1 -boltzmann_electron_response = true evolve_moments_density = true evolve_moments_parallel_flow = true evolve_moments_parallel_pressure = true evolve_moments_conservation = true -recycling_fraction = 0.25 -T_e = 0.2 # 1.0 -T_wall = 0.1 -initial_density1 = 1.0 -initial_temperature1 = 1.0 -z_IC_option1 = "gaussian" -z_IC_density_amplitude1 = 0.001 -z_IC_density_phase1 = 0.0 -z_IC_upar_amplitude1 = 1.0 -z_IC_upar_phase1 = 0.0 -z_IC_temperature_amplitude1 = 0.0 -z_IC_temperature_phase1 = 0.0 -vpa_IC_option1 = "gaussian" -vpa_IC_density_amplitude1 = 1.0 -vpa_IC_density_phase1 = 0.0 -vpa_IC_upar_amplitude1 = 0.0 -vpa_IC_upar_phase1 = 0.0 -vpa_IC_temperature_amplitude1 = 0.0 -vpa_IC_temperature_phase1 = 0.0 -initial_density2 = 1.0 -initial_temperature2 = 1.0 -z_IC_option2 = "gaussian" -z_IC_density_amplitude2 = 0.001 -z_IC_density_phase2 = 0.0 -z_IC_upar_amplitude2 = -1.0 -z_IC_upar_phase2 = 0.0 -z_IC_temperature_amplitude2 = 0.0 -z_IC_temperature_phase2 = 0.0 -vpa_IC_option2 = "gaussian" -vpa_IC_density_amplitude2 = 1.0 -vpa_IC_density_phase2 = 0.0 -vpa_IC_upar_amplitude2 = 0.0 -vpa_IC_upar_phase2 = 0.0 -vpa_IC_temperature_amplitude2 = 0.0 -vpa_IC_temperature_phase2 = 0.0 charge_exchange_frequency = 0.75 ionization_frequency = 0.5 constant_ionization_rate = false @@ -65,6 +27,58 @@ vz_L = 30.0 vz_bc = "zero" vz_discretization = "chebyshev_pseudospectral" +[composition] +n_ion_species = 1 +n_neutral_species = 1 +electron_physics = "boltzmann_electron_response" +recycling_fraction = 0.25 +T_e = 0.2 # 1.0 +T_wall = 0.1 + +[ion_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = 1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_ion_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[neutral_species_1] +initial_density = 1.0 +initial_temperature = 1.0 + +[z_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 0.001 +density_phase = 0.0 +upar_amplitude = -1.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + +[vpa_IC_neutral_species_1] +initialization_option = "gaussian" +density_amplitude = 1.0 +density_phase = 0.0 +upar_amplitude = 0.0 +upar_phase = 0.0 +temperature_amplitude = 0.0 +temperature_phase = 0.0 + [timestepping] nstep = 1000000 dt = 1.0e-5 diff --git a/makie_post_processing/makie_post_processing/src/shared_utils.jl b/makie_post_processing/makie_post_processing/src/shared_utils.jl index 32acaf1ec..7ce536326 100644 --- a/makie_post_processing/makie_post_processing/src/shared_utils.jl +++ b/makie_post_processing/makie_post_processing/src/shared_utils.jl @@ -1,6 +1,6 @@ module shared_utils -export calculate_and_write_frequencies, get_geometry, get_composition +export calculate_and_write_frequencies, get_geometry using moment_kinetics.analysis: fit_delta_phi_mode using moment_kinetics.array_allocation: allocate_float @@ -8,11 +8,10 @@ using moment_kinetics.coordinates: define_coordinate using moment_kinetics.input_structs: boltzmann_electron_response, boltzmann_electron_response_with_simple_sheath, grid_input, geometry_input, species_composition -using moment_kinetics.moment_kinetics_input: get_default_rhostar, setup_reference_parameters using moment_kinetics.type_definitions: mk_float, mk_int using moment_kinetics.reference_parameters: setup_reference_parameters -using moment_kinetics.moment_kinetics_input: get_default_rhostar using moment_kinetics.geo: init_magnetic_geometry, setup_geometry_input +using moment_kinetics.species_input: get_species_input using MPI """ @@ -62,58 +61,8 @@ function calculate_and_write_frequencies(run_name, ntime, time, z, itime_min, it return frequency, growth_rate, shifted_time, fitted_delta_phi end -""" -""" -function get_composition(scan_input) - reference_params = setup_reference_parameters(scan_input) - # set composition input - # MRH need to get this in way that does not duplicate code - # MRH from moment_kinetics_input.jl - electron_physics = get(scan_input, "electron_physics", boltzmann_electron_response) - - n_ion_species = get(scan_input, "n_ion_species", 1) - n_neutral_species = get(scan_input, "n_neutral_species", 1) - if electron_physics ∈ (boltzmann_electron_response, boltzmann_electron_response_with_simple_sheath) - n_species = n_ion_species + n_neutral_species - else - n_species = n_ion_species + n_neutral_species + 1 - end - T_e = get(scan_input, "T_e", 1.0) - # set wall temperature T_wall = Tw/Te - T_wall = get(scan_input, "T_wall", 1.0) - # set initial neutral temperature Tn/Tₑ = 1 - # set initial nᵢ/Nₑ = 1.0 - # set phi_wall at z = 0 - phi_wall = get(scan_input, "phi_wall", 0.0) - # if false use true Knudsen cosine for neutral wall bc - use_test_neutral_wall_pdf = get(scan_input, "use_test_neutral_wall_pdf", false) - gyrokinetic_ions = get(scan_input, "gyrokinetic_ions", false) - # constant to be used to test nonzero Er in wall boundary condition - recycling_fraction = get(scan_input, "recycling_fraction", 1.0) - # constant to be used to control Ez divergences - epsilon_offset = get(scan_input, "epsilon_offset", 0.001) - # bool to control if dfni is a function of vpa or vpabar in MMS test - use_vpabar_in_mms_dfni = get(scan_input, "use_vpabar_in_mms_dfni", true) - if use_vpabar_in_mms_dfni - alpha_switch = 1.0 - else - alpha_switch = 0.0 - end - # ratio of the neutral particle mass to the ion particle mass - mn_over_mi = 1.0 - # ratio of the electron particle mass to the ion particle mass - me_over_mi = 1.0/1836.0 - composition = species_composition(n_species, n_ion_species, n_neutral_species, - electron_physics, use_test_neutral_wall_pdf, T_e, T_wall, phi_wall, - mn_over_mi, me_over_mi, recycling_fraction, gyrokinetic_ions, allocate_float(n_species)) - return composition - -end - function get_geometry(scan_input,z,r) - reference_params = setup_reference_parameters(scan_input) - reference_rhostar = get_default_rhostar(reference_params) - geo_in = setup_geometry_input(scan_input, reference_rhostar) + geo_in = setup_geometry_input(scan_input) geometry = init_magnetic_geometry(geo_in,z,r) return geometry end diff --git a/moment_kinetics/debug_test/fokker_planck_collisions_inputs.jl b/moment_kinetics/debug_test/fokker_planck_collisions_inputs.jl index 912d7787b..671a69448 100644 --- a/moment_kinetics/debug_test/fokker_planck_collisions_inputs.jl +++ b/moment_kinetics/debug_test/fokker_planck_collisions_inputs.jl @@ -1,34 +1,41 @@ +using moment_kinetics.type_definitions: OptionsDict test_type = "Fokker-Planck collisions" # default input for test -test_input_full_f = Dict( +test_input_full_f = OptionsDict( "run_name" => "full_f", - "timestepping" => Dict{String,Any}("dt" => 0.0, + "timestepping" => OptionsDict("dt" => 0.0, "nstep" => 3, "nwrite" => 2, "nwrite_dfns" => 2), - "T_e" => 1.0, - "T_wall" => 1.0, - "electron_physics" => "boltzmann_electron_response", + "composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 0, + "T_e" => 1.0, + "T_wall" => 1.0, + "electron_physics" => "boltzmann_electron_response"), "evolve_moments_conservation" => false, "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, - "initial_density1" => 0.5, - "initial_density2" => 0.5, - "initial_temperature1" => 1.0, - "initial_temperature2" => 1.0, + "ion_species_1" => OptionsDict("initial_density" => 0.5, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("density_amplitude" => 0.001, + "density_phase" => 0.0, + "initialization_option" => "sinusoid", + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0), "charge_exchange_frequency" => 0.0, "ionization_frequency" => 0.0, "constant_ionization_rate" => false, - "n_ion_species" => 1, - "n_neutral_species" => 0, - "nuii" => 1.0, + "fokker_planck_collisions" => OptionsDict("use_fokker_planck" => true, + "nuii" => 1.0, + "frequency_option" => "manual"), "r_bc" => "periodic", "r_discretization" => "chebyshev_pseudospectral", "r_nelement" => 1, "r_ngrid" => 3, - "split_operators" => false, "vpa_L" => 6.0, "vpa_bc" => "zero", "vpa_discretization" => "gausslegendre_pseudospectral", @@ -38,20 +45,6 @@ test_input_full_f = Dict( "vperp_discretization" => "gausslegendre_pseudospectral", "vperp_nelement" => 2, "vperp_ngrid" => 3, - "z_IC_density_amplitude1" => 0.001, - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase1" => 0.0, - "z_IC_density_phase2" => 0.0, - "z_IC_option1" => "sinusoid", - "z_IC_option2" => "sinusoid", - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "z_IC_temperature_phase2" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_upar_phase2" => 0.0, "z_bc" => "wall", "z_discretization" => "chebyshev_pseudospectral", "z_nelement" => 1, diff --git a/moment_kinetics/debug_test/gyroaverage_inputs.jl b/moment_kinetics/debug_test/gyroaverage_inputs.jl index e0a8a5ffe..516d4c674 100644 --- a/moment_kinetics/debug_test/gyroaverage_inputs.jl +++ b/moment_kinetics/debug_test/gyroaverage_inputs.jl @@ -1,53 +1,38 @@ +using moment_kinetics.type_definitions: OptionsDict test_type = "gyroaverage" # default inputs for tests -test_input = Dict( +test_input = OptionsDict( "run_name" => "gyroaverage", - "n_ion_species" => 1, - "n_neutral_species" => 0, + "composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 0, + "gyrokinetic_ions" => true, + "T_e" => 1.0, + "T_wall" => 1.0), "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => false, - "gyrokinetic_ions" => true, - "T_e" => 1.0, - "T_wall" => 1.0, - "initial_density1" => 1.0, - "initial_temperature1" => 1.0, - "z_IC_option1" => "gaussian", - "z_IC_density_amplitude1" => 0.001, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 1.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "vpa_IC_option1" => "gaussian", - "vpa_IC_density_amplitude1" => 1.0, - "vpa_IC_density_phase1" => 0.0, - "vpa_IC_upar_amplitude1" => 0.0, - "vpa_IC_upar_phase1" => 0.0, - "vpa_IC_temperature_amplitude1" => 0.0, - "vpa_IC_temperature_phase1" => 0.0, - "initial_density2" => 1.0, - "initial_temperature2" => 1.0, - "z_IC_option2" => "gaussian", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => -1.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, - "vpa_IC_option2" => "gaussian", - "vpa_IC_density_amplitude2" => 1.0, - "vpa_IC_density_phase2" => 0.0, - "vpa_IC_upar_amplitude2" => 0.0, - "vpa_IC_upar_phase2" => 0.0, - "vpa_IC_temperature_amplitude2" => 0.0, - "vpa_IC_temperature_phase2" => 0.0, - "charge_exchange_frequency" => 0.5, + "ion_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => 1.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "charge_exchange_frequency" => 0.0, "ionization_frequency" => 0.05, "constant_ionization_rate" => true, - "timestepping" => Dict{String,Any}("nstep" => 3, + "timestepping" => OptionsDict("nstep" => 3, "dt" => 1.0e-12, "nwrite" => 2, "nwrite_dfns" => 2,), @@ -73,9 +58,9 @@ test_input = Dict( "vz_L" => 6.0, "vz_bc" => "zero", "vz_discretization" => "chebyshev_pseudospectral", - "numerical_dissipation" => Dict("vpa_dissipation_coefficient" => 1.0e-3, + "numerical_dissipation" => OptionsDict("vpa_dissipation_coefficient" => 1.0e-3, "vperp_dissipation_coefficient" => 1.0e-3), - "geometry" => Dict("DeltaB"=>0.0, + "geometry" => OptionsDict("DeltaB"=>0.0, "option"=>"constant-helical", "pitch"=>0.1, "rhostar"=> 0.1), diff --git a/moment_kinetics/debug_test/kinetic_electron_inputs.jl b/moment_kinetics/debug_test/kinetic_electron_inputs.jl index 5b8d4f7b0..96d1de29e 100644 --- a/moment_kinetics/debug_test/kinetic_electron_inputs.jl +++ b/moment_kinetics/debug_test/kinetic_electron_inputs.jl @@ -1,53 +1,54 @@ test_type = "Kinetic electron" +using moment_kinetics.type_definitions: OptionsDict -test_input = Dict("n_ion_species" => 1, - "n_neutral_species" => 1, - "electron_physics" => "kinetic_electrons", +test_input = OptionsDict("composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 1, + "electron_physics" => "kinetic_electrons", + "recycling_fraction" => 0.5, + "T_e" => 0.2, + "T_wall" => 0.1), "run_name" => "kinetic_electron", "base_directory" => test_output_directory, "evolve_moments_density" => true, "evolve_moments_parallel_flow" => true, "evolve_moments_parallel_pressure" => true, "evolve_moments_conservation" => true, - "recycling_fraction" => 0.5, - "T_e" => 0.2, - "T_wall" => 0.1, - "initial_density1" => 1.0, - "initial_temperature1" => 1.0, - "z_IC_option1" => "gaussian", - "z_IC_density_amplitude1" => 0.001, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 1.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "vpa_IC_option1" => "gaussian", - "vpa_IC_density_amplitude1" => 1.0, - "vpa_IC_density_phase1" => 0.0, - "vpa_IC_upar_amplitude1" => 0.0, - "vpa_IC_upar_phase1" => 0.0, - "vpa_IC_temperature_amplitude1" => 0.0, - "vpa_IC_temperature_phase1" => 0.0, - "initial_density2" => 1.0, - "initial_temperature2" => 1.0, - "z_IC_option2" => "gaussian", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => -1.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, - "vpa_IC_option2" => "gaussian", - "vpa_IC_density_amplitude2" => 1.0, - "vpa_IC_density_phase2" => 0.0, - "vpa_IC_upar_amplitude2" => 0.0, - "vpa_IC_upar_phase2" => 0.0, - "vpa_IC_temperature_amplitude2" => 0.0, - "vpa_IC_temperature_phase2" => 0.0, + "ion_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => 1.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "neutral_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_neutral_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => -1.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_neutral_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), "charge_exchange_frequency" => 0.75, "ionization_frequency" => 0.5, "constant_ionization_rate" => false, - "timestepping" => Dict{String,Any}("type" => "Fekete4(3)", + "timestepping" => OptionsDict("type" => "Fekete4(3)", "nstep" => 3, "dt" => 2.0e-8, "minimum_dt" => 1.0e-8, @@ -55,7 +56,7 @@ test_input = Dict("n_ion_species" => 1, "step_update_prefactor" => 0.4, "nwrite" => 2, "split_operators" => false), - "electron_timestepping" => Dict{String,Any}("type" => "Fekete4(3)", + "electron_timestepping" => OptionsDict("type" => "Fekete4(3)", "nstep" => 10, "dt" => 4.0e-11, "minimum_dt" => 2.0e-11, @@ -81,13 +82,13 @@ test_input = Dict("n_ion_species" => 1, "vz_L" => 6.0, "vz_bc" => "zero", "vz_discretization" => "chebyshev_pseudospectral", - "ion_source_1" => Dict{String,Any}("active" => true, + "ion_source_1" => OptionsDict("active" => true, "z_profile" => "gaussian", "z_width" => 0.125, "source_strength" => 2.0, "source_T" => 2.0), - "krook_collisions" => Dict{String,Any}("use_krook" => true), - "numerical_dissipation" => Dict{String,Any}("force_minimum_pdf_value" => 0.0, + "krook_collisions" => OptionsDict("use_krook" => true), + "numerical_dissipation" => OptionsDict("force_minimum_pdf_value" => 0.0, "vpa_dissipation_coefficient" => 1e-2)) diff --git a/moment_kinetics/debug_test/mms_inputs.jl b/moment_kinetics/debug_test/mms_inputs.jl index 79fae0812..5db15d46b 100644 --- a/moment_kinetics/debug_test/mms_inputs.jl +++ b/moment_kinetics/debug_test/mms_inputs.jl @@ -1,39 +1,22 @@ +using moment_kinetics.type_definitions: OptionsDict test_type = "MMS" # default inputs for tests -test_input = Dict( - "use_manufactured_solns" => true, - "n_ion_species" => 1, - "n_neutral_species" => 1, - "electron_physics" => "boltzmann_electron_response", - "run_name" => "MMS-2D-wall_cheb-with-neutrals", +test_input = OptionsDict( + "manufactured_solns" => OptionsDict("use_for_advance"=>true), "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => false, - "T_e" => 1.0, - "T_wall" => 1.0, - "initial_density1" => 0.5, - "initial_temperature1" => 1.0, - "initial_density2" => 0.5, - "initial_temperature2" => 1.0, - "z_IC_option1" => "sinusoid", - "z_IC_density_amplitude1" => 0.001, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "z_IC_option2" => "sinusoid", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, + "composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 1, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0, + "T_wall" => 1.0), + "run_name" => "MMS-2D-wall_cheb-with-neutrals", "charge_exchange_frequency" => 0.0, "ionization_frequency" => 0.0, - "timestepping" => Dict{String,Any}("nstep" => 3, + "timestepping" => OptionsDict("nstep" => 3, "dt" => 1.e-8, "nwrite" => 2, "type" => "SSPRK2", @@ -70,7 +53,7 @@ test_input = Dict( "vzeta_L" => 12.0, "vzeta_bc" => "none", "vzeta_discretization" => "chebyshev_pseudospectral", - "geometry" => Dict{String,Any}("rhostar" => 1.0,), + "geometry" => OptionsDict("rhostar" => 1.0,), ) test_input_list = [ diff --git a/moment_kinetics/debug_test/recycling_fraction_inputs.jl b/moment_kinetics/debug_test/recycling_fraction_inputs.jl index a49015970..545860c48 100644 --- a/moment_kinetics/debug_test/recycling_fraction_inputs.jl +++ b/moment_kinetics/debug_test/recycling_fraction_inputs.jl @@ -1,54 +1,55 @@ test_type = "Recycling fraction and adaptive timestepping" +using moment_kinetics.type_definitions: OptionsDict -test_input = Dict("n_ion_species" => 1, - "n_neutral_species" => 1, - "boltzmann_electron_response" => true, +test_input = OptionsDict("composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 1, + "electron_physics" => "boltzmann_electron_response", + "recycling_fraction" => 0.5, + "T_e" => 0.2, + "T_wall" => 2.0), + "ion_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), "run_name" => "full-f", "base_directory" => test_output_directory, "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => false, - "recycling_fraction" => 0.5, - "krook_collisions" => Dict{String,Any}("use_krook" => true), - "T_e" => 0.2, - "T_wall" => 2.0, - "initial_density1" => 1.0, - "initial_temperature1" => 1.0, - "z_IC_option1" => "gaussian", - "z_IC_density_amplitude1" => 0.001, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 1.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "vpa_IC_option1" => "gaussian", - "vpa_IC_density_amplitude1" => 1.0, - "vpa_IC_density_phase1" => 0.0, - "vpa_IC_upar_amplitude1" => 0.0, - "vpa_IC_upar_phase1" => 0.0, - "vpa_IC_temperature_amplitude1" => 0.0, - "vpa_IC_temperature_phase1" => 0.0, - "initial_density2" => 1.0, - "initial_temperature2" => 1.0, - "z_IC_option2" => "gaussian", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => -1.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, - "vpa_IC_option2" => "gaussian", - "vpa_IC_density_amplitude2" => 1.0, - "vpa_IC_density_phase2" => 0.0, - "vpa_IC_upar_amplitude2" => 0.0, - "vpa_IC_upar_phase2" => 0.0, - "vpa_IC_temperature_amplitude2" => 0.0, - "vpa_IC_temperature_phase2" => 0.0, + "krook_collisions" => OptionsDict("use_krook" => true), + "z_IC_ion_species_1" => OptionsDict("density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => 1.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0, + "initialization_option" => "gaussian"), + "vpa_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "neutral_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_neutral_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => -1.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_neutral_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), "charge_exchange_frequency" => 0.75, "ionization_frequency" => 0.5, "constant_ionization_rate" => false, - "timestepping" => Dict{String,Any}("type" => "Fekete4(3)", + "timestepping" => OptionsDict("type" => "Fekete4(3)", "nstep" => 3, "dt" => 1.0e-8, "minimum_dt" => 1.0e-8, @@ -73,7 +74,7 @@ test_input = Dict("n_ion_species" => 1, "vz_L" => 6.0, "vz_bc" => "zero", "vz_discretization" => "chebyshev_pseudospectral", - "ion_source_1" => Dict("active" => true, + "ion_source_1" => OptionsDict("active" => true, "z_profile" => "gaussian", "z_width" => 0.125, "source_strength" => 2.0, @@ -81,23 +82,23 @@ test_input = Dict("n_ion_species" => 1, test_input_split1 = merge(test_input, - Dict("run_name" => "split1", + OptionsDict("run_name" => "split1", "evolve_moments_density" => true, "evolve_moments_conservation" => true)) test_input_split2 = merge(test_input_split1, - Dict("run_name" => "split2", + OptionsDict("run_name" => "split2", "evolve_moments_parallel_flow" => true)) test_input_split2["timestepping"] = merge(test_input_split2["timestepping"], - Dict{String,Any}("step_update_prefactor" => 0.4)) + OptionsDict("step_update_prefactor" => 0.4)) test_input_split3 = merge(test_input_split2, - Dict("run_name" => "split3", + OptionsDict("run_name" => "split3", "evolve_moments_parallel_pressure" => true, "vpa_nelement" => 8, "vz_nelement" => 8, - "numerical_dissipation" => Dict{String,Any}("force_minimum_pdf_value" => 0.0, + "numerical_dissipation" => OptionsDict("force_minimum_pdf_value" => 0.0, "vpa_dissipation_coefficient" => 1e-2))) test_input_split3["timestepping"] = merge(test_input_split3["timestepping"], - Dict{String,Any}("dt" => 1.0e-9, + OptionsDict("dt" => 1.0e-9, "minimum_dt" => 1.0e-9)) diff --git a/moment_kinetics/debug_test/restart_interpolation_inputs.jl b/moment_kinetics/debug_test/restart_interpolation_inputs.jl index c914bc231..1041423cf 100644 --- a/moment_kinetics/debug_test/restart_interpolation_inputs.jl +++ b/moment_kinetics/debug_test/restart_interpolation_inputs.jl @@ -1,38 +1,21 @@ test_type = "restart_interpolation" +using moment_kinetics.type_definitions: OptionsDict # default inputs for tests -base_input = Dict( +base_input = OptionsDict( "run_name" => "base", - "n_ion_species" => 2, - "n_neutral_species" => 2, - "boltzmann_electron_response" => true, + "composition" => OptionsDict("n_ion_species" => 2, + "n_neutral_species" => 2, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0), "base_directory" => test_output_directory, "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => true, - "T_e" => 1.0, - "initial_density1" => 0.5, - "initial_temperature1" => 1.0, - "initial_density2" => 0.5, - "initial_temperature2" => 1.0, - "z_IC_option1" => "sinusoid", - "z_IC_density_amplitude1" => 0.001, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "z_IC_option2" => "sinusoid", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, "charge_exchange_frequency" => 2*π*0.1, "ionization_frequency" => 0.0, - "timestepping" => Dict{String,Any}("nstep" => 3, + "timestepping" => OptionsDict("nstep" => 3, "dt" => 0.0, "nwrite" => 2, "type" => "SSPRK2", @@ -59,29 +42,29 @@ base_input = Dict( "vzeta_nelement" => 1, "vr_ngrid" => 1, "vr_nelement" => 1, - "ion_numerical_dissipation" => Dict{String,Any}("force_minimum_pdf_value" => 0.0), - "neutral_numerical_dissipation" => Dict{String,Any}("force_minimum_pdf_value" => 0.0)) + "ion_numerical_dissipation" => OptionsDict("force_minimum_pdf_value" => 0.0), + "neutral_numerical_dissipation" => OptionsDict("force_minimum_pdf_value" => 0.0)) test_input = merge(base_input, - Dict("run_name" => "full-f", + OptionsDict("run_name" => "full-f", "z_nelement" => 3, "vpa_nelement" => 3, "vz_nelement" => 3)) test_input_split1 = merge(test_input, - Dict("run_name" => "split1", + OptionsDict("run_name" => "split1", "evolve_moments_density" => true)) test_input_split2 = merge(test_input_split1 , - Dict("run_name" => "split2", + OptionsDict("run_name" => "split2", "evolve_moments_parallel_flow" => true)) test_input_split3 = merge(test_input_split2, - Dict("run_name" => "split3", + OptionsDict("run_name" => "split3", "evolve_moments_parallel_pressure" => true)) test_input_list = [ diff --git a/moment_kinetics/debug_test/sound_wave_inputs.jl b/moment_kinetics/debug_test/sound_wave_inputs.jl index 5bbbbb0d6..45b8caedc 100644 --- a/moment_kinetics/debug_test/sound_wave_inputs.jl +++ b/moment_kinetics/debug_test/sound_wave_inputs.jl @@ -1,38 +1,21 @@ test_type = "sound_wave" +using moment_kinetics.type_definitions: OptionsDict # default inputs for tests -test_input_finite_difference_1D1V = Dict( +test_input_finite_difference_1D1V = OptionsDict( "run_name" => "finite_difference_1D1V", - "n_ion_species" => 2, - "n_neutral_species" => 2, - "boltzmann_electron_response" => true, + "composition" => OptionsDict("n_ion_species" => 2, + "n_neutral_species" => 2, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0), "base_directory" => test_output_directory, "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => true, - "T_e" => 1.0, - "initial_density1" => 0.5, - "initial_temperature1" => 1.0, - "initial_density2" => 0.5, - "initial_temperature2" => 1.0, - "z_IC_option1" => "sinusoid", - "z_IC_density_amplitude1" => 0.001, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "z_IC_option2" => "sinusoid", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, "charge_exchange_frequency" => 2*π*0.1, "ionization_frequency" => 0.0, - "timestepping" => Dict{String,Any}("nstep" => 3, + "timestepping" => OptionsDict("nstep" => 3, "dt" => 1.e-8, "nwrite" => 2, "type" => "SSPRK2", @@ -62,42 +45,42 @@ test_input_finite_difference_1D1V = Dict( test_input_finite_difference_1D1V_split_1_moment = merge(test_input_finite_difference_1D1V, - Dict("run_name" => "finite_difference_1D1V_split_1_moment", + OptionsDict("run_name" => "finite_difference_1D1V_split_1_moment", "evolve_moments_density" => true)) test_input_finite_difference_1D1V_split_2_moments = merge(test_input_finite_difference_1D1V_split_1_moment, - Dict("run_name" => "finite_difference_1D1V_split_2_moments", + OptionsDict("run_name" => "finite_difference_1D1V_split_2_moments", "evolve_moments_parallel_flow" => true)) test_input_finite_difference_1D1V_split_3_moments = merge(test_input_finite_difference_1D1V_split_2_moments, - Dict("run_name" => "finite_difference_1D1V_split_3_moments", + OptionsDict("run_name" => "finite_difference_1D1V_split_3_moments", "evolve_moments_parallel_pressure" => true)) test_input_finite_difference_cx0_1D1V = merge(test_input_finite_difference_1D1V, - Dict("run_name" => "finite_difference_cx0_1D1V", + OptionsDict("run_name" => "finite_difference_cx0_1D1V", "charge_exchange_frequency" => 0.0)) test_input_finite_difference_cx0_1D1V_split_1_moment = merge(test_input_finite_difference_cx0_1D1V, - Dict("run_name" => "finite_difference_cx0_1D1V_split_1_moment", + OptionsDict("run_name" => "finite_difference_cx0_1D1V_split_1_moment", "evolve_moments_density" => true)) test_input_finite_difference_cx0_1D1V_split_2_moments = merge(test_input_finite_difference_cx0_1D1V_split_1_moment, - Dict("run_name" => "finite_difference_cx0_1D1V_split_2_moments", + OptionsDict("run_name" => "finite_difference_cx0_1D1V_split_2_moments", "evolve_moments_parallel_flow" => true)) test_input_finite_difference_cx0_1D1V_split_3_moments = merge(test_input_finite_difference_cx0_1D1V_split_2_moments, - Dict("run_name" => "finite_difference_cx0_1D1V_split_3_moments", + OptionsDict("run_name" => "finite_difference_cx0_1D1V_split_3_moments", "evolve_moments_parallel_pressure" => true)) test_input_finite_difference = merge(test_input_finite_difference_1D1V, - Dict("run_name" => "finite_difference", + OptionsDict("run_name" => "finite_difference", "r_ngrid" => 4, "r_nelement" => 1, "r_discretization" => "finite_difference", @@ -116,41 +99,41 @@ test_input_finite_difference = test_input_finite_difference_split_1_moment = merge(test_input_finite_difference, - Dict("run_name" => "finite_difference_split_1_moment", + OptionsDict("run_name" => "finite_difference_split_1_moment", "evolve_moments_density" => true)) test_input_finite_difference_split_2_moments = merge(test_input_finite_difference_split_1_moment, - Dict("run_name" => "finite_difference_split_2_moments", + OptionsDict("run_name" => "finite_difference_split_2_moments", "evolve_moments_parallel_flow" => true)) test_input_finite_difference_split_3_moments = merge(test_input_finite_difference_split_2_moments, - Dict("run_name" => "finite_difference_split_3_moments", + OptionsDict("run_name" => "finite_difference_split_3_moments", "evolve_moments_parallel_pressure" => true)) test_input_finite_difference_cx0 = merge(test_input_finite_difference, - Dict("run_name" => "finite_difference_cx0", + OptionsDict("run_name" => "finite_difference_cx0", "charge_exchange_frequency" => 0.0)) test_input_finite_difference_cx0_split_1_moment = merge(test_input_finite_difference_cx0, - Dict("run_name" => "finite_difference_cx0_split_1_moment", + OptionsDict("run_name" => "finite_difference_cx0_split_1_moment", "evolve_moments_density" => true)) test_input_finite_difference_cx0_split_2_moments = merge(test_input_finite_difference_cx0_split_1_moment, - Dict("run_name" => "finite_difference_cx0_split_2_moments", + OptionsDict("run_name" => "finite_difference_cx0_split_2_moments", "evolve_moments_parallel_flow" => true)) test_input_finite_difference_cx0_split_3_moments = merge(test_input_finite_difference_cx0_split_2_moments, - Dict("run_name" => "finite_difference_cx0_split_3_moments", + OptionsDict("run_name" => "finite_difference_cx0_split_3_moments", "evolve_moments_parallel_pressure" => true)) test_input_chebyshev = merge(test_input_finite_difference, - Dict("run_name" => "chebyshev_pseudospectral", + OptionsDict("run_name" => "chebyshev_pseudospectral", "r_discretization" => "chebyshev_pseudospectral", "r_ngrid" => 3, "r_nelement" => 1, @@ -175,42 +158,42 @@ test_input_chebyshev = merge(test_input_finite_difference, test_input_chebyshev_split_1_moment = merge(test_input_chebyshev, - Dict("run_name" => "chebyshev_pseudospectral_split_1_moment", + OptionsDict("run_name" => "chebyshev_pseudospectral_split_1_moment", "evolve_moments_density" => true)) test_input_chebyshev_split_2_moments = merge(test_input_chebyshev_split_1_moment, - Dict("run_name" => "chebyshev_pseudospectral_split_2_moments", + OptionsDict("run_name" => "chebyshev_pseudospectral_split_2_moments", "evolve_moments_parallel_flow" => true)) test_input_chebyshev_split_3_moments = merge(test_input_chebyshev_split_2_moments, - Dict("run_name" => "chebyshev_pseudospectral_split_3_moments", + OptionsDict("run_name" => "chebyshev_pseudospectral_split_3_moments", "evolve_moments_parallel_pressure" => true)) test_input_chebyshev_cx0 = merge(test_input_chebyshev, - Dict("run_name" => "chebyshev_pseudospectral_cx0", + OptionsDict("run_name" => "chebyshev_pseudospectral_cx0", "charge_exchange_frequency" => 0.0)) test_input_chebyshev_cx0_split_1_moment = merge(test_input_chebyshev_cx0, - Dict("run_name" => "chebyshev_pseudospectral_cx0_split_1_moment", + OptionsDict("run_name" => "chebyshev_pseudospectral_cx0_split_1_moment", "evolve_moments_density" => true)) test_input_chebyshev_cx0_split_2_moments = merge(test_input_chebyshev_cx0_split_1_moment, - Dict("run_name" => "chebyshev_pseudospectral_cx0_split_2_moments", + OptionsDict("run_name" => "chebyshev_pseudospectral_cx0_split_2_moments", "evolve_moments_parallel_flow" => true)) test_input_chebyshev_cx0_split_3_moments = merge(test_input_chebyshev_cx0_split_2_moments, - Dict("run_name" => "chebyshev_pseudospectral_cx0_split_3_moments", + OptionsDict("run_name" => "chebyshev_pseudospectral_cx0_split_3_moments", "evolve_moments_parallel_pressure" => true)) test_input_chebyshev_1D1V = merge(test_input_finite_difference_1D1V, - Dict("run_name" => "chebyshev_pseudospectral_1D1V", + OptionsDict("run_name" => "chebyshev_pseudospectral_1D1V", "z_discretization" => "chebyshev_pseudospectral", "z_ngrid" => 3, "z_nelement" => 2, @@ -223,37 +206,37 @@ test_input_chebyshev_1D1V = test_input_chebyshev_1D1V_split_1_moment = merge(test_input_chebyshev_1D1V, - Dict("run_name" => "chebyshev_pseudospectral_1D1V_split_1_moment", + OptionsDict("run_name" => "chebyshev_pseudospectral_1D1V_split_1_moment", "evolve_moments_density" => true)) test_input_chebyshev_1D1V_split_2_moments = merge(test_input_chebyshev_1D1V_split_1_moment, - Dict("run_name" => "chebyshev_pseudospectral_1D1V_split_2_moments", + OptionsDict("run_name" => "chebyshev_pseudospectral_1D1V_split_2_moments", "evolve_moments_parallel_flow" => true)) test_input_chebyshev_1D1V_split_3_moments = merge(test_input_chebyshev_1D1V_split_2_moments, - Dict("run_name" => "chebyshev_pseudospectral_1D1V_split_3_moments", + OptionsDict("run_name" => "chebyshev_pseudospectral_1D1V_split_3_moments", "evolve_moments_parallel_pressure" => true, "runtime_plots" => true)) test_input_chebyshev_cx0_1D1V = merge(test_input_chebyshev_1D1V, - Dict("run_name" => "chebyshev_pseudospectral_cx0_1D1V", + OptionsDict("run_name" => "chebyshev_pseudospectral_cx0_1D1V", "charge_exchange_frequency" => 0.0)) test_input_chebyshev_cx0_1D1V_split_1_moment = merge(test_input_chebyshev_cx0_1D1V, - Dict("run_name" => "chebyshev_pseudospectral_cx0_1D1V_split_1_moment", + OptionsDict("run_name" => "chebyshev_pseudospectral_cx0_1D1V_split_1_moment", "evolve_moments_density" => true)) test_input_chebyshev_cx0_1D1V_split_2_moments = merge(test_input_chebyshev_cx0_1D1V_split_1_moment, - Dict("run_name" => "chebyshev_pseudospectral_cx0_1D1V_split_2_moments", + OptionsDict("run_name" => "chebyshev_pseudospectral_cx0_1D1V_split_2_moments", "evolve_moments_parallel_flow" => true)) test_input_chebyshev_cx0_1D1V_split_3_moments = merge(test_input_chebyshev_cx0_1D1V_split_2_moments, - Dict("run_name" => "chebyshev_pseudospectral_cx0_1D1V_split_3_moments", + OptionsDict("run_name" => "chebyshev_pseudospectral_cx0_1D1V_split_3_moments", "evolve_moments_parallel_pressure" => true)) test_input_list = [ diff --git a/moment_kinetics/debug_test/wall_bc_inputs.jl b/moment_kinetics/debug_test/wall_bc_inputs.jl index 7e7b2ef85..6698d2700 100644 --- a/moment_kinetics/debug_test/wall_bc_inputs.jl +++ b/moment_kinetics/debug_test/wall_bc_inputs.jl @@ -1,55 +1,24 @@ test_type = "Wall boundary conditions" +using moment_kinetics.type_definitions: OptionsDict +using moment_kinetics.input_structs: merge_dict_of_dicts # default inputs for tests -test_input_finite_difference_1D1V = Dict( +test_input_finite_difference_1D1V = OptionsDict( "run_name" => "finite_difference_1D1V", - "n_ion_species" => 2, - "n_neutral_species" => 2, - "boltzmann_electron_response" => true, + "composition" => OptionsDict("n_ion_species" => 2, + "n_neutral_species" => 2, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0, + "T_wall" => 1.0), "base_directory" => test_output_directory, "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => true, - "electron_physics" => "boltzmann_electron_response", - "T_e" => 1.0, - "T_wall" => 1.0, - "initial_density1" => 1.0, - "initial_temperature1" => 1.0, - "z_IC_option1" => "gaussian", - "z_IC_density_amplitude1" => 0.001, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "vpa_IC_option1" => "gaussian", - "vpa_IC_density_amplitude1" => 1.0, - "vpa_IC_density_phase1" => 0.0, - "vpa_IC_upar_amplitude1" => 0.0, - "vpa_IC_upar_phase1" => 0.0, - "vpa_IC_temperature_amplitude1" => 0.0, - "vpa_IC_temperature_phase1" => 0.0, - "initial_density2" => 1.0, - "initial_temperature2" => 1.0, - "z_IC_option2" => "gaussian", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, - "vpa_IC_option2" => "gaussian", - "vpa_IC_density_amplitude2" => 1.0, - "vpa_IC_density_phase2" => 0.0, - "vpa_IC_upar_amplitude2" => 0.0, - "vpa_IC_upar_phase2" => 0.0, - "vpa_IC_temperature_amplitude2" => 0.0, - "vpa_IC_temperature_phase2" => 0.0, "charge_exchange_frequency" => 2.0, "ionization_frequency" => 2.0, "constant_ionization_rate" => false, - "timestepping" => Dict{String,Any}("nstep" => 3, + "timestepping" => OptionsDict("nstep" => 3, "dt" => 1.0e-8, "nwrite" => 2, "type" => "SSPRK2", @@ -77,14 +46,14 @@ test_input_finite_difference_1D1V = Dict( "vr_ngrid" => 1, "vr_nelement" => 1) -test_input_finite_difference_simple_sheath_1D1V = merge( +test_input_finite_difference_simple_sheath_1D1V = merge_dict_of_dicts( test_input_finite_difference_1D1V, - Dict("run_name" => "finite_difference_simple_sheath_1D1V", - "electron_physics" => "boltzmann_electron_response_with_simple_sheath")) + OptionsDict("run_name" => "finite_difference_simple_sheath_1D1V", + "composition" => OptionsDict("electron_physics" => "boltzmann_electron_response_with_simple_sheath"))) test_input_finite_difference = merge( test_input_finite_difference_1D1V, - Dict("run_name" => "finite_difference", + OptionsDict("run_name" => "finite_difference", "r_ngrid" => 4, "r_nelement" => 1, "r_discretization" => "finite_difference", @@ -101,14 +70,14 @@ test_input_finite_difference = merge( "vzeta_nelement" => 1, "vzeta_discretization" => "finite_difference")) -test_input_finite_difference_simple_sheath = merge( +test_input_finite_difference_simple_sheath = merge_dict_of_dicts( test_input_finite_difference, - Dict("run_name" => "finite_difference_simple_sheath", - "electron_physics" => "boltzmann_electron_response_with_simple_sheath")) + OptionsDict("run_name" => "finite_difference_simple_sheath", + "composition" => OptionsDict("electron_physics" => "boltzmann_electron_response_with_simple_sheath"))) test_input_chebyshev_1D1V = merge( test_input_finite_difference_1D1V, - Dict("run_name" => "chebyshev_pseudospectral_1D1V", + OptionsDict("run_name" => "chebyshev_pseudospectral_1D1V", "z_discretization" => "chebyshev_pseudospectral", "z_ngrid" => 3, "z_nelement" => 2, @@ -120,26 +89,26 @@ test_input_chebyshev_1D1V = merge( "vz_nelement" => 2)) test_input_chebyshev_split1_1D1V = merge(test_input_chebyshev_1D1V, - Dict("run_name" => "chebyshev_pseudospectral_split1_1D1V", + OptionsDict("run_name" => "chebyshev_pseudospectral_split1_1D1V", "evolve_moments_density" => true)) test_input_chebyshev_split2_1D1V = merge(test_input_chebyshev_split1_1D1V, - Dict("run_name" => "chebyshev_pseudospectral_split2_1D1V", + OptionsDict("run_name" => "chebyshev_pseudospectral_split2_1D1V", "evolve_moments_parallel_flow" => true)) test_input_chebyshev_split3_1D1V = merge(test_input_chebyshev_split2_1D1V, - Dict("run_name" => "chebyshev_pseudospectral_split3_1D1V", + OptionsDict("run_name" => "chebyshev_pseudospectral_split3_1D1V", "evolve_moments_parallel_pressure" => true)) -test_input_chebyshev_simple_sheath_1D1V = merge( +test_input_chebyshev_simple_sheath_1D1V = merge_dict_of_dicts( test_input_chebyshev_1D1V, - Dict("run_name" => "chebyshev_pseudospectral_simple_sheath_1D1V", - "electron_physics" => "boltzmann_electron_response_with_simple_sheath")) + OptionsDict("run_name" => "chebyshev_pseudospectral_simple_sheath_1D1V", + "composition" => OptionsDict("electron_physics" => "boltzmann_electron_response_with_simple_sheath"))) test_input_chebyshev = merge( test_input_chebyshev_1D1V, - Dict("run_name" => "chebyshev_pseudospectral", + OptionsDict("run_name" => "chebyshev_pseudospectral", "r_discretization" => "chebyshev_pseudospectral", "r_ngrid" => 3, "r_nelement" => 1, @@ -156,10 +125,10 @@ test_input_chebyshev = merge( "vzeta_ngrid" => 3, "vzeta_nelement" => 1)) -test_input_chebyshev_simple_sheath = merge( +test_input_chebyshev_simple_sheath = merge_dict_of_dicts( test_input_chebyshev, - Dict("run_name" => "chebyshev_pseudospectral_simple_sheath", - "electron_physics" => "boltzmann_electron_response_with_simple_sheath")) + OptionsDict("run_name" => "chebyshev_pseudospectral_simple_sheath", + "composition" => OptionsDict("electron_physics" => "boltzmann_electron_response_with_simple_sheath"))) test_input_list = [ #test_input_finite_difference, diff --git a/moment_kinetics/ext/file_io_netcdf.jl b/moment_kinetics/ext/file_io_netcdf.jl index bb7a86f2b..fa22f99c3 100644 --- a/moment_kinetics/ext/file_io_netcdf.jl +++ b/moment_kinetics/ext/file_io_netcdf.jl @@ -97,9 +97,17 @@ end function write_single_value!(file_or_group::NCDataset, name, value::Union{Number, AbstractString, AbstractArray{T,N}}, - coords...; parallel_io, n_ion_species=nothing, - n_neutral_species=nothing, description=nothing, - units=nothing) where {T,N} + coords::Union{coordinate,NamedTuple}...; parallel_io, + description=nothing, units=nothing) where {T,N} + + if any(c.n < 0 for c ∈ coords) + error("Got a negative `n` in $coords") + end + if any(c.n == 0 for c ∈ coords) + # No data to write + return nothing + end + if description !== nothing || units !== nothing attributes = Dict{String, Any}() if description !== nothing @@ -112,11 +120,6 @@ function write_single_value!(file_or_group::NCDataset, name, attributes = () end - if n_ion_species !== nothing && n_neutral_species != nothing - error("Cannot have both ion-species and neutral species dimensions." * - "Got n_ion_species=$n_ion_species, n_neutral_species=$n_neutral_species") - end - if isa(value, Number) || isa(value, AbstractString) coords !== () && error("cannot pass coordinates with a scalar") @@ -134,26 +137,6 @@ function write_single_value!(file_or_group::NCDataset, name, maybe_create_netcdf_dim(file_or_group, c) end dims = Tuple(c.name for c in coords) - - if n_ion_species !== nothing - if n_ion_species < 0 - error("n_ion_species must be non-negative, got $n_ion_species") - elseif n_ion_species == 0 - # No data to write - return nothing - end - maybe_create_netcdf_dim(file_or_group, "ion_species", n_ion_species) - dims = tuple(dims..., "ion_species") - elseif n_neutral_species !== nothing - if n_neutral_species < 0 - error("n_neutral_species must be non-negative, got $n_neutral_species") - elseif n_neutral_species == 0 - # No data to write - return nothing - end - maybe_create_netcdf_dim(file_or_group, "neutral_species", n_neutral_species) - dims = tuple(dims..., "neutral_species") - end end if isa(value, Bool) # As a hack, write bools to NetCDF as Char, as NetCDF does not support bools (?), @@ -169,50 +152,20 @@ function write_single_value!(file_or_group::NCDataset, name, end function create_dynamic_variable!(file_or_group::NCDataset, name, type, - coords::coordinate...; parallel_io, - n_ion_species=nothing, n_neutral_species=nothing, - diagnostic_var_size=nothing, description=nothing, - units=nothing) - - if n_ion_species !== nothing && n_neutral_species !== nothing - error("Variable should not contain both ion and neutral species dimensions. " - * "Got n_ion_species=$n_ion_species and " - * "n_neutral_species=$n_neutral_species") - end - if diagnostic_var_size !== nothing && n_ion_species !== nothing - error("Diagnostic variable should not contain both ion species dimension. Got " - * "diagnostic_var_size=$diagnostic_var_size and " - * "n_ion_species=$n_ion_species") + coords::Union{coordinate,NamedTuple}...; parallel_io, + description=nothing, units=nothing) + + if any(c.n < 0 for c ∈ coords) + error("Got a negative `n` in $coords") end - if diagnostic_var_size !== nothing && n_neutral_species !== nothing - error("Diagnostic variable should not contain both neutral species dimension. " - * "Got diagnostic_var_size=$diagnostic_var_size and " - * "n_neutral_species=$n_neutral_species") + if any(c.n == 0 for c ∈ coords) + # No data to write + return nothing end # Create time dimension if necessary maybe_create_netcdf_dim(file_or_group, "time", Inf) - # Create species dimension if necessary - if n_ion_species !== nothing - if n_ion_species < 0 - error("n_ion_species must be non-negative, got $n_ion_species") - elseif n_ion_species == 0 - # No data to write - return nothing - end - maybe_create_netcdf_dim(file_or_group, "ion_species", n_ion_species) - end - if n_neutral_species !== nothing - if n_neutral_species < 0 - error("n_neutral_species must be non-negative, got $n_neutral_species") - elseif n_neutral_species == 0 - # No data to write - return nothing - end - maybe_create_netcdf_dim(file_or_group, "neutral_species", n_neutral_species) - end - # Create other dimensions if necessary for c ∈ coords maybe_create_netcdf_dim(file_or_group, c) @@ -221,23 +174,7 @@ function create_dynamic_variable!(file_or_group::NCDataset, name, type, # create the variable so it can be expanded indefinitely (up to the largest unsigned # integer in size) in the time dimension coord_dims = Tuple(c.name for c ∈ coords) - if diagnostic_var_size !== nothing - if isa(diagnostic_var_size, Number) - # Make diagnostic_var_size a Tuple - diagnostic_var_size = (diagnostic_var_size,) - end - for (i,dim_size) ∈ enumerate(diagnostic_var_size) - maybe_create_netcdf_dim(file_or_group, "$name$i", dim_size) - end - fixed_dims = Tuple("$name$i" for i ∈ 1:length(diagnostic_var_size)) - elseif n_ion_species !== nothing - fixed_dims = tuple(coord_dims..., "ion_species") - elseif n_neutral_species !== nothing - fixed_dims = tuple(coord_dims..., "neutral_species") - else - fixed_dims = coord_dims - end - dims = tuple(fixed_dims..., "time") + dims = tuple(coord_dims..., "time") # create the variable so it can be expanded indefinitely (up to the largest unsigned # integer in size) in the time dimension diff --git a/moment_kinetics/src/communication.jl b/moment_kinetics/src/communication.jl index be3ed60a3..f8fa46fff 100644 --- a/moment_kinetics/src/communication.jl +++ b/moment_kinetics/src/communication.jl @@ -433,7 +433,7 @@ end previous_is_read .= true previous_is_written = Array{Bool}(undef, dims) previous_is_written .= true - return DebugMPISharedArray(array, is_initialized, is_read, is_written, + return DebugMPISharedArray(array, accessed, is_initialized, is_read, is_written, creation_stack_trace, previous_is_read, previous_is_written) end diff --git a/moment_kinetics/src/coordinates.jl b/moment_kinetics/src/coordinates.jl index a18c2a75e..158de0074 100644 --- a/moment_kinetics/src/coordinates.jl +++ b/moment_kinetics/src/coordinates.jl @@ -293,7 +293,34 @@ function set_element_boundaries(nelement_global, L, element_spacing_option, coor for j in 1:nsqrt element_boundaries[(nelement_global+1)+ 1 - j] = (L/2.0) - fac*(L/2.0)*((j-1)/(nsqrt-1))^2 end - + elseif element_spacing_option == "coarse_tails" + # Element boundaries at + # + # x = (1 + (BT)^2 / 3) T tan(BT a) / (1 + (BT a)^2 / 3) + # + # where a = (i - 1 - c) / c, c = (n-1)/2, i is the grid index, so that a=-1 at + # i=1, a=1 at i=n and a=0 on the central grid point (if n is odd, so that there is + # a central point). Also B=1/T*atan(L/2T). + # + # Choosing x∼tan(a) gives dx/da∼1+x^2 so that we get grid spacing roughly + # proportional to x^2 for large |x|, which for w_∥ advection compensates the + # w_∥^2 terms in moment-kinetics so that the CFL condition should be roughly + # constant across the grid. The constant B.T multiplying a inside the tan() is + # chosen so that the transition between roughly constant spacing and roughly x^2 + # spacing happens at x=T. The (1 + (BT a)^2 / 3) denominator removes the quadratic + # part of the Taylor expansion of dx/da around a=0 so that we get a flatter region + # of grid spacing for |x| x.active, electron_source_settings) @@ -1570,16 +1557,16 @@ function define_dynamic_electron_moment_variables!(fid, r::coordinate, z::coordi electron_constraints_A_coefficient = create_dynamic_variable!(dynamic, "electron_constraints_A_coefficient", mk_float, z, r; - parallel_io=parallel_io, - description="'A' coefficient enforcing density constraint for electrons") + parallel_io=parallel_io, + description="'A' coefficient enforcing density constraint for electrons") electron_constraints_B_coefficient = create_dynamic_variable!(dynamic, "electron_constraints_B_coefficient", mk_float, z, r; - parallel_io=parallel_io, - description="'B' coefficient enforcing flow constraint for electrons") + parallel_io=parallel_io, + description="'B' coefficient enforcing flow constraint for electrons") electron_constraints_C_coefficient = create_dynamic_variable!(dynamic, "electron_constraints_C_coefficient", mk_float, z, r; - parallel_io=parallel_io, - description="'C' coefficient enforcing pressure constraint for electrons") + parallel_io=parallel_io, + description="'C' coefficient enforcing pressure constraint for electrons") if electron_physics ∈ (kinetic_electrons, kinetic_electrons_with_temperature_equation) io_electron_step_counter = create_dynamic_variable!( @@ -1604,15 +1591,15 @@ function define_dynamic_electron_moment_variables!(fid, r::coordinate, z::coordi n_failure_vars = length(t_params.failure_caused_by) io_electron_failure_caused_by = create_dynamic_variable!( - dynamic, "electron_failure_caused_by", mk_int; - diagnostic_var_size=n_failure_vars, parallel_io=parallel_io, + dynamic, "electron_failure_caused_by", mk_int, + (name="n_failure_vars", n=n_failure_vars); parallel_io=parallel_io, description="cumulative count of how many times each variable caused an " * "electron pseudo-timestep failure for the run") n_limit_vars = length(t_params.limit_caused_by) io_electron_limit_caused_by = create_dynamic_variable!( - dynamic, "electron_limit_caused_by", mk_int; diagnostic_var_size=n_limit_vars, - parallel_io=parallel_io, + dynamic, "electron_limit_caused_by", mk_int, + (name="n_limit_vars", n=n_limit_vars); parallel_io=parallel_io, description="cumulative count of how many times each factor limited the " * "electron pseudo-timestep for the run") @@ -1655,18 +1642,18 @@ function define_dynamic_neutral_moment_variables!(fid, n_neutral_species, r::coo evolve_ppar, write_error_diagnostics, write_steady_state_diagnostics) dynamic = get_group(fid, "dynamic_data") + n_neutral_species_coord = (name="n_neutral_species", n=n_neutral_species) # io_density_neutral is the handle for the neutral particle density - io_density_neutral = create_dynamic_variable!(dynamic, "density_neutral", mk_float, z, r; - n_neutral_species=n_neutral_species, + io_density_neutral = create_dynamic_variable!(dynamic, "density_neutral", mk_float, z, + r, n_neutral_species_coord; parallel_io=parallel_io, description="neutral species density", units="n_ref") if write_error_diagnostics io_density_neutral_loworder = - create_dynamic_variable!(dynamic, "density_neutral_loworder", mk_float, z, r; - n_neutral_species=n_neutral_species, - parallel_io=parallel_io, + create_dynamic_variable!(dynamic, "density_neutral_loworder", mk_float, z, r, + n_neutral_species_coord; parallel_io=parallel_io, description="low-order approximation to neutral species density, used to diagnose timestepping error", units="n_ref") else @@ -1674,9 +1661,8 @@ function define_dynamic_neutral_moment_variables!(fid, n_neutral_species, r::coo end if write_steady_state_diagnostics io_density_neutral_start_last_timestep = - create_dynamic_variable!(dynamic, "density_neutral_start_last_timestep", mk_float, z, r; - n_neutral_species=n_neutral_species, - parallel_io=parallel_io, + create_dynamic_variable!(dynamic, "density_neutral_start_last_timestep", mk_float, z, r, + n_neutral_species_coord; parallel_io=parallel_io, description="neutral species density at the start of the last timestep before output, used to measure steady state residual", units="n_ref") else @@ -1684,16 +1670,15 @@ function define_dynamic_neutral_moment_variables!(fid, n_neutral_species, r::coo end # io_uz_neutral is the handle for the neutral z momentum density - io_uz_neutral = create_dynamic_variable!(dynamic, "uz_neutral", mk_float, z, r; - n_neutral_species=n_neutral_species, + io_uz_neutral = create_dynamic_variable!(dynamic, "uz_neutral", mk_float, z, r, + n_neutral_species_coord; parallel_io=parallel_io, description="neutral species mean z velocity", units="c_ref = sqrt(2*T_ref/mi)") if write_error_diagnostics io_uz_neutral_loworder = - create_dynamic_variable!(dynamic, "uz_neutral_loworder", mk_float, z, r; - n_neutral_species=n_neutral_species, - parallel_io=parallel_io, + create_dynamic_variable!(dynamic, "uz_neutral_loworder", mk_float, z, r, + n_neutral_species_coord; parallel_io=parallel_io, description="low-order approximation to neutral species mean z velocity, used to diagnose timestepping error", units="c_ref = sqrt(2*T_ref/mi)") else @@ -1701,8 +1686,8 @@ function define_dynamic_neutral_moment_variables!(fid, n_neutral_species, r::coo end if write_steady_state_diagnostics io_uz_neutral_start_last_timestep = - create_dynamic_variable!(dynamic, "uz_neutral_start_last_timestep", mk_float, z, r; - n_neutral_species=n_neutral_species, + create_dynamic_variable!(dynamic, "uz_neutral_start_last_timestep", mk_float, + z, r, n_neutral_species_coord; parallel_io=parallel_io, description="neutral species mean z velocity at the start of the last timestep before output, used to measure steady state residual", units="c_ref = sqrt(2*T_ref/mi)") @@ -1711,16 +1696,15 @@ function define_dynamic_neutral_moment_variables!(fid, n_neutral_species, r::coo end # io_pz_neutral is the handle for the neutral species zz pressure - io_pz_neutral = create_dynamic_variable!(dynamic, "pz_neutral", mk_float, z, r; - n_neutral_species=n_neutral_species, + io_pz_neutral = create_dynamic_variable!(dynamic, "pz_neutral", mk_float, z, r, + n_neutral_species_coord; parallel_io=parallel_io, description="neutral species mean zz pressure", units="n_ref*T_ref") if write_error_diagnostics io_pz_neutral_loworder = - create_dynamic_variable!(dynamic, "pz_neutral_loworder", mk_float, z, r; - n_neutral_species=n_neutral_species, - parallel_io=parallel_io, + create_dynamic_variable!(dynamic, "pz_neutral_loworder", mk_float, z, r, + n_neutral_species_coord; parallel_io=parallel_io, description="low-order approximation to neutral species mean zz pressure, used to diagnose timestepping error", units="n_ref*T_ref") else @@ -1728,8 +1712,8 @@ function define_dynamic_neutral_moment_variables!(fid, n_neutral_species, r::coo end if write_steady_state_diagnostics io_pz_neutral_start_last_timestep = - create_dynamic_variable!(dynamic, "pz_neutral_start_last_timestep", mk_float, z, r; - n_neutral_species=n_neutral_species, + create_dynamic_variable!(dynamic, "pz_neutral_start_last_timestep", mk_float, + z, r, n_neutral_species_coord; parallel_io=parallel_io, description="neutral species mean zz pressure at the start of the last timestep before output, used to measure steady state residual", units="n_ref*T_ref") @@ -1738,16 +1722,15 @@ function define_dynamic_neutral_moment_variables!(fid, n_neutral_species, r::coo end # io_qz_neutral is the handle for the neutral z heat flux - io_qz_neutral = create_dynamic_variable!(dynamic, "qz_neutral", mk_float, z, r; - n_neutral_species=n_neutral_species, + io_qz_neutral = create_dynamic_variable!(dynamic, "qz_neutral", mk_float, z, r, + n_neutral_species_coord; parallel_io=parallel_io, description="neutral species z heat flux", units="n_ref*T_ref*c_ref") # io_thermal_speed_neutral is the handle for the neutral thermal speed io_thermal_speed_neutral = create_dynamic_variable!( - dynamic, "thermal_speed_neutral", mk_float, z, r; - n_neutral_species=n_neutral_species, + dynamic, "thermal_speed_neutral", mk_float, z, r, n_neutral_species_coord; parallel_io=parallel_io, description="neutral species thermal speed", units="c_ref") @@ -1807,20 +1790,20 @@ function define_dynamic_neutral_moment_variables!(fid, n_neutral_species, r::coo if evolve_density || evolve_upar || evolve_ppar neutral_constraints_A_coefficient = - create_dynamic_variable!(dynamic, "neutral_constraints_A_coefficient", mk_float, z, r; - n_neutral_species=n_neutral_species, - parallel_io=parallel_io, - description="'A' coefficient enforcing density constraint for neutrals") + create_dynamic_variable!(dynamic, "neutral_constraints_A_coefficient", + mk_float, z, r, n_neutral_species_coord; + parallel_io=parallel_io, + description="'A' coefficient enforcing density constraint for neutrals") neutral_constraints_B_coefficient = - create_dynamic_variable!(dynamic, "neutral_constraints_B_coefficient", mk_float, z, r; - n_neutral_species=n_neutral_species, - parallel_io=parallel_io, - description="'B' coefficient enforcing flow constraint for neutrals") + create_dynamic_variable!(dynamic, "neutral_constraints_B_coefficient", + mk_float, z, r, n_neutral_species_coord; + parallel_io=parallel_io, + description="'B' coefficient enforcing flow constraint for neutrals") neutral_constraints_C_coefficient = - create_dynamic_variable!(dynamic, "neutral_constraints_C_coefficient", mk_float, z, r; - n_neutral_species=n_neutral_species, - parallel_io=parallel_io, - description="'C' coefficient enforcing pressure constraint for neutrals") + create_dynamic_variable!(dynamic, "neutral_constraints_C_coefficient", + mk_float, z, r, n_neutral_species_coord; + parallel_io=parallel_io, + description="'C' coefficient enforcing pressure constraint for neutrals") else neutral_constraints_A_coefficient = nothing neutral_constraints_B_coefficient = nothing @@ -1859,16 +1842,15 @@ function define_dynamic_dfn_variables!(fid, r, z, vperp, vpa, vzeta, vr, vz, com nl_solver_params) dynamic = get_group(fid, "dynamic_data") + n_ion_species_coord = (name="n_ion_species", n=composition.n_ion_species) # io_f is the handle for the ion pdf - io_f = create_dynamic_variable!(dynamic, "f", mk_float, vpa, vperp, z, r; - n_ion_species=composition.n_ion_species, - parallel_io=parallel_io, + io_f = create_dynamic_variable!(dynamic, "f", mk_float, vpa, vperp, z, r, + n_ion_species_coord; parallel_io=parallel_io, description="ion species distribution function") if io_input.write_error_diagnostics io_f_loworder = create_dynamic_variable!(dynamic, "f_loworder", mk_float, vpa, - vperp, z, r; - n_ion_species=composition.n_ion_species, + vperp, z, r, n_ion_species_coord; parallel_io=parallel_io, description="low-order approximation to ion species distribution function, used to diagnose timestepping error") else @@ -1877,8 +1859,7 @@ function define_dynamic_dfn_variables!(fid, r, z, vperp, vpa, vzeta, vr, vz, com if io_input.write_steady_state_diagnostics io_f_start_last_timestep = create_dynamic_variable!(dynamic, "f_start_last_timestep", mk_float, vpa, - vperp, z, r; - n_ion_species=composition.n_ion_species, + vperp, z, r, n_ion_species_coord; parallel_io=parallel_io, description="ion species distribution function at the start of the last timestep before output, used to measure steady state residual") else @@ -1916,16 +1897,17 @@ function define_dynamic_dfn_variables!(fid, r, z, vperp, vpa, vzeta, vr, vz, com io_f_electron_start_last_timestep = nothing end + n_neutral_species_coord = (name="n_neutral_species", n=composition.n_neutral_species) + # io_f_neutral is the handle for the neutral pdf - io_f_neutral = create_dynamic_variable!(dynamic, "f_neutral", mk_float, vz, vr, vzeta, z, r; - n_neutral_species=composition.n_neutral_species, + io_f_neutral = create_dynamic_variable!(dynamic, "f_neutral", mk_float, vz, vr, vzeta, z, r, + n_neutral_species_coord; parallel_io=parallel_io, description="neutral species distribution function") if io_input.write_error_diagnostics io_f_neutral_loworder = create_dynamic_variable!(dynamic, "f_neutral_loworder", mk_float, vz, vr, - vzeta, z, r; - n_ion_species=composition.n_ion_species, + vzeta, z, r, n_neutral_species_coord; parallel_io=parallel_io, description="low-order approximation to neutral species distribution function, used to diagnose timestepping error") else @@ -1934,9 +1916,8 @@ function define_dynamic_dfn_variables!(fid, r, z, vperp, vpa, vzeta, vr, vz, com if io_input.write_steady_state_diagnostics io_f_neutral_start_last_timestep = create_dynamic_variable!(dynamic, "f_neutral_start_last_timestep", - mk_float, vz, vr, vzeta, z, r; - n_ion_species=composition.n_ion_species, - parallel_io=parallel_io, + mk_float, vz, vr, vzeta, z, r, + n_neutral_species_coord; parallel_io=parallel_io, description="neutral species distribution function at the start of the last timestep before output, used to measure steady state residual") else io_f_neutral_start_last_timestep = nothing diff --git a/moment_kinetics/src/file_io_hdf5.jl b/moment_kinetics/src/file_io_hdf5.jl index 271d79fee..53675051c 100644 --- a/moment_kinetics/src/file_io_hdf5.jl +++ b/moment_kinetics/src/file_io_hdf5.jl @@ -85,8 +85,7 @@ end # HDF5.H5DataStore is the supertype for HDF5.File and HDF5.Group function write_single_value!(file_or_group::HDF5.H5DataStore, name, data::Union{Number, AbstractString, AbstractArray{T,N}}, - coords::Union{coordinate,mk_int}...; parallel_io, - n_ion_species=nothing, n_neutral_species=nothing, + coords::Union{coordinate,mk_int,NamedTuple}...; parallel_io, description=nothing, units=nothing) where {T,N} if isa(data, Union{Number, AbstractString}) file_or_group[name] = data @@ -99,32 +98,18 @@ function write_single_value!(file_or_group::HDF5.H5DataStore, name, return nothing end - if n_ion_species !== nothing && n_neutral_species != nothing - error("Cannot have both ion-species and neutral species dimensions." * - "Got n_ion_species=$n_ion_species, n_neutral_species=$n_neutral_species") + if any(isa(c, mk_int) ? c < 0 : c.n < 0 for c ∈ coords) + error("Got a negative `n` in $coords") end - - if n_ion_species !== nothing - if n_ion_species < 0 - error("n_ion_species must be non-negative, got $n_ion_species") - elseif n_ion_species == 0 - # No data to write - return nothing - end - coords = tuple(coords..., n_ion_species) - elseif n_neutral_species !== nothing - if n_neutral_species < 0 - error("n_neutral_species must be non-negative, got $n_neutral_species") - elseif n_neutral_species == 0 - # No data to write - return nothing - end - coords = tuple(coords..., n_neutral_species) + if any(isa(c, mk_int) ? c == 0 : c.n == 0 for c ∈ coords) + # No data to write + return nothing end + dim_sizes, chunk_sizes = hdf5_get_fixed_dim_sizes(coords, parallel_io) io_var = create_dataset(file_or_group, name, T, dim_sizes, chunk=chunk_sizes) - local_ranges = Tuple(isa(c, mk_int) ? (1:c) : c.local_io_range for c ∈ coords) - global_ranges = Tuple(isa(c, mk_int) ? (1:c) : c.global_io_range for c ∈ coords) + local_ranges = Tuple(isa(c, mk_int) ? (1:c) : isa(c, coordinate) ? c.local_io_range : c.n for c ∈ coords) + global_ranges = Tuple(isa(c, mk_int) ? (1:c) : isa(c, coordinate) ? c.global_io_range : c.n for c ∈ coords) if N == 1 io_var[global_ranges[1]] = @view data[local_ranges[1]] @@ -176,7 +161,7 @@ of species). """ function hdf5_get_fixed_dim_sizes(coords, parallel_io) if parallel_io - dim_sizes = Tuple(isa(c, mk_int) ? c : c.n_global for c in coords) + dim_sizes = Tuple(isa(c, mk_int) ? c : (isa(c, coordinate) ? c.n_global : c.n) for c in coords) else dim_sizes = Tuple(isa(c, mk_int) ? c : c.n for c in coords) end @@ -209,65 +194,24 @@ function hdf5_get_dynamic_dim_sizes(fixed_coords, parallel_io) end function create_dynamic_variable!(file_or_group::HDF5.H5DataStore, name, type, - coords::coordinate...; parallel_io, - n_ion_species=nothing, n_neutral_species=nothing, - diagnostic_var_size=nothing, description=nothing, - units=nothing) - - if n_ion_species !== nothing && n_neutral_species !== nothing - error("Variable should not contain both ion and neutral species dimensions. " - * "Got n_ion_species=$n_ion_species and " - * "n_neutral_species=$n_neutral_species") - end - if diagnostic_var_size !== nothing && n_ion_species !== nothing - error("Diagnostic variable should not contain both ion species dimension. Got " - * "diagnostic_var_size=$diagnostic_var_size and " - * "n_ion_species=$n_ion_species") + coords::Union{coordinate,NamedTuple}...; parallel_io, + description=nothing, units=nothing) + + if any(isa(c, mk_int) ? c < 0 : c.n < 0 for c ∈ coords) + error("Got a negative `n` in $coords") end - if diagnostic_var_size !== nothing && n_neutral_species !== nothing - error("Diagnostic variable should not contain both neutral species dimension. " - * "Got diagnostic_var_size=$diagnostic_var_size and " - * "n_neutral_species=$n_neutral_species") + if any(isa(c, mk_int) ? c == 0 : c.n == 0 for c ∈ coords) + # No data to write + return nothing end - # Add the number of species to the spatial/velocity-space coordinates - if diagnostic_var_size !== nothing - if isa(diagnostic_var_size, Number) - # Make diagnostic_var_size a Tuple - diagnostic_var_size = (diagnostic_var_size,) - end - fixed_coords = diagnostic_var_size - elseif n_ion_species !== nothing - if n_ion_species < 0 - error("n_ion_species must be non-negative, got $n_ion_species") - elseif n_ion_species == 0 - # No data to write - return nothing - end - fixed_coords = tuple(coords..., n_ion_species) - elseif n_neutral_species !== nothing - if n_neutral_species < 0 - error("n_neutral_species must be non-negative, got $n_neutral_species") - elseif n_neutral_species == 0 - # No data to write - return nothing - end - fixed_coords = tuple(coords..., n_neutral_species) - else - fixed_coords = coords - end initial_dim_sizes, max_dim_sizes, chunk_size = - hdf5_get_dynamic_dim_sizes(fixed_coords, parallel_io) + hdf5_get_dynamic_dim_sizes(coords, parallel_io) var = create_dataset(file_or_group, name, type, (initial_dim_sizes, max_dim_sizes), chunk=chunk_size) # Add attribute listing the dimensions belonging to this variable dim_names = Tuple(c.name for c ∈ coords) - if n_ion_species !== nothing - dim_names = tuple(dim_names..., "ion_species") - elseif n_neutral_species !== nothing - dim_names = tuple(dim_names..., "neutral_species") - end add_attribute!(var, "dims", join(dim_names, ",")) if description !== nothing diff --git a/moment_kinetics/src/fokker_planck.jl b/moment_kinetics/src/fokker_planck.jl index fb9c6ef19..2365ce0c4 100644 --- a/moment_kinetics/src/fokker_planck.jl +++ b/moment_kinetics/src/fokker_planck.jl @@ -70,6 +70,7 @@ using ..fokker_planck_calculus: calculate_rosenbluth_potentials_via_elliptic_sol using ..fokker_planck_test: Cssp_fully_expanded_form, calculate_collisional_fluxes, H_Maxwellian, dGdvperp_Maxwellian using ..fokker_planck_test: d2Gdvpa2_Maxwellian, d2Gdvperpdvpa_Maxwellian, d2Gdvperp2_Maxwellian, dHdvpa_Maxwellian, dHdvperp_Maxwellian using ..fokker_planck_test: F_Maxwellian, dFdvpa_Maxwellian, dFdvperp_Maxwellian +using ..reference_parameters: setup_reference_parameters """ Function for reading Fokker Planck collision operator input parameters. @@ -80,7 +81,8 @@ use_fokker_planck = true nuii = 1.0 frequency_option = "manual" """ -function setup_fkpl_collisions_input(toml_input::Dict, reference_params) +function setup_fkpl_collisions_input(toml_input::Dict) + reference_params = setup_reference_parameters(toml_input) # get reference collision frequency (note factor of 1/2 due to definition choices) nuii_fkpl_default = 0.5*get_reference_collision_frequency_ii(reference_params) # read the input toml and specify a sensible default diff --git a/moment_kinetics/src/geo.jl b/moment_kinetics/src/geo.jl index 3635230dc..41be4d0db 100644 --- a/moment_kinetics/src/geo.jl +++ b/moment_kinetics/src/geo.jl @@ -12,7 +12,7 @@ using ..input_structs: geometry_input, set_defaults_and_check_section! using ..file_io: input_option_error using ..array_allocation: allocate_float using ..type_definitions: mk_float, mk_int - +using ..reference_parameters: setup_reference_parameters """ struct containing the geometric data necessary for @@ -60,6 +60,15 @@ gbdriftr::Array{mk_float,2} gbdriftz::Array{mk_float,2} end +""" + function get_default_rhostar(reference_params) + +Calculate the normalised ion gyroradius at reference parameters +""" +function get_default_rhostar(reference_params) + return reference_params.cref / reference_params.Omegaref / reference_params.Lref +end + """ function to read the geometry input data from the TOML file @@ -72,7 +81,10 @@ DeltaB = 0.0 option = "" """ -function setup_geometry_input(toml_input::Dict, reference_rhostar) +function setup_geometry_input(toml_input::Dict) + + reference_params = setup_reference_parameters(toml_input) + reference_rhostar = get_default_rhostar(reference_params) # read the input toml and specify a sensible default input_section = set_defaults_and_check_section!(toml_input, "geometry", # begin default inputs (as kwargs) diff --git a/moment_kinetics/src/input_structs.jl b/moment_kinetics/src/input_structs.jl index 284cf147a..ec5750e95 100644 --- a/moment_kinetics/src/input_structs.jl +++ b/moment_kinetics/src/input_structs.jl @@ -8,8 +8,8 @@ export time_info export advection_input, advection_input_mutable export grid_input, grid_input_mutable export initial_condition_input, initial_condition_input_mutable -export mk_to_toml -export species_parameters, species_parameters_mutable +export spatial_initial_condition_input, velocity_initial_condition_input +export ion_species_parameters, neutral_species_parameters, species_parameters_mutable export species_composition export drive_input, drive_input_mutable export ion_source_data, electron_source_data, neutral_source_data @@ -18,12 +18,14 @@ export io_input export pp_input export geometry_input export set_defaults_and_check_top_level!, set_defaults_and_check_section!, - Dict_to_NamedTuple + options_to_TOML, Dict_to_NamedTuple +export merge_dict_with_kwargs!, merge_dict_of_dicts!, merge_dict_of_dicts using ..communication using ..type_definitions: mk_float, mk_int using MPI +using TOML """ """ @@ -264,7 +266,26 @@ end """ """ -struct initial_condition_input +Base.@kwdef struct spatial_initial_condition_input + # initialization inputs for one coordinate of a separable distribution function + initialization_option::String + # inputs for "gaussian" initial condition + width::mk_float + # inputs for "sinusoid" initial condition + wavenumber::mk_int + density_amplitude::mk_float + density_phase::mk_float + upar_amplitude::mk_float + upar_phase::mk_float + temperature_amplitude::mk_float + temperature_phase::mk_float + # inputs for "monomial" initial condition + monomial_degree::mk_int +end + +""" +""" +Base.@kwdef struct velocity_initial_condition_input # initialization inputs for one coordinate of a separable distribution function initialization_option::String # inputs for "gaussian" initial condition @@ -305,25 +326,49 @@ end """ """ -struct species_parameters - # type is the type of species; options are 'ion' or 'neutral' +Base.@kwdef struct ion_species_parameters + # type is the type of species type::String + # mass/reference mass + mass::mk_float + # charge number, absolute w.r.t. proton charge + zeds::mk_float # array containing the initial line-averaged temperature for this species initial_temperature::mk_float # array containing the initial line-averaged density for this species initial_density::mk_float # struct containing the initial condition info in z for this species - z_IC::initial_condition_input + z_IC::spatial_initial_condition_input # struct containing the initial condition info in r for this species - r_IC::initial_condition_input + r_IC::spatial_initial_condition_input # struct containing the initial condition info in vpa for this species - vpa_IC::initial_condition_input + vpa_IC::velocity_initial_condition_input end """ """ -mutable struct species_composition +Base.@kwdef struct neutral_species_parameters + # type is the type of species + type::String + # mass/reference mass + mass::mk_float + # array containing the initial line-averaged temperature for this species + initial_temperature::mk_float + # array containing the initial line-averaged density for this species + initial_density::mk_float + # struct containing the initial condition info in z for this species + z_IC::spatial_initial_condition_input + # struct containing the initial condition info in r for this species + r_IC::spatial_initial_condition_input + # struct containing the initial condition info in vpa for this species + vpa_IC::velocity_initial_condition_input +end + +""" +""" +Base.@kwdef struct species_composition # n_species = total number of evolved species (including ions, neutrals and electrons) + # a diagnostic, not an input parameter n_species::mk_int # n_ion_species is the number of evolved ion species n_ion_species::mk_int @@ -344,7 +389,6 @@ mutable struct species_composition T_wall::mk_float # wall potential used if electron_physics=boltzmann_electron_response_with_simple_sheath phi_wall::mk_float - # constant for testing nonzero Er # ratio of the neutral particle mass to the ion mass mn_over_mi::mk_float # ratio of the electron particle mass to the ion mass @@ -356,8 +400,10 @@ mutable struct species_composition # gyrokinetic_ions = true -> use gyroaveraged fields at fixed guiding centre and moments of the pdf computed at fixed r # gyrokinetic_ions = false -> use drift kinetic approximation gyrokinetic_ions::Bool - # scratch buffer whose size is n_species - scratch::Vector{mk_float} + # array of structs of parameters for each ion species + ion::Vector{ion_species_parameters} + # array of structs of parameters for each neutral species + neutral::Vector{neutral_species_parameters} end """ @@ -841,17 +887,6 @@ function get(d::Dict, key, default::Enum) end end -""" -Convert some types used by moment_kinetics to types that are supported by TOML -""" -function mk_to_toml(value) - if isa(value, Enum) - return string(value) - else - return value - end -end - """ Set the defaults for options in the top level of the input, and check that there are not any unexpected options (i.e. options that have no default). @@ -921,9 +956,11 @@ function set_defaults_and_check_section!(options::AbstractDict, section_name; end # Set default values if a key was not set explicitly - for (key_sym, value) ∈ kwargs + for (key_sym, default_value) ∈ kwargs key = String(key_sym) - section[key] = get(section, key, value) + # Use `Base.get()` here to take advantage of our `Enum`-handling method of + # `Base.get()` defined above. + section[key] = get(section, key, default_value) end return section @@ -938,4 +975,76 @@ function Dict_to_NamedTuple(d) return NamedTuple(Symbol(k)=>v for (k,v) ∈ d) end +""" +Dict merge function for named keyword arguments +for case when input Dict is a mixed Dict of Dicts +and non-Dict float/int/string entries, and the +keyword arguments are also a mix of Dicts and non-Dicts +""" + +function merge_dict_with_kwargs!(dict_base; args...) + for (k,v) in args + k = String(k) + if k in keys(dict_base) && isa(v, AbstractDict) + v = merge(dict_base[k], v) + end + dict_base[k] = v + end + return nothing +end + +""" +Dict merge function for merging Dicts of Dicts +In place merge, returns nothing +""" + +function merge_dict_of_dicts!(dict_base, dict_mod) + for (k,v) in dict_mod + k = String(k) + if k in keys(dict_base) && isa(v, AbstractDict) + v = merge(dict_base[k], v) + end + dict_base[k] = v + end + return nothing +end + +""" +Dict merge function for merging Dicts of Dicts +Creates new dict, which is returned +""" + +function merge_dict_of_dicts(dict_base, dict_mod) + dict_new = deepcopy(dict_base) + for (k,v) in dict_mod + k = String(k) + if k in keys(dict_new) && isa(v, AbstractDict) + v = merge(dict_new[k], v) + end + dict_new[k] = v + end + return dict_new +end + +""" + options_to_toml(io::IO [=stdout], data::AbstractDict; sorted=false, by=identity) + +Convert `moment_kinetics` 'options' (in the form of a `Dict`) to TOML format. + +This function is defined so that we can handle some extra types, for example `Enum`. + +For descriptions of the arguments, see `TOML.print`. +""" +function options_to_TOML(args...; kwargs...) + function handle_extra_types(x) + if isa(x, Enum) + return string(x) + else + error("Unhandled type $(typeof(x)) for x=$x") + end + end + + return TOML.print(handle_extra_types, args...; kwargs...) +end + end diff --git a/moment_kinetics/src/krook_collisions.jl b/moment_kinetics/src/krook_collisions.jl index c113f0bca..3fb386961 100644 --- a/moment_kinetics/src/krook_collisions.jl +++ b/moment_kinetics/src/krook_collisions.jl @@ -10,6 +10,7 @@ using ..input_structs: krook_collisions_input, set_defaults_and_check_section! using ..reference_parameters: get_reference_collision_frequency_ii, get_reference_collision_frequency_ee, get_reference_collision_frequency_ei +using ..reference_parameters: setup_reference_parameters """ @@ -21,7 +22,8 @@ use_krook = true nuii0 = 1.0 frequency_option = "manual" """ -function setup_krook_collisions_input(toml_input::Dict, reference_params) +function setup_krook_collisions_input(toml_input::Dict) + reference_params = setup_reference_parameters(toml_input) # get reference collision frequency nuii_krook_default = get_reference_collision_frequency_ii(reference_params) nuee_krook_default = get_reference_collision_frequency_ee(reference_params) diff --git a/moment_kinetics/src/load_data.jl b/moment_kinetics/src/load_data.jl index c2e6a53e7..99c260372 100644 --- a/moment_kinetics/src/load_data.jl +++ b/moment_kinetics/src/load_data.jl @@ -30,7 +30,7 @@ using ..looping using ..moment_kinetics_input: mk_input using ..neutral_vz_advection: update_speed_neutral_vz! using ..neutral_z_advection: update_speed_neutral_z! -using ..type_definitions: mk_float, mk_int +using ..type_definitions: mk_float, mk_int, OptionsDict using ..utils: get_CFL!, get_minimum_CFL_z, get_minimum_CFL_vpa, get_minimum_CFL_neutral_z, get_minimum_CFL_neutral_vz, enum_from_string using ..vpa_advection: update_speed_vpa! @@ -189,7 +189,7 @@ function read_Dict_from_section(file_or_group, section_name; ignore_subsections= # Function that can be called recursively to read nested Dicts from sub-groups in # the output file section_io = get_group(file_or_group, section_name) - section = Dict{String,Any}() + section = OptionsDict() for key ∈ get_variable_keys(section_io) section[key] = load_variable(section_io, key) diff --git a/moment_kinetics/src/maxwell_diffusion.jl b/moment_kinetics/src/maxwell_diffusion.jl index 03b4daa96..124e43176 100644 --- a/moment_kinetics/src/maxwell_diffusion.jl +++ b/moment_kinetics/src/maxwell_diffusion.jl @@ -18,7 +18,7 @@ export setup_mxwl_diff_collisions_input, ion_vpa_maxwell_diffusion!, neutral_vz_ using ..looping using ..input_structs: mxwl_diff_collisions_input, set_defaults_and_check_section! using ..calculus: second_derivative! -using ..reference_parameters: get_reference_collision_frequency_ii +using ..reference_parameters: get_reference_collision_frequency_ii, setup_reference_parameters """ Function for reading Maxwell diffusion operator input parameters. @@ -29,7 +29,8 @@ use_maxwell_diffusion = true D_ii = 1.0 diffusion_coefficient_option = "manual" """ -function setup_mxwl_diff_collisions_input(toml_input::Dict, reference_params) +function setup_mxwl_diff_collisions_input(toml_input::Dict) + reference_params = setup_reference_parameters(toml_input) # get reference diffusion coefficient, made up of collision frequency and # thermal speed for now. NOTE THAT THIS CONSTANT PRODUCES ERRORS. DO NOT USE D_ii_mxwl_diff_default = get_reference_collision_frequency_ii(reference_params)# * @@ -256,4 +257,4 @@ function neutral_vz_maxwell_diffusion!(f_out, f_in, moments, vzeta, vr, vz, spec return nothing end -end # maxwell_diffusion \ No newline at end of file +end # maxwell_diffusion diff --git a/moment_kinetics/src/moment_kinetics.jl b/moment_kinetics/src/moment_kinetics.jl index 3712ba994..4c57e6ed8 100644 --- a/moment_kinetics/src/moment_kinetics.jl +++ b/moment_kinetics/src/moment_kinetics.jl @@ -68,6 +68,7 @@ include("energy_equation.jl") include("force_balance.jl") include("source_terms.jl") include("numerical_dissipation.jl") +include("species_input.jl") include("moment_kinetics_input.jl") include("utils.jl") include("load_data.jl") diff --git a/moment_kinetics/src/moment_kinetics_input.jl b/moment_kinetics/src/moment_kinetics_input.jl index 12e0a879f..99459663c 100644 --- a/moment_kinetics/src/moment_kinetics_input.jl +++ b/moment_kinetics/src/moment_kinetics_input.jl @@ -6,9 +6,8 @@ export mk_input export performance_test #export advective_form export read_input_file -export get_default_rhostar -using ..type_definitions: mk_float, mk_int +using ..type_definitions: mk_float, mk_int, OptionsDict using ..array_allocation: allocate_float using ..communication using ..coordinates: define_coordinate @@ -22,7 +21,7 @@ using ..input_structs using ..numerical_dissipation: setup_numerical_dissipation using ..reference_parameters using ..geo: init_magnetic_geometry, setup_geometry_input - +using ..species_input: get_species_input using MPI using TOML using UUIDs @@ -54,7 +53,11 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) # Check for input options that used to exist, but do not any more. If these are # present, the user probably needs to update their input file. - removed_options_list = ("Bzed", "Bmag", "rhostar", "geometry_option", "pitch", "DeltaB") + removed_options_list = ("Bzed", "Bmag", "rhostar", "geometry_option", "pitch", "DeltaB", + "n_ion_species","n_neutral_species","recycling_fraction","gyrokinetic_ions","T_e","T_wall", + "z_IC_option1","z_IC_option2","vpa_IC_option1","vpa_IC_option2", + "boltzmann_electron_response","boltzmann_electron_response_with_simple_sheath", + "electron_physics","nstep","dt") for opt in removed_options_list if opt ∈ keys(scan_input) error("Option '$opt' is no longer used. Please update your input file. You " @@ -62,22 +65,14 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) * "removed ones.") end end - - # n_ion_species is the number of evolved ion species - # currently only n_ion_species = 1 is supported - n_ion_species = get(scan_input, "n_ion_species", 1) - # n_neutral_species is the number of evolved neutral species - # currently only n_neutral_species = 0,1 is supported - n_neutral_species = get(scan_input, "n_neutral_species", 1) - # * if electron_physics=boltzmann_electron_response, then the electron density is - # fixed to be N_e*(eϕ/T_e) - # * if electron_physics=boltzmann_electron_response_with_simple_sheath, then the - # electron density is fixed to be N_e*(eϕ/T_e) and N_e is calculated w.r.t a - # reference value using J_||e + J_||i = 0 at z = 0 - electron_physics = get(scan_input, "electron_physics", boltzmann_electron_response) - z, r, vpa, vperp, gyrophase, vz, vr, vzeta, species, composition, drive, evolve_moments = - load_defaults(n_ion_species, n_neutral_species, electron_physics) + # read composition and species data + composition = get_species_input(scan_input) + n_ion_species = composition.n_ion_species + n_neutral_species = composition.n_neutral_species + + z, r, vpa, vperp, gyrophase, vz, vr, vzeta, drive, evolve_moments = + load_defaults() # this is the prefix for all output files associated with this run run_name = get(scan_input, "run_name", "wallBC") @@ -92,111 +87,25 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) evolve_moments.parallel_pressure = get(scan_input, "evolve_moments_parallel_pressure", false) evolve_moments.conservation = get(scan_input, "evolve_moments_conservation", false) - ####### specify any deviations from default inputs for evolved species ####### - # set initial Tₑ = 1 - composition.T_e = get(scan_input, "T_e", 1.0) - # set wall temperature T_wall = Tw/Te - composition.T_wall = get(scan_input, "T_wall", 1.0) - # set initial neutral temperature Tn/Tₑ = 1 - # set initial nᵢ/Nₑ = 1.0 - # set phi_wall at z = 0 - composition.phi_wall = get(scan_input, "phi_wall", 0.0) - # if false use true Knudsen cosine for neutral wall bc - composition.use_test_neutral_wall_pdf = get(scan_input, "use_test_neutral_wall_pdf", false) - # constant to be used to test nonzero Er in wall boundary condition - #composition.Er_constant = get(scan_input, "Er_constant", 0.0) - # The ion flux reaching the wall that is recycled as neutrals is reduced by - # `recycling_fraction` to account for ions absorbed by the wall. - composition.recycling_fraction = get(scan_input, "recycling_fraction", 1.0) - if !(0.0 <= composition.recycling_fraction <= 1.0) - error("recycling_fraction must be between 0 and 1. Got $recycling_fraction.") - end - # gyrokinetic_ions = True -> use gyroaveraged fields at fixed guiding centre and moments of the pdf computed at fixed r - # gyrokinetic_ions = False -> use drift kinetic approximation - composition.gyrokinetic_ions = get(scan_input, "gyrokinetic_ions", false) - # Reference parameters that define the conversion between physical quantities and # normalised values used in the code. reference_params = setup_reference_parameters(scan_input) - - # Set me_over_mi here so we can use reference_params - composition.me_over_mi = reference_params.me / reference_params.mref - + ## set geometry_input - geometry_in = setup_geometry_input(scan_input, get_default_rhostar(reference_params)) + geometry_in = setup_geometry_input(scan_input) - ispecies = 1 - species.ion[1].z_IC.initialization_option = get(scan_input, "z_IC_option$ispecies", "gaussian") - species.ion[1].initial_density = get(scan_input, "initial_density$ispecies", 1.0) - species.ion[1].initial_temperature = get(scan_input, "initial_temperature$ispecies", 1.0) - species.ion[1].z_IC.width = get(scan_input, "z_IC_width$ispecies", 0.125) - species.ion[1].z_IC.wavenumber = get(scan_input, "z_IC_wavenumber$ispecies", 1) - species.ion[1].z_IC.density_amplitude = get(scan_input, "z_IC_density_amplitude$ispecies", 0.001) - species.ion[1].z_IC.density_phase = get(scan_input, "z_IC_density_phase$ispecies", 0.0) - species.ion[1].z_IC.upar_amplitude = get(scan_input, "z_IC_upar_amplitude$ispecies", 0.0) - species.ion[1].z_IC.upar_phase = get(scan_input, "z_IC_upar_phase$ispecies", 0.0) - species.ion[1].z_IC.temperature_amplitude = get(scan_input, "z_IC_temperature_amplitude$ispecies", 0.0) - species.ion[1].z_IC.temperature_phase = get(scan_input, "z_IC_temperature_phase$ispecies", 0.0) - species.ion[1].r_IC.initialization_option = get(scan_input, "r_IC_option$ispecies", "gaussian") - species.ion[1].r_IC.wavenumber = get(scan_input, "r_IC_wavenumber$ispecies", 1) - species.ion[1].r_IC.density_amplitude = get(scan_input, "r_IC_density_amplitude$ispecies", 0.0) - species.ion[1].r_IC.density_phase = get(scan_input, "r_IC_density_phase$ispecies", 0.0) - species.ion[1].r_IC.upar_amplitude = get(scan_input, "r_IC_upar_amplitude$ispecies", 0.0) - species.ion[1].r_IC.upar_phase = get(scan_input, "r_IC_upar_phase$ispecies", 0.0) - species.ion[1].r_IC.temperature_amplitude = get(scan_input, "r_IC_temperature_amplitude$ispecies", 0.0) - species.ion[1].r_IC.temperature_phase = get(scan_input, "r_IC_temperature_phase$ispecies", 0.0) - species.ion[1].vpa_IC.initialization_option = get(scan_input, "vpa_IC_option$ispecies", "gaussian") - species.ion[1].vpa_IC.density_amplitude = get(scan_input, "vpa_IC_density_amplitude$ispecies", 1.000) - species.ion[1].vpa_IC.width = get(scan_input, "vpa_IC_width$ispecies", 1.0) - species.ion[1].vpa_IC.density_phase = get(scan_input, "vpa_IC_density_phase$ispecies", 0.0) - species.ion[1].vpa_IC.upar_amplitude = get(scan_input, "vpa_IC_upar_amplitude$ispecies", 0.0) - species.ion[1].vpa_IC.upar_phase = get(scan_input, "vpa_IC_upar_phase$ispecies", 0.0) - species.ion[1].vpa_IC.temperature_amplitude = get(scan_input, "vpa_IC_temperature_amplitude$ispecies", 0.0) - species.ion[1].vpa_IC.temperature_phase = get(scan_input, "vpa_IC_temperature_phase$ispecies", 0.0) - ispecies += 1 - if n_neutral_species > 0 - species.neutral[1].z_IC.initialization_option = get(scan_input, "z_IC_option$ispecies", "gaussian") - species.neutral[1].initial_density = get(scan_input, "initial_density$ispecies", 1.0) - species.neutral[1].initial_temperature = get(scan_input, "initial_temperature$ispecies", 1.0) - species.neutral[1].z_IC.width = get(scan_input, "z_IC_width$ispecies", species.ion[1].z_IC.width) - species.neutral[1].z_IC.density_amplitude = get(scan_input, "z_IC_density_amplitude$ispecies", 0.001) - species.neutral[1].z_IC.density_phase = get(scan_input, "z_IC_density_phase$ispecies", 0.0) - species.neutral[1].z_IC.upar_amplitude = get(scan_input, "z_IC_upar_amplitude$ispecies", 0.0) - species.neutral[1].z_IC.upar_phase = get(scan_input, "z_IC_upar_phase$ispecies", 0.0) - species.neutral[1].z_IC.temperature_amplitude = get(scan_input, "z_IC_temperature_amplitude$ispecies", 0.0) - species.neutral[1].z_IC.temperature_phase = get(scan_input, "z_IC_temperature_phase$ispecies", 0.0) - species.neutral[1].r_IC.initialization_option = get(scan_input, "r_IC_option$ispecies", "gaussian") - species.neutral[1].r_IC.density_amplitude = get(scan_input, "r_IC_density_amplitude$ispecies", 0.001) - species.neutral[1].r_IC.density_phase = get(scan_input, "r_IC_density_phase$ispecies", 0.0) - species.neutral[1].r_IC.upar_amplitude = get(scan_input, "r_IC_upar_amplitude$ispecies", 0.0) - species.neutral[1].r_IC.upar_phase = get(scan_input, "r_IC_upar_phase$ispecies", 0.0) - species.neutral[1].r_IC.temperature_amplitude = get(scan_input, "r_IC_temperature_amplitude$ispecies", 0.0) - species.neutral[1].r_IC.temperature_phase = get(scan_input, "r_IC_temperature_phase$ispecies", 0.0) - species.neutral[1].vpa_IC.initialization_option = get(scan_input, "vpa_IC_option$ispecies", "gaussian") - species.neutral[1].vpa_IC.density_amplitude = get(scan_input, "vpa_IC_density_amplitude$ispecies", 1.000) - species.neutral[1].vpa_IC.width = get(scan_input, "vpa_IC_width$ispecies", species.ion[1].vpa_IC.width) - species.neutral[1].vpa_IC.density_phase = get(scan_input, "vpa_IC_density_phase$ispecies", 0.0) - species.neutral[1].vpa_IC.upar_amplitude = get(scan_input, "vpa_IC_upar_amplitude$ispecies", 0.0) - species.neutral[1].vpa_IC.upar_phase = get(scan_input, "vpa_IC_upar_phase$ispecies", 0.0) - species.neutral[1].vpa_IC.temperature_amplitude = get(scan_input, "vpa_IC_temperature_amplitude$ispecies", 0.0) - species.neutral[1].vpa_IC.temperature_phase = get(scan_input, "vpa_IC_temperature_phase$ispecies", 0.0) - ispecies += 1 - end - #################### end specification of species inputs ##################### - - # Build the main collisions struct using scan_input and reference parameters - charge_exchange = get(scan_input, "charge_exchange_frequency", 2.0*sqrt(species.ion[1].initial_temperature)) + charge_exchange = get(scan_input, "charge_exchange_frequency", 2.0*sqrt(composition.ion[1].initial_temperature)) charge_exchange_electron = get(scan_input, "electron_charge_exchange_frequency", 0.0) ionization = get(scan_input, "ionization_frequency", charge_exchange) ionization_electron = get(scan_input, "electron_ionization_frequency", ionization) ionization_energy = get(scan_input, "ionization_energy", 0.0) nu_ei = get(scan_input, "nu_ei", 0.0) # set up krook collision inputs - krook_input = setup_krook_collisions_input(scan_input, reference_params) + krook_input = setup_krook_collisions_input(scan_input) # set up Fokker-Planck collision inputs - fkpl_input = setup_fkpl_collisions_input(scan_input, reference_params) + fkpl_input = setup_fkpl_collisions_input(scan_input) # set up maxwell diffusion collision inputs - mxwl_diff_input = setup_mxwl_diff_collisions_input(scan_input, reference_params) + mxwl_diff_input = setup_mxwl_diff_collisions_input(scan_input) # write total collision struct using the structs above, as each setup function # for the collisions outputs itself a struct of the type of collision, which # is a substruct of the overall collisions_input struct. @@ -208,7 +117,7 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) timestepping_section = set_defaults_and_check_section!( scan_input, "timestepping"; nstep=5, - dt=0.00025/sqrt(species.ion[1].initial_temperature), + dt=0.00025/sqrt(composition.ion[1].initial_temperature), CFL_prefactor=-1.0, nwrite=1, nwrite_dfns=nothing, @@ -448,7 +357,7 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) # do not parallelise vpa with distributed-memory MPI vpa.nelement_local = vpa.nelement_global # L is the box length in units of vthermal_species - vpa.L = get(scan_input, "vpa_L", 8.0*sqrt(species.ion[1].initial_temperature)) + vpa.L = get(scan_input, "vpa_L", 8.0*sqrt(composition.ion[1].initial_temperature)) # determine the boundary condition # only supported option at present is "zero" and "periodic" vpa.bc = get(scan_input, "vpa_bc", "periodic") @@ -466,7 +375,7 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) # do not parallelise vperp with distributed-memory MPI vperp.nelement_local = vperp.nelement_global # L is the box length in units of vthermal_species - vperp.L = get(scan_input, "vperp_L", 8.0*sqrt(species.ion[1].initial_temperature)) + vperp.L = get(scan_input, "vperp_L", 8.0*sqrt(composition.ion[1].initial_temperature)) # Note vperp.bc is set below, after numerical dissipation is initialized, so that it # can use the numerical dissipation settings to set its default value. # @@ -510,7 +419,7 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) # do not parallelise vz with distributed-memory MPI vr.nelement_local = vr.nelement_global # L is the box length in units of vthermal_species - vr.L = get(scan_input, "vr_L", 8.0*sqrt(species.ion[1].initial_temperature)) + vr.L = get(scan_input, "vr_L", 8.0*sqrt(composition.ion[1].initial_temperature)) # determine the boundary condition # only supported option at present is "zero" and "periodic" vr.bc = get(scan_input, "vr_bc", "none") @@ -527,7 +436,7 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) # do not parallelise vz with distributed-memory MPI vzeta.nelement_local = vzeta.nelement_global # L is the box length in units of vthermal_species - vzeta.L = get(scan_input, "vzeta_L", 8.0*sqrt(species.ion[1].initial_temperature)) + vzeta.L = get(scan_input, "vzeta_L", 8.0*sqrt(composition.ion[1].initial_temperature)) # determine the boundary condition # only supported option at present is "zero" and "periodic" vzeta.bc = get(scan_input, "vzeta_bc", "none") @@ -540,9 +449,9 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) is_1V = (vperp.ngrid == vperp.nelement_global == 1 && vzeta.ngrid == vzeta.nelement_global == 1 && vr.ngrid == vr.nelement_global == 1) - ion_num_diss_param_dict = get(scan_input, "ion_numerical_dissipation", Dict{String,Any}()) - electron_num_diss_param_dict = get(scan_input, "electron_numerical_dissipation", Dict{String,Any}()) - neutral_num_diss_param_dict = get(scan_input, "neutral_numerical_dissipation", Dict{String,Any}()) + ion_num_diss_param_dict = get(scan_input, "ion_numerical_dissipation", OptionsDict()) + electron_num_diss_param_dict = get(scan_input, "electron_numerical_dissipation", OptionsDict()) + neutral_num_diss_param_dict = get(scan_input, "neutral_numerical_dissipation", OptionsDict()) num_diss_params = setup_numerical_dissipation(ion_num_diss_param_dict, electron_num_diss_param_dict, neutral_num_diss_param_dict, is_1V) @@ -627,89 +536,6 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) vzeta_immutable = grid_input("vzeta", vzeta.ngrid, vzeta.nelement_global, vzeta.nelement_local, 1, 0, vzeta.L, vzeta.discretization, vzeta.fd_option, vzeta.cheb_option, vzeta.bc, vzeta_advection_immutable, MPI.COMM_NULL, vzeta.element_spacing_option) - species_ion_immutable = Array{species_parameters,1}(undef,n_ion_species) - species_neutral_immutable = Array{species_parameters,1}(undef,n_neutral_species) - - for is ∈ 1:n_ion_species - species_type = "ion" - # species_type = "electron" - z_IC = initial_condition_input(species.ion[is].z_IC.initialization_option, - species.ion[is].z_IC.width, species.ion[is].z_IC.wavenumber, - species.ion[is].z_IC.density_amplitude, species.ion[is].z_IC.density_phase, - species.ion[is].z_IC.upar_amplitude, species.ion[is].z_IC.upar_phase, - species.ion[is].z_IC.temperature_amplitude, species.ion[is].z_IC.temperature_phase, - species.ion[is].z_IC.monomial_degree, 0.0, 0.0, 0.0, 0.0) - r_IC = initial_condition_input(species.ion[is].r_IC.initialization_option, - species.ion[is].r_IC.width, species.ion[is].r_IC.wavenumber, - species.ion[is].r_IC.density_amplitude, species.ion[is].r_IC.density_phase, - species.ion[is].r_IC.upar_amplitude, species.ion[is].r_IC.upar_phase, - species.ion[is].r_IC.temperature_amplitude, species.ion[is].r_IC.temperature_phase, - species.ion[is].r_IC.monomial_degree, 0.0, 0.0, 0.0, 0.0) - vpa_IC = initial_condition_input(species.ion[is].vpa_IC.initialization_option, - species.ion[is].vpa_IC.width, species.ion[is].vpa_IC.wavenumber, - species.ion[is].vpa_IC.density_amplitude, species.ion[is].vpa_IC.density_phase, - species.ion[is].vpa_IC.upar_amplitude, species.ion[is].vpa_IC.upar_phase, - species.ion[is].vpa_IC.temperature_amplitude, - species.ion[is].vpa_IC.temperature_phase, species.ion[is].vpa_IC.monomial_degree, - get(scan_input, "vpa_IC_v0$is", 0.5*sqrt(vperp.L^2 + (0.5*vpa.L)^2)), - get(scan_input, "vpa_IC_vth0$is", 0.1*sqrt(vperp.L^2 + (0.5*vpa.L)^2)), - get(scan_input, "vpa_IC_vpa0$is", 0.25*0.5*abs(vpa.L)), - get(scan_input, "vpa_IC_vperp0$is", 0.5*abs(vperp.L))) - species_ion_immutable[is] = species_parameters(species_type, species.ion[is].initial_temperature, - species.ion[is].initial_density, z_IC, r_IC, vpa_IC) - end - if n_neutral_species > 0 - for is ∈ 1:n_neutral_species - species_type = "neutral" - z_IC = initial_condition_input(species.neutral[is].z_IC.initialization_option, - species.neutral[is].z_IC.width, species.neutral[is].z_IC.wavenumber, - species.neutral[is].z_IC.density_amplitude, species.neutral[is].z_IC.density_phase, - species.neutral[is].z_IC.upar_amplitude, species.neutral[is].z_IC.upar_phase, - species.neutral[is].z_IC.temperature_amplitude, species.neutral[is].z_IC.temperature_phase, - species.neutral[is].z_IC.monomial_degree, 0.0, 0.0, 0.0, 0.0) - r_IC = initial_condition_input(species.neutral[is].r_IC.initialization_option, - species.neutral[is].r_IC.width, species.neutral[is].r_IC.wavenumber, - species.neutral[is].r_IC.density_amplitude, species.neutral[is].r_IC.density_phase, - species.neutral[is].r_IC.upar_amplitude, species.neutral[is].r_IC.upar_phase, - species.neutral[is].r_IC.temperature_amplitude, species.neutral[is].r_IC.temperature_phase, - species.neutral[is].r_IC.monomial_degree, 0.0, 0.0, 0.0, 0.0) - vpa_IC = initial_condition_input(species.neutral[is].vpa_IC.initialization_option, - species.neutral[is].vpa_IC.width, species.neutral[is].vpa_IC.wavenumber, - species.neutral[is].vpa_IC.density_amplitude, species.neutral[is].vpa_IC.density_phase, - species.neutral[is].vpa_IC.upar_amplitude, species.neutral[is].vpa_IC.upar_phase, - species.neutral[is].vpa_IC.temperature_amplitude, - species.neutral[is].vpa_IC.temperature_phase, species.neutral[is].vpa_IC.monomial_degree, - get(scan_input, "vpa_IC_v0$is", 0.5*sqrt(vperp.L^2 + (0.5*vpa.L)^2)), - get(scan_input, "vpa_IC_vth0$is", 0.1*sqrt(vperp.L^2 + (0.5*vpa.L)^2)), - get(scan_input, "vpa_IC_vpa0$is", 0.25*0.5*abs(vpa.L)), - get(scan_input, "vpa_IC_vperp0$is", 0.5*abs(vperp.L))) - species_neutral_immutable[is] = species_parameters(species_type, species.neutral[is].initial_temperature, - species.neutral[is].initial_density, z_IC, r_IC, vpa_IC) - end - end - z_IC = initial_condition_input(species.electron.z_IC.initialization_option, - species.electron.z_IC.width, species.electron.z_IC.wavenumber, - species.electron.z_IC.density_amplitude, species.electron.z_IC.density_phase, - species.electron.z_IC.upar_amplitude, species.electron.z_IC.upar_phase, - species.electron.z_IC.temperature_amplitude, species.electron.z_IC.temperature_phase, - species.electron.z_IC.monomial_degree, 0.0, 0.0, 0.0, 0.0) - r_IC = initial_condition_input(species.electron.r_IC.initialization_option, - species.electron.r_IC.width, species.electron.r_IC.wavenumber, - species.electron.r_IC.density_amplitude, species.electron.r_IC.density_phase, - species.electron.r_IC.upar_amplitude, species.electron.r_IC.upar_phase, - species.electron.r_IC.temperature_amplitude, species.electron.r_IC.temperature_phase, - species.electron.r_IC.monomial_degree, 0.0, 0.0, 0.0, 0.0) - vpa_IC = initial_condition_input(species.electron.vpa_IC.initialization_option, - species.electron.vpa_IC.width, species.electron.vpa_IC.wavenumber, - species.electron.vpa_IC.density_amplitude, species.electron.vpa_IC.density_phase, - species.electron.vpa_IC.upar_amplitude, species.electron.vpa_IC.upar_phase, - species.electron.vpa_IC.temperature_amplitude, - species.electron.vpa_IC.temperature_phase, - species.electron.vpa_IC.monomial_degree, 0.0, 0.0, 0.0, 0.0) - species_electron_immutable = species_parameters("electron", species.electron.initial_temperature, - species.electron.initial_density, z_IC, r_IC, vpa_IC) - species_immutable = (ion = species_ion_immutable, electron = species_electron_immutable, neutral = species_neutral_immutable) - force_Er_zero = get(scan_input, "force_Er_zero_at_wall", false) drive_immutable = drive_input(drive.force_phi, drive.amplitude, drive.frequency, force_Er_zero) @@ -796,6 +622,8 @@ function mk_input(scan_input=Dict(); save_inputs_to_txt=false, ignore_MPI=true) error("Mirror terms not yet implemented for moment-kinetic modes") end + species_immutable = (ion = composition.ion, neutral = composition.neutral) + # check input (and initialized coordinate structs) to catch errors/unsupported options check_input(io, output_dir, timestepping_section["nstep"], timestepping_section["dt"], r, z, vpa, vperp, composition, species_immutable, evolve_moments, @@ -817,7 +645,7 @@ end """ """ -function load_defaults(n_ion_species, n_neutral_species, electron_physics) +function load_defaults() ############## options related to the equations being solved ############### evolve_density = false evolve_parallel_flow = false @@ -1134,120 +962,6 @@ function load_defaults(n_ion_species, n_neutral_species, electron_physics) vzeta = grid_input_mutable("vzeta", ngrid_vzeta, nelement_vzeta, nelement_vzeta, L_vzeta, discretization_option_vzeta, finite_difference_option_vzeta, cheb_option_vzeta, boundary_option_vzeta, advection_vzeta, element_spacing_option_vzeta) - ############################################################################# - # define default values and create corresponding mutable structs holding - # information about the composition of the species and their initial conditions - if electron_physics ∈ (boltzmann_electron_response, boltzmann_electron_response_with_simple_sheath) - n_species = n_ion_species + n_neutral_species - else - n_species = n_ion_species + n_neutral_species + 1 - end - use_test_neutral_wall_pdf = false - # electron temperature over reference temperature - T_e = 1.0 - # temperature at the entrance to the wall in terms of the electron temperature - T_wall = 1.0 - # wall potential at z = 0 - phi_wall = 0.0 - # ratio of the neutral particle mass to the ion particle mass - mn_over_mi = 1.0 - # ratio of the electron particle mass to the ion particle mass - value set later using - # reference_params - me_over_mi = NaN - # The ion flux reaching the wall that is recycled as neutrals is reduced by - # `recycling_fraction` to account for ions absorbed by the wall. - recycling_fraction = 1.0 - gyrokinetic_ions = false - composition = species_composition(n_species, n_ion_species, n_neutral_species, - electron_physics, use_test_neutral_wall_pdf, T_e, T_wall, phi_wall, - mn_over_mi, me_over_mi, recycling_fraction, gyrokinetic_ions, allocate_float(n_species)) - - species_ion = Array{species_parameters_mutable,1}(undef,n_ion_species) - species_neutral = Array{species_parameters_mutable,1}(undef,n_neutral_species) - - # initial temperature for each species defaults to Tₑ - initial_temperature = 1.0 - # initial density for each species defaults to Nₑ - initial_density = 1.0 - # initialization inputs for z part of distribution function - # supported options are "gaussian", "sinusoid" and "monomial" - z_initialization_option = "sinusoid" - # inputs for "gaussian" initial condition - # width of the Gaussian in z - z_width = 0.125 - # inputs for "sinusoid" initial condition - # z_wavenumber should be an integer - z_wavenumber = 1 - z_density_amplitude = 0.1 - z_density_phase = 0.0 - z_upar_amplitude = 0.0 - z_upar_phase = 0.0 - z_temperature_amplitude = 0.0 - z_temperature_phase = 0.0 - # inputs for "monomial" initial condition - z_monomial_degree = 2 - z_initial_conditions = initial_condition_input_mutable(z_initialization_option, - z_width, z_wavenumber, z_density_amplitude, z_density_phase, z_upar_amplitude, - z_upar_phase, z_temperature_amplitude, z_temperature_phase, z_monomial_degree) - # initialization inputs for r part of distribution function - # supported options are "gaussian", "sinusoid" and "monomial" - r_initialization_option = "sinusoid" - # inputs for "gaussian" initial condition - # width of the Gaussian in r - r_width = 0.125 - # inputs for "sinusoid" initial condition - # r_wavenumber should be an integer - r_wavenumber = 1 - r_density_amplitude = 0.0 - r_density_phase = 0.0 - r_upar_amplitude = 0.0 - r_upar_phase = 0.0 - r_temperature_amplitude = 0.0 - r_temperature_phase = 0.0 - # inputs for "monomial" initial condition - r_monomial_degree = 2 - r_initial_conditions = initial_condition_input_mutable(r_initialization_option, - r_width, r_wavenumber, r_density_amplitude, r_density_phase, r_upar_amplitude, - r_upar_phase, r_temperature_amplitude, r_temperature_phase, r_monomial_degree) - # initialization inputs for vpa part of distribution function - # supported options are "gaussian", "sinusoid" and "monomial" - # inputs for 'gaussian' initial condition - vpa_initialization_option = "gaussian" - # if initializing a Maxwellian, vpa_width = 1.0 for each species - # any temperature-dependence will be self-consistently treated using initial_temperature - vpa_width = 1.0 - # inputs for "sinusoid" initial condition - vpa_wavenumber = 1 - vpa_density_amplitude = 1.0 - vpa_density_phase = 0.0 - vpa_upar_amplitude = 0.0 - vpa_upar_phase = 0.0 - vpa_temperature_amplitude = 0.0 - vpa_temperature_phase = 0.0 - # inputs for "monomial" initial condition - vpa_monomial_degree = 2 - vpa_initial_conditions = initial_condition_input_mutable(vpa_initialization_option, - vpa_width, vpa_wavenumber, vpa_density_amplitude, vpa_density_phase, - vpa_upar_amplitude, vpa_upar_phase, vpa_temperature_amplitude, - vpa_temperature_phase, vpa_monomial_degree) - - # fill in entries in species struct corresponding to ion species - for is ∈ 1:n_ion_species - species_ion[is] = species_parameters_mutable("ion", initial_temperature, initial_density, - deepcopy(z_initial_conditions), deepcopy(r_initial_conditions), - deepcopy(vpa_initial_conditions)) - end - # if there are neutrals, fill in corresponding entries in species struct - if n_neutral_species > 0 - for is ∈ 1:n_neutral_species - species_neutral[is] = species_parameters_mutable("neutral", initial_temperature, - initial_density, deepcopy(z_initial_conditions), - deepcopy(r_initial_conditions), deepcopy(vpa_initial_conditions)) - end - end - species_electron = species_parameters_mutable("electron", T_e, 1.0, deepcopy(z_initial_conditions), - deepcopy(r_initial_conditions), deepcopy(vpa_initial_conditions)) - species = (ion = species_ion, electron = species_electron, neutral = species_neutral) # if drive_phi = true, include external electrostatic potential of form # phi(z,t=0)*drive_amplitude*sinpi(time*drive_frequency) @@ -1256,7 +970,7 @@ function load_defaults(n_ion_species, n_neutral_species, electron_physics) drive_frequency = 1.0 drive = drive_input_mutable(drive_phi, drive_amplitude, drive_frequency) - return z, r, vpa, vperp, gyrophase, vz, vr, vzeta, species, composition, drive, evolve_moments + return z, r, vpa, vperp, gyrophase, vz, vr, vzeta, drive, evolve_moments end """ @@ -1440,13 +1154,4 @@ function check_input_initialization(composition, species, io) end end -""" - function get_default_rhostar(reference_params) - -Calculate the normalised ion gyroradius at reference parameters -""" -function get_default_rhostar(reference_params) - return reference_params.cref / reference_params.Omegaref / reference_params.Lref -end - end diff --git a/moment_kinetics/src/parameter_scans.jl b/moment_kinetics/src/parameter_scans.jl index 62fbc0af9..4cd896e0e 100644 --- a/moment_kinetics/src/parameter_scans.jl +++ b/moment_kinetics/src/parameter_scans.jl @@ -4,10 +4,10 @@ export get_scan_inputs, generate_scan_input_files using ..command_line_options: get_options using ..moment_kinetics_input: read_input_file +using ..input_structs: options_to_TOML using Glob using OrderedCollections: OrderedDict -using TOML """ get_scan_inputs(scan_inputs::AbstractDict) @@ -184,7 +184,7 @@ function generate_scan_input_files(scan_input::AbstractDict, dirname::AbstractSt # The run name will be created from the name of the input file, so do not need # to save "run_name" in the file. pop!(input, "run_name") - TOML.print(io, input) + options_to_TOML(io, input) end end diff --git a/moment_kinetics/src/species_input.jl b/moment_kinetics/src/species_input.jl new file mode 100644 index 000000000..35d8755e0 --- /dev/null +++ b/moment_kinetics/src/species_input.jl @@ -0,0 +1,207 @@ +""" +Module for handling i/o for species specific input parameters +which are hosted in the composition and species structs for passing to functions +""" +module species_input + +export get_species_input + +using ..type_definitions: mk_float, mk_int +using ..input_structs: set_defaults_and_check_section! +using ..input_structs: species_composition, ion_species_parameters, neutral_species_parameters +using ..input_structs: spatial_initial_condition_input, velocity_initial_condition_input +using ..input_structs: boltzmann_electron_response, boltzmann_electron_response_with_simple_sheath +using ..reference_parameters: setup_reference_parameters + +function get_species_input(toml_input) + + reference_params = setup_reference_parameters(toml_input) + + # read general composition parameters + composition_section = set_defaults_and_check_section!(toml_input, "composition", + # n_ion_species is the number of evolved ion species + n_ion_species = 1, + # n_neutral_species is the number of evolved neutral species + n_neutral_species = 1, + # * if electron_physics=boltzmann_electron_response, then the electron density is + # fixed to be N_e*(eϕ/T_e) + # * if electron_physics=boltzmann_electron_response_with_simple_sheath, then the + # electron density is fixed to be N_e*(eϕ/T_e) and N_e is calculated w.r.t a + # reference value using J_||e + J_||i = 0 at z = 0 + electron_physics = boltzmann_electron_response, + # initial Tₑ = 1 + T_e = 1.0, + # wall temperature T_wall = Tw/Te + T_wall = 1.0, + # phi_wall at z = -L/2 + phi_wall = 0.0, + # ratio of the neutral particle mass to the ion mass + mn_over_mi = 1.0, + # ratio of the electron particle mass to the ion mass + me_over_mi = reference_params.me / reference_params.mref, + # if false use true Knudsen cosine for neutral wall bc + use_test_neutral_wall_pdf = false, + # The ion flux reaching the wall that is recycled as neutrals is reduced by + # `recycling_fraction` to account for ions absorbed by the wall. + recycling_fraction = 1.0, + # gyrokinetic_ions = True -> use gyroaveraged fields at fixed guiding centre and moments of the pdf computed at fixed r + # gyrokinetic_ions = False -> use drift kinetic approximation + gyrokinetic_ions = false) + + nspec_ion = composition_section["n_ion_species"] + nspec_neutral = composition_section["n_neutral_species"] + nspec_tot = nspec_ion + nspec_neutral + + # read individual species parameters + ion_spec_params_list = Array{ion_species_parameters,1}(undef,nspec_ion) + neutral_spec_params_list = Array{neutral_species_parameters,1}(undef,nspec_neutral) + for is in 1:nspec_ion + spec_section = set_defaults_and_check_section!(toml_input, "ion_species_$is", + # [ion_species_1], [ion_species_2], etc + # mass of ion species + mass = 1.0, + # charge number + zeds = 1.0, + # initial density + initial_density = 1.0, + # initial temperature + initial_temperature = 1.0) + + z_IC_section = set_defaults_and_check_section!(toml_input, "z_IC_ion_species_$is", + # [ion_z_IC_species_1], [ion_z_IC_species_2], etc + initialization_option = "gaussian", + width = 0.125, + wavenumber = 1, + density_amplitude = 0.001, + density_phase = 0.0, + upar_amplitude = 0.0, + upar_phase = 0.0, + temperature_amplitude = 0.0, + temperature_phase = 0.0, + monomial_degree = 2) + z_IC_input = Dict(Symbol(k)=>v for (k,v) in z_IC_section) + z_IC = spatial_initial_condition_input(; z_IC_input...) + + r_IC_section = set_defaults_and_check_section!(toml_input, "r_IC_ion_species_$is", + # [ion_r_IC_species_1], [ion_r_IC_species_2], etc + initialization_option = "gaussian", + width = 0.125, + wavenumber = 1, + density_amplitude = 0.001, + density_phase = 0.0, + upar_amplitude = 0.0, + upar_phase = 0.0, + temperature_amplitude = 0.0, + temperature_phase = 0.0, + monomial_degree = 2) + r_IC_input= Dict(Symbol(k)=>v for (k,v) in r_IC_section) + r_IC = spatial_initial_condition_input(; r_IC_input...) + + vpa_IC_section = set_defaults_and_check_section!(toml_input, "vpa_IC_ion_species_$is", + # [ion_vpa_IC_species_1], [ion_vpa_IC_species_2], etc + initialization_option = "gaussian", + width = 1.0, + wavenumber = 1, + density_amplitude = 1.0, + density_phase = 0.0, + upar_amplitude = 0.0, + upar_phase = 0.0, + temperature_amplitude = 0.0, + temperature_phase = 0.0, + monomial_degree = 2, + # need to read resolutions before setting defaults here + v0 = 1.0, + vth0 = 1.0, + vpa0 = 1.0, + vperp0 = 1.0) + vpa_IC_input= Dict(Symbol(k)=>v for (k,v) in vpa_IC_section) + vpa_IC = velocity_initial_condition_input(; vpa_IC_input...) + + IC_input = Dict("z_IC" => z_IC, "r_IC" => r_IC, "vpa_IC" => vpa_IC) + type_input = Dict("type" => "ion") + spec_section = merge(spec_section, IC_input, type_input) + spec_input = Dict(Symbol(k)=>v for (k,v) in spec_section) + ion_spec_params_list[is] = ion_species_parameters(; spec_input...) + end + for isn in 1:nspec_neutral + spec_section = set_defaults_and_check_section!(toml_input, "neutral_species_$isn", + # [neutral_species_1], [neutral_species_2], etc + # mass of neutral species + mass = 1.0, + # initial density + initial_density = 1.0, + # initial temperature + initial_temperature = 1.0) + + z_IC_section = set_defaults_and_check_section!(toml_input, "z_IC_neutral_species_$isn", + # [neutral_z_IC_species_1], [neutral_z_IC_species_2], etc + initialization_option = "gaussian", + width = 0.125, + wavenumber = 1, + density_amplitude = 0.001, + density_phase = 0.0, + upar_amplitude = 0.0, + upar_phase = 0.0, + temperature_amplitude = 0.0, + temperature_phase = 0.0, + monomial_degree = 2) + z_IC_input = Dict(Symbol(k)=>v for (k,v) in z_IC_section) + z_IC = spatial_initial_condition_input(; z_IC_input...) + + r_IC_section = set_defaults_and_check_section!(toml_input, "r_IC_neutral_species_$isn", + # [neutral_r_IC_species_1], [neutral_r_IC_species_2], etc + initialization_option = "gaussian", + width = 0.125, + wavenumber = 1, + density_amplitude = 0.001, + density_phase = 0.0, + upar_amplitude = 0.0, + upar_phase = 0.0, + temperature_amplitude = 0.0, + temperature_phase = 0.0, + monomial_degree = 2) + r_IC_input= Dict(Symbol(k)=>v for (k,v) in r_IC_section) + r_IC = spatial_initial_condition_input(; r_IC_input...) + + vpa_IC_section = set_defaults_and_check_section!(toml_input, "vz_IC_neutral_species_$isn", + # [neutral_vpa_IC_species_1], [neutral_vpa_IC_species_2], etc + initialization_option = "gaussian", + width = 1.0, + wavenumber = 1, + density_amplitude = 1.0, + density_phase = 0.0, + upar_amplitude = 0.0, + upar_phase = 0.0, + temperature_amplitude = 0.0, + temperature_phase = 0.0, + monomial_degree = 2, + # need to read resolutions before setting defaults here + v0 = 1.0, + vth0 = 1.0, + vpa0 = 1.0, + vperp0 = 1.0) + vpa_IC_input= Dict(Symbol(k)=>v for (k,v) in vpa_IC_section) + vpa_IC = velocity_initial_condition_input(; vpa_IC_input...) + + IC_input = Dict("z_IC" => z_IC, "r_IC" => r_IC, "vpa_IC" => vpa_IC) + type_input = Dict("type" => "neutral") + spec_section = merge(spec_section, IC_input, type_input) + spec_input = Dict(Symbol(k)=>v for (k,v) in spec_section) + neutral_spec_params_list[isn] = neutral_species_parameters(; spec_input...) + end + # construct composition dict + species_dict = Dict("n_species" => nspec_tot, "ion" => ion_spec_params_list, "neutral" => neutral_spec_params_list) + composition_section = merge(composition_section,species_dict) + input = Dict(Symbol(k)=>v for (k,v) in composition_section) + # construct composition struct + composition = species_composition(; input...) + + ## checks and errors + if !(0.0 <= composition.recycling_fraction <= 1.0) + error("recycling_fraction must be between 0 and 1. Got $recycling_fraction.") + end + + return composition +end + +end diff --git a/moment_kinetics/src/type_definitions.jl b/moment_kinetics/src/type_definitions.jl index d0a6f6943..e53fea73d 100644 --- a/moment_kinetics/src/type_definitions.jl +++ b/moment_kinetics/src/type_definitions.jl @@ -4,6 +4,7 @@ module type_definitions export mk_float export mk_int +export OptionsDict """ """ @@ -13,4 +14,8 @@ const mk_float = Float64 """ const mk_int = Int64 +""" +""" +const OptionsDict = Dict{String,Any} + end diff --git a/moment_kinetics/test/Krook_collisions_tests.jl b/moment_kinetics/test/Krook_collisions_tests.jl index 9bb7197bf..806bad279 100644 --- a/moment_kinetics/test/Krook_collisions_tests.jl +++ b/moment_kinetics/test/Krook_collisions_tests.jl @@ -7,14 +7,14 @@ include("setup.jl") using Base.Filesystem: tempname using moment_kinetics.coordinates: define_coordinate -using moment_kinetics.input_structs: grid_input, advection_input +using moment_kinetics.input_structs: grid_input, advection_input, merge_dict_with_kwargs! using moment_kinetics.load_data: open_readonly_output_file, load_coordinate_data, load_species_data, load_fields_data, load_ion_moments_data, load_pdf_data, load_neutral_particle_moments_data, load_neutral_pdf_data, load_time_data, load_species_data using moment_kinetics.interpolation: interpolate_to_grid_z, interpolate_to_grid_vpa -using moment_kinetics.type_definitions: mk_float +using moment_kinetics.type_definitions: mk_float, OptionsDict # Useful parameters const z_L = 1.0 # always 1 in normalized units? @@ -85,37 +85,38 @@ const expected = 0.024284888662941113 0.010011392733734206 0.008423252360063494 0.019281192435730943 0.036719507768509525 0.041644492169994836 0.03692283098105331 0.03638215764882269 0.04191389118981368 0.04071460358290303 0.024284888662941134]) # default inputs for tests -test_input_full_f = Dict("n_ion_species" => 1, - "n_neutral_species" => 1, - "boltzmann_electron_response" => true, +test_input_full_f = Dict("composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 1, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0, + "T_wall" => 1.0), + "ion_species_1" => OptionsDict("initial_density" => 0.5, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "sinusoid", + "density_amplitude" => 0.5, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.5, + "temperature_phase" => mk_float(π)), + "neutral_species_1" => OptionsDict("initial_density" => 0.5, + "initial_temperature" => 1.0), + "z_IC_neutral_species_1" => OptionsDict("initialization_option" => "sinusoid", + "density_amplitude" => 0.5, + "density_phase" => mk_float(π), + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.5, + "temperature_phase" => 0.0), "run_name" => "full_f", "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => true, - "krook_collisions" => Dict{String,Any}("use_krook" => true,"frequency_option" => "reference_parameters"), - "T_e" => 1.0, - "initial_density1" => 0.5, - "initial_temperature1" => 1.0, - "initial_density2" => 0.5, - "initial_temperature2" => 1.0, - "z_IC_option1" => "sinusoid", - "z_IC_density_amplitude1" => 0.5, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.5, - "z_IC_temperature_phase1" => mk_float(π), - "z_IC_option2" => "sinusoid", - "z_IC_density_amplitude2" => 0.5, - "z_IC_density_phase2" => mk_float(π), - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.5, - "z_IC_temperature_phase2" => 0.0, + "krook_collisions" => OptionsDict("use_krook" => true,"frequency_option" => "reference_parameters"), "charge_exchange_frequency" => 2*π*0.1, "ionization_frequency" => 0.0, - "timestepping" => Dict{String,Any}("nstep" => 100, + "timestepping" => OptionsDict("nstep" => 100, "dt" => 0.001, "nwrite" => 100, "nwrite_dfns" => 100, @@ -166,10 +167,10 @@ function run_test(test_input, rtol, atol; args...) # Make a copy to make sure nothing modifies the input Dicts defined in this test # script. - test_input = deepcopy(test_input) + input = deepcopy(test_input) # Convert keyword arguments to a unique name - name = test_input["run_name"] + name = input["run_name"] if length(args) > 0 name = string(name, "_", (string(k, "-", v, "_") for (k, v) in args)...) @@ -180,12 +181,8 @@ function run_test(test_input, rtol, atol; args...) # Provide some progress info println(" - testing ", name) - # Convert dict from symbol keys to String keys - modified_inputs = Dict(String(k) => v for (k, v) in args) - # Update default inputs with values to be changed - input = merge(test_input, modified_inputs) - + merge_dict_with_kwargs!(input; args...) input["run_name"] = name # Suppress console output while running diff --git a/moment_kinetics/test/braginskii_electrons_imex_tests.jl b/moment_kinetics/test/braginskii_electrons_imex_tests.jl index f784e0cf2..4bf902b8c 100644 --- a/moment_kinetics/test/braginskii_electrons_imex_tests.jl +++ b/moment_kinetics/test/braginskii_electrons_imex_tests.jl @@ -10,57 +10,58 @@ using Base.Filesystem: tempname using MPI using moment_kinetics.coordinates: define_coordinate -using moment_kinetics.input_structs: grid_input, advection_input +using moment_kinetics.input_structs: grid_input, advection_input, merge_dict_with_kwargs! using moment_kinetics.interpolation: interpolate_to_grid_z using moment_kinetics.load_data: get_run_info_no_setup, close_run_info, get_variable +using moment_kinetics.type_definitions: OptionsDict # default inputs for tests -test_input = Dict("n_ion_species" => 1, - "n_neutral_species" => 1, - "electron_physics" => "braginskii_fluid", +test_input = OptionsDict( "composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 1, + "electron_physics" => "braginskii_fluid", + "T_e" => 0.2), "run_name" => "braginskii-electrons-imex", "evolve_moments_density" => true, "evolve_moments_parallel_flow" => true, "evolve_moments_parallel_pressure" => true, "evolve_moments_conservation" => true, - "T_e" => 0.2, + "ion_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "sinusoid", + "density_amplitude" => 0.1, + "density_phase" => 0.0, + "upar_amplitude" => 1.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.1, + "temperature_phase" => 1.0), + "vpa_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "neutral_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_neutral_species_1" => OptionsDict("initialization_option" => "sinusoid", + "density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_neutral_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), "nu_ei" => 1.0e3, - "initial_density1" => 1.0, - "initial_temperature1" => 1.0, - "z_IC_option1" => "sinusoid", - "z_IC_density_amplitude1" => 0.1, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 1.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.1, - "z_IC_temperature_phase1" => 1.0, - "vpa_IC_option1" => "gaussian", - "vpa_IC_density_amplitude1" => 1.0, - "vpa_IC_density_phase1" => 0.0, - "vpa_IC_upar_amplitude1" => 0.0, - "vpa_IC_upar_phase1" => 0.0, - "vpa_IC_temperature_amplitude1" => 0.0, - "vpa_IC_temperature_phase1" => 0.0, - "initial_density2" => 1.0, - "initial_temperature2" => 1.0, - "z_IC_option2" => "sinusoid", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, - "vpa_IC_option2" => "gaussian", - "vpa_IC_density_amplitude2" => 1.0, - "vpa_IC_density_phase2" => 0.0, - "vpa_IC_upar_amplitude2" => 0.0, - "vpa_IC_upar_phase2" => 0.0, - "vpa_IC_temperature_amplitude2" => 0.0, - "vpa_IC_temperature_phase2" => 0.0, "charge_exchange_frequency" => 0.75, "ionization_frequency" => 0.5, "constant_ionization_rate" => false, - "timestepping" => Dict{String,Any}("type" => "KennedyCarpenterARK324", + "timestepping" => OptionsDict("type" => "KennedyCarpenterARK324", "implicit_ion_advance" => false, "implicit_vpa_advection" => false, "nstep" => 10000, @@ -69,7 +70,7 @@ test_input = Dict("n_ion_species" => 1, "rtol" => 1.0e-7, "nwrite" => 10000, "high_precision_error_sum" => true), - "nonlinear_solver" => Dict{String,Any}("nonlinear_max_iterations" => 100), + "nonlinear_solver" => OptionsDict("nonlinear_max_iterations" => 100), "r_ngrid" => 1, "r_nelement" => 1, "z_ngrid" => 17, @@ -86,9 +87,9 @@ test_input = Dict("n_ion_species" => 1, "vz_L" => 12.0, "vz_bc" => "zero", "vz_discretization" => "chebyshev_pseudospectral", - "ion_numerical_dissipation" => Dict{String,Any}("force_minimum_pdf_value" => 0.0, + "ion_numerical_dissipation" => OptionsDict("force_minimum_pdf_value" => 0.0, "vpa_dissipation_coefficient" => 1e0), - "neutral_numerical_dissipation" => Dict{String,Any}("force_minimum_pdf_value" => 0.0, + "neutral_numerical_dissipation" => OptionsDict("force_minimum_pdf_value" => 0.0, "vz_dissipation_coefficient" => 1e-1)) if global_size[] > 2 && global_size[] % 2 == 0 @@ -106,10 +107,10 @@ function run_test(test_input, expected_p, expected_q, expected_vt; rtol=1.e-6, # Make a copy to make sure nothing modifies the input Dicts defined in this test # script. - test_input = deepcopy(test_input) + input = deepcopy(test_input) # Convert keyword arguments to a unique name - name = test_input["run_name"] + name = input["run_name"] if length(args) > 0 name = string(name, "_", (string(k, "-", v, "_") for (k, v) in args)...) @@ -120,12 +121,8 @@ function run_test(test_input, expected_p, expected_q, expected_vt; rtol=1.e-6, # Provide some progress info println(" - testing ", name) - # Convert dict from symbol keys to String keys - modified_inputs = Dict(String(k) => v for (k, v) in args) - # Update default inputs with values to be changed - input = merge(test_input, modified_inputs) - + merge_dict_with_kwargs!(input; args...) input["run_name"] = name # Suppress console output while running diff --git a/moment_kinetics/test/fokker_planck_time_evolution_tests.jl b/moment_kinetics/test/fokker_planck_time_evolution_tests.jl index 4ce363165..544a5fafa 100644 --- a/moment_kinetics/test/fokker_planck_time_evolution_tests.jl +++ b/moment_kinetics/test/fokker_planck_time_evolution_tests.jl @@ -5,12 +5,12 @@ using Base.Filesystem: tempname using MPI using moment_kinetics.coordinates: define_coordinate -using moment_kinetics.input_structs: grid_input, advection_input +using moment_kinetics.input_structs: grid_input, advection_input, merge_dict_with_kwargs! using moment_kinetics.load_data: open_readonly_output_file, load_coordinate_data, load_species_data, load_fields_data, load_ion_moments_data, load_pdf_data, load_time_data, load_species_data -using moment_kinetics.type_definitions: mk_float +using moment_kinetics.type_definitions: mk_float, OptionsDict const analytical_rtol = 3.e-2 const regression_rtol = 2.e-8 @@ -225,11 +225,19 @@ end # default inputs for tests test_input_gauss_legendre = Dict("run_name" => "gausslegendre_pseudospectral", "base_directory" => test_output_directory, - "n_ion_species" => 1, - "n_neutral_species" => 0, - "T_wall" => 1.0, - "T_e" => 1.0, - "initial_temperature2" => 1.0, + "composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 0, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0), + "ion_species_1" => OptionsDict("initial_density" => 0.5, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "sinusoid", + "density_amplitude" => 0.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), "vpa_ngrid" => 3, "vpa_L" => 6.0, "vpa_nelement" => 6, @@ -239,34 +247,14 @@ test_input_gauss_legendre = Dict("run_name" => "gausslegendre_pseudospectral", "vperp_nelement" => 3, "vperp_L" => 3.0, "vperp_discretization" => "gausslegendre_pseudospectral", - #"split_operators" => false, "ionization_frequency" => 0.0, "charge_exchange_frequency" => 0.0, - "constant_ionization_rate" => false, - "electron_physics" => "boltzmann_electron_response", - "fokker_planck_collisions" => Dict{String,Any}("use_fokker_planck" => true, "nuii" => 1.0, "frequency_option" => "manual"), - "z_IC_upar_amplitude1" => 0.0, - "z_IC_density_amplitude1" => 0.0, - "z_IC_upar_amplitude2" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, + "fokker_planck_collisions" => OptionsDict("use_fokker_planck" => true, "nuii" => 1.0, "frequency_option" => "manual"), "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => false, - "z_IC_option1" => "sinusoid", "evolve_moments_parallel_flow" => false, - "z_IC_density_phase2" => 0.0, "z_discretization" => "chebyshev_pseudospectral", - "z_IC_upar_phase2" => 0.0, "evolve_moments_density" => false, - "z_IC_temperature_amplitude2" => 0.0, - "initial_density1" => 0.5, - "z_IC_upar_phase1" => 0.0, - "initial_density2" => 0.5, - "z_IC_density_phase1" => 0.0, - "z_IC_option2" => "sinusoid", - "z_IC_density_amplitude2" => 0.001, - "initial_temperature1" => 1.0, - "z_IC_temperature_phase2" => 0.0, "z_ngrid" => 1, "z_nelement_local" => 1, "z_nelement" => 1, @@ -276,14 +264,14 @@ test_input_gauss_legendre = Dict("run_name" => "gausslegendre_pseudospectral", "r_nelement" => 1, "r_nelement_local" => 1, "r_bc" => "periodic", - "timestepping" => Dict{String,Any}("dt" => 0.01, + "timestepping" => OptionsDict("dt" => 0.01, "nstep" => 5000, "nwrite" => 5000, "nwrite_dfns" => 5000 )) """ -Run a sound-wave test for a single set of parameters +Run a test for a single set of parameters """ # Note 'name' should not be shared by any two tests in this file function run_test(test_input, expected, rtol, atol, upar_rtol=nothing; args...) @@ -292,14 +280,14 @@ function run_test(test_input, expected, rtol, atol, upar_rtol=nothing; args...) # Make a copy to make sure nothing modifies the input Dicts defined in this test # script. - test_input = deepcopy(test_input) + input = deepcopy(test_input) if upar_rtol === nothing upar_rtol = rtol end # Convert keyword arguments to a unique name - name = test_input["run_name"] + name = input["run_name"] if length(args) > 0 name = string(name, "_", (string(k, "-", v, "_") for (k, v) in args)...) @@ -310,12 +298,8 @@ function run_test(test_input, expected, rtol, atol, upar_rtol=nothing; args...) # Provide some progress info println(" - testing ", name) - # Convert dict from symbol keys to String keys - modified_inputs = Dict(String(k) => v for (k, v) in args) - # Update default inputs with values to be changed - input = merge(test_input, modified_inputs) - + merge_dict_with_kwargs!(input; args...) input["run_name"] = name # Suppress console output while running quietoutput() do diff --git a/moment_kinetics/test/gyroaverage_tests.jl b/moment_kinetics/test/gyroaverage_tests.jl index 21c43f0b7..c4f2e5a2a 100644 --- a/moment_kinetics/test/gyroaverage_tests.jl +++ b/moment_kinetics/test/gyroaverage_tests.jl @@ -16,7 +16,8 @@ using moment_kinetics.looping using moment_kinetics.array_allocation: allocate_float, allocate_shared_float using moment_kinetics.gyroaverages: gyroaverage_pdf! using moment_kinetics.gyroaverages: gyroaverage_field!, init_gyro_operators -using moment_kinetics.type_definitions: mk_float, mk_int +using moment_kinetics.type_definitions: mk_float, mk_int, OptionsDict +using moment_kinetics.species_input: get_species_input print_test_results = false @@ -144,7 +145,7 @@ function gyroaverage_test(absolute_error; rhostar=0.1, pitch=0.5, ngrid=5, kr=2, # create test geometry option = "constant-helical" inputdict = Dict("geometry" => Dict("option" => option, "rhostar" => rhostar, "pitch" => pitch)) - geometry_in = setup_geometry_input(inputdict, 0.1) + geometry_in = setup_geometry_input(inputdict) geometry = init_magnetic_geometry(geometry_in,z,r) # create test composition @@ -229,30 +230,9 @@ function gyroaverage_test(absolute_error; rhostar=0.1, pitch=0.5, ngrid=5, kr=2, end function create_test_composition() - electron_physics = boltzmann_electron_response - n_ion_species = 1 - n_neutral_species = 0 - n_species = n_ion_species + n_neutral_species - use_test_neutral_wall_pdf = false - # electron temperature over reference temperature - T_e = 1.0 - # temperature at the entrance to the wall in terms of the electron temperature - T_wall = 1.0 - # wall potential at z = 0 - phi_wall = 0.0 - # constant to test nonzero Er - #Er_constant = 0.0 - # ratio of the neutral particle mass to the ion particle mass - mn_over_mi = 1.0 - # ratio of the electron particle mass to the ion particle mass - me_over_mi = 1.0/1836.0 - # The ion flux reaching the wall that is recycled as neutrals is reduced by - # `recycling_fraction` to account for ions absorbed by the wall. - recycling_fraction = 1.0 - gyrokinetic_ions = true - return composition = species_composition(n_species, n_ion_species, n_neutral_species, - electron_physics, use_test_neutral_wall_pdf, T_e, T_wall, phi_wall, #Er_constant, - mn_over_mi, me_over_mi, recycling_fraction, gyrokinetic_ions, allocate_float(n_species)) + input_dict = OptionsDict("composition" => OptionsDict("n_ion_species" => 1, "n_neutral_species" => 0, "gyrokinetic_ions" => true ) ) + #println(input_dict) + return get_species_input(input_dict) end function fill_test_arrays!(phi,gphi,vperp,z,r,geometry,composition,kz,kr,phasez,phaser) diff --git a/moment_kinetics/test/harrisonthompson.jl b/moment_kinetics/test/harrisonthompson.jl index 4830cb216..007d4efd1 100644 --- a/moment_kinetics/test/harrisonthompson.jl +++ b/moment_kinetics/test/harrisonthompson.jl @@ -11,6 +11,8 @@ using SpecialFunctions: dawson using moment_kinetics.load_data: open_readonly_output_file using moment_kinetics.load_data: load_fields_data, load_time_data using moment_kinetics.load_data: load_species_data, load_coordinate_data +using moment_kinetics.input_structs: merge_dict_with_kwargs! +using moment_kinetics.type_definitions: OptionsDict ionization_frequency = 0.688 @@ -61,36 +63,36 @@ function findphi(z, R_ion) end # default inputs for tests -test_input_finite_difference = Dict("n_ion_species" => 1, - "n_neutral_species" => 0, - "boltzmann_electron_response" => true, +test_input_finite_difference = Dict("composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 0, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0, + "T_wall" => 1.0), + "ion_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 0.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), "run_name" => "finite_difference", "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => false, - "T_e" => 1.0, - "T_wall" => 1.0, - "initial_density1" => 1.0, - "initial_temperature1" => 1.0, - "z_IC_option1" => "gaussian", - "z_IC_density_amplitude1" => 0.0, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "vpa_IC_option1" => "gaussian", - "vpa_IC_density_amplitude1" => 1.0, - "vpa_IC_density_phase1" => 0.0, - "vpa_IC_upar_amplitude1" => 0.0, - "vpa_IC_upar_phase1" => 0.0, - "vpa_IC_temperature_amplitude1" => 0.0, - "vpa_IC_temperature_phase1" => 0.0, "charge_exchange_frequency" => 0.0, "ionization_frequency" => 0.0, "constant_ionization_rate" => true, - "timestepping" => Dict{String,Any}("nstep" => 9000, + "timestepping" => OptionsDict("nstep" => 9000, "dt" => 0.0005, "nwrite" => 9000, "split_operators" => false), @@ -156,10 +158,10 @@ function run_test(test_input, analytic_rtol, analytic_atol, expected_phi, # Make a copy to make sure nothing modifies the input Dicts defined in this test # script. - test_input = deepcopy(test_input) + input = deepcopy(test_input) # Convert keyword arguments to a unique name - name = test_input["run_name"] + name = input["run_name"] if length(args) > 0 name = string(name, "_", (string(k, "-", v, "_") for (k, v) in args)...) @@ -170,12 +172,8 @@ function run_test(test_input, analytic_rtol, analytic_atol, expected_phi, # Provide some progress info println(" - testing ", name) - # Convert dict from symbol keys to String keys - modified_inputs = Dict(String(k) => v for (k, v) in args) - # Update default inputs with values to be changed - input = merge(test_input, modified_inputs) - + merge_dict_with_kwargs!(input; args...) input["run_name"] = name # Suppress console output while running diff --git a/moment_kinetics/test/nonlinear_solver_tests.jl b/moment_kinetics/test/nonlinear_solver_tests.jl index 23d62acf9..b37dc0187 100644 --- a/moment_kinetics/test/nonlinear_solver_tests.jl +++ b/moment_kinetics/test/nonlinear_solver_tests.jl @@ -9,7 +9,7 @@ using moment_kinetics.input_structs: advection_input using moment_kinetics.looping using moment_kinetics.looping: setup_loop_ranges! using moment_kinetics.nonlinear_solvers -using moment_kinetics.type_definitions: mk_float, mk_int +using moment_kinetics.type_definitions: mk_float, mk_int, OptionsDict using MPI @@ -113,8 +113,8 @@ function linear_test() end nl_solver_params = setup_nonlinear_solve( - Dict{String,Any}("nonlinear_solver" => - Dict{String,Any}("rtol" => 0.0, + OptionsDict("nonlinear_solver" => + OptionsDict("rtol" => 0.0, "atol" => atol, "linear_restart" => restart, "linear_max_restarts" => max_restarts)), @@ -245,8 +245,8 @@ function nonlinear_test() end nl_solver_params = setup_nonlinear_solve( - Dict{String,Any}("nonlinear_solver" => - Dict{String,Any}("rtol" => 0.0, + OptionsDict("nonlinear_solver" => + OptionsDict("rtol" => 0.0, "atol" => atol, "linear_restart" => restart, "linear_max_restarts" => max_restarts, diff --git a/moment_kinetics/test/nonlinear_sound_wave_inputs_and_expected_data.jl b/moment_kinetics/test/nonlinear_sound_wave_inputs_and_expected_data.jl index d76a644f9..031591e51 100644 --- a/moment_kinetics/test/nonlinear_sound_wave_inputs_and_expected_data.jl +++ b/moment_kinetics/test/nonlinear_sound_wave_inputs_and_expected_data.jl @@ -82,36 +82,36 @@ const expected = 0.024285034070612672 0.01001177872485688 0.00842420216637052 0.019283695804388705 0.03672486160719087 0.04165072188572364 0.0369234055803037 0.036374533667106045 0.041904838760501203 0.040712367539469434 0.02428503407061266]) # default inputs for tests -test_input_finite_difference = Dict("n_ion_species" => 1, - "n_neutral_species" => 1, - "boltzmann_electron_response" => true, +test_input_finite_difference = Dict("composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 1, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0), + "ion_species_1" => OptionsDict("initial_density" => 0.5, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "sinusoid", + "density_amplitude" => 0.5, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.5, + "temperature_phase" => mk_float(π)), + "neutral_species_1" => OptionsDict("initial_density" => 0.5, + "initial_temperature" => 1.0), + "z_IC_neutral_species_1" => OptionsDict("initialization_option" => "sinusoid", + "density_amplitude" => 0.5, + "density_phase" => mk_float(π), + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.5, + "temperature_phase" => 0.0), "run_name" => "finite_difference", "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => true, - "T_e" => 1.0, - "initial_density1" => 0.5, - "initial_temperature1" => 1.0, - "initial_density2" => 0.5, - "initial_temperature2" => 1.0, - "z_IC_option1" => "sinusoid", - "z_IC_density_amplitude1" => 0.5, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.5, - "z_IC_temperature_phase1" => mk_float(π), - "z_IC_option2" => "sinusoid", - "z_IC_density_amplitude2" => 0.5, - "z_IC_density_phase2" => mk_float(π), - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.5, - "z_IC_temperature_phase2" => 0.0, "charge_exchange_frequency" => 2*π*0.1, "ionization_frequency" => 0.0, - "timestepping" => Dict{String,Any}("nstep" => 100, + "timestepping" => OptionsDict("nstep" => 100, "dt" => 0.001, "nwrite" => 100, "nwrite_dfns" => 100, diff --git a/moment_kinetics/test/nonlinear_sound_wave_tests.jl b/moment_kinetics/test/nonlinear_sound_wave_tests.jl index 590047000..7da52ab70 100644 --- a/moment_kinetics/test/nonlinear_sound_wave_tests.jl +++ b/moment_kinetics/test/nonlinear_sound_wave_tests.jl @@ -5,11 +5,11 @@ include("setup.jl") using Base.Filesystem: tempname using moment_kinetics.coordinates: define_coordinate -using moment_kinetics.input_structs: grid_input, advection_input +using moment_kinetics.input_structs: grid_input, advection_input, merge_dict_with_kwargs! using moment_kinetics.interpolation: interpolate_to_grid_z, interpolate_to_grid_vpa using moment_kinetics.load_data: get_run_info_no_setup, close_run_info, postproc_load_variable -using moment_kinetics.type_definitions: mk_float +using moment_kinetics.type_definitions: mk_float, OptionsDict const analytical_rtol = 3.e-2 const regression_rtol = 2.e-8 @@ -26,14 +26,14 @@ function run_test(test_input, rtol, atol, upar_rtol=nothing; args...) # Make a copy to make sure nothing modifies the input Dicts defined in this test # script. - test_input = deepcopy(test_input) + input = deepcopy(test_input) if upar_rtol === nothing upar_rtol = rtol end # Convert keyword arguments to a unique name - name = test_input["run_name"] + name = input["run_name"] if length(args) > 0 name = string(name, "_", (string(k, "-", v, "_") for (k, v) in args)...) @@ -44,12 +44,8 @@ function run_test(test_input, rtol, atol, upar_rtol=nothing; args...) # Provide some progress info println(" - testing ", name) - # Convert dict from symbol keys to String keys - modified_inputs = Dict(String(k) => v for (k, v) in args) - # Update default inputs with values to be changed - input = merge(test_input, modified_inputs) - + merge_dict_with_kwargs!(input; args...) input["run_name"] = name # Suppress console output while running diff --git a/moment_kinetics/test/recycling_fraction_tests.jl b/moment_kinetics/test/recycling_fraction_tests.jl index 8add56a1f..91d302868 100644 --- a/moment_kinetics/test/recycling_fraction_tests.jl +++ b/moment_kinetics/test/recycling_fraction_tests.jl @@ -10,59 +10,60 @@ using Base.Filesystem: tempname using MPI using moment_kinetics.coordinates: define_coordinate -using moment_kinetics.input_structs: grid_input, advection_input +using moment_kinetics.input_structs: grid_input, advection_input, merge_dict_with_kwargs! using moment_kinetics.interpolation: interpolate_to_grid_z using moment_kinetics.load_data: get_run_info_no_setup, close_run_info, postproc_load_variable +using moment_kinetics.type_definitions: OptionsDict # default inputs for tests -test_input = Dict("n_ion_species" => 1, - "n_neutral_species" => 1, - "boltzmann_electron_response" => true, +test_input = Dict("composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 1, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 0.2, + "T_wall" => 0.1, + "recycling_fraction" => 0.5), + "ion_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 0.0, + "density_phase" => 0.0, + "upar_amplitude" => 1.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "neutral_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_neutral_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => -1.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_neutral_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), "run_name" => "full-f", "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => false, - "recycling_fraction" => 0.5, - "T_e" => 0.2, - "T_wall" => 0.1, - "initial_density1" => 1.0, - "initial_temperature1" => 1.0, - "z_IC_option1" => "gaussian", - "z_IC_density_amplitude1" => 0.0, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 1.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "vpa_IC_option1" => "gaussian", - "vpa_IC_density_amplitude1" => 1.0, - "vpa_IC_density_phase1" => 0.0, - "vpa_IC_upar_amplitude1" => 0.0, - "vpa_IC_upar_phase1" => 0.0, - "vpa_IC_temperature_amplitude1" => 0.0, - "vpa_IC_temperature_phase1" => 0.0, - "initial_density2" => 1.0, - "initial_temperature2" => 1.0, - "z_IC_option2" => "gaussian", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => -1.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, - "vpa_IC_option2" => "gaussian", - "vpa_IC_density_amplitude2" => 1.0, - "vpa_IC_density_phase2" => 0.0, - "vpa_IC_upar_amplitude2" => 0.0, - "vpa_IC_upar_phase2" => 0.0, - "vpa_IC_temperature_amplitude2" => 0.0, - "vpa_IC_temperature_phase2" => 0.0, "charge_exchange_frequency" => 0.75, "ionization_frequency" => 0.5, "constant_ionization_rate" => false, - "timestepping" => Dict{String,Any}("nstep" => 1000, + "timestepping" => OptionsDict("nstep" => 1000, "dt" => 1.0e-4, "nwrite" => 1000, "split_operators" => false), @@ -78,11 +79,13 @@ test_input = Dict("n_ion_species" => 1, "vpa_L" => 18.0, "vpa_bc" => "zero", "vpa_discretization" => "chebyshev_pseudospectral", + "vpa_element_spacing_option" => "coarse_tails", "vz_ngrid" => 10, "vz_nelement" => 15, "vz_L" => 18.0, "vz_bc" => "zero", "vz_discretization" => "chebyshev_pseudospectral", + "vz_element_spacing_option" => "coarse_tails", "ion_source_1" => Dict("active" => true, "z_profile" => "gaussian", "z_width" => 0.125, @@ -107,8 +110,8 @@ test_input_split3 = merge(test_input_split2, "vpa_nelement" => 31, "vz_nelement" => 31, "evolve_moments_parallel_pressure" => true, - "ion_numerical_dissipation" => Dict{String,Any}("force_minimum_pdf_value" => 0.0, "vpa_dissipation_coefficient" => 1e-2), - "neutral_numerical_dissipation" => Dict{String,Any}("force_minimum_pdf_value" => 0.0, "vz_dissipation_coefficient" => 1e-2))) + "ion_numerical_dissipation" => OptionsDict("force_minimum_pdf_value" => 0.0, "vpa_dissipation_coefficient" => 1e-2), + "neutral_numerical_dissipation" => OptionsDict("force_minimum_pdf_value" => 0.0, "vz_dissipation_coefficient" => 1e-2))) test_input_split3["timestepping"] = merge(test_input_split3["timestepping"], Dict("dt" => 1.0e-5, "write_error_diagnostics" => true, @@ -116,7 +119,7 @@ test_input_split3["timestepping"] = merge(test_input_split3["timestepping"], # default inputs for adaptive timestepping tests test_input_adaptive = merge(test_input, - Dict{String,Any}("run_name" => "adaptive full-f", + OptionsDict("run_name" => "adaptive full-f", "z_ngrid" => 5, "z_nelement" => 16, "vpa_ngrid" => 6, @@ -130,7 +133,7 @@ test_input_adaptive = merge(test_input, # though the difference should be negligible compared to the # discretization error of the simulation). test_input_adaptive["timestepping"] = merge(test_input_adaptive["timestepping"], - Dict{String,Any}("type" => "Fekete4(3)", + OptionsDict("type" => "Fekete4(3)", "nstep" => 5000, "dt" => 1.0e-5, "minimum_dt" => 1.0e-5, @@ -147,18 +150,18 @@ test_input_adaptive_split2 = merge(test_input_adaptive_split1, Dict("run_name" => "adaptive split2", "evolve_moments_parallel_flow" => true)) test_input_adaptive_split2["timestepping"] = merge(test_input_adaptive_split2["timestepping"], - Dict{String,Any}("step_update_prefactor" => 0.4)) + OptionsDict("step_update_prefactor" => 0.4)) test_input_adaptive_split3 = merge(test_input_adaptive_split2, Dict("run_name" => "adaptive split3", "evolve_moments_parallel_pressure" => true, - "numerical_dissipation" => Dict{String,Any}("force_minimum_pdf_value" => 0.0, + "numerical_dissipation" => OptionsDict("force_minimum_pdf_value" => 0.0, "vpa_dissipation_coefficient" => 1e-2))) # The initial conditions seem to make the split3 case hard to advance without any # failures. In a real simulation, would just set the minimum_dt higher to try to get # through this without crashing. For this test, want the timestep to adapt (not just sit # at minimum_dt), so just set a very small timestep. test_input_adaptive_split3["timestepping"] = merge(test_input_adaptive_split3["timestepping"], - Dict{String,Any}("dt" => 1.0e-7, + OptionsDict("dt" => 1.0e-7, "rtol" => 2.0e-4, "atol" => 2.0e-10, "minimum_dt" => 1.0e-7, @@ -173,10 +176,10 @@ function run_test(test_input, expected_phi; rtol=4.e-14, atol=1.e-15, args...) # Make a copy to make sure nothing modifies the input Dicts defined in this test # script. - test_input = deepcopy(test_input) + input = deepcopy(test_input) # Convert keyword arguments to a unique name - name = test_input["run_name"] + name = input["run_name"] if length(args) > 0 name = string(name, "_", (string(k, "-", v, "_") for (k, v) in args)...) @@ -187,12 +190,8 @@ function run_test(test_input, expected_phi; rtol=4.e-14, atol=1.e-15, args...) # Provide some progress info println(" - testing ", name) - # Convert dict from symbol keys to String keys - modified_inputs = Dict(String(k) => v for (k, v) in args) - # Update default inputs with values to be changed - input = merge(test_input, modified_inputs) - + merge_dict_with_kwargs!(input; args...) input["run_name"] = name # Suppress console output while running @@ -242,70 +241,70 @@ function runtests() @long @testset "Full-f" begin test_input["base_directory"] = test_output_directory run_test(test_input, - [-0.05519530428547719, -0.017715187591731293, -0.0014094765667960986, - 0.0017408709303110715, 0.002364329303626605, 0.0015912944705669578, - 0.0015964146438650865, 0.003860702183595992, 0.0069126570648780075, - 0.01502802246799623, 0.034672817945651656, 0.03605806530524313, - 0.022451501088277735, 0.007636465002105951, 0.005249626321396431, - 0.0019202967839667788, 0.0015870957754252823, 0.0019420461064341924, - 0.0027769433764546388, 2.482219694607524e-5, -0.009668963817923988, - -0.04888254078430223]) + [-0.0546579889285807, -0.019016549127873168, -0.0014860800466385304, + 0.0009959205072609873, 0.0018297472055798175, 0.001071042733974246, + 0.0010872542779497558, 0.0034088344425557424, 0.006495346769181668, + 0.014654320273015945, 0.03434558121245117, 0.0357330046889818, + 0.02209990163293976, 0.0072248464387002585, 0.004816169992667908, + 0.001426397872859017, 0.001056590777701787, 0.0014051997473547636, + 0.002295772235866664, -0.0002868846663738925, -0.010975801853574857, + -0.04842263416979855]) end @long @testset "Split 1" begin test_input_split1["base_directory"] = test_output_directory run_test(test_input_split1, - [-0.05499683305021959, -0.017648671323931234, -0.001435044896193346, - 0.0018073884147499259, 0.0023450881700708397, 0.0015955143089305631, - 0.001589815317774866, 0.003860937118209949, 0.006911057359417227, - 0.015026521129765527, 0.03467295602711963, 0.03605680131391841, - 0.022451426419324128, 0.007635385849475049, 0.005247408512658831, - 0.0019234631747149433, 0.001566853129890402, 0.001949947092934496, - 0.0027475042305556622, -0.00010906536252042205, - -0.00962961346763738, -0.04864884428378774]) + [-0.054564400690150644, -0.01880050885497155, -0.0013804889155909434, + 0.0009426267362423344, 0.0018708794999890794, 0.0010048035580616115, + 0.0010869046046222948, 0.0034056101774940675, 0.0064957786740579455, + 0.01465251207308323, 0.034345864665430555, 0.03573156224898501, + 0.022099994048796447, 0.007223371167561782, 0.004815984673023357, + 0.0014246219209092864, 0.0010492088800026246, 0.001358555443115789, + 0.002355419499405167, -9.616282952819355e-5, -0.010989980720963986, + -0.04820698953610652]) end @long @testset "Split 2" begin test_input_split2["base_directory"] = test_output_directory run_test(test_input_split2, - [-0.05584608895693617, -0.020285311011810747, 0.0013246162852513857, - 0.002408198079080654, 0.002193404660625343, 0.0014165984310586497, - 0.0015838582299817442, 0.003942456292519074, 0.006915806487555444, - 0.014996822639406769, 0.034698460163972725, 0.03601812331030096, - 0.022438422037486003, 0.007592137358805067, 0.00532114704663586, - 0.001973382574270663, 0.0013804707387267182, 0.0016443777257862315, - 0.0025134094388913966, 0.0018832456170377893, -0.008404304571565805, - -0.05034925353831177]) + [-0.055351930552923125, -0.0200209368236471, -0.0010274232338285407, + 0.0011445828881595096, 0.001990016623266284, 0.0011847791295251302, + 0.0012178159250162924, 0.003389968304925306, 0.006471876165122262, + 0.014666710317521392, 0.034363113016583055, 0.03570763645228305, + 0.022015422551673866, 0.007249734444536539, 0.004848925796605709, + 0.0012928880774780984, 0.0009085783825923187, 0.0014263120887848147, + 0.0023594712302784752, 0.0002954708425330566, -0.009955206404411004, + -0.04714624635817171]) end @long @testset "Split 3" begin test_input_split3["base_directory"] = test_output_directory run_test(test_input_split3, - [-0.03620705983288495, -0.030483526856225397, -0.028960441350906176, - -0.028549218778503995, -0.025515599608030678, -0.021975115062752498, - -0.019818943505064867, -0.013314608790987136, -0.009839994543852062, - -0.005265524793578627, 0.002150328580191541, 0.004621192779726743, - 0.011510249894025814, 0.017574569324021832, 0.020149366401796907, - 0.027122843852491103, 0.03050649889203747, 0.03404441833358536, - 0.039323018405068834, 0.04089864462026069, 0.04436314083820065, - 0.04582518382395237, 0.045703097564838854, 0.04312195015009901, - 0.04054713854267327, 0.0378719503058148, 0.03223787080558438, - 0.030105904373564214, 0.024828730387096765, 0.01859677066598083, - 0.01621033424329937, 0.008755805694319756, 0.004008885194932725, - 3.98551863685712e-5, -0.007641449438487893, -0.010257112218851392, - -0.01554078023638837, -0.021190999288843403, -0.022783488732253034, - -0.026872207781674047, -0.028748355604856834, -0.02921966520151288, - -0.03230397503173283]) + [-0.036195418620494954, -0.030489030308458488, -0.028975057418733397, + -0.02856021807109163, -0.025513413807863268, -0.0219696963676536, + -0.019843060635768725, -0.013329641098584045, -0.009865951845346884, + -0.005274664099474674, 0.0021551620276032725, 0.004604147727212109, + 0.011494982185711863, 0.017553116141190095, 0.020142011471035323, + 0.02711278698585964, 0.0304955647516801, 0.03404001571064709, + 0.039318184954120955, 0.040888755835348824, 0.04435714972215338, + 0.04581950770664514, 0.04569761337067911, 0.04311624840495188, + 0.0405404864794332, 0.0378656646347818, 0.032230200940856144, + 0.030099328699440486, 0.024820489910128835, 0.018584207663623988, + 0.01620878075694702, 0.00875792663483109, 0.003998273774255805, + 2.6225005465422193e-5, -0.007645978144613239, -0.010283112908873734, + -0.01555130379029211, -0.02119151686032106, -0.022798520707706906, + -0.026895590584576676, -0.02875783077548144, -0.029235490314989378, + -0.03231930055546638]) end - fullf_expected_output = [-0.04413552960518834, -0.021828861958540703, - -0.012581752434237016, -0.010579192578141765, - -0.0068512759586887885, 2.5839426347419376e-5, - 0.006155432086970659, 0.011968120005188723, - 0.019681941313251225, 0.029904657995405693, - 0.03949771002617614, 0.04255717403165738, - 0.031939444000420925, 0.02124792913154375, - 0.015253505295222548, 0.00930078535463162, - 0.0012208189549702839, -0.005751247690841759, - -0.009217769053947429, -0.011407780388153488, - -0.020596064125157174, -0.03809484046514718] + fullf_expected_output = [-0.04372543535228032, -0.02233515082616229, + -0.012793688037658377, -0.010786492944264052, + -0.007051439902278702, -0.0001605908774545327, + 0.005982619745890949, 0.0118094191749825, + 0.01954207152061524, 0.02978202423468538, + 0.039384279904624404, 0.042446003403153604, + 0.03181914367119813, 0.021111423438351817, + 0.015103049638495273, 0.009135485828230407, + 0.0010369322036392606, -0.005949066066045502, + -0.00942148866222427, -0.011607485576226423, + -0.020871221194795328, -0.03762871759968933] @testset "Adaptive timestep - full-f" begin test_input_adaptive["base_directory"] = test_output_directory run_test(test_input_adaptive, @@ -314,38 +313,40 @@ function runtests() @testset "Adaptive timestep - split 1" begin test_input_adaptive_split1["base_directory"] = test_output_directory run_test(test_input_adaptive_split1, - [-0.04411241514173686, -0.02173832960900953, -0.012507206800103619, - -0.010594605015685111, -0.006851937496868262, 2.4307749760781248e-5, - 0.006153573001701797, 0.011966908336801292, 0.019680600194907028, - 0.02990265026906549, 0.039494202889752195, 0.04255801055036077, - 0.031941240640856954, 0.02124538117173497, 0.0152520119972139, - 0.009299543598122585, 0.001218486350949803, -0.005753814631808573, - -0.009211138614098327, -0.011500666056267622, -0.020424831739003606, - -0.03808534246490289], rtol=6.0e-4, atol=2.0e-12) + [-0.04375862714017892, -0.022363510973059945, -0.012739964397542611, + -0.010806509398868007, -0.007052551067569563, + -0.0001618866835357178, 0.005980921838191561, 0.011808361372364367, + 0.019540868336503224, 0.02978014755372564, 0.03938085813395519, + 0.042446888380863836, 0.031821059258512106, 0.021109010112552534, + 0.015101702015235266, 0.009134407186439548, 0.0010347434646523774, + -0.005951302261109976, -0.009412276056941643, -0.011636393512121094, + -0.020739923046188418, -0.03769486232955374], rtol=6.0e-4, + atol=2.0e-12) end @testset "Adaptive timestep - split 2" begin test_input_adaptive_split2["base_directory"] = test_output_directory run_test(test_input_adaptive_split2, - [-0.044658773996679106, -0.022770640350132876, -0.01291279676887995, - -0.010818472056813256, -0.00692137979236985, 8.260915374129437e-6, - 0.006095505380954945, 0.012043966021961394, 0.01969312249006842, - 0.02993329149668162, 0.03951863202813308, 0.04254329784045647, - 0.031905905757383245, 0.0212173464030042, 0.015225863469416798, - 0.00923409202948059, 0.0012431576067072942, -0.005777971895837924, - -0.009047333684784373, -0.010964221005155143, -0.020937032832434074, - -0.03762542957657465], rtol=6.0e-4, atol=2.0e-12) + [-0.0440004026002034, -0.022740771274011903, -0.012908307424861458, + -0.010957840207013755, -0.007098397545728348, + -0.00020528082369771782, 0.0059601664366275495, + 0.011802849958075045, 0.019546525347314055, 0.02976627257948505, + 0.03937863700013744, 0.0424357099316342, 0.03182280591999282, + 0.021097437598690982, 0.015088139859851357, 0.009141943563305855, + 0.0010114496202298438, -0.0059305646605444726, + -0.009328644946126851, -0.011284802819960504, -0.020872565412882932, + -0.03785398593006839], rtol=6.0e-4, atol=2.0e-12) end @testset "Adaptive timestep - split 3" begin test_input_adaptive_split3["base_directory"] = test_output_directory run_test(test_input_adaptive_split3, - [-0.03462849854420647, -0.03201042148267427, -0.027145441768761876, - -0.020930163084065857, -0.010155888649583823, 0.0027838306741690046, - 0.012832285048924648, 0.022090624745954916, 0.033028935673319444, - 0.041525790733438206, 0.04537601028144605, 0.046240136469284064, - 0.042545918106145095, 0.03480923464250141, 0.02707487186844719, - 0.017880803893474347, 0.004778898480075153, -0.007767501511791003, - -0.016298557311046468, -0.0241393991660673, -0.03156718517969005, - -0.03417441352897386], rtol=6.0e-4, atol=2.0e-12) + [-0.034623352735472034, -0.03200541773193755, -0.02714032291656093, + -0.020924986472905527, -0.01015057042512689, 0.0027893133203071574, + 0.012837899470698978, 0.022096372980618853, 0.0330348469665054, + 0.041531828755231016, 0.045382106043818246, 0.046246244563868354, + 0.042551970615727366, 0.034815169767529956, 0.027080688565416164, + 0.017886490800418996, 0.004784403555306537, -0.007762152788142663, + -0.01629330539573498, -0.02413421820486561, -0.0315621379076817, + -0.03416924694766477], rtol=6.0e-4, atol=2.0e-12) end @long @testset "Check other timestep - $type" for diff --git a/moment_kinetics/test/restart_interpolation_tests.jl b/moment_kinetics/test/restart_interpolation_tests.jl index 9c0a1c99b..ca6a166ba 100644 --- a/moment_kinetics/test/restart_interpolation_tests.jl +++ b/moment_kinetics/test/restart_interpolation_tests.jl @@ -9,7 +9,7 @@ using Base.Filesystem: tempname using moment_kinetics.communication using moment_kinetics.coordinates: define_coordinate using moment_kinetics.file_io: io_has_parallel -using moment_kinetics.input_structs: grid_input, advection_input, hdf5 +using moment_kinetics.input_structs: grid_input, advection_input, hdf5, merge_dict_with_kwargs! using moment_kinetics.load_data: open_readonly_output_file, load_coordinate_data, load_species_data, load_fields_data, load_ion_moments_data, load_pdf_data, @@ -18,7 +18,7 @@ using moment_kinetics.load_data: open_readonly_output_file, load_coordinate_data using moment_kinetics.interpolation: interpolate_to_grid_z, interpolate_to_grid_vpa using moment_kinetics.load_data: get_run_info_no_setup, close_run_info, postproc_load_variable -using moment_kinetics.type_definitions: mk_float +using moment_kinetics.type_definitions: mk_float, OptionsDict include("nonlinear_sound_wave_inputs_and_expected_data.jl") @@ -30,11 +30,11 @@ if global_size[] > 1 && global_size[] % 2 == 0 # Test using distributed-memory base_input["z_nelement_local"] = base_input["z_nelement"] ÷ 2 end -base_input["output"] = Dict{String,Any}("parallel_io" => false) +base_input["output"] = OptionsDict("parallel_io" => false) restart_test_input_chebyshev = merge(deepcopy(base_input), - Dict("run_name" => "restart_chebyshev_pseudospectral", + OptionsDict("run_name" => "restart_chebyshev_pseudospectral", "r_ngrid" => 3, "r_nelement" => 2, "r_discretization" => "chebyshev_pseudospectral", "z_ngrid" => 17, "z_nelement" => 2, @@ -47,18 +47,18 @@ end restart_test_input_chebyshev_split_1_moment = merge(deepcopy(restart_test_input_chebyshev), - Dict("run_name" => "restart_chebyshev_pseudospectral_split_1_moment", + OptionsDict("run_name" => "restart_chebyshev_pseudospectral_split_1_moment", "evolve_moments_density" => true)) restart_test_input_chebyshev_split_2_moments = merge(deepcopy(restart_test_input_chebyshev_split_1_moment), - Dict("run_name" => "restart_chebyshev_pseudospectral_split_2_moments", + OptionsDict("run_name" => "restart_chebyshev_pseudospectral_split_2_moments", "r_ngrid" => 1, "r_nelement" => 1, "evolve_moments_parallel_flow" => true)) restart_test_input_chebyshev_split_3_moments = merge(deepcopy(restart_test_input_chebyshev_split_2_moments), - Dict("run_name" => "restart_chebyshev_pseudospectral_split_3_moments", + OptionsDict("run_name" => "restart_chebyshev_pseudospectral_split_3_moments", "evolve_moments_parallel_pressure" => true, "vpa_L" => 1.5*vpa_L, "vz_L" => 1.5*vpa_L)) @@ -66,13 +66,13 @@ restart_test_input_chebyshev_split_3_moments = Run a sound-wave test for a single set of parameters """ # Note 'name' should not be shared by any two tests in this file -function run_test(test_input, base, message, rtol, atol; tol_3V, kwargs...) - # by passing keyword arguments to run_test, kwargs becomes a Tuple of Pairs which can be used to +function run_test(test_input, base, message, rtol, atol; tol_3V, args...) + # by passing keyword arguments to run_test, args becomes a Tuple of Pairs which can be used to # update the default inputs # Make a copy to make sure nothing modifies the input Dicts defined in this test # script. - test_input = deepcopy(test_input) + input = deepcopy(test_input) if tol_3V === nothing atol_3V = atol @@ -82,11 +82,21 @@ function run_test(test_input, base, message, rtol, atol; tol_3V, kwargs...) rtol_3V = tol_3V end - parallel_io = test_input["output"]["parallel_io"] + parallel_io = input["output"]["parallel_io"] # Convert keyword arguments to a unique name - name = test_input["run_name"] - if length(kwargs) > 0 - name = string(name, (string(String(k)[1], v) for (k, v) in kwargs)...) + function stringify_arg(key, value) + if isa(value, AbstractDict) + return string(string(key)[1], (stringify_arg(k, v) for (k, v) in value)...) + else + return string(string(key)[1], value) + end + end + name = input["run_name"] + if length(args) > 0 + name = string(name, "_", (stringify_arg(k, v) for (k, v) in args)...) + + # Remove trailing "_" + name = chop(name) end if parallel_io name *= "parallel-io" @@ -95,17 +105,7 @@ function run_test(test_input, base, message, rtol, atol; tol_3V, kwargs...) # Provide some progress info println(" - testing ", message) - # Convert from Tuple of Pairs with symbol keys to Dict with String keys - modified_inputs = Dict(String(k) => v for (k, v) in kwargs - if String(k) ∉ keys(test_input["timestepping"])) - modified_timestepping_inputs = Dict(String(k) => v for (k, v) in kwargs - if String(k) ∈ keys(test_input["timestepping"])) - - # Update default inputs with values to be changed - input = merge(test_input, modified_inputs) - input["timestepping"] = merge(test_input["timestepping"], - modified_timestepping_inputs) - + merge_dict_with_kwargs!(input; args...) input["run_name"] = name # Suppress console output while running @@ -290,7 +290,7 @@ end function runtests() function do_tests(label, rtol=1.0e-3, nstep=50, include_moment_kinetic=true; - tol_3V=nothing, kwargs...) + tol_3V=nothing, args...) # Only testing Chebyshev discretization because interpolation not yet implemented # for finite-difference @@ -298,14 +298,14 @@ function runtests() base_input_full_f = deepcopy(base_input) base_input_full_f["timestepping"] = merge(base_input["timestepping"], - Dict("nstep" => nstep)) + OptionsDict("nstep" => nstep)) base_input_evolve_density = merge(base_input_full_f, - Dict("evolve_moments_density" => true)) + OptionsDict("evolve_moments_density" => true)) base_input_evolve_upar = merge(base_input_evolve_density, - Dict("evolve_moments_parallel_flow" => true, + OptionsDict("evolve_moments_parallel_flow" => true, "vpa_L" => 1.5*vpa_L, "vz_L" => 1.5*vpa_L)) base_input_evolve_ppar = merge(base_input_evolve_upar, - Dict("evolve_moments_parallel_pressure" => true, + OptionsDict("evolve_moments_parallel_pressure" => true, "vpa_L" => 1.5*vpa_L, "vz_L" => 1.5*vpa_L)) for (base, base_label) ∈ ((base_input_full_f, "full-f"), @@ -332,7 +332,7 @@ function runtests() this_input = deepcopy(restart_test_input_chebyshev) this_input["base_directory"] = test_output_directory this_input["output"]["parallel_io"] = parallel_io - run_test(this_input, base, message, rtol, 1.e-15; tol_3V=tol_3V, kwargs...) + run_test(this_input, base, message, rtol, 1.e-15; tol_3V=tol_3V, args...) end if include_moment_kinetic message = "restart split 1 from $base_label$label" @@ -340,21 +340,21 @@ function runtests() this_input = deepcopy(restart_test_input_chebyshev_split_1_moment) this_input["base_directory"] = test_output_directory this_input["output"]["parallel_io"] = parallel_io - run_test(this_input, base, message, rtol, 1.e-15; tol_3V=tol_3V, kwargs...) + run_test(this_input, base, message, rtol, 1.e-15; tol_3V=tol_3V, args...) end message = "restart split 2 from $base_label$label" @testset "$message" begin this_input = deepcopy(restart_test_input_chebyshev_split_2_moments) this_input["base_directory"] = test_output_directory this_input["output"]["parallel_io"] = parallel_io - run_test(this_input, base, message, rtol, 1.e-15; tol_3V=tol_3V, kwargs...) + run_test(this_input, base, message, rtol, 1.e-15; tol_3V=tol_3V, args...) end message = "restart split 3 from $base_label$label" @testset "$message" begin this_input = deepcopy(restart_test_input_chebyshev_split_3_moments) this_input["base_directory"] = test_output_directory this_input["output"]["parallel_io"] = parallel_io - run_test(this_input, base, message, rtol, 1.e-15; tol_3V=tol_3V, kwargs...) + run_test(this_input, base, message, rtol, 1.e-15; tol_3V=tol_3V, args...) end end @@ -373,11 +373,11 @@ function runtests() # Note: only do 2 steps in 2V/3V mode because it is so slow. Also, linear # interpolation used for ion-neutral coupling in 2V/3V case has low accuracy, so # use looser tolerance for various things. - @long do_tests(", 2V/3V", 1.0e-1, 98, false; tol_3V=0.3, nstep=2, r_ngrid=1, - r_nelement=1, vperp_ngrid=17, vperp_nelement=4, vperp_L=vpa_L, - vpa_ngrid=17, vpa_nelement=8, vzeta_ngrid=17, vzeta_nelement=4, - vzeta_L=vpa_L, vr_ngrid=17, vr_nelement=4, vr_L=vpa_L, vz_ngrid=17, - vz_nelement=8) + @long do_tests(", 2V/3V", 1.0e-1, 98, false; tol_3V=0.3, + timestepping=OptionsDict("nstep" => 2), r_ngrid=1, r_nelement=1, + vperp_ngrid=17, vperp_nelement=4, vperp_L=vpa_L, vpa_ngrid=17, + vpa_nelement=8, vzeta_ngrid=17, vzeta_nelement=4, vzeta_L=vpa_L, + vr_ngrid=17, vr_nelement=4, vr_L=vpa_L, vz_ngrid=17, vz_nelement=8) if io_has_parallel(Val(hdf5)) orig_base_input = deepcopy(base_input) @@ -391,10 +391,11 @@ function runtests() # interpolation used for ion-neutral coupling in 2V/3V case has low accuracy, # so use looser tolerance for various things. @long do_tests(", 2V/3V, parallel I/O", 2.0e-1, 98, false; tol_3V=0.3, - nstep=2, r_ngrid=1, r_nelement=1, vperp_ngrid=17, - vperp_nelement=4, vperp_L=vpa_L, vpa_ngrid=17, vpa_nelement=8, - vzeta_ngrid=17, vzeta_nelement=4, vzeta_L=vpa_L, vr_ngrid=17, - vr_nelement=4, vr_L=vpa_L, vz_ngrid=17, vz_nelement=8) + timestepping=OptionsDict("nstep" => 2), r_ngrid=1, + r_nelement=1, vperp_ngrid=17, vperp_nelement=4, vperp_L=vpa_L, + vpa_ngrid=17, vpa_nelement=8, vzeta_ngrid=17, vzeta_nelement=4, + vzeta_L=vpa_L, vr_ngrid=17, vr_nelement=4, vr_L=vpa_L, + vz_ngrid=17, vz_nelement=8) global base_input = orig_base_input end diff --git a/moment_kinetics/test/sound_wave_tests.jl b/moment_kinetics/test/sound_wave_tests.jl index f72cdf1c7..7da2ab497 100644 --- a/moment_kinetics/test/sound_wave_tests.jl +++ b/moment_kinetics/test/sound_wave_tests.jl @@ -6,13 +6,14 @@ using Base.Filesystem: tempname #using Plots: plot, plot!, gui using moment_kinetics.array_allocation: allocate_float -using moment_kinetics.input_structs: netcdf +using moment_kinetics.input_structs: netcdf, merge_dict_with_kwargs! using moment_kinetics.file_io: io_has_implementation using moment_kinetics.load_data: open_readonly_output_file using moment_kinetics.load_data: load_fields_data, load_time_data using moment_kinetics.load_data: load_species_data, load_coordinate_data using moment_kinetics.analysis: analyze_fields_data using moment_kinetics.analysis: fit_delta_phi_mode +using moment_kinetics.type_definitions: OptionsDict const analytical_rtol = 3.e-2 const regression_rtol = 1.e-14 @@ -24,36 +25,36 @@ const binary_format = (force_optional_dependencies || io_has_implementation(netc "netcdf" : "hdf5" # default inputs for tests -test_input_finite_difference = Dict("n_ion_species" => 1, - "n_neutral_species" => 1, - "boltzmann_electron_response" => true, +test_input_finite_difference = Dict("composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 1, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0), + "ion_species_1" => OptionsDict("initial_density" => 0.5, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "sinusoid", + "density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "neutral_species_1" => OptionsDict("initial_density" => 0.5, + "initial_temperature" => 1.0), + "z_IC_neutral_species_1" => OptionsDict("initialization_option" => "sinusoid", + "density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), "run_name" => "finite_difference", "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => true, - "T_e" => 1.0, - "initial_density1" => 0.5, - "initial_temperature1" => 1.0, - "initial_density2" => 0.5, - "initial_temperature2" => 1.0, - "z_IC_option1" => "sinusoid", - "z_IC_density_amplitude1" => 0.001, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "z_IC_option2" => "sinusoid", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, "charge_exchange_frequency" => 2*π*0.1, "ionization_frequency" => 0.0, - "timestepping" => Dict{String,Any}("nstep" => 1500, + "timestepping" => OptionsDict("nstep" => 1500, "dt" => 0.002, "nwrite" => 20, "split_operators" => false), @@ -79,7 +80,7 @@ test_input_finite_difference = Dict("n_ion_species" => 1, "vz_L" => 8.0, "vz_bc" => "periodic", "vz_discretization" => "finite_difference", - "output" => Dict{String,Any}("binary_format" => binary_format) + "output" => OptionsDict("binary_format" => binary_format) ) test_input_finite_difference_split_1_moment = @@ -138,14 +139,21 @@ function run_test(test_input, analytic_frequency, analytic_growth_rate, # Make a copy to make sure nothing modifies the input Dicts defined in this test # script. - test_input = deepcopy(test_input) + input = deepcopy(test_input) # Convert keyword arguments to a unique name - name = test_input["run_name"] + function stringify_arg(key, value) + if isa(value, AbstractDict) + return string(string(key)[1], (stringify_arg(k, v) for (k, v) in value)...) + else + return string(string(key)[1], value) + end + end + name = input["run_name"] shortname = name if length(args) > 0 name = string(name, "_", (string(k, "-", v, "_") for (k, v) in args)...) - shortname = string(shortname, "_", (string(string(k)[1], v) for (k, v) in args)...) + shortname = string(shortname, "_", (stringify_arg(k, v) for (k, v) in args)...) # Remove trailing "_" name = chop(name) @@ -154,17 +162,8 @@ function run_test(test_input, analytic_frequency, analytic_growth_rate, # Provide some progress info println(" - testing ", name) - # Convert dict from symbol keys to String keys - modified_inputs = Dict(String(k) => v for (k, v) in args - if String(k) ∉ keys(test_input["timestepping"])) - modified_timestepping_inputs = Dict(String(k) => v for (k, v) in args - if String(k) ∈ keys(test_input["timestepping"])) - # Update default inputs with values to be changed - input = merge(test_input, modified_inputs) - input["timestepping"] = merge(test_input["timestepping"], - modified_timestepping_inputs) - + merge_dict_with_kwargs!(input; args...) input["run_name"] = shortname # Suppress console output while running @@ -269,39 +268,47 @@ function run_test_set_finite_difference() [-0.001068422466592656, -0.001050527721698838, -0.0010288041337549816, -0.0010033394223323698, -0.0009742364063442995, -0.000941612585497573]; - initial_density1=0.9999, initial_density2=0.0001) + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001)) @long run_test(test_input_finite_difference, 2*π*1.4467, -2*π*0.6020, [-0.001068422466592656, -0.001050527721698838, -0.0010288041337549816, -0.0010033394223323698, -0.0009742364063442995, - -0.000941612585497573]; initial_density1=0.9999, - initial_density2=0.0001, charge_exchange_frequency=2*π*2.0) + -0.000941612585497573]; + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001), + charge_exchange_frequency=2*π*2.0) # n_i< 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999)) @long run_test(test_input_finite_difference, 2*π*0.0, -2*π*0.5112, [-9.211308789442441, -9.211290894697548, -9.211269171109604, -9.21124370639818, -9.211214603382192, -9.211181979561346]; - initial_density1=0.0001, initial_density2=0.9999, + ion_species_1 = OptionsDict("initial_density" => 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=0.5 @long run_test(test_input_finite_difference, 2*π*1.2671, -2*π*0.8033, [-0.34705779901310196, -0.34704885164065513, -0.3470379898466833, -0.3470252574909716, -0.3470107059829777, -0.3469943940725544], 30; - T_e=0.5, nstep=1300, charge_exchange_frequency=2*π*0.0) + composition = OptionsDict("T_e" => 0.5), + timestepping = OptionsDict("nstep" => 1300), + charge_exchange_frequency=2*π*0.0) @long run_test(test_input_finite_difference, 2*π*0.0, -2*π*0.2727, [-0.34705779901310196, -0.34704885164065513, -0.3470379898466833, -0.3470252574909716, -0.3470107059829777, -0.3469943940725544]; - T_e=0.5, charge_exchange_frequency=2*π*2.0) + composition = OptionsDict("T_e" => 0.5), + charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=4 @long run_test(test_input_finite_difference, 2*π*1.9919, -2*π*0.2491, [-2.7764623921048157, -2.776390813125241, -2.7763039187734666, -2.7762020599277726, -2.7760856478638214, -2.775955152580435]; - T_e=4.0) + composition = OptionsDict("T_e" => 4.0)) # CX=2*π*2.0 case with T_e=4 is too hard to converge, so skip end @@ -327,38 +334,46 @@ function run_test_set_finite_difference_split_1_moment() run_test(test_input_finite_difference_split_1_moment, 2*π*1.4467, -2*π*0.6020, [-0.0010684224665919893, -0.0010505277216983934, -0.0010288041337547594, -0.0010033394223312585, -0.0009742364063434105, -0.0009416125854969064]; - initial_density1=0.9999, initial_density2=0.0001) + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001)) run_test(test_input_finite_difference_split_1_moment, 2*π*1.4467, -2*π*0.6020, [-0.0010684224665919893, -0.0010505277216983934, -0.0010288041337547594, -0.0010033394223312585, -0.0009742364063434105, -0.0009416125854969064]; - initial_density1=0.9999, initial_density2=0.0001, + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001), charge_exchange_frequency=2*π*2.0) # n_i< 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999)) run_test(test_input_finite_difference_split_1_moment, 2*π*0.0, -2*π*0.5112, [-9.211308789442441, -9.211290894697548, -9.211269171109604, -9.21124370639818, -9.211214603382192, -9.211181979561346]; - initial_density1=0.0001, initial_density2=0.9999, + ion_species_1 = OptionsDict("initial_density" => 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=0.5 run_test(test_input_finite_difference_split_1_moment, 2*π*1.2671, -2*π*0.8033, [-0.34705779901310196, -0.34704885164065513, -0.3470379898466833, -0.3470252574909716, -0.3470107059829777, -0.3469943940725544], 30; - T_e=0.5, nstep=1300, charge_exchange_frequency=2*π*0.0) + composition = OptionsDict("T_e" => 0.5), + timestepping = OptionsDict("nstep" => 1300), + charge_exchange_frequency=2*π*0.0) run_test(test_input_finite_difference_split_1_moment, 2*π*0.0, -2*π*0.2727, [-0.34705779901310196, -0.34704885164065513, -0.3470379898466833, - -0.3470252574909716, -0.3470107059829777, -0.3469943940725544]; T_e=0.5, + -0.3470252574909716, -0.3470107059829777, -0.3469943940725544]; + composition = OptionsDict("T_e" => 0.5), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=4 run_test(test_input_finite_difference_split_1_moment, 2*π*1.9919, -2*π*0.2491, [-2.7764623921048157, -2.776390813125241, -2.7763039187734666, - -2.7762020599277726, -2.7760856478638214, -2.775955152580435]; T_e=4.0) + -2.7762020599277726, -2.7760856478638214, -2.775955152580435]; + composition = OptionsDict("T_e" => 4.0)) # CX=2*π*2.0 case with T_e=4 is too hard to converge, so skip end @@ -384,38 +399,46 @@ function run_test_set_finite_difference_split_2_moments() run_test(test_input_finite_difference_split_2_moments, 2*π*1.4467, -2*π*0.6020, [-0.0010684224665919893, -0.0010505277216983934, -0.0010288041337547594, -0.0010033394223312585, -0.0009742364063434105, -0.0009416125854969064]; - initial_density1=0.9999, initial_density2=0.0001) + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001)) run_test(test_input_finite_difference_split_2_moments, 2*π*1.4467, -2*π*0.6020, [-0.0010684224665919893, -0.0010505277216983934, -0.0010288041337547594, -0.0010033394223312585, -0.0009742364063434105, -0.0009416125854969064]; - initial_density1=0.9999, initial_density2=0.0001, + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001), charge_exchange_frequency=2*π*2.0) # n_i< 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999)) run_test(test_input_finite_difference_split_2_moments, 2*π*0.0, -2*π*0.5112, [-9.211308789442441, -9.211290894697548, -9.211269171109604, -9.21124370639818, -9.211214603382192, -9.211181979561346]; - initial_density1=0.0001, initial_density2=0.9999, + ion_species_1 = OptionsDict("initial_density" => 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=0.5 run_test(test_input_finite_difference_split_2_moments, 2*π*1.2671, -2*π*0.8033, [-0.34706673733456106, -0.3470627566790802, -0.3470579059173919, -0.347052193699157, -0.34704563020982493, -0.3470382271523149], 30; - T_e=0.5, nstep=1300, z_ngrid=150, charge_exchange_frequency=2*π*0.0) + composition = OptionsDict("T_e" => 0.5), + timestepping = OptionsDict("nstep" => 1300), z_ngrid=150, + charge_exchange_frequency=2*π*0.0) run_test(test_input_finite_difference_split_2_moments, 2*π*0.0, -2*π*0.2727, [-0.34705779901310196, -0.34704885164065513, -0.3470379898466833, - -0.3470252574909716, -0.3470107059829777, -0.3469943940725544]; T_e=0.5, + -0.3470252574909716, -0.3470107059829777, -0.3469943940725544]; + composition = OptionsDict("T_e" => 0.5), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=4 run_test(test_input_finite_difference_split_2_moments, 2*π*1.9919, -2*π*0.2491, [-2.7764623921048157, -2.776390813125241, -2.7763039187734666, - -2.7762020599277726, -2.7760856478638214, -2.775955152580435]; T_e=4.0) + -2.7762020599277726, -2.7760856478638214, -2.775955152580435]; + composition = OptionsDict("T_e" => 4.0)) # CX=2*π*2.0 case with T_e=4 is too hard to converge, so skip end @@ -443,12 +466,14 @@ function run_test_set_finite_difference_split_3_moments() -2*π*0.6020, [-0.0010684224665919893, -0.0010505277216983934, -0.0010288041337547594, -0.0010033394223312585, -0.0009742364063434105, -0.0009416125854969064]; - initial_density1=0.9999, initial_density2=0.0001) + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001)) @long run_test(test_input_finite_difference_split_3_moments, 2*π*1.4467, -2*π*0.6020, [-0.0010684224665919893, -0.0010505277216983934, -0.0010288041337547594, -0.0010033394223312585, -0.0009742364063434105, -0.0009416125854969064]; - initial_density1=0.9999, initial_density2=0.0001, + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001), charge_exchange_frequency=2*π*2.0) # n_i< 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999)) @long run_test(test_input_finite_difference_split_3_moments, 2*π*0.0, -2*π*0.5112, [-9.211308789442441, -9.211290894697548, -9.211269171109604, -9.21124370639818, -9.211214603382192, -9.211181979561346]; - initial_density1=0.0001, initial_density2=0.9999, + ion_species_1 = OptionsDict("initial_density" => 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=0.5 @@ -468,17 +495,21 @@ function run_test_set_finite_difference_split_3_moments() -2*π*0.8033, [-0.34705779901310196, -0.34704885164065513, -0.3470379898466833, -0.3470252574909716, -0.3470107059829777, -0.3469943940725544], 30; - T_e=0.5, nstep=1300, charge_exchange_frequency=2*π*0.0) + composition = OptionsDict("T_e" => 0.5), + timestepping = OptionsDict("nstep" => 1300), + charge_exchange_frequency=2*π*0.0) @long run_test(test_input_finite_difference_split_3_moments, 2*π*0.0, -2*π*0.2727, [-0.34705779901310196, -0.34704885164065513, -0.3470379898466833, -0.3470252574909716, -0.3470107059829777, -0.3469943940725544]; - T_e=0.5, charge_exchange_frequency=2*π*2.0) + composition = OptionsDict("T_e" => 0.5), + charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=4 @long run_test(test_input_finite_difference_split_3_moments, 2*π*1.9919, -2*π*0.2491, [-2.7764623921048157, -2.776390813125241, -2.7763039187734666, -2.7762020599277726, - -2.7760856478638214, -2.775955152580435]; T_e=4.0) + -2.7760856478638214, -2.775955152580435]; + composition = OptionsDict("T_e" => 4.0)) # CX=2*π*2.0 case with T_e=4 is too hard to converge, so skip end @@ -504,39 +535,46 @@ function run_test_set_chebyshev() @long run_test(test_input_chebyshev, 2*π*1.4467, -2*π*0.6020, [-0.00010000500033334732, 0.0004653997510461739, 0.0007956127502558478, 0.0008923624901804128, 0.0008994953327500175, 0.0008923624901804128]; - initial_density1=0.9999, initial_density2=0.0001) + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001)) @long run_test(test_input_chebyshev, 2*π*1.4467, -2*π*0.6020, [-0.00010000500033334732, 0.0004653997510461739, 0.0007956127502558478, 0.0008923624901804128, 0.0008994953327500175, 0.0008923624901804128]; - initial_density1=0.9999, initial_density2=0.0001, + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001), charge_exchange_frequency=2*π*2.0) # n_i< 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999)) @long run_test(test_input_chebyshev, 2*π*0.0, -2*π*0.5112, [-9.210340371976182, -9.209774967224805, -9.209444754225593, -9.209348004485669, -9.2093408716431, -9.209348004485669]; - initial_density1=0.0001, initial_density2=0.9999, + ion_species_1 = OptionsDict("initial_density" => 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=0.5 @long run_test(test_input_chebyshev, 2*π*1.2671, -2*π*0.8033, [-0.34657359027997264, -0.34629088790428314, -0.34612578140467837, -0.34607740653471614, -0.34607384011343095, -0.34607740653471614], - 30; T_e=0.5, nstep=1300, charge_exchange_frequency=2*π*0.0) + 30; composition = OptionsDict("T_e" => 0.5), + timestepping = OptionsDict("nstep" => 1300), + charge_exchange_frequency=2*π*0.0) @long run_test(test_input_chebyshev, 2*π*0.0, -2*π*0.2727, [-0.34657359027997264, -0.34629088790428314, -0.34612578140467837, -0.34607740653471614, -0.34607384011343095, -0.34607740653471614]; - T_e=0.5, charge_exchange_frequency=2*π*2.0) + composition = OptionsDict("T_e" => 0.5), + charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=4 @long run_test(test_input_chebyshev, 2*π*1.9919, -2*π*0.2491, [-2.772588722239781, -2.770327103234265, -2.769006251237427, -2.768619252277729, -2.7685907209074476, -2.768619252277729]; - T_e=4.0) + composition = OptionsDict("T_e" => 4.0)) # CX=2*π*2.0 case with T_e=4 is too hard to converge, so skip end @@ -562,40 +600,48 @@ function run_test_set_chebyshev_split_1_moment() @long run_test(test_input_chebyshev_split_1_moment, 2*π*1.4467, -2*π*0.6020, [-0.00010000500033334732, 0.00046539975104573, 0.0007956127502551822, 0.0008923624901797472, 0.0008994953327500175, - 0.0008923624901797472]; initial_density1=0.9999, - initial_density2=0.0001) + 0.0008923624901797472]; + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001)) @long run_test(test_input_chebyshev_split_1_moment, 2*π*1.4467, -2*π*0.6020, [-0.00010000500033334732, 0.00046539975104573, 0.0007956127502551822, 0.0008923624901797472, 0.0008994953327500175, - 0.0008923624901797472]; initial_density1=0.9999, - initial_density2=0.0001, charge_exchange_frequency=2*π*2.0) + 0.0008923624901797472]; + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001), + charge_exchange_frequency=2*π*2.0) # n_i< 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999)) @long run_test(test_input_chebyshev_split_1_moment, 2*π*0.0, -2*π*0.5112, [-9.210340371976182, -9.209774967224805, -9.209444754225593, -9.209348004485669, -9.2093408716431, -9.209348004485669]; - initial_density1=0.0001, initial_density2=0.9999, + ion_species_1 = OptionsDict("initial_density" => 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=0.5 @long run_test(test_input_chebyshev_split_1_moment, 2*π*1.2671, -2*π*0.8033, [-0.34657359027997264, -0.34629088790428314, -0.34612578140467837, -0.34607740653471614, -0.34607384011343095, -0.34607740653471614], - 30; T_e=0.5, nstep=1300, charge_exchange_frequency=2*π*0.0) + 30; composition = OptionsDict("T_e" => 0.5), + timestepping = OptionsDict("nstep" => 1300), + charge_exchange_frequency=2*π*0.0) @long run_test(test_input_chebyshev_split_1_moment, 2*π*0.0, -2*π*0.2727, [-0.34657359027997264, -0.34629088790428314, -0.34612578140467837, -0.34607740653471614, -0.34607384011343095, -0.34607740653471614]; - T_e=0.5, charge_exchange_frequency=2*π*2.0) + composition = OptionsDict("T_e" => 0.5), + charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=4 @long run_test(test_input_chebyshev_split_1_moment, 2*π*1.9919, -2*π*0.2491, [-2.772588722239781, -2.770327103234265, -2.769006251237427, -2.768619252277729, -2.7685907209074476, -2.768619252277729]; - T_e=4.0) + composition = OptionsDict("T_e" => 4.0)) # CX=2*π*2.0 case with T_e=4 is too hard to converge, so skip end @@ -621,41 +667,48 @@ function run_test_set_chebyshev_split_2_moments() @long run_test(test_input_chebyshev_split_2_moments, 2*π*1.4467, -2*π*0.6020, [-0.00010000500033334732, 0.00046539975104573, 0.0007956127502551822, 0.0008923624901797472, 0.0008994953327500175, - 0.0008923624901797472]; initial_density1=0.9999, - initial_density2=0.0001) + 0.0008923624901797472]; + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001)) @long run_test(test_input_chebyshev_split_2_moments, 2*π*1.4467, -2*π*0.6020, [-0.00010000500033334732, 0.00046539975104573, 0.0007956127502551822, 0.0008923624901797472, 0.0008994953327500175, - 0.0008923624901797472]; initial_density1=0.9999, - initial_density2=0.0001, charge_exchange_frequency=2*π*2.0) + 0.0008923624901797472]; + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001), + charge_exchange_frequency=2*π*2.0) # n_i< 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999)) @long run_test(test_input_chebyshev_split_2_moments, 2*π*0.0, -2*π*0.5112, [-9.210340371976182, -9.209774967224805, -9.209444754225593, -9.209348004485669, -9.2093408716431, -9.209348004485669]; - initial_density1=0.0001, initial_density2=0.9999, + ion_species_1 = OptionsDict("initial_density" => 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=0.5 @long run_test(test_input_chebyshev_split_2_moments, 2*π*1.2671, -2*π*0.8033, [-0.34657359027997264, -0.34629088790428314, -0.34612578140467837, -0.34607740653471614, -0.34607384011343095, -0.34607740653471614], - 40; T_e=0.5, nstep=1300, nwrite=10, + 40; composition = OptionsDict("T_e" => 0.5), + timestepping = OptionsDict("nstep" => 1300, "nwrite" => 10), charge_exchange_frequency=2*π*0.0) @long run_test(test_input_chebyshev_split_2_moments, 2*π*0.0, -2*π*0.2727, [-0.34657359027997264, -0.34629088790428314, -0.34612578140467837, -0.34607740653471614, -0.34607384011343095, -0.34607740653471614]; - T_e=0.5, charge_exchange_frequency=2*π*2.0) + composition = OptionsDict("T_e" => 0.5), + charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=4 @long run_test(test_input_chebyshev_split_2_moments, 2*π*1.9919, -2*π*0.2491, [-2.772588722239781, -2.770327103234265, -2.769006251237427, -2.768619252277729, -2.7685907209074476, -2.768619252277729]; - T_e=4.0) + composition = OptionsDict("T_e" => 4.0)) # CX=2*π*2.0 case with T_e=4 is too hard to converge, so skip end @@ -681,40 +734,48 @@ function run_test_set_chebyshev_split_3_moments() @long run_test(test_input_chebyshev_split_3_moments, 2*π*1.4467, -2*π*0.6020, [-0.00010000500033334732, 0.00046539975104573, 0.0007956127502551822, 0.0008923624901797472, 0.0008994953327500175, - 0.0008923624901797472]; initial_density1=0.9999, - initial_density2=0.0001) + 0.0008923624901797472]; + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001)) @long run_test(test_input_chebyshev_split_3_moments, 2*π*1.4467, -2*π*0.6020, [-0.00010000500033334732, 0.00046539975104573, 0.0007956127502551822, 0.0008923624901797472, 0.0008994953327500175, - 0.0008923624901797472]; initial_density1=0.9999, - initial_density2=0.0001, charge_exchange_frequency=2*π*2.0) + 0.0008923624901797472]; + ion_species_1 = OptionsDict("initial_density" => 0.9999), + neutral_species_1 = OptionsDict("initial_density" => 0.0001), + charge_exchange_frequency=2*π*2.0) # n_i< 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999)) @long run_test(test_input_chebyshev_split_3_moments, 2*π*0.0, -2*π*0.5112, [-9.210340371976182, -9.209774967224805, -9.209444754225593, -9.209348004485669, -9.2093408716431, -9.209348004485669]; - initial_density1=0.0001, initial_density2=0.9999, + ion_species_1 = OptionsDict("initial_density" => 0.0001), + neutral_species_1 = OptionsDict("initial_density" => 0.9999), charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=0.5 @long run_test(test_input_chebyshev_split_3_moments, 2*π*1.2671, -2*π*0.8033, [-0.34657359027997264, -0.34629088790428314, -0.34612578140467837, -0.34607740653471614, -0.34607384011343095, -0.34607740653471614], - 80; T_e=0.5, nstep=1300, nwrite=5, charge_exchange_frequency=2*π*0.0) + 80; composition = OptionsDict("T_e" => 0.5), + timestepping = OptionsDict("nstep" => 1300, "nwrite" => 5), + charge_exchange_frequency=2*π*0.0) @long run_test(test_input_chebyshev_split_3_moments, 2*π*0.0, -2*π*0.2727, [-0.34657359027997264, -0.34629088790428314, -0.34612578140467837, -0.34607740653471614, -0.34607384011343095, -0.34607740653471614]; - T_e=0.5, charge_exchange_frequency=2*π*2.0) + composition = OptionsDict("T_e" => 0.5), + charge_exchange_frequency=2*π*2.0) # n_i=n_n T_e=4 @long run_test(test_input_chebyshev_split_3_moments, 2*π*1.9919, -2*π*0.2491, [-2.772588722239781, -2.770327103234265, -2.769006251237427, -2.768619252277729, -2.7685907209074476, -2.768619252277729]; - T_e=4.0) + composition = OptionsDict("T_e" => 4.0)) # CX=2*π*2.0 case with T_e=4 is too hard to converge, so skip end diff --git a/moment_kinetics/test/wall_bc_tests.jl b/moment_kinetics/test/wall_bc_tests.jl index ab09fec48..ccb03adbe 100644 --- a/moment_kinetics/test/wall_bc_tests.jl +++ b/moment_kinetics/test/wall_bc_tests.jl @@ -9,60 +9,61 @@ using Base.Filesystem: tempname using MPI using moment_kinetics.coordinates: define_coordinate -using moment_kinetics.input_structs: grid_input, advection_input +using moment_kinetics.input_structs: grid_input, advection_input, merge_dict_with_kwargs! using moment_kinetics.interpolation: interpolate_to_grid_z using moment_kinetics.load_data: open_readonly_output_file using moment_kinetics.load_data: load_fields_data, load_pdf_data, load_time_data, load_species_data +using moment_kinetics.type_definitions: OptionsDict # default inputs for tests -test_input_finite_difference = Dict("n_ion_species" => 1, - "n_neutral_species" => 1, - "boltzmann_electron_response" => true, +test_input_finite_difference = Dict("composition" => OptionsDict("n_ion_species" => 1, + "n_neutral_species" => 1, + "electron_physics" => "boltzmann_electron_response", + "T_e" => 1.0, + "T_wall" => 1.0), + "ion_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 0.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_ion_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "neutral_species_1" => OptionsDict("initial_density" => 1.0, + "initial_temperature" => 1.0), + "z_IC_neutral_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 0.001, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), + "vpa_IC_neutral_species_1" => OptionsDict("initialization_option" => "gaussian", + "density_amplitude" => 1.0, + "density_phase" => 0.0, + "upar_amplitude" => 0.0, + "upar_phase" => 0.0, + "temperature_amplitude" => 0.0, + "temperature_phase" => 0.0), "run_name" => "finite_difference", "evolve_moments_density" => false, "evolve_moments_parallel_flow" => false, "evolve_moments_parallel_pressure" => false, "evolve_moments_conservation" => false, - "T_e" => 1.0, - "T_wall" => 1.0, - "initial_density1" => 1.0, - "initial_temperature1" => 1.0, - "z_IC_option1" => "gaussian", - "z_IC_density_amplitude1" => 0.0, - "z_IC_density_phase1" => 0.0, - "z_IC_upar_amplitude1" => 0.0, - "z_IC_upar_phase1" => 0.0, - "z_IC_temperature_amplitude1" => 0.0, - "z_IC_temperature_phase1" => 0.0, - "vpa_IC_option1" => "gaussian", - "vpa_IC_density_amplitude1" => 1.0, - "vpa_IC_density_phase1" => 0.0, - "vpa_IC_upar_amplitude1" => 0.0, - "vpa_IC_upar_phase1" => 0.0, - "vpa_IC_temperature_amplitude1" => 0.0, - "vpa_IC_temperature_phase1" => 0.0, - "initial_density2" => 1.0, - "initial_temperature2" => 1.0, - "z_IC_option2" => "gaussian", - "z_IC_density_amplitude2" => 0.001, - "z_IC_density_phase2" => 0.0, - "z_IC_upar_amplitude2" => 0.0, - "z_IC_upar_phase2" => 0.0, - "z_IC_temperature_amplitude2" => 0.0, - "z_IC_temperature_phase2" => 0.0, - "vpa_IC_option2" => "gaussian", - "vpa_IC_density_amplitude2" => 1.0, - "vpa_IC_density_phase2" => 0.0, - "vpa_IC_upar_amplitude2" => 0.0, - "vpa_IC_upar_phase2" => 0.0, - "vpa_IC_temperature_amplitude2" => 0.0, - "vpa_IC_temperature_phase2" => 0.0, "charge_exchange_frequency" => 2.0, "ionization_frequency" => 2.0, "constant_ionization_rate" => false, - "timestepping" => Dict{String,Any}("nstep" => 10000, + "timestepping" => OptionsDict("nstep" => 10000, "dt" => 1.0e-5, "nwrite" => 100, "split_operators" => false), @@ -142,10 +143,10 @@ function run_test(test_input, expected_phi, tolerance; args...) # Make a copy to make sure nothing modifies the input Dicts defined in this test # script. - test_input = deepcopy(test_input) + input = deepcopy(test_input) # Convert keyword arguments to a unique name - name = test_input["run_name"] * ", with element spacing: " * test_input["z_element_spacing_option"] + name = input["run_name"] * ", with element spacing: " * input["z_element_spacing_option"] if length(args) > 0 name = string(name, "_", (string(k, "-", v, "_") for (k, v) in args)...) @@ -156,12 +157,8 @@ function run_test(test_input, expected_phi, tolerance; args...) # Provide some progress info println(" - testing ", name) - # Convert dict from symbol keys to String keys - modified_inputs = Dict(String(k) => v for (k, v) in args) - # Update default inputs with values to be changed - input = merge(test_input, modified_inputs) - + merge_dict_with_kwargs!(input; args...) input["run_name"] = name # Suppress console output while running diff --git a/plots_post_processing/plots_post_processing/src/plot_MMS_sequence.jl b/plots_post_processing/plots_post_processing/src/plot_MMS_sequence.jl index 92d780b27..17ba9c02b 100644 --- a/plots_post_processing/plots_post_processing/src/plot_MMS_sequence.jl +++ b/plots_post_processing/plots_post_processing/src/plot_MMS_sequence.jl @@ -17,7 +17,7 @@ using ..post_processing_input: pp using ..plots_post_processing: compare_ion_pdf_symbolic_test, compare_fields_symbolic_test using ..plots_post_processing: compare_moments_symbolic_test, compare_neutral_pdf_symbolic_test using ..plots_post_processing: allocate_global_zr_neutral_moments, allocate_global_zr_ion_moments -using ..plots_post_processing: allocate_global_zr_fields, get_composition +using ..plots_post_processing: allocate_global_zr_fields using ..plots_post_processing: get_coords_nelement, get_coords_ngrid using moment_kinetics.array_allocation: allocate_float using moment_kinetics.type_definitions: mk_float, mk_int @@ -29,9 +29,10 @@ using moment_kinetics.load_data: load_block_data, load_coordinate_data, load_inp using moment_kinetics.load_data: read_distributed_zr_data!, construct_global_zr_coords using moment_kinetics.velocity_moments: integrate_over_vspace using moment_kinetics.manufactured_solns: manufactured_solutions, manufactured_electric_fields -using moment_kinetics.moment_kinetics_input: mk_input, read_input_file, get_default_rhostar +using moment_kinetics.moment_kinetics_input: mk_input, read_input_file using moment_kinetics.input_structs: geometry_input using moment_kinetics.reference_parameters +using moment_kinetics.species_input: get_species_input import Base: get @@ -240,14 +241,8 @@ function get_MMS_error_data(path_list,scan_type,scan_name) else Lr_in = 1.0 end - composition = get_composition(scan_input) - - reference_params = setup_reference_parameters(scan_input) - option = get(scan_input, "geometry_option", "constant-helical") #"1D-mirror" - pitch = get(scan_input, "pitch", 1.0) - rhostar = get(scan_input, "rhostar", get_default_rhostar(reference_params)) - DeltaB = get(scan_input, "DeltaB", 1.0) - geo_in = geometry_input(rhostar,option,pitch,DeltaB) + composition = get_species_input(scan_input) + geo_in = setup_geometry_input(scan_input) manufactured_solns_list = manufactured_solutions(manufactured_solns_input,Lr_in,z.L,r_bc,z_bc,geo_in,composition,species,r.n,vperp.n) dfni_func = manufactured_solns_list.dfni_func diff --git a/plots_post_processing/plots_post_processing/src/plots_post_processing.jl b/plots_post_processing/plots_post_processing/src/plots_post_processing.jl index 00b8c7558..2c56208de 100644 --- a/plots_post_processing/plots_post_processing/src/plots_post_processing.jl +++ b/plots_post_processing/plots_post_processing/src/plots_post_processing.jl @@ -59,14 +59,15 @@ using moment_kinetics.velocity_moments: integrate_over_vspace using moment_kinetics.manufactured_solns: manufactured_solutions, manufactured_electric_fields, manufactured_geometry -using moment_kinetics.moment_kinetics_input: mk_input, get, get_default_rhostar +using moment_kinetics.moment_kinetics_input: mk_input, get using moment_kinetics.input_structs: geometry_input, grid_input, species_composition -using moment_kinetics.input_structs: electron_physics_type, boltzmann_electron_response, +using moment_kinetics.input_structs: boltzmann_electron_response, #electron_physics_type, boltzmann_electron_response_with_simple_sheath +using moment_kinetics.species_input: get_species_input using moment_kinetics.reference_parameters using moment_kinetics.geo: init_magnetic_geometry using .post_processing_input: pp -using .shared_utils: calculate_and_write_frequencies, get_geometry, get_composition +using .shared_utils: calculate_and_write_frequencies, get_geometry using TOML import Base: get @@ -679,7 +680,7 @@ function analyze_and_plot_data(prefix...; run_index=nothing) geometry = get_tuple_of_return_values(get_geometry, scan_input, z, r) composition = - get_tuple_of_return_values(get_composition, scan_input) + get_tuple_of_return_values(get_species_input, scan_input) # initialise the post-processing input options nwrite_movie, itime_min, itime_max, nwrite_movie_pdfs, itime_min_pdfs, itime_max_pdfs, @@ -3242,7 +3243,7 @@ function plot_fields_2D(phi, Ez, Er, time, z, r, iz0, ir0, trygif(anim, outfile, fps=5) elseif pp.animate_phi_vs_r_z && nr == 1 && nz > 1 # make a gif animation of ϕ(z) at different times anim = @animate for i ∈ itime_min:nwrite_movie:itime_max - @views plot(z, phi[:,1,i], xlabel="z", ylabel=L"\widetilde{\phi}", ylims = (phimin,phimax)) + @views plot(z, phi[:,1,i], xlabel="z", ylabel=L"\widetilde{\phi}", ylims = (phimin,phimax),label ="") end outfile = string(run_name, "_phi_vs_z.gif") trygif(anim, outfile, fps=5) @@ -3267,13 +3268,13 @@ function plot_fields_2D(phi, Ez, Er, time, z, r, iz0, ir0, outfile = string(run_name, "_Ez"*description*"_vs_r_z.gif") trygif(anim, outfile, fps=5) anim = @animate for i ∈ itime_min:nwrite_movie:itime_max - @views plot(r, Ez[1,:,i], xlabel="r", ylabel=L"\widetilde{E}_z", ylims = (Ezmin,Ezmax)) + @views plot(r, Ez[1,:,i], xlabel="r", ylabel=L"\widetilde{E}_z", ylims = (Ezmin,Ezmax), label="") end outfile = string(run_name, "_Ez(zwall-)_vs_r.gif") trygif(anim, outfile, fps=5) elseif pp.animate_Ez_vs_r_z && nr == 1 && nz > 1 anim = @animate for i ∈ itime_min:nwrite_movie:itime_max - @views plot(z, Ez[:,1,i], xlabel="z", ylabel=L"\widetilde{E}_z", ylims = (Ezmin,Ezmax)) + @views plot(z, Ez[:,1,i], xlabel="z", ylabel=L"\widetilde{E}_z", ylims = (Ezmin,Ezmax), label="") end outfile = string(run_name, "_Ez_vs_z.gif") trygif(anim, outfile, fps=5) @@ -3290,7 +3291,7 @@ function plot_fields_2D(phi, Ez, Er, time, z, r, iz0, ir0, outfile = string(run_name, "_Er"*description*"(r,z_wall-)_vs_r.pdf") trysavefig(outfile) anim = @animate for i ∈ itime_min:nwrite_movie:itime_max - @views plot(r, Er[1,:,i], xlabel="r", ylabel=L"\widetilde{E}_r", ylims = (Ermin,Ermax)) + @views plot(r, Er[1,:,i], xlabel="r", ylabel=L"\widetilde{E}_r", ylims = (Ermin,Ermax), label="") end outfile = string(run_name, "_Er(zwall-)_vs_r.gif") trygif(anim, outfile, fps=5) @@ -3319,7 +3320,7 @@ function plot_ion_moments_2D(density, parallel_flow, parallel_pressure, description = "_ion_spec"*string(is)*"_" # the density densitymin = minimum(density[:,:,is,:]) - densitymax = maximum(density) + densitymax = maximum(density[:,:,is,:]) if pp.plot_density_vs_r0_z && nz > 1 # plot last timestep density[z,ir0] @views plot(z, density[:,ir0,is,end], xlabel=L"z/L_z", ylabel=L"n_i") outfile = string(run_name, "_density"*description*"(r0,z)_vs_z.pdf") @@ -3337,7 +3338,13 @@ function plot_ion_moments_2D(density, parallel_flow, parallel_pressure, end outfile = string(run_name, "_density"*description*"_vs_r_z.gif") trygif(anim, outfile, fps=5) - end + elseif pp.animate_density_vs_r_z && nr == 1 && nz > 1 + anim = @animate for i ∈ itime_min:nwrite_movie:itime_max + @views plot(z, density[:,1,is,i], xlabel="z", ylabel=L"n_i", ylims = (densitymin,densitymax),label ="") + end + outfile = string(run_name, "_density"*description*"_vs_z.gif") + trygif(anim, outfile, fps=5) + end if pp.plot_density_vs_r_z && nr > 1 && nz > 1 @views heatmap(r, z, density[:,:,is,end], xlabel=L"r", ylabel=L"z", c = :deep, interpolation = :cubic, windowsize = (360,240), margin = 15pt) @@ -3354,7 +3361,7 @@ function plot_ion_moments_2D(density, parallel_flow, parallel_pressure, end # the parallel flow parallel_flowmin = minimum(parallel_flow[:,:,is,:]) - parallel_flowmax = maximum(parallel_flow) + parallel_flowmax = maximum(parallel_flow[:,:,is,:]) if pp.plot_parallel_flow_vs_r0_z && nz > 1 # plot last timestep parallel_flow[z,ir0] @views plot(z, parallel_flow[:,ir0,is,end], xlabel=L"z/L_z", ylabel=L"u_{i\|\|}") outfile = string(run_name, "_parallel_flow"*description*"(r0,z)_vs_z.pdf") @@ -3372,6 +3379,12 @@ function plot_ion_moments_2D(density, parallel_flow, parallel_pressure, end outfile = string(run_name, "_parallel_flow"*description*"_vs_r_z.gif") trygif(anim, outfile, fps=5) + elseif pp.animate_parallel_flow_vs_r_z && nr == 1 && nz > 1 + anim = @animate for i ∈ itime_min:nwrite_movie:itime_max + @views plot(z, parallel_flow[:,1,is,i], xlabel="z", ylabel=L"u_{i\|\|}", ylims = (parallel_flowmin,parallel_flowmax),label ="") + end + outfile = string(run_name, "_parallel_flow"*description*"_vs_z.gif") + trygif(anim, outfile, fps=5) end if pp.plot_parallel_flow_vs_r_z && nr > 1 && nz > 1 @views heatmap(r, z, parallel_flow[:,:,is,end], xlabel=L"r", ylabel=L"z", c = :deep, interpolation = :cubic, @@ -3499,6 +3512,14 @@ function plot_ion_moments_2D(density, parallel_flow, parallel_pressure, label = [L"p_{i\|\|}" L"p_{i\perp}" L"p_{i}"], foreground_color_legend = nothing, background_color_legend = nothing) outfile = string(run_name, "_all_pressures"*description*"(r0,z)_vs_z.pdf") trysavefig(outfile) + pmin = min(minimum(parallel_pressure[:,ir0,is,:]),minimum(perpendicular_pressure[:,ir0,is,:]),minimum(total_pressure[:,ir0,is,:])) + pmax = max(maximum(parallel_pressure[:,ir0,is,:]),maximum(perpendicular_pressure[:,ir0,is,:]),maximum(total_pressure[:,ir0,is,:])) + anim = @animate for i ∈ itime_min:nwrite_movie:itime_max + @views plot([z,z,z], [parallel_pressure[:,ir0,is,i],perpendicular_pressure[:,ir0,is,i],total_pressure[:,ir0,is,i]], xlabel=L"z/L_z", ylabel="", + label = [L"p_{i\|\|}" L"p_{i\perp}" L"p_{i}"], foreground_color_legend = nothing, background_color_legend = nothing, ylims = (pmin,pmax)) + end + outfile = string(run_name, "_all_pressures"*description*"(r0,z)_vs_z.gif") + trygif(anim, outfile, fps=5) end # the thermal speed if pp.plot_vth0_vs_t diff --git a/util/precompile_makie_plots.jl b/util/precompile_makie_plots.jl index 80a0dcb1e..132556e93 100644 --- a/util/precompile_makie_plots.jl +++ b/util/precompile_makie_plots.jl @@ -1,4 +1,5 @@ using moment_kinetics +using moment_kinetics.type_definitions: OptionsDict using makie_post_processing # Create a temporary directory for test output @@ -8,7 +9,6 @@ mkpath(test_output_directory) input_dict = Dict("run_name"=>run_name, "base_directory" => test_output_directory, - "dt" => 0.0, "r_ngrid" => 5, "r_nelement" => 1, "r_bc" => "periodic", @@ -42,7 +42,7 @@ input_dict = Dict("run_name"=>run_name, "vz_bc" => "periodic", "vz_L" => 4.0, "vz_discretization" => "chebyshev_pseudospectral", - "timestepping" => Dict{String,Any}("nstep" => 1)) + "timestepping" => OptionsDict("nstep" => 1, "dt" => 2.0e-11)) run_moment_kinetics(input_dict) diff --git a/util/precompile_plots_plots.jl b/util/precompile_plots_plots.jl index a67d85103..e299919fc 100644 --- a/util/precompile_plots_plots.jl +++ b/util/precompile_plots_plots.jl @@ -1,4 +1,5 @@ using moment_kinetics +using moment_kinetics.type_definitions: OptionsDict using plots_post_processing # Create a temporary directory for test output @@ -8,7 +9,6 @@ mkpath(test_output_directory) input_dict = Dict("run_name"=>run_name, "base_directory" => test_output_directory, - "dt" => 0.0, "r_ngrid" => 5, "r_nelement" => 1, "r_bc" => "periodic", @@ -42,7 +42,7 @@ input_dict = Dict("run_name"=>run_name, "vz_bc" => "periodic", "vz_L" => 4.0, "vz_discretization" => "chebyshev_pseudospectral", - "timestepping" => Dict{String,Any}("nstep" => 1)) + "timestepping" => OptionsDict("nstep" => 1, "dt" => 2.0e-11)) run_moment_kinetics(input_dict) diff --git a/util/precompile_run.jl b/util/precompile_run.jl index d4e16965e..41f6b1d57 100644 --- a/util/precompile_run.jl +++ b/util/precompile_run.jl @@ -3,6 +3,7 @@ using Pkg Pkg.activate(".") using moment_kinetics +using moment_kinetics.type_definitions: OptionsDict # Create a temporary directory for test output test_output_directory = tempname() @@ -10,7 +11,6 @@ mkpath(test_output_directory) base_input = Dict("run_name" => "precompilation", "base_directory" => test_output_directory, - "dt" => 0.0, "r_ngrid" => 5, "r_nelement" => 3, "r_bc" => "periodic", @@ -44,7 +44,7 @@ base_input = Dict("run_name" => "precompilation", "vz_bc" => "zero", "vz_L" => 8.0, "vz_discretization" => "finite_difference", - "timestepping" => Dict{String,Any}("nstep" => 1)) + "timestepping" => OptionsDict("nstep" => 1, "dt" => 2.0e-11)) cheb_input = merge(base_input, Dict("r_discretization" => "chebyshev_pseudospectral", "z_discretization" => "chebyshev_pseudospectral", "vperp_discretization" => "chebyshev_pseudospectral", @@ -66,22 +66,22 @@ for input ∈ [base_input, cheb_input, wall_bc_input, wall_bc_cheb_input] push!(inputs_list, x) end -collisions_input1 = merge(wall_bc_cheb_input, Dict("n_neutral_species" => 0, - "krook_collisions" => Dict{String,Any}("use_krook" => true), - "fokker_planck_collisions" => Dict{String,Any}("use_fokker_planck" => true, "self_collisions" => true, "slowing_down_test" => true), +collisions_input1 = merge(wall_bc_cheb_input, Dict( "composition" => OptionsDict("n_neutral_species" => 0), + "krook_collisions" => OptionsDict("use_krook" => true), + "fokker_planck_collisions" => OptionsDict("use_fokker_planck" => true, "self_collisions" => true, "slowing_down_test" => true), "vperp_discretization" => "gausslegendre_pseudospectral", "vpa_discretization" => "gausslegendre_pseudospectral", )) -collisions_input2 = merge(wall_bc_cheb_input, Dict("n_neutral_species" => 0, - "krook_collisions" => Dict{String,Any}("use_krook" => true), - "fokker_planck_collisions" => Dict{String,Any}("use_fokker_planck" => true, "self_collisions" => true, "slowing_down_test" => true), +collisions_input2 = merge(wall_bc_cheb_input, Dict("composition" => OptionsDict("n_neutral_species" => 0), + "krook_collisions" => OptionsDict("use_krook" => true), + "fokker_planck_collisions" => OptionsDict("use_fokker_planck" => true, "self_collisions" => true, "slowing_down_test" => true), "vperp_discretization" => "gausslegendre_pseudospectral", "vpa_discretization" => "gausslegendre_pseudospectral", "vperp_bc" => "zero-impose-regularity", )) # add an additional input for every geometry option available in addition to the default -geo_input1 = merge(wall_bc_cheb_input, Dict("n_neutral_species" => 0, - "geometry" => Dict{String,Any}("option" => "1D-mirror", "DeltaB" => 0.5, "pitch" => 0.5, "rhostar" => 1.0))) +geo_input1 = merge(wall_bc_cheb_input, Dict("composition" => OptionsDict("n_neutral_species" => 0), + "geometry" => OptionsDict("option" => "1D-mirror", "DeltaB" => 0.5, "pitch" => 0.5, "rhostar" => 1.0))) kinetic_electron_input = merge(cheb_input, Dict("evolve_moments_density" => true, "evolve_moments_parallel_flow" => true, @@ -94,8 +94,8 @@ kinetic_electron_input = merge(cheb_input, Dict("evolve_moments_density" => true "vzeta_nelement" => 1, "vr_ngrid" => 1, "vr_nelement" => 1, - "electron_physics" => "kinetic_electrons", - "electron_timestepping" => Dict{String,Any}("nstep" => 1, + "composition" => OptionsDict("electron_physics" => "kinetic_electrons"), + "electron_timestepping" => OptionsDict("nstep" => 1, "dt" => 2.0e-11, "initialization_residual_value" => 1.0e10, "converged_residual_value" => 1.0e10, diff --git a/util/precompile_run_kinetic-electrons.jl b/util/precompile_run_kinetic-electrons.jl index b605fcf16..212d9f9bf 100644 --- a/util/precompile_run_kinetic-electrons.jl +++ b/util/precompile_run_kinetic-electrons.jl @@ -3,6 +3,7 @@ using Pkg Pkg.activate(".") using moment_kinetics +using moment_kinetics.type_definitions: OptionsDict # Create a temporary directory for test output test_output_directory = tempname() @@ -10,11 +11,10 @@ mkpath(test_output_directory) input = Dict("run_name" => "precompilation", "base_directory" => test_output_directory, - "dt" => 0.0, "evolve_moments_density" => true, "evolve_moments_parallel_flow" => true, "evolve_moments_parallel_pressure" => true, - "electron_physics" => "kinetic_electrons", + "composition" => OptionsDict("electron_physics" => "kinetic_electrons"), "r_ngrid" => 1, "r_nelement" => 1, "r_bc" => "periodic", @@ -48,9 +48,9 @@ input = Dict("run_name" => "precompilation", "vz_bc" => "zero", "vz_L" => 8.0, "vz_discretization" => "chebyshev_pseudospectral", - "timestepping" => Dict{String,Any}("nstep" => 1, + "timestepping" => OptionsDict("nstep" => 1, "dt" => 2.0e-11), - "electron_timestepping" => Dict{String,Any}("nstep" => 1, + "electron_timestepping" => OptionsDict("nstep" => 1, "dt" => 2.0e-11, "initialization_residual_value" => 1.0e10, "converged_residual_value" => 1.0e10, diff --git a/util/precompile_run_long.jl b/util/precompile_run_long.jl index fb80de9d6..441935757 100644 --- a/util/precompile_run_long.jl +++ b/util/precompile_run_long.jl @@ -6,6 +6,7 @@ using Pkg Pkg.activate(".") using moment_kinetics +using moment_kinetics.type_definitions: OptionsDict # Create a temporary directory for test output test_output_directory = tempname() @@ -13,7 +14,6 @@ mkpath(test_output_directory) base_input = Dict("run_name"=>"precompilation", "base_directory" => test_output_directory, - "dt" => 0.0, "z_ngrid" => 5, "z_nelement" => 1, "z_bc" => "periodic", @@ -22,13 +22,13 @@ base_input = Dict("run_name"=>"precompilation", "vpa_nelement" => 1, "vpa_bc" => "periodic", "vpa_discretization" => "finite_difference", - "timestepping" => Dict{String,Any}("nstep" => 1)) + "timestepping" => OptionsDict("nstep" => 1, "dt" => 2.0e-11)) cheb_input = merge(base_input, Dict("z_discretization" => "chebyshev_pseudospectral", "vpa_discretization" => "chebyshev_pseudospectral")) wall_bc_input = merge(base_input, Dict("z_bc" => "wall")) wall_bc_cheb_input = merge(cheb_input, Dict("z_bc" => "wall")) -inputs_list = Vector{Dict{String, Any}}(undef, 0) +inputs_list = Vector{OptionsDict}(undef, 0) for input ∈ [base_input, cheb_input, wall_bc_input, wall_bc_cheb_input] push!(inputs_list, input) x = merge(input, Dict("evolve_moments_density" => true, "ionization_frequency" => 0.0)) diff --git a/util/precompile_run_long_debug1.jl b/util/precompile_run_long_debug1.jl index 3340e140a..dbc009bfa 100644 --- a/util/precompile_run_long_debug1.jl +++ b/util/precompile_run_long_debug1.jl @@ -6,6 +6,7 @@ using Pkg Pkg.activate(".") using moment_kinetics +using moment_kinetics.type_definitions: OptionsDict # Create a temporary directory for test output test_output_directory = tempname() @@ -13,7 +14,6 @@ mkpath(test_output_directory) base_input = Dict("run_name"=>"precompilation", "base_directory" => test_output_directory, - "dt" => 0.0, "z_ngrid" => 5, "z_nelement" => 1, "z_bc" => "periodic", @@ -22,13 +22,13 @@ base_input = Dict("run_name"=>"precompilation", "vpa_nelement" => 1, "vpa_bc" => "periodic", "vpa_discretization" => "finite_difference", - "timestepping" => Dict{String,Any}("nstep" => 1)) + "timestepping" => OptionsDict("nstep" => 1, "dt" => 2.0e-11)) cheb_input = merge(base_input, Dict("z_discretization" => "chebyshev_pseudospectral", "vpa_discretization" => "chebyshev_pseudospectral")) wall_bc_input = merge(base_input, Dict("z_bc" => "wall")) wall_bc_cheb_input = merge(cheb_input, Dict("z_bc" => "wall")) -inputs_list = Vector{Dict{String, Any}}(undef, 0) +inputs_list = Vector{OptionsDict}(undef, 0) for input ∈ [base_input, cheb_input, wall_bc_input, wall_bc_cheb_input] push!(inputs_list, input) x = merge(input, Dict("evolve_moments_density" => true, "ionization_frequency" => 0.0)) diff --git a/util/precompile_run_short.jl b/util/precompile_run_short.jl index fb2ac5109..458cf803f 100644 --- a/util/precompile_run_short.jl +++ b/util/precompile_run_short.jl @@ -3,6 +3,7 @@ using Pkg Pkg.activate(".") using moment_kinetics +using moment_kinetics.type_definitions: OptionsDict # Create a temporary directory for test output test_output_directory = tempname() @@ -10,7 +11,7 @@ mkpath(test_output_directory) input_dict = Dict("run_name"=>"precompilation", "base_directory" => test_output_directory, - "timestepping" => Dict{String,Any}("nstep" => 1)) + "timestepping" => OptionsDict("nstep" => 1, "dt" => 2.0e-11)) to = TimerOutput() run_moment_kinetics(to, input_dict)