classes_dipolar_interactions_facade.f90 Source File

This File Depends On

sourcefile~~classes_dipolar_interactions_facade.f90~~EfferentGraph sourcefile~classes_dipolar_interactions_facade.f90 classes_dipolar_interactions_facade.f90 sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~types_dipolar_interactions_dynamic_wrapper.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~procedures_dipolar_interactions_visitor.f90 procedures_dipolar_interactions_visitor.f90 sourcefile~types_dipolar_interactions_dynamic_wrapper.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~types_dipolar_interactions_static_wrapper.f90 types_dipolar_interactions_static_wrapper.f90 sourcefile~types_dipolar_interactions_static_wrapper.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~procedures_dipolar_interactions_resetter.f90 procedures_dipolar_interactions_resetter.f90 sourcefile~types_dipolar_interactions_static_wrapper.f90->sourcefile~procedures_dipolar_interactions_resetter.f90 sourcefile~types_real_wrapper.f90 types_real_wrapper.f90 sourcefile~types_real_wrapper.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~types_real_wrapper.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~procedures_triangle_observables.f90 procedures_triangle_observables.f90 sourcefile~types_real_wrapper.f90->sourcefile~procedures_triangle_observables.f90 sourcefile~procedures_reals_factory.f90 procedures_reals_factory.f90 sourcefile~types_real_wrapper.f90->sourcefile~procedures_reals_factory.f90 sourcefile~procedures_dipolar_interactions_visitor.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_box_size_memento.f90 classes_box_size_memento.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_box_size_memento.f90->sourcefile~types_dipolar_interactions_static_wrapper.f90 sourcefile~classes_des_real_pair.f90 classes_des_real_pair.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_real_pair.f90 sourcefile~classes_box_size_memento.f90->sourcefile~procedures_dipolar_interactions_resetter.f90 sourcefile~classes_des_real_component.f90 classes_des_real_component.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_real_component.f90 sourcefile~classes_des_reci_visitor.f90 classes_des_reci_visitor.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~classes_des_reci_structure.f90 classes_des_reci_structure.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~classes_des_reci_weight.f90 classes_des_reci_weight.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_reci_weight.f90 sourcefile~classes_des_real_pair.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_des_real_pair.f90->sourcefile~types_dipolar_interactions_static_wrapper.f90 sourcefile~classes_des_real_pair.f90->sourcefile~procedures_dipolar_interactions_resetter.f90 sourcefile~classes_des_real_pair.f90->sourcefile~classes_des_real_component.f90 sourcefile~types_component_wrapper.f90 types_component_wrapper.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~types_component_wrapper.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_mixture_total_moment.f90 classes_mixture_total_moment.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_mixture_total_moment.f90 sourcefile~classes_dlc_structures.f90 classes_dlc_structures.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_dlc_structures.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~classes_periodic_box.f90 classes_periodic_box.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_box_size_memento.f90 sourcefile~classes_des_self_component.f90 classes_des_self_component.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_des_self_component.f90 sourcefile~classes_des_surf_mixture.f90 classes_des_surf_mixture.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_des_surf_mixture.f90 sourcefile~classes_dlc_visitor.f90 classes_dlc_visitor.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_des_real_component.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~classes_component_coordinates.f90 classes_component_coordinates.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_component_coordinates.f90 sourcefile~classes_reciprocal_lattice.f90 classes_reciprocal_lattice.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_reciprocal_lattice.f90 sourcefile~classes_dlc_weight.f90 classes_dlc_weight.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_dlc_weight.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_dlc_structures.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~classes_parallelepiped_domain.f90 classes_parallelepiped_domain.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~classes_visitable_walls.f90 classes_visitable_walls.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_visitable_walls.f90 sourcefile~procedures_dipolar_interactions_resetter.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_des_self_component.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_self_component.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_des_surf_mixture.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_convergence_parameter.f90 classes_des_convergence_parameter.f90 sourcefile~classes_des_convergence_parameter.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_convergence_parameter.f90->sourcefile~classes_des_real_pair.f90 sourcefile~classes_des_convergence_parameter.f90->sourcefile~classes_des_self_component.f90 sourcefile~classes_des_convergence_parameter.f90->sourcefile~classes_des_reci_weight.f90 sourcefile~classes_dlc_visitor.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_real_component.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_real_component.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_des_reci_visitor.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_component_dipole_moments.f90 classes_component_dipole_moments.f90 sourcefile~classes_component_dipole_moments.f90->sourcefile~types_component_wrapper.f90 sourcefile~classes_component_dipole_moments.f90->sourcefile~classes_des_self_component.f90 sourcefile~classes_component_dipole_moments.f90->sourcefile~classes_des_real_component.f90 sourcefile~procedures_dipoles_field_interaction.f90 procedures_dipoles_field_interaction.f90 sourcefile~classes_component_dipole_moments.f90->sourcefile~procedures_dipoles_field_interaction.f90 sourcefile~classes_permittivity.f90 classes_permittivity.f90 sourcefile~classes_permittivity.f90->sourcefile~classes_des_real_pair.f90 sourcefile~classes_permittivity.f90->sourcefile~classes_des_self_component.f90 sourcefile~classes_permittivity.f90->sourcefile~classes_des_surf_mixture.f90 sourcefile~classes_permittivity.f90->sourcefile~classes_dlc_weight.f90 sourcefile~classes_permittivity.f90->sourcefile~classes_des_reci_weight.f90 sourcefile~classes_field_expression.f90 classes_field_expression.f90 sourcefile~classes_permittivity.f90->sourcefile~classes_field_expression.f90 sourcefile~procedures_field_expression_factory.f90 procedures_field_expression_factory.f90 sourcefile~classes_permittivity.f90->sourcefile~procedures_field_expression_factory.f90 sourcefile~data_constants.f90 data_constants.f90 sourcefile~data_constants.f90->sourcefile~classes_box_size_memento.f90 sourcefile~data_constants.f90->sourcefile~classes_des_real_pair.f90 sourcefile~data_constants.f90->sourcefile~classes_periodic_box.f90 sourcefile~data_constants.f90->sourcefile~classes_des_self_component.f90 sourcefile~data_constants.f90->sourcefile~classes_des_surf_mixture.f90 sourcefile~data_constants.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~data_constants.f90->sourcefile~classes_des_real_component.f90 sourcefile~data_constants.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~data_constants.f90->sourcefile~classes_component_dipole_moments.f90 sourcefile~classes_coordinates.f90 classes_coordinates.f90 sourcefile~data_constants.f90->sourcefile~classes_coordinates.f90 sourcefile~data_constants.f90->sourcefile~classes_component_coordinates.f90 sourcefile~procedures_checks.f90 procedures_checks.f90 sourcefile~data_constants.f90->sourcefile~procedures_checks.f90 sourcefile~procedures_coordinates_micro.f90 procedures_coordinates_micro.f90 sourcefile~data_constants.f90->sourcefile~procedures_coordinates_micro.f90 sourcefile~data_constants.f90->sourcefile~classes_mixture_total_moment.f90 sourcefile~procedures_dipolar_interactions_micro.f90 procedures_dipolar_interactions_micro.f90 sourcefile~data_constants.f90->sourcefile~procedures_dipolar_interactions_micro.f90 sourcefile~types_particle_wrapper.f90 types_particle_wrapper.f90 sourcefile~data_constants.f90->sourcefile~types_particle_wrapper.f90 sourcefile~data_constants.f90->sourcefile~classes_reciprocal_lattice.f90 sourcefile~data_constants.f90->sourcefile~classes_dlc_weight.f90 sourcefile~data_constants.f90->sourcefile~classes_dlc_structures.f90 sourcefile~data_constants.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~data_constants.f90->sourcefile~classes_des_reci_weight.f90 sourcefile~classes_external_field.f90 classes_external_field.f90 sourcefile~data_constants.f90->sourcefile~classes_external_field.f90 sourcefile~data_constants.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~data_constants.f90->sourcefile~classes_field_expression.f90 sourcefile~data_constants.f90->sourcefile~classes_visitable_walls.f90 sourcefile~procedures_parallelepiped_domain_micro.f90 procedures_parallelepiped_domain_micro.f90 sourcefile~data_constants.f90->sourcefile~procedures_parallelepiped_domain_micro.f90 sourcefile~classes_floor_penetration.f90 classes_floor_penetration.f90 sourcefile~data_constants.f90->sourcefile~classes_floor_penetration.f90 sourcefile~procedures_field_expression_micro.f90 procedures_field_expression_micro.f90 sourcefile~data_constants.f90->sourcefile~procedures_field_expression_micro.f90 sourcefile~classes_coordinates.f90->sourcefile~classes_component_dipole_moments.f90 sourcefile~classes_coordinates.f90->sourcefile~classes_component_coordinates.f90 sourcefile~classes_component_coordinates.f90->sourcefile~types_component_wrapper.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_des_real_component.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_component_dipole_moments.f90 sourcefile~classes_component_coordinates.f90->sourcefile~procedures_dipoles_field_interaction.f90 sourcefile~procedures_checks.f90->sourcefile~classes_des_real_pair.f90 sourcefile~procedures_checks.f90->sourcefile~classes_periodic_box.f90 sourcefile~procedures_checks.f90->sourcefile~classes_des_convergence_parameter.f90 sourcefile~procedures_checks.f90->sourcefile~classes_component_dipole_moments.f90 sourcefile~procedures_checks.f90->sourcefile~classes_permittivity.f90 sourcefile~procedures_checks.f90->sourcefile~classes_component_coordinates.f90 sourcefile~procedures_checks.f90->sourcefile~procedures_coordinates_micro.f90 sourcefile~procedures_checks.f90->sourcefile~classes_mixture_total_moment.f90 sourcefile~procedures_checks.f90->sourcefile~classes_reciprocal_lattice.f90 sourcefile~procedures_checks.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~procedures_checks.f90->sourcefile~classes_field_expression.f90 sourcefile~procedures_checks.f90->sourcefile~procedures_field_expression_factory.f90 sourcefile~procedures_checks.f90->sourcefile~classes_visitable_walls.f90 sourcefile~classes_pair_potential.f90 classes_pair_potential.f90 sourcefile~procedures_checks.f90->sourcefile~classes_pair_potential.f90 sourcefile~procedures_checks.f90->sourcefile~classes_floor_penetration.f90 sourcefile~classes_min_distance.f90 classes_min_distance.f90 sourcefile~procedures_checks.f90->sourcefile~classes_min_distance.f90 sourcefile~classes_potential_expression.f90 classes_potential_expression.f90 sourcefile~procedures_checks.f90->sourcefile~classes_potential_expression.f90 sourcefile~classes_component_chemical_potential.f90 classes_component_chemical_potential.f90 sourcefile~procedures_checks.f90->sourcefile~classes_component_chemical_potential.f90 sourcefile~classes_num_particles.f90 classes_num_particles.f90 sourcefile~classes_num_particles.f90->sourcefile~types_component_wrapper.f90 sourcefile~classes_num_particles.f90->sourcefile~classes_component_coordinates.f90 sourcefile~procedures_coordinates_micro.f90->sourcefile~classes_component_coordinates.f90 sourcefile~procedures_errors.f90 procedures_errors.f90 sourcefile~procedures_errors.f90->sourcefile~classes_des_real_pair.f90 sourcefile~procedures_errors.f90->sourcefile~classes_periodic_box.f90 sourcefile~procedures_errors.f90->sourcefile~classes_component_coordinates.f90 sourcefile~procedures_errors.f90->sourcefile~procedures_checks.f90 sourcefile~procedures_errors.f90->sourcefile~classes_num_particles.f90 sourcefile~procedures_errors.f90->sourcefile~procedures_coordinates_micro.f90 sourcefile~procedures_errors.f90->sourcefile~classes_reciprocal_lattice.f90 sourcefile~procedures_errors.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~procedures_errors.f90->sourcefile~classes_field_expression.f90 sourcefile~procedures_errors.f90->sourcefile~procedures_field_expression_factory.f90 sourcefile~procedures_errors.f90->sourcefile~classes_visitable_walls.f90 sourcefile~procedures_errors.f90->sourcefile~classes_floor_penetration.f90 sourcefile~data_strings.f90 data_strings.f90 sourcefile~data_strings.f90->sourcefile~procedures_coordinates_micro.f90 sourcefile~classes_number_to_string.f90 classes_number_to_string.f90 sourcefile~data_strings.f90->sourcefile~classes_number_to_string.f90 sourcefile~types_potential_domain.f90 types_potential_domain.f90 sourcefile~types_potential_domain.f90->sourcefile~classes_des_real_pair.f90 sourcefile~types_potential_domain.f90->sourcefile~procedures_checks.f90 sourcefile~types_potential_domain.f90->sourcefile~classes_pair_potential.f90 sourcefile~classes_number_to_string.f90->sourcefile~procedures_checks.f90 sourcefile~types_potential_domain_selector.f90 types_potential_domain_selector.f90 sourcefile~types_potential_domain_selector.f90->sourcefile~classes_des_real_pair.f90 sourcefile~types_potential_domain_selector.f90->sourcefile~procedures_checks.f90 sourcefile~types_potential_domain_selector.f90->sourcefile~classes_pair_potential.f90 sourcefile~classes_mixture_total_moment.f90->sourcefile~classes_des_surf_mixture.f90 sourcefile~procedures_dipolar_interactions_micro.f90->sourcefile~classes_des_real_pair.f90 sourcefile~procedures_dipolar_interactions_micro.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~procedures_dipolar_interactions_micro.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~procedures_dipolar_interactions_micro.f90->sourcefile~classes_dlc_structures.f90 sourcefile~procedures_dipolar_interactions_micro.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~classes_structure_visitor.f90 classes_structure_visitor.f90 sourcefile~classes_structure_visitor.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~classes_structure_visitor.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_des_real_component.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_structure_visitor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_dlc_structures.f90 sourcefile~classes_structure_factor.f90 classes_structure_factor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_structure_factor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~types_particle_wrapper.f90->sourcefile~procedures_dipoles_field_interaction.f90 sourcefile~classes_reciprocal_lattice.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~classes_reciprocal_lattice.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~classes_reciprocal_lattice.f90->sourcefile~classes_dlc_weight.f90 sourcefile~classes_reciprocal_lattice.f90->sourcefile~classes_dlc_structures.f90 sourcefile~classes_reciprocal_lattice.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~classes_reciprocal_lattice.f90->sourcefile~classes_des_reci_weight.f90 sourcefile~classes_dlc_weight.f90->sourcefile~types_dipolar_interactions_static_wrapper.f90 sourcefile~classes_dlc_weight.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~classes_dlc_structures.f90->sourcefile~types_dipolar_interactions_static_wrapper.f90 sourcefile~classes_dlc_structures.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~classes_structure_factor.f90->sourcefile~classes_dlc_structures.f90 sourcefile~classes_structure_factor.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~procedures_visit_condition.f90 procedures_visit_condition.f90 sourcefile~procedures_visit_condition.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~procedures_visit_condition.f90->sourcefile~classes_des_real_component.f90 sourcefile~classes_des_reci_structure.f90->sourcefile~types_dipolar_interactions_static_wrapper.f90 sourcefile~classes_des_reci_structure.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~classes_des_reci_weight.f90->sourcefile~types_dipolar_interactions_static_wrapper.f90 sourcefile~classes_des_reci_weight.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~procedures_triangle_observables.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~procedures_dipoles_field_interaction.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~procedures_reals_factory.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_dipoles_field_interaction.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_external_field.f90 sourcefile~classes_field_expression.f90->sourcefile~classes_external_field.f90 sourcefile~classes_field_expression.f90->sourcefile~procedures_field_expression_factory.f90 sourcefile~procedures_field_expression_factory.f90->sourcefile~classes_external_field.f90 sourcefile~classes_visitable_walls.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~procedures_parallelepiped_domain_micro.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~classes_pair_potential.f90->sourcefile~classes_visitable_walls.f90 sourcefile~classes_floor_penetration.f90->sourcefile~classes_visitable_walls.f90 sourcefile~classes_min_distance.f90->sourcefile~classes_visitable_walls.f90 sourcefile~classes_potential_expression.f90->sourcefile~classes_pair_potential.f90 sourcefile~procedures_centered_block_micro.f90 procedures_centered_block_micro.f90 sourcefile~procedures_centered_block_micro.f90->sourcefile~classes_floor_penetration.f90 sourcefile~procedures_field_expression_micro.f90->sourcefile~classes_field_expression.f90 sourcefile~procedures_box_size.f90 procedures_box_size.f90 sourcefile~procedures_box_size.f90->sourcefile~classes_des_real_pair.f90 sourcefile~classes_component_chemical_potential.f90->sourcefile~types_component_wrapper.f90
Help

Files Dependent On This One

sourcefile~~classes_dipolar_interactions_facade.f90~~AfferentGraph sourcefile~classes_dipolar_interactions_facade.f90 classes_dipolar_interactions_facade.f90 sourcefile~procedures_dipolar_interactions_facades_factory.f90 procedures_dipolar_interactions_facades_factory.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~procedures_dipolar_interactions_facades_factory.f90 sourcefile~classes_box_volume_change.f90 classes_box_volume_change.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~classes_box_volume_change.f90 sourcefile~types_physical_model_wrapper.f90 types_physical_model_wrapper.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~types_physical_model_wrapper.f90 sourcefile~classes_volume_change_method.f90 classes_volume_change_method.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~classes_volume_change_method.f90 sourcefile~classes_boxes_volume_exchange.f90 classes_boxes_volume_exchange.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~procedures_physical_model_factory.f90 procedures_physical_model_factory.f90 sourcefile~procedures_dipolar_interactions_facades_factory.f90->sourcefile~procedures_physical_model_factory.f90 sourcefile~procedures_box_volume_change_factory.f90 procedures_box_volume_change_factory.f90 sourcefile~classes_box_volume_change.f90->sourcefile~procedures_box_volume_change_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_physical_model_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_box_volume_change_factory.f90 sourcefile~procedures_generating_algorithms_factory.f90 procedures_generating_algorithms_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~plmc_generate.f90 plmc_generate.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~plmc_generate.f90 sourcefile~procedures_markov_chain_generator_factory.f90 procedures_markov_chain_generator_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_markov_chain_generator_factory.f90 sourcefile~procedures_box_particle_exchange_factory.f90 procedures_box_particle_exchange_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_box_particle_exchange_factory.f90 sourcefile~procedures_plmc_resetter.f90 procedures_plmc_resetter.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_plmc_resetter.f90 sourcefile~procedures_plmc_visitor.f90 procedures_plmc_visitor.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_plmc_visitor.f90 sourcefile~procedures_markov_chain_explorer_factory.f90 procedures_markov_chain_explorer_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_boxes_volume_exchange_factory.f90 procedures_boxes_volume_exchange_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_boxes_volume_exchange_factory.f90 sourcefile~procedures_maximum_boxes_compression_explorer_factory.f90 procedures_maximum_boxes_compression_explorer_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_maximum_boxes_compression_explorer_factory.f90 sourcefile~procedures_box_particles_swap_factory.f90 procedures_box_particles_swap_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_box_particles_swap_factory.f90 sourcefile~procedures_boxes_particle_teleportation_factory.f90 procedures_boxes_particle_teleportation_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_boxes_particle_teleportation_factory.f90 sourcefile~procedures_volume_change_method_factory.f90 procedures_volume_change_method_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_volume_change_method_factory.f90 sourcefile~procedures_particle_insertion_method_factory.f90 procedures_particle_insertion_method_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_particle_insertion_method_factory.f90 sourcefile~procedures_box_particle_move_factory.f90 procedures_box_particle_move_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_box_particle_move_factory.f90 sourcefile~procedures_dipolar_neighbourhoods_visitors_factory.f90 procedures_dipolar_neighbourhoods_visitors_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_dipolar_neighbourhoods_visitors_factory.f90 sourcefile~procedures_boxes_particles_swap_factory.f90 procedures_boxes_particles_swap_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_boxes_particles_swap_factory.f90 sourcefile~plmc_explore.f90 plmc_explore.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~plmc_explore.f90 sourcefile~classes_volume_change_method.f90->sourcefile~procedures_volume_change_method_factory.f90 sourcefile~types_markov_chain_explorer_wrapper.f90 types_markov_chain_explorer_wrapper.f90 sourcefile~classes_volume_change_method.f90->sourcefile~types_markov_chain_explorer_wrapper.f90 sourcefile~procedures_exploration_inquirers.f90 procedures_exploration_inquirers.f90 sourcefile~classes_volume_change_method.f90->sourcefile~procedures_exploration_inquirers.f90 sourcefile~classes_boxes_volume_exchange.f90->sourcefile~procedures_boxes_volume_exchange_factory.f90 sourcefile~procedures_box_volume_change_factory.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~procedures_generating_algorithms_factory.f90->sourcefile~plmc_generate.f90 sourcefile~procedures_generating_algorithms_factory.f90->sourcefile~procedures_markov_chain_generator_factory.f90 sourcefile~procedures_box_particle_exchange_factory.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~procedures_plmc_resetter.f90->sourcefile~plmc_generate.f90 sourcefile~procedures_plmc_resetter.f90->sourcefile~plmc_explore.f90 sourcefile~procedures_plmc_visitor.f90->sourcefile~plmc_generate.f90 sourcefile~procedures_plmc_visitor.f90->sourcefile~plmc_explore.f90 sourcefile~procedures_markov_chain_explorer_factory.f90->sourcefile~plmc_explore.f90 sourcefile~procedures_boxes_volume_exchange_factory.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~procedures_maximum_boxes_compression_explorer_factory.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_box_particles_swap_factory.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~procedures_boxes_particle_teleportation_factory.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~procedures_volume_change_method_factory.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_particle_insertion_method_factory.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_box_particle_move_factory.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~procedures_dipolar_neighbourhoods_visitors_factory.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_boxes_particles_swap_factory.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~types_markov_chain_explorer_wrapper.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~types_markov_chain_explorer_wrapper.f90->sourcefile~plmc_explore.f90 sourcefile~procedures_exploring_writers_factory.f90 procedures_exploring_writers_factory.f90 sourcefile~types_markov_chain_explorer_wrapper.f90->sourcefile~procedures_exploring_writers_factory.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~procedures_dipolar_interactions_facades_factory.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~plmc_explore.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~procedures_exploring_writers_factory.f90 sourcefile~procedures_short_interactions_factory.f90 procedures_short_interactions_factory.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~procedures_short_interactions_factory.f90 sourcefile~procedures_short_interactions_factory.f90->sourcefile~procedures_physical_model_factory.f90
Help


Source Code

module classes_dipolar_interactions_facade

use, intrinsic :: iso_fortran_env, only: DP => REAL64
use classes_periodic_box, only: Abstract_Periodic_Box
use classes_box_size_memento, only: Abstract_Box_Size_Memento
use procedures_boxes_factory, boxes_destroy => destroy
use classes_des_real_pair, only: Abstract_DES_Real_Pair
use procedures_des_reci_factory, only: des_reci_destroy => destroy
use procedures_dlc_factory, only: dlc_destroy => destroy
use types_component_wrapper, only: Component_Wrapper
use procedures_des_real_factory, only: des_real_destroy => destroy
use types_dipolar_interactions_dynamic_wrapper, only: Dipolar_Interactions_Dynamic_Wrapper
use types_dipolar_interactions_static_wrapper, only: Dipolar_Interactions_Static_Wrapper
use types_real_wrapper, only: Real_Line
use procedures_dipolar_interactions_resetter, only: dipolar_interactions_reset => reset, &
    dipolar_interactions_reset_real => reset_real
use procedures_dipolar_interactions_visitor, only: dipolar_interactions_visit => visit

implicit none

private

    type, abstract, public :: Abstract_Dipolar_Interactions_Facade
    private
        type(Component_Wrapper), pointer :: components(:) => null()
        type(Dipolar_Interactions_Dynamic_Wrapper), pointer :: dipolar_interactions_dynamic => &
                null()
        type(Dipolar_Interactions_Static_Wrapper), pointer :: dipolar_interactions_static => null()
    contains
        procedure(Abstract_destroy), deferred :: destroy
        procedure :: save => Abstract_save
        procedure :: restore => Abstract_restore
        procedure(Abstract_reset), deferred :: reset
        procedure(Abstract_visit), deferred :: visit
        procedure(Abstract_set_real_pair_flag), private, deferred :: set_real_pair_flag
        procedure(Abstract_clone), deferred, private :: clone
        procedure(Abstract_target), deferred, private :: target
        procedure, private :: target_real => Abstract_target_real
    end type Abstract_Dipolar_Interactions_Facade

    abstract interface

        subroutine Abstract_destroy(this)
        import :: Abstract_Dipolar_Interactions_Facade
            class(Abstract_Dipolar_Interactions_Facade), intent(inout) :: this
        end subroutine Abstract_destroy

        subroutine Abstract_set_real_pair_flag(this, reset_real_pair, new_box_size)
        import :: DP, Abstract_Dipolar_Interactions_Facade
            class(Abstract_Dipolar_Interactions_Facade), intent(in) :: this
            logical, intent(out) :: reset_real_pair
            real(DP), intent(in) :: new_box_size(:)
        end subroutine Abstract_set_real_pair_flag

        subroutine Abstract_clone(this, dipolar_interactions_static_target, &
            dipolar_interactions_static_source, reset_real_pair)
        import :: Dipolar_Interactions_Static_Wrapper, Abstract_Dipolar_Interactions_Facade
            class(Abstract_Dipolar_Interactions_Facade), intent(in) :: this
            type(Dipolar_Interactions_Static_Wrapper), intent(inout) :: &
                dipolar_interactions_static_target
            type(Dipolar_Interactions_Static_Wrapper), intent(in) :: &
                dipolar_interactions_static_source
            logical, intent(in) :: reset_real_pair
        end subroutine Abstract_clone

        subroutine Abstract_target(this, reset_real_pair)
        import :: Abstract_Dipolar_Interactions_Facade
            class(Abstract_Dipolar_Interactions_Facade), intent(in) :: this
            logical, intent(in) :: reset_real_pair
        end subroutine Abstract_target

        subroutine Abstract_reset(this, reset_real_pair)
        import :: Abstract_Dipolar_Interactions_Facade
            class(Abstract_Dipolar_Interactions_Facade), intent(in) :: this
            logical, intent(in) :: reset_real_pair
        end subroutine Abstract_reset

        subroutine Abstract_visit(this, new_energies, new_shared_energy, box_volume_ratio, &
            energies, shared_energy)
        import :: DP, Real_Line, Abstract_Dipolar_Interactions_Facade
            class(Abstract_Dipolar_Interactions_Facade), intent(in) :: this
            type(Real_Line), intent(inout) :: new_energies(:)
            real(DP), intent(out) :: new_shared_energy
            real(DP), intent(in) :: box_volume_ratio !! \( \frac{V^\prime}{V} \)
            type(Real_Line), intent(in) :: energies(:)
            real(DP), intent(in) :: shared_energy
        end subroutine Abstract_visit

    end interface

    type, extends(Abstract_Dipolar_Interactions_Facade), public :: &
        Scalable_Dipolar_Interactions_Facade
    contains
        procedure :: construct => Scalable_construct
        procedure :: destroy => Scalable_destroy
        procedure :: reset => Scalable_reset
        procedure :: visit => Scalable_visit
        procedure, private :: set_real_pair_flag => Scalable_set_real_pair_flag
        procedure, private :: clone => Scalable_clone
        procedure, private :: target => Scalable_target
    end type Scalable_Dipolar_Interactions_Facade

    type, extends(Abstract_Dipolar_Interactions_Facade), public :: &
        Unscalable_Dipolar_Interactions_Facade
    private
        class(Abstract_Periodic_Box), pointer :: periodic_box => null()
    contains
        procedure :: construct => Unscalable_construct
        procedure :: destroy => Unscalable_destroy
        procedure :: reset => Unscalable_reset
        procedure :: visit => Unscalable_visit
        procedure, private :: set_real_pair_flag => Unscalable_set_real_pair_flag
        procedure, private :: clone => Unscalable_clone
        procedure, private :: target => Unscalable_target
    end type Unscalable_Dipolar_Interactions_Facade

    type, extends(Abstract_Dipolar_Interactions_Facade), public :: Null_Dipolar_Interactions_Facade
    contains
        procedure :: destroy => Null_destroy
        procedure :: reset => Null_reset
        procedure :: visit => Null_visit
        procedure, private :: set_real_pair_flag => Null_set_real_pair_flag
        procedure, private :: clone => Null_clone
        procedure, private :: target => Null_target
    end type Null_Dipolar_Interactions_Facade

contains

!implementation Abstract_Dipolar_Interactions_Facade

    subroutine Abstract_save(this, dipolar_interactions_static, reset_real_pair, new_box_size)
        class(Abstract_Dipolar_Interactions_Facade), intent(in) :: this
        type(Dipolar_Interactions_Static_Wrapper), intent(inout) :: dipolar_interactions_static
        logical, intent(out) :: reset_real_pair
        real(DP), intent(in) :: new_box_size(:)

        call this%set_real_pair_flag(reset_real_pair, new_box_size)
        call this%clone(dipolar_interactions_static, this%dipolar_interactions_static, &
            reset_real_pair)
    end subroutine Abstract_save

    subroutine Abstract_restore(this, dipolar_interactions_static, reset_real_pair)
        class(Abstract_Dipolar_Interactions_Facade), intent(in) :: this
        type(Dipolar_Interactions_Static_Wrapper), intent(in) :: dipolar_interactions_static
        logical, intent(in) :: reset_real_pair

        call this%clone(this%dipolar_interactions_static, dipolar_interactions_static, &
            reset_real_pair)
        call this%target(reset_real_pair)
    end subroutine Abstract_restore

    subroutine Abstract_target_real(this, reset_real_pair)
        class(Abstract_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(in) :: reset_real_pair

        integer :: i_component, j_component

        if (reset_real_pair) then
            call this%dipolar_interactions_static%real_pair%target(this%&
                dipolar_interactions_static%box_size_memento_real)
            do j_component = 1, size(this%dipolar_interactions_dynamic%real_components, 2)
                do i_component = 1, size(this%dipolar_interactions_dynamic%real_components, 1)
                    call this%dipolar_interactions_dynamic%&
                        real_components(i_component, j_component)%component%&
                        target(this%dipolar_interactions_static%box_size_memento_real, this%&
                            dipolar_interactions_static%real_pair)
                end do
            end do
        end if
    end subroutine Abstract_target_real

!end implementation Abstract_Dipolar_Interactions_Facade

!implementation Scalable_Dipolar_Interactions_Facade

    subroutine Scalable_construct(this, components, dipolar_interactions_dynamic, &
        dipolar_interactions_static)
        class(Scalable_Dipolar_Interactions_Facade), intent(out) :: this
        type(Component_Wrapper), target, intent(in) :: components(:)
        type(Dipolar_Interactions_Dynamic_Wrapper), target, intent(in) :: &
            dipolar_interactions_dynamic
        type(Dipolar_Interactions_Static_Wrapper), target, intent(in) :: dipolar_interactions_static

        this%components => components
        this%dipolar_interactions_dynamic => dipolar_interactions_dynamic
        this%dipolar_interactions_static => dipolar_interactions_static
    end subroutine Scalable_construct

    subroutine Scalable_destroy(this)
        class(Scalable_Dipolar_Interactions_Facade), intent(inout) :: this

        this%dipolar_interactions_static => null()
        this%dipolar_interactions_dynamic => null()
        this%components => null()
    end subroutine Scalable_destroy

    subroutine Scalable_set_real_pair_flag(this, reset_real_pair, new_box_size)
        class(Scalable_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(out) :: reset_real_pair
        real(DP), intent(in) :: new_box_size(:)

        reset_real_pair = product(new_box_size) > product(this%dipolar_interactions_static%&
            box_size_memento_real%get())
    end subroutine Scalable_set_real_pair_flag

    subroutine Scalable_target(this, reset_real_pair)
        class(Scalable_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(in) :: reset_real_pair

        call this%target_real(reset_real_pair)
    end subroutine Scalable_target

    subroutine Scalable_clone(this, dipolar_interactions_static_target, &
        dipolar_interactions_static_source, reset_real_pair)
        class(Scalable_Dipolar_Interactions_Facade), intent(in) :: this
        type(Dipolar_Interactions_Static_Wrapper), intent(inout) :: &
            dipolar_interactions_static_target
        type(Dipolar_Interactions_Static_Wrapper), intent(in) :: dipolar_interactions_static_source
        logical, intent(in) :: reset_real_pair

        if (.not.reset_real_pair) return
        call clone_real(dipolar_interactions_static_target%box_size_memento_real, &
            dipolar_interactions_static_target%real_pair, dipolar_interactions_static_source%&
            box_size_memento_real, dipolar_interactions_static_source%real_pair)
    end subroutine Scalable_clone

    subroutine Scalable_reset(this, reset_real_pair)
        class(Scalable_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(in) :: reset_real_pair

        call dipolar_interactions_reset_real(this%dipolar_interactions_static%&
            box_size_memento_real, this%dipolar_interactions_static%real_pair, reset_real_pair)
    end subroutine Scalable_reset

    subroutine Scalable_visit(this, new_energies, new_shared_energy, box_volume_ratio, energies, &
        shared_energy)
        class(Scalable_Dipolar_Interactions_Facade), intent(in) :: this
        type(Real_Line), intent(inout) :: new_energies(:)
        real(DP), intent(out) :: new_shared_energy
        real(DP), intent(in) :: box_volume_ratio
        type(Real_Line), intent(in) :: energies(:)
        real(DP), intent(in) :: shared_energy

        integer :: i_component

        do i_component = 1, size(new_energies)
            new_energies(i_component)%line = energies(i_component)%line / box_volume_ratio
        end do
        new_shared_energy = shared_energy / box_volume_ratio
    end subroutine Scalable_visit

!implementation Scalable_Dipolar_Interactions_Facade

!implementation Unscalable_Dipolar_Interactions_Facade

    subroutine Unscalable_construct(this, periodic_box, components, dipolar_interactions_dynamic, &
        dipolar_interactions_static)
        class(Unscalable_Dipolar_Interactions_Facade), intent(out) :: this
        class(Abstract_Periodic_Box), target, intent(in) :: periodic_box
        type(Component_Wrapper), target, intent(in) :: components(:)
        type(Dipolar_Interactions_Dynamic_Wrapper), target, intent(in) :: &
            dipolar_interactions_dynamic
        type(Dipolar_Interactions_Static_Wrapper), target, intent(in) :: dipolar_interactions_static

        this%periodic_box => periodic_box
        this%components => components
        this%dipolar_interactions_dynamic => dipolar_interactions_dynamic
        this%dipolar_interactions_static => dipolar_interactions_static
    end subroutine Unscalable_construct

    subroutine Unscalable_destroy(this)
        class(Unscalable_Dipolar_Interactions_Facade), intent(inout) :: this

        this%dipolar_interactions_static => null()
        this%dipolar_interactions_dynamic => null()
        this%components => null()
        this%periodic_box => null()
    end subroutine Unscalable_destroy

    subroutine Unscalable_set_real_pair_flag(this, reset_real_pair, new_box_size)
        class(Unscalable_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(out) :: reset_real_pair
        real(DP), intent(in) :: new_box_size(:)

        reset_real_pair = .true.
    end subroutine Unscalable_set_real_pair_flag

    subroutine Unscalable_target(this, reset_real_pair)
        class(Unscalable_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(in) :: reset_real_pair

        call this%dipolar_interactions_static%box_size_memento_real%target(this%periodic_box)
        call this%target_real(reset_real_pair)
        call this%dipolar_interactions_static%box_size_memento_reci%target(this%periodic_box)
        call this%dipolar_interactions_static%reci_weight%target(this%dipolar_interactions_static%&
            box_size_memento_reci)
        call this%dipolar_interactions_static%reci_structure%target(this%periodic_box, this%&
            dipolar_interactions_static%box_size_memento_reci, this%components)
        call this%dipolar_interactions_dynamic%reci_visitor%target(this%&
            dipolar_interactions_static%box_size_memento_reci, this%dipolar_interactions_static%&
            reci_weight, this%dipolar_interactions_static%reci_structure)
        call this%dipolar_interactions_static%dlc_weight%target(this%periodic_box)
        call this%dipolar_interactions_static%dlc_structures%target(this%periodic_box, this%&
            components)
        call this%dipolar_interactions_dynamic%dlc_visitor%target(this%dipolar_interactions_static%&
            dlc_weight, this%dipolar_interactions_static%dlc_structures)
    end subroutine Unscalable_target

    subroutine Unscalable_clone(this, dipolar_interactions_static_target, &
        dipolar_interactions_static_source, reset_real_pair)
        class(Unscalable_Dipolar_Interactions_Facade), intent(in) :: this
        type(Dipolar_Interactions_Static_Wrapper), intent(inout) :: &
            dipolar_interactions_static_target
        type(Dipolar_Interactions_Static_Wrapper), intent(in) :: dipolar_interactions_static_source
        logical, intent(in) :: reset_real_pair

        if (reset_real_pair) then
            call clone_real(dipolar_interactions_static_target%box_size_memento_real, &
                dipolar_interactions_static_target%real_pair, dipolar_interactions_static_source%&
                box_size_memento_real, dipolar_interactions_static_source%real_pair)
        end if
        call boxes_destroy(dipolar_interactions_static_target%box_size_memento_reci)
        allocate(dipolar_interactions_static_target%box_size_memento_reci, &
            source=dipolar_interactions_static_source%box_size_memento_reci)
        call des_reci_destroy(dipolar_interactions_static_target%reci_weight)
        allocate(dipolar_interactions_static_target%reci_weight, &
            source=dipolar_interactions_static_source%reci_weight)
        call des_reci_destroy(dipolar_interactions_static_target%reci_structure)
        allocate(dipolar_interactions_static_target%reci_structure, &
            source=dipolar_interactions_static_source%reci_structure)
        call dlc_destroy(dipolar_interactions_static_target%dlc_weight)
        allocate(dipolar_interactions_static_target%dlc_weight, &
            source=dipolar_interactions_static_source%dlc_weight)
        call dlc_destroy(dipolar_interactions_static_target%dlc_structures)
        allocate(dipolar_interactions_static_target%dlc_structures, &
            source=dipolar_interactions_static_source%dlc_structures)
    end subroutine Unscalable_clone

    subroutine Unscalable_reset(this, reset_real_pair)
        class(Unscalable_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(in) :: reset_real_pair

        call dipolar_interactions_reset(this%dipolar_interactions_static, reset_real_pair)
    end subroutine Unscalable_reset

    subroutine Unscalable_visit(this, new_energies, new_shared_energy, box_volume_ratio, energies, &
        shared_energy)
        class(Unscalable_Dipolar_Interactions_Facade), intent(in) :: this
        type(Real_Line), intent(inout) :: new_energies(:)
        real(DP), intent(out) :: new_shared_energy
        real(DP), intent(in) :: box_volume_ratio
        type(Real_Line), intent(in) :: energies(:)
        real(DP), intent(in) :: shared_energy

        call dipolar_interactions_visit(new_energies, new_shared_energy, this%components, this%&
            dipolar_interactions_dynamic)
    end subroutine Unscalable_visit

!end implementation Unscalable_Dipolar_Interactions_Facade

    subroutine clone_real(box_size_memento_target, des_real_pair_target, box_size_memento_source, &
        des_real_pair_source)
        class(Abstract_Box_Size_Memento), allocatable, intent(inout) :: box_size_memento_target
        class(Abstract_DES_Real_Pair), allocatable, intent(inout) :: des_real_pair_target
        class(Abstract_Box_Size_Memento), intent(in) :: box_size_memento_source
        class(Abstract_DES_Real_Pair), intent(in) :: des_real_pair_source

        call des_real_destroy(des_real_pair_target)
        call boxes_destroy(box_size_memento_target)
        allocate(box_size_memento_target, source=box_size_memento_source)
        allocate(des_real_pair_target, source=des_real_pair_source)
    end subroutine clone_real

!implementation Null_Dipolar_Interactions_Facade

    subroutine Null_destroy(this)
        class(Null_Dipolar_Interactions_Facade), intent(inout) :: this
    end subroutine Null_destroy

    subroutine Null_set_real_pair_flag(this, reset_real_pair, new_box_size)
        class(Null_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(out) :: reset_real_pair
        real(DP), intent(in) :: new_box_size(:)
        reset_real_pair = .false.
    end subroutine Null_set_real_pair_flag

    subroutine Null_target(this, reset_real_pair)
        class(Null_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(in) :: reset_real_pair
    end subroutine Null_target

    subroutine Null_clone(this, dipolar_interactions_static_target, &
        dipolar_interactions_static_source, reset_real_pair)
        class(Null_Dipolar_Interactions_Facade), intent(in) :: this
        type(Dipolar_Interactions_Static_Wrapper), intent(inout) :: &
            dipolar_interactions_static_target
        type(Dipolar_Interactions_Static_Wrapper), intent(in) :: dipolar_interactions_static_source
        logical, intent(in) :: reset_real_pair
    end subroutine Null_clone

    subroutine Null_reset(this, reset_real_pair)
        class(Null_Dipolar_Interactions_Facade), intent(in) :: this
        logical, intent(in) :: reset_real_pair
    end subroutine Null_reset

    subroutine Null_visit(this, new_energies, new_shared_energy, box_volume_ratio, energies, &
        shared_energy)
        class(Null_Dipolar_Interactions_Facade), intent(in) :: this
        type(Real_Line), intent(inout) :: new_energies(:)
        real(DP), intent(out) :: new_shared_energy
        real(DP), intent(in) :: box_volume_ratio
        type(Real_Line), intent(in) :: energies(:)
        real(DP), intent(in) :: shared_energy
        integer :: i_component
        do i_component = 1, size(new_energies)
            new_energies(i_component)%line = 0._DP
        end do
        new_shared_energy = 0._DP
    end subroutine Null_visit

!end implementation Null_Dipolar_Interactions_Facade

end module classes_dipolar_interactions_facade

classes_average_num_particles.f90 classes_beta_pressure.f90 classes_beta_pressure_excess.f90 classes_box_particle_exchange.f90 classes_box_particle_move.f90 classes_box_particles_swap.f90 classes_box_size_checker.f90 classes_box_size_memento.f90 classes_box_volume_change.f90 classes_boxes_particle_teleportation.f90 classes_boxes_particles_swap.f90 classes_boxes_volume_exchange.f90 classes_changed_box_size.f90 classes_changed_box_size_ratio.f90 classes_changes_success_writer.f90 classes_complete_coordinates_reader.f90 classes_complete_coordinates_writer.f90 classes_component_chemical_potential.f90 classes_component_coordinates.f90 classes_component_coordinates_reader.f90 classes_component_coordinates_writer.f90 classes_component_dipole_moments.f90 classes_coordinates.f90 classes_coordinates_copier.f90 classes_density_explorer.f90 classes_des_convergence_parameter.f90 classes_des_real_component.f90 classes_des_real_pair.f90 classes_des_reci_structure.f90 classes_des_reci_visitor.f90 classes_des_reci_weight.f90 classes_des_self_component.f90 classes_des_surf_mixture.f90 classes_dipolar_interactions_facade.f90 classes_dipolar_neighbourhood.f90 classes_dipolar_neighbourhoods_visitor.f90 classes_dirac_distribution_plus.f90 classes_directed_graph_writer.f90 classes_dlc_structures.f90 classes_dlc_visitor.f90 classes_dlc_weight.f90 classes_exchanged_boxes_size.f90 classes_external_field.f90 classes_field_expression.f90 classes_floor_penetration.f90 classes_generating_algorithm.f90 classes_hard_contact.f90 classes_hetero_couples.f90 classes_line_writer.f90 classes_maximum_box_compression.f90 classes_maximum_box_compression_explorer.f90 classes_min_distance.f90 classes_mixture_total_moment.f90 classes_move_tuner.f90 classes_moved_coordinates.f90 classes_neighbour_cells.f90 classes_num_particles.f90 classes_number_to_string.f90 classes_pair_potential.f90 classes_parallelepiped_domain.f90 classes_particle_insertion_method.f90 classes_periodic_box.f90 classes_permittivity.f90 classes_plmc_propagator.f90 classes_potential_expression.f90 classes_radial_explorer.f90 classes_random_coordinates.f90 classes_random_orientation.f90 classes_random_position.f90 classes_real_writer.f90 classes_reciprocal_lattice.f90 classes_rectangle_writer.f90 classes_rotated_orientations.f90 classes_short_pairs_visitor.f90 classes_structure_factor.f90 classes_structure_visitor.f90 classes_temperature.f90 classes_tower_sampler.f90 classes_translated_positions.f90 classes_triangle_writer.f90 classes_tunable_move.f90 classes_visitable_cells.f90 classes_visitable_cells_memento.f90 classes_visitable_list.f90 classes_visitable_walls.f90 classes_volume_change_method.f90 classes_walls_visitor.f90 data_cells.f90 data_constants.f90 data_input_prefixes.f90 data_output_objects.f90 data_strings.f90 density.f90 module_changes_success.f90 module_list_node.f90 module_move_tuning.f90 plmc_explore.f90 plmc_generate.f90 procedures_average_nums_particles_factory.f90 procedures_beta_pressure_factory.f90 procedures_beta_pressures_excess_factory.f90 procedures_box_particle_exchange_factory.f90 procedures_box_particle_move_factory.f90 procedures_box_particles_swap_factory.f90 procedures_box_size.f90 procedures_box_size_memento_factory.f90 procedures_box_volume_change_factory.f90 procedures_boxes_particle_teleportation_factory.f90 procedures_boxes_particles_swap_factory.f90 procedures_boxes_size_checker_factory.f90 procedures_boxes_volume_exchange_factory.f90 procedures_cells_memento.f90 procedures_centered_block_micro.f90 procedures_changed_boxes_size_factory.f90 procedures_changed_boxes_size_ratio_factory.f90 procedures_changes_component_factory.f90 procedures_changes_factory.f90 procedures_changes_properties.f90 procedures_changes_success_writer_factory.f90 procedures_checks.f90 procedures_command_arguments.f90 procedures_complete_coordinates_reader.f90 procedures_complete_coordinates_reader_factory.f90 procedures_complete_coordinates_writer_factory.f90 procedures_component_chemical_potential_factory.f90 procedures_component_coordinates_factory.f90 procedures_component_coordinates_reader_factory.f90 procedures_component_coordinates_writer_factory.f90 procedures_component_dipole_moments_factory.f90 procedures_component_factory.f90 procedures_coordinates_copier_factory.f90 procedures_coordinates_micro.f90 procedures_coordinates_reader.f90 procedures_density_explorer_factory.f90 procedures_des_convergence_parameter_factory.f90 procedures_des_real_component_factory.f90 procedures_des_real_pair_factory.f90 procedures_des_reci_structure_factory.f90 procedures_des_reci_visitor_factory.f90 procedures_des_reci_weight_factory.f90 procedures_des_surf_mixture_factory.f90 procedures_dipolar_interactions_facades_factory.f90 procedures_dipolar_interactions_factory.f90 procedures_dipolar_interactions_micro.f90 procedures_dipolar_interactions_resetter.f90 procedures_dipolar_interactions_visitor.f90 procedures_dipolar_neighbourhoods_factory.f90 procedures_dipolar_neighbourhoods_visitors_factory.f90 procedures_dipoles_field_interaction.f90 procedures_dirac_distribution_plus.f90 procedures_directed_graph_writer_factory.f90 procedures_dlc_structures_factory.f90 procedures_dlc_visitor_factory.f90 procedures_dlc_weight_factory.f90 procedures_elementary_geometry.f90 procedures_elementary_statistics.f90 procedures_energies_writers_factory.f90 procedures_environment_factory.f90 procedures_environment_inquirers.f90 procedures_errors.f90 procedures_exchange_updaters.f90 procedures_exchange_visitors.f90 procedures_exchanged_boxes_size_factory.f90 procedures_exploration_inquirers.f90 procedures_exploring_observables_factory.f90 procedures_exploring_writers_factory.f90 procedures_external_fields_factory.f90 procedures_field_expression_factory.f90 procedures_field_expression_micro.f90 procedures_floor_penetration_factory.f90 procedures_generating_algorithms_factory.f90 procedures_generating_observables_factory.f90 procedures_generating_writers_factory.f90 procedures_hard_contact_factory.f90 procedures_hetero_couples_factory.f90 procedures_json_data_factory.f90 procedures_json_reports_factory.f90 procedures_line_writer_factory.f90 procedures_logical_factory.f90 procedures_markov_chain_explorer_factory.f90 procedures_markov_chain_generator_factory.f90 procedures_maximum_box_compression_factory.f90 procedures_maximum_boxes_compression_explorer_factory.f90 procedures_metropolis_algorithm.f90 procedures_min_distance_factory.f90 procedures_mixture_inquirers.f90 procedures_mixture_properties.f90 procedures_mixture_total_moments_factory.f90 procedures_move_tuner_factory.f90 procedures_moved_coordinates_factory.f90 procedures_neighbour_cells_factory.f90 procedures_num_particles_factory.f90 procedures_observables_changes_factory.f90 procedures_observables_energies_factory.f90 procedures_observables_factory.f90 procedures_pair_potential_factory.f90 procedures_parallelepiped_domain_macro.f90 procedures_parallelepiped_domain_micro.f90 procedures_parallelepiped_domains_factory.f90 procedures_particle_insertion_method_factory.f90 procedures_periodic_boxes_factory.f90 procedures_permittivity_factory.f90 procedures_physical_model_factory.f90 procedures_plmc_help.f90 procedures_plmc_iterations.f90 procedures_plmc_propagator_factory.f90 procedures_plmc_resetter.f90 procedures_plmc_visitor.f90 procedures_plmc_writer.f90 procedures_potential_expression_factory.f90 procedures_property_inquirers.f90 procedures_radial_explorer_factory.f90 procedures_random_coordinates_factory.f90 procedures_random_number.f90 procedures_random_seed_factory.f90 procedures_readers_factory.f90 procedures_real_writer_factory.f90 procedures_reals_factory.f90 procedures_reciprocal_lattices_factory.f90 procedures_rectangle_writer_factory.f90 procedures_selectors_resetters.f90 procedures_short_interactions_factory.f90 procedures_short_interactions_inquirers.f90 procedures_short_interactions_resetter.f90 procedures_short_interactions_visitor.f90 procedures_short_pairs_visitors_factory.f90 procedures_string_factory.f90 procedures_temperature_factory.f90 procedures_tower_sampler_factory.f90 procedures_transmutation_updaters.f90 procedures_transmutation_visitors.f90 procedures_triangle_observables.f90 procedures_triangle_writer_factory.f90 procedures_visit_condition.f90 procedures_visitable_cells_factory.f90 procedures_visitable_cells_memento_factory.f90 procedures_visitable_list_factory.f90 procedures_visitable_walls_factory.f90 procedures_volume_change_method_factory.f90 procedures_walls_visitors_factory.f90 procedures_writers_inquirers.f90 radial.f90 types_cells_wrapper.f90 types_changes_component_wrapper.f90 types_changes_success_writer_selector.f90 types_changes_wrapper.f90 types_component_coordinates_reader_selector.f90 types_component_coordinates_writer_selector.f90 types_component_wrapper.f90 types_dipolar_interactions_dynamic_wrapper.f90 types_dipolar_interactions_static_wrapper.f90 types_energies_writers.f90 types_environment_wrapper.f90 types_exploring_io.f90 types_exploring_writers_wrapper.f90 types_generating_io.f90 types_generating_observables_wrapper.f90 types_generating_writers_wrapper.f90 types_json_report.f90 types_logical_wrapper.f90 types_markov_chain_explorer_wrapper.f90 types_markov_chain_generator_wrapper.f90 types_mixture_wrapper.f90 types_move_tuner_parameters.f90 types_observables_changes.f90 types_observables_energies.f90 types_particle_wrapper.f90 types_physical_model_wrapper.f90 types_potential_domain.f90 types_potential_domain_selector.f90 types_raw_coordinates.f90 types_readers_wrapper.f90 types_real_wrapper.f90 types_short_interactions_wrapper.f90 types_string_wrapper.f90