classes_volume_change_method.f90 Source File

This File Depends On

sourcefile~~classes_volume_change_method.f90~~EfferentGraph sourcefile~classes_volume_change_method.f90 classes_volume_change_method.f90 sourcefile~types_observables_energies.f90 types_observables_energies.f90 sourcefile~types_observables_energies.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_observables_energies_factory.f90 procedures_observables_energies_factory.f90 sourcefile~types_observables_energies.f90->sourcefile~procedures_observables_energies_factory.f90 sourcefile~procedures_cells_memento.f90 procedures_cells_memento.f90 sourcefile~procedures_cells_memento.f90->sourcefile~classes_volume_change_method.f90 sourcefile~types_dipolar_interactions_static_wrapper.f90 types_dipolar_interactions_static_wrapper.f90 sourcefile~types_dipolar_interactions_static_wrapper.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_dipolar_interactions_factory.f90 procedures_dipolar_interactions_factory.f90 sourcefile~types_dipolar_interactions_static_wrapper.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~classes_dipolar_interactions_facade.f90 classes_dipolar_interactions_facade.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_logical_wrapper.f90 types_logical_wrapper.f90 sourcefile~types_logical_wrapper.f90->sourcefile~classes_volume_change_method.f90 sourcefile~types_logical_wrapper.f90->sourcefile~procedures_cells_memento.f90 sourcefile~procedures_short_interactions_resetter.f90 procedures_short_interactions_resetter.f90 sourcefile~types_logical_wrapper.f90->sourcefile~procedures_short_interactions_resetter.f90 sourcefile~procedures_short_interactions_visitor.f90 procedures_short_interactions_visitor.f90 sourcefile~types_logical_wrapper.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~procedures_logical_factory.f90 procedures_logical_factory.f90 sourcefile~types_logical_wrapper.f90->sourcefile~procedures_logical_factory.f90 sourcefile~classes_visitable_cells_memento.f90 classes_visitable_cells_memento.f90 sourcefile~types_logical_wrapper.f90->sourcefile~classes_visitable_cells_memento.f90 sourcefile~procedures_checks.f90 procedures_checks.f90 sourcefile~procedures_checks.f90->sourcefile~classes_volume_change_method.f90 sourcefile~classes_changed_box_size_ratio.f90 classes_changed_box_size_ratio.f90 sourcefile~procedures_checks.f90->sourcefile~classes_changed_box_size_ratio.f90 sourcefile~classes_neighbour_cells.f90 classes_neighbour_cells.f90 sourcefile~procedures_checks.f90->sourcefile~classes_neighbour_cells.f90 sourcefile~classes_pair_potential.f90 classes_pair_potential.f90 sourcefile~procedures_checks.f90->sourcefile~classes_pair_potential.f90 sourcefile~classes_dipolar_neighbourhood.f90 classes_dipolar_neighbourhood.f90 sourcefile~procedures_checks.f90->sourcefile~classes_dipolar_neighbourhood.f90 sourcefile~classes_periodic_box.f90 classes_periodic_box.f90 sourcefile~procedures_checks.f90->sourcefile~classes_periodic_box.f90 sourcefile~classes_potential_expression.f90 classes_potential_expression.f90 sourcefile~procedures_checks.f90->sourcefile~classes_potential_expression.f90 sourcefile~classes_component_coordinates.f90 classes_component_coordinates.f90 sourcefile~procedures_checks.f90->sourcefile~classes_component_coordinates.f90 sourcefile~procedures_coordinates_micro.f90 procedures_coordinates_micro.f90 sourcefile~procedures_checks.f90->sourcefile~procedures_coordinates_micro.f90 sourcefile~classes_dirac_distribution_plus.f90 classes_dirac_distribution_plus.f90 sourcefile~procedures_checks.f90->sourcefile~classes_dirac_distribution_plus.f90 sourcefile~classes_parallelepiped_domain.f90 classes_parallelepiped_domain.f90 sourcefile~procedures_checks.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~classes_visitable_walls.f90 classes_visitable_walls.f90 sourcefile~procedures_checks.f90->sourcefile~classes_visitable_walls.f90 sourcefile~classes_floor_penetration.f90 classes_floor_penetration.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_des_real_pair.f90 classes_des_real_pair.f90 sourcefile~procedures_checks.f90->sourcefile~classes_des_real_pair.f90 sourcefile~classes_reciprocal_lattice.f90 classes_reciprocal_lattice.f90 sourcefile~procedures_checks.f90->sourcefile~classes_reciprocal_lattice.f90 sourcefile~classes_permittivity.f90 classes_permittivity.f90 sourcefile~procedures_checks.f90->sourcefile~classes_permittivity.f90 sourcefile~classes_des_convergence_parameter.f90 classes_des_convergence_parameter.f90 sourcefile~procedures_checks.f90->sourcefile~classes_des_convergence_parameter.f90 sourcefile~procedures_des_convergence_parameter_factory.f90 procedures_des_convergence_parameter_factory.f90 sourcefile~procedures_checks.f90->sourcefile~procedures_des_convergence_parameter_factory.f90 sourcefile~procedures_environment_inquirers.f90 procedures_environment_inquirers.f90 sourcefile~procedures_checks.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_mixture_total_moment.f90 classes_mixture_total_moment.f90 sourcefile~procedures_checks.f90->sourcefile~classes_mixture_total_moment.f90 sourcefile~procedures_mixture_inquirers.f90 procedures_mixture_inquirers.f90 sourcefile~procedures_checks.f90->sourcefile~procedures_mixture_inquirers.f90 sourcefile~classes_translated_positions.f90 classes_translated_positions.f90 sourcefile~procedures_checks.f90->sourcefile~classes_translated_positions.f90 sourcefile~classes_rotated_orientations.f90 classes_rotated_orientations.f90 sourcefile~procedures_checks.f90->sourcefile~classes_rotated_orientations.f90 sourcefile~classes_component_chemical_potential.f90 classes_component_chemical_potential.f90 sourcefile~procedures_checks.f90->sourcefile~classes_component_chemical_potential.f90 sourcefile~classes_component_dipole_moments.f90 classes_component_dipole_moments.f90 sourcefile~procedures_checks.f90->sourcefile~classes_component_dipole_moments.f90 sourcefile~procedures_property_inquirers.f90 procedures_property_inquirers.f90 sourcefile~procedures_checks.f90->sourcefile~procedures_property_inquirers.f90 sourcefile~procedures_random_number.f90 procedures_random_number.f90 sourcefile~procedures_checks.f90->sourcefile~procedures_random_number.f90 sourcefile~classes_changed_box_size.f90 classes_changed_box_size.f90 sourcefile~procedures_checks.f90->sourcefile~classes_changed_box_size.f90 sourcefile~classes_beta_pressure.f90 classes_beta_pressure.f90 sourcefile~procedures_checks.f90->sourcefile~classes_beta_pressure.f90 sourcefile~classes_field_expression.f90 classes_field_expression.f90 sourcefile~procedures_checks.f90->sourcefile~classes_field_expression.f90 sourcefile~procedures_field_expression_factory.f90 procedures_field_expression_factory.f90 sourcefile~procedures_checks.f90->sourcefile~procedures_field_expression_factory.f90 sourcefile~classes_temperature.f90 classes_temperature.f90 sourcefile~procedures_checks.f90->sourcefile~classes_temperature.f90 sourcefile~procedures_short_interactions_resetter.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_dipolar_interactions_factory.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_dipolar_interactions_visitor.f90 procedures_dipolar_interactions_visitor.f90 sourcefile~procedures_dipolar_interactions_visitor.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_dipolar_interactions_visitor.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_changed_box_size_ratio.f90->sourcefile~classes_volume_change_method.f90 sourcefile~classes_changed_box_size_ratio.f90->sourcefile~classes_changed_box_size.f90 sourcefile~procedures_triangle_observables.f90 procedures_triangle_observables.f90 sourcefile~procedures_triangle_observables.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_triangle_observables.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_short_interactions_visitor.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_observables_energies_factory.f90->sourcefile~classes_volume_change_method.f90 sourcefile~data_constants.f90 data_constants.f90 sourcefile~data_constants.f90->sourcefile~classes_volume_change_method.f90 sourcefile~data_constants.f90->sourcefile~procedures_checks.f90 sourcefile~data_constants.f90->sourcefile~classes_changed_box_size_ratio.f90 sourcefile~classes_visitable_cells.f90 classes_visitable_cells.f90 sourcefile~data_constants.f90->sourcefile~classes_visitable_cells.f90 sourcefile~data_constants.f90->sourcefile~classes_neighbour_cells.f90 sourcefile~data_constants.f90->sourcefile~classes_periodic_box.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_component_coordinates.f90 sourcefile~module_list_node.f90 module_list_node.f90 sourcefile~data_constants.f90->sourcefile~module_list_node.f90 sourcefile~classes_coordinates.f90 classes_coordinates.f90 sourcefile~data_constants.f90->sourcefile~classes_coordinates.f90 sourcefile~data_constants.f90->sourcefile~procedures_coordinates_micro.f90 sourcefile~data_constants.f90->sourcefile~classes_dirac_distribution_plus.f90 sourcefile~procedures_dipolar_interactions_micro.f90 procedures_dipolar_interactions_micro.f90 sourcefile~data_constants.f90->sourcefile~procedures_dipolar_interactions_micro.f90 sourcefile~data_cells.f90 data_cells.f90 sourcefile~data_constants.f90->sourcefile~data_cells.f90 sourcefile~data_constants.f90->sourcefile~classes_parallelepiped_domain.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~data_constants.f90->sourcefile~classes_floor_penetration.f90 sourcefile~classes_dlc_weight.f90 classes_dlc_weight.f90 sourcefile~data_constants.f90->sourcefile~classes_dlc_weight.f90 sourcefile~classes_dlc_structures.f90 classes_dlc_structures.f90 sourcefile~data_constants.f90->sourcefile~classes_dlc_structures.f90 sourcefile~classes_box_size_memento.f90 classes_box_size_memento.f90 sourcefile~data_constants.f90->sourcefile~classes_box_size_memento.f90 sourcefile~data_constants.f90->sourcefile~classes_des_real_pair.f90 sourcefile~classes_des_reci_weight.f90 classes_des_reci_weight.f90 sourcefile~data_constants.f90->sourcefile~classes_des_reci_weight.f90 sourcefile~classes_des_reci_structure.f90 classes_des_reci_structure.f90 sourcefile~data_constants.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~data_constants.f90->sourcefile~classes_reciprocal_lattice.f90 sourcefile~data_constants.f90->sourcefile~classes_mixture_total_moment.f90 sourcefile~data_constants.f90->sourcefile~classes_translated_positions.f90 sourcefile~data_constants.f90->sourcefile~classes_rotated_orientations.f90 sourcefile~data_constants.f90->sourcefile~classes_component_dipole_moments.f90 sourcefile~classes_moved_coordinates.f90 classes_moved_coordinates.f90 sourcefile~data_constants.f90->sourcefile~classes_moved_coordinates.f90 sourcefile~data_constants.f90->sourcefile~procedures_random_number.f90 sourcefile~classes_des_self_component.f90 classes_des_self_component.f90 sourcefile~data_constants.f90->sourcefile~classes_des_self_component.f90 sourcefile~classes_des_surf_mixture.f90 classes_des_surf_mixture.f90 sourcefile~data_constants.f90->sourcefile~classes_des_surf_mixture.f90 sourcefile~classes_dlc_visitor.f90 classes_dlc_visitor.f90 sourcefile~data_constants.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~classes_des_real_component.f90 classes_des_real_component.f90 sourcefile~data_constants.f90->sourcefile~classes_des_real_component.f90 sourcefile~classes_des_reci_visitor.f90 classes_des_reci_visitor.f90 sourcefile~data_constants.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~data_constants.f90->sourcefile~classes_changed_box_size.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_field_expression.f90 sourcefile~procedures_field_expression_micro.f90 procedures_field_expression_micro.f90 sourcefile~data_constants.f90->sourcefile~procedures_field_expression_micro.f90 sourcefile~procedures_logical_factory.f90->sourcefile~classes_volume_change_method.f90 sourcefile~types_component_wrapper.f90 types_component_wrapper.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_volume_change_method.f90 sourcefile~types_component_wrapper.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~types_component_wrapper.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~procedures_visitable_cells_factory.f90 procedures_visitable_cells_factory.f90 sourcefile~types_component_wrapper.f90->sourcefile~procedures_visitable_cells_factory.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_dlc_structures.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~procedures_mixture_total_moments_factory.f90 procedures_mixture_total_moments_factory.f90 sourcefile~types_component_wrapper.f90->sourcefile~procedures_mixture_total_moments_factory.f90 sourcefile~types_mixture_wrapper.f90 types_mixture_wrapper.f90 sourcefile~types_component_wrapper.f90->sourcefile~types_mixture_wrapper.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_mixture_total_moment.f90 sourcefile~classes_average_num_particles.f90 classes_average_num_particles.f90 sourcefile~types_component_wrapper.f90->sourcefile~classes_average_num_particles.f90 sourcefile~types_short_interactions_wrapper.f90 types_short_interactions_wrapper.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_volume_change_method.f90 sourcefile~types_environment_wrapper.f90 types_environment_wrapper.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_volume_change_method.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~procedures_errors.f90 procedures_errors.f90 sourcefile~procedures_errors.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_errors.f90->sourcefile~procedures_checks.f90 sourcefile~procedures_errors.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~procedures_errors.f90->sourcefile~classes_visitable_cells.f90 sourcefile~procedures_errors.f90->sourcefile~classes_neighbour_cells.f90 sourcefile~procedures_errors.f90->sourcefile~classes_periodic_box.f90 sourcefile~procedures_errors.f90->sourcefile~classes_component_coordinates.f90 sourcefile~classes_num_particles.f90 classes_num_particles.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_parallelepiped_domain.f90 sourcefile~procedures_errors.f90->sourcefile~classes_visitable_walls.f90 sourcefile~procedures_errors.f90->sourcefile~classes_floor_penetration.f90 sourcefile~procedures_errors.f90->sourcefile~classes_des_real_pair.f90 sourcefile~procedures_errors.f90->sourcefile~classes_reciprocal_lattice.f90 sourcefile~procedures_des_surf_mixture_factory.f90 procedures_des_surf_mixture_factory.f90 sourcefile~procedures_errors.f90->sourcefile~procedures_des_surf_mixture_factory.f90 sourcefile~procedures_errors.f90->sourcefile~classes_translated_positions.f90 sourcefile~module_move_tuning.f90 module_move_tuning.f90 sourcefile~procedures_errors.f90->sourcefile~module_move_tuning.f90 sourcefile~procedures_errors.f90->sourcefile~classes_field_expression.f90 sourcefile~procedures_errors.f90->sourcefile~procedures_field_expression_factory.f90 sourcefile~classes_box_size_checker.f90 classes_box_size_checker.f90 sourcefile~procedures_errors.f90->sourcefile~classes_box_size_checker.f90 sourcefile~types_cells_wrapper.f90 types_cells_wrapper.f90 sourcefile~types_cells_wrapper.f90->sourcefile~classes_volume_change_method.f90 sourcefile~types_cells_wrapper.f90->sourcefile~procedures_cells_memento.f90 sourcefile~types_cells_wrapper.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~types_real_wrapper.f90 types_real_wrapper.f90 sourcefile~types_real_wrapper.f90->sourcefile~types_observables_energies.f90 sourcefile~types_real_wrapper.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~types_real_wrapper.f90->sourcefile~procedures_triangle_observables.f90 sourcefile~types_real_wrapper.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~types_real_wrapper.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~types_real_wrapper.f90->sourcefile~procedures_observables_energies_factory.f90 sourcefile~procedures_reals_factory.f90 procedures_reals_factory.f90 sourcefile~types_real_wrapper.f90->sourcefile~procedures_reals_factory.f90 sourcefile~classes_visitable_cells_memento.f90->sourcefile~procedures_cells_memento.f90 sourcefile~classes_visitable_cells_memento.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~procedures_visitable_cells_factory.f90->sourcefile~classes_visitable_cells_memento.f90 sourcefile~classes_visitable_cells.f90->sourcefile~procedures_short_interactions_resetter.f90 sourcefile~classes_visitable_cells.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~classes_visitable_cells.f90->sourcefile~types_cells_wrapper.f90 sourcefile~classes_visitable_cells.f90->sourcefile~classes_visitable_cells_memento.f90 sourcefile~classes_visitable_cells.f90->sourcefile~procedures_visitable_cells_factory.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~procedures_short_interactions_resetter.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~types_cells_wrapper.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~classes_visitable_cells_memento.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~procedures_visitable_cells_factory.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~classes_visitable_cells.f90 sourcefile~classes_pair_potential.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~classes_pair_potential.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~classes_pair_potential.f90->sourcefile~procedures_visitable_cells_factory.f90 sourcefile~classes_pair_potential.f90->sourcefile~classes_visitable_cells.f90 sourcefile~classes_pair_potential.f90->sourcefile~classes_neighbour_cells.f90 sourcefile~classes_visitable_list.f90 classes_visitable_list.f90 sourcefile~classes_pair_potential.f90->sourcefile~classes_visitable_list.f90 sourcefile~classes_pair_potential.f90->sourcefile~classes_visitable_walls.f90 sourcefile~classes_walls_visitor.f90 classes_walls_visitor.f90 sourcefile~classes_pair_potential.f90->sourcefile~classes_walls_visitor.f90 sourcefile~classes_short_pairs_visitor.f90 classes_short_pairs_visitor.f90 sourcefile~classes_pair_potential.f90->sourcefile~classes_short_pairs_visitor.f90 sourcefile~classes_visitable_list.f90->sourcefile~procedures_visitable_cells_factory.f90 sourcefile~classes_visitable_list.f90->sourcefile~classes_visitable_cells.f90 sourcefile~classes_hard_contact.f90 classes_hard_contact.f90 sourcefile~classes_hard_contact.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~classes_hard_contact.f90->sourcefile~procedures_visitable_cells_factory.f90 sourcefile~classes_hard_contact.f90->sourcefile~classes_visitable_cells.f90 sourcefile~classes_hard_contact.f90->sourcefile~classes_neighbour_cells.f90 sourcefile~classes_hard_contact.f90->sourcefile~classes_visitable_list.f90 sourcefile~classes_dipolar_neighbourhood.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~classes_dipolar_neighbourhood.f90->sourcefile~procedures_visitable_cells_factory.f90 sourcefile~classes_dipolar_neighbourhood.f90->sourcefile~classes_visitable_cells.f90 sourcefile~classes_dipolar_neighbourhood.f90->sourcefile~classes_neighbour_cells.f90 sourcefile~classes_dipolar_neighbourhood.f90->sourcefile~classes_visitable_list.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_periodic_box.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_periodic_box.f90->sourcefile~procedures_visitable_cells_factory.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_visitable_cells.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_visitable_list.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_component_coordinates.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_visitable_walls.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_box_size_memento.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_reciprocal_lattice.f90 sourcefile~classes_periodic_box.f90->sourcefile~procedures_des_surf_mixture_factory.f90 sourcefile~classes_periodic_box.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_translated_positions.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_des_self_component.f90 sourcefile~classes_periodic_box.f90->sourcefile~classes_des_surf_mixture.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_periodic_box.f90->sourcefile~classes_short_pairs_visitor.f90 sourcefile~classes_potential_expression.f90->sourcefile~classes_pair_potential.f90 sourcefile~types_potential_domain.f90 types_potential_domain.f90 sourcefile~types_potential_domain.f90->sourcefile~procedures_checks.f90 sourcefile~types_potential_domain.f90->sourcefile~classes_pair_potential.f90 sourcefile~types_potential_domain.f90->sourcefile~classes_des_real_pair.f90 sourcefile~types_potential_domain_selector.f90 types_potential_domain_selector.f90 sourcefile~types_potential_domain_selector.f90->sourcefile~procedures_checks.f90 sourcefile~types_potential_domain_selector.f90->sourcefile~classes_pair_potential.f90 sourcefile~types_potential_domain_selector.f90->sourcefile~classes_des_real_pair.f90 sourcefile~procedures_box_size.f90 procedures_box_size.f90 sourcefile~procedures_box_size.f90->sourcefile~classes_visitable_cells.f90 sourcefile~procedures_box_size.f90->sourcefile~classes_visitable_list.f90 sourcefile~procedures_box_size.f90->sourcefile~classes_des_real_pair.f90 sourcefile~types_particle_wrapper.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_visitable_cells.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_visitable_list.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_dlc_structures.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_des_reci_structure.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_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~classes_structure_visitor.f90 classes_structure_visitor.f90 sourcefile~types_particle_wrapper.f90->sourcefile~classes_structure_visitor.f90 sourcefile~procedures_dipoles_field_interaction.f90 procedures_dipoles_field_interaction.f90 sourcefile~types_particle_wrapper.f90->sourcefile~procedures_dipoles_field_interaction.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~procedures_short_interactions_visitor.f90 sourcefile~procedures_visit_condition.f90->sourcefile~classes_visitable_cells.f90 sourcefile~procedures_visit_condition.f90->sourcefile~classes_visitable_list.f90 sourcefile~procedures_visit_condition.f90->sourcefile~classes_des_real_component.f90 sourcefile~classes_component_coordinates.f90->sourcefile~types_component_wrapper.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_visitable_cells.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_visitable_list.f90 sourcefile~classes_component_coordinates.f90->sourcefile~procedures_mixture_inquirers.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_translated_positions.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_rotated_orientations.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_component_dipole_moments.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_des_real_component.f90 sourcefile~classes_component_coordinates.f90->sourcefile~procedures_dipoles_field_interaction.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_walls_visitor.f90 sourcefile~classes_component_coordinates.f90->sourcefile~classes_short_pairs_visitor.f90 sourcefile~module_list_node.f90->sourcefile~classes_visitable_list.f90 sourcefile~classes_coordinates.f90->sourcefile~classes_component_coordinates.f90 sourcefile~classes_coordinates.f90->sourcefile~classes_component_dipole_moments.f90 sourcefile~classes_num_particles.f90->sourcefile~types_component_wrapper.f90 sourcefile~classes_num_particles.f90->sourcefile~classes_component_coordinates.f90 sourcefile~classes_num_particles.f90->sourcefile~procedures_mixture_inquirers.f90 sourcefile~classes_num_particles.f90->sourcefile~classes_average_num_particles.f90 sourcefile~procedures_coordinates_micro.f90->sourcefile~classes_component_coordinates.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~classes_dirac_distribution_plus.f90->sourcefile~classes_hard_contact.f90 sourcefile~procedures_dipolar_interactions_micro.f90->sourcefile~classes_dipolar_neighbourhood.f90 sourcefile~procedures_dipolar_interactions_micro.f90->sourcefile~classes_dlc_structures.f90 sourcefile~procedures_dipolar_interactions_micro.f90->sourcefile~classes_des_real_pair.f90 sourcefile~procedures_dipolar_interactions_micro.f90->sourcefile~classes_des_reci_structure.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~data_cells.f90->sourcefile~classes_visitable_cells.f90 sourcefile~data_cells.f90->sourcefile~classes_neighbour_cells.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_neighbour_cells.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_average_num_particles.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_external_field.f90 sourcefile~classes_beta_pressure_excess.f90 classes_beta_pressure_excess.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_beta_pressure_excess.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_box_size_checker.f90 sourcefile~classes_visitable_walls.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_visitable_walls.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~classes_visitable_walls.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_visitable_walls.f90->sourcefile~classes_walls_visitor.f90 sourcefile~classes_visitable_walls.f90->sourcefile~classes_box_size_checker.f90 sourcefile~procedures_parallelepiped_domain_micro.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~classes_floor_penetration.f90->sourcefile~classes_visitable_walls.f90 sourcefile~classes_floor_penetration.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_min_distance.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_min_distance.f90->sourcefile~classes_visitable_walls.f90 sourcefile~classes_min_distance.f90->sourcefile~types_mixture_wrapper.f90 sourcefile~procedures_centered_block_micro.f90 procedures_centered_block_micro.f90 sourcefile~procedures_centered_block_micro.f90->sourcefile~classes_floor_penetration.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_box_size_memento.f90->sourcefile~types_dipolar_interactions_static_wrapper.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_real_pair.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_reci_weight.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_real_component.f90 sourcefile~classes_box_size_memento.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~classes_box_size_memento.f90->sourcefile~procedures_dipolar_interactions_resetter.f90 sourcefile~classes_des_real_pair.f90->sourcefile~types_dipolar_interactions_static_wrapper.f90 sourcefile~classes_des_real_pair.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_des_real_pair.f90->sourcefile~classes_des_real_component.f90 sourcefile~classes_des_real_pair.f90->sourcefile~procedures_dipolar_interactions_resetter.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~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_reciprocal_lattice.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~classes_reciprocal_lattice.f90->sourcefile~types_environment_wrapper.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_weight.f90 sourcefile~classes_reciprocal_lattice.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~classes_reciprocal_lattice.f90->sourcefile~procedures_environment_inquirers.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_box_size_checker.f90 sourcefile~classes_permittivity.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~classes_permittivity.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_permittivity.f90->sourcefile~classes_dlc_weight.f90 sourcefile~classes_permittivity.f90->sourcefile~classes_des_real_pair.f90 sourcefile~classes_permittivity.f90->sourcefile~classes_des_reci_weight.f90 sourcefile~classes_permittivity.f90->sourcefile~procedures_des_surf_mixture_factory.f90 sourcefile~classes_permittivity.f90->sourcefile~procedures_environment_inquirers.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_field_expression.f90 sourcefile~classes_permittivity.f90->sourcefile~procedures_field_expression_factory.f90 sourcefile~classes_structure_factor.f90->sourcefile~classes_dlc_structures.f90 sourcefile~classes_structure_factor.f90->sourcefile~classes_des_reci_structure.f90 sourcefile~classes_des_convergence_parameter.f90->sourcefile~classes_des_real_pair.f90 sourcefile~classes_des_convergence_parameter.f90->sourcefile~classes_des_reci_weight.f90 sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_convergence_parameter.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_convergence_parameter.f90->sourcefile~procedures_des_convergence_parameter_factory.f90 sourcefile~classes_des_convergence_parameter.f90->sourcefile~classes_des_self_component.f90 sourcefile~classes_number_to_string.f90->sourcefile~procedures_checks.f90 sourcefile~procedures_mixture_total_moments_factory.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~types_dipolar_interactions_dynamic_wrapper.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~types_dipolar_interactions_dynamic_wrapper.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~types_dipolar_interactions_dynamic_wrapper.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~procedures_des_convergence_parameter_factory.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~procedures_des_surf_mixture_factory.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_des_surf_mixture_factory.f90 sourcefile~data_input_prefixes.f90 data_input_prefixes.f90 sourcefile~data_input_prefixes.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~classes_mixture_total_moment.f90->sourcefile~procedures_mixture_total_moments_factory.f90 sourcefile~classes_mixture_total_moment.f90->sourcefile~types_mixture_wrapper.f90 sourcefile~classes_mixture_total_moment.f90->sourcefile~procedures_des_surf_mixture_factory.f90 sourcefile~classes_mixture_total_moment.f90->sourcefile~classes_des_surf_mixture.f90 sourcefile~procedures_mixture_inquirers.f90->sourcefile~procedures_mixture_total_moments_factory.f90 sourcefile~classes_translated_positions.f90->sourcefile~procedures_mixture_inquirers.f90 sourcefile~classes_rotated_orientations.f90->sourcefile~procedures_mixture_inquirers.f90 sourcefile~classes_component_chemical_potential.f90->sourcefile~types_component_wrapper.f90 sourcefile~classes_component_chemical_potential.f90->sourcefile~procedures_mixture_inquirers.f90 sourcefile~classes_component_chemical_potential.f90->sourcefile~classes_average_num_particles.f90 sourcefile~classes_component_dipole_moments.f90->sourcefile~types_component_wrapper.f90 sourcefile~classes_component_dipole_moments.f90->sourcefile~procedures_mixture_inquirers.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~classes_component_dipole_moments.f90->sourcefile~procedures_dipoles_field_interaction.f90 sourcefile~procedures_property_inquirers.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~procedures_property_inquirers.f90->sourcefile~procedures_mixture_inquirers.f90 sourcefile~classes_moved_coordinates.f90->sourcefile~procedures_mixture_inquirers.f90 sourcefile~classes_moved_coordinates.f90->sourcefile~classes_translated_positions.f90 sourcefile~classes_moved_coordinates.f90->sourcefile~classes_rotated_orientations.f90 sourcefile~module_move_tuning.f90->sourcefile~classes_translated_positions.f90 sourcefile~module_move_tuning.f90->sourcefile~classes_rotated_orientations.f90 sourcefile~module_move_tuning.f90->sourcefile~classes_changed_box_size.f90 sourcefile~procedures_random_number.f90->sourcefile~classes_rotated_orientations.f90 sourcefile~classes_tunable_move.f90 classes_tunable_move.f90 sourcefile~classes_tunable_move.f90->sourcefile~classes_moved_coordinates.f90 sourcefile~classes_tunable_move.f90->sourcefile~classes_changed_box_size.f90 sourcefile~classes_des_self_component.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_des_self_component.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_surf_mixture.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_surf_mixture.f90->sourcefile~procedures_des_surf_mixture_factory.f90 sourcefile~classes_dlc_visitor.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_real_component.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_des_real_component.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_des_reci_visitor.f90->sourcefile~types_dipolar_interactions_dynamic_wrapper.f90 sourcefile~classes_structure_visitor.f90->sourcefile~classes_dlc_visitor.f90 sourcefile~classes_structure_visitor.f90->sourcefile~classes_des_reci_visitor.f90 sourcefile~classes_average_num_particles.f90->sourcefile~types_mixture_wrapper.f90 sourcefile~classes_changed_box_size.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_beta_pressure.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_beta_pressure.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_external_field.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_dipoles_field_interaction.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~procedures_field_expression_micro.f90->sourcefile~classes_field_expression.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~procedures_reals_factory.f90->sourcefile~procedures_observables_energies_factory.f90 sourcefile~procedures_dipolar_interactions_resetter.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~classes_walls_visitor.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~classes_walls_visitor.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~classes_short_pairs_visitor.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~classes_short_pairs_visitor.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~classes_beta_pressure_excess.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~classes_temperature.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_box_size_checker.f90->sourcefile~types_environment_wrapper.f90
Help

Files Dependent On This One

sourcefile~~classes_volume_change_method.f90~~AfferentGraph sourcefile~classes_volume_change_method.f90 classes_volume_change_method.f90 sourcefile~procedures_volume_change_method_factory.f90 procedures_volume_change_method_factory.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~procedures_markov_chain_explorer_factory.f90 procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_volume_change_method_factory.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~types_markov_chain_explorer_wrapper.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~plmc_explore.f90 plmc_explore.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_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_dipolar_interactions_facades_factory.f90 procedures_dipolar_interactions_facades_factory.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~procedures_dipolar_interactions_facades_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_markov_chain_explorer_factory.f90->sourcefile~plmc_explore.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_short_interactions_factory.f90->sourcefile~procedures_physical_model_factory.f90
Help


Source Code

module classes_volume_change_method

use, intrinsic :: iso_fortran_env, only: DP => REAL64
use data_constants, only: num_dimensions
use procedures_errors, only: error_exit
use procedures_checks, only: check_positive
use types_logical_wrapper, only: Logical_Line
use procedures_logical_factory, only: logical_create => create
use types_environment_wrapper, only: Environment_Wrapper
use types_component_wrapper, only: Component_Wrapper
use procedures_mixture_factory, only: mixture_rescale_positions => rescale_positions
use types_cells_wrapper, only: Cells_Wrapper
use procedures_cells_memento, only: cells_memento_save => save, cells_memento_restore => restore
use types_short_interactions_wrapper, only: Short_Interactions_Wrapper
use procedures_short_interactions_resetter, only: short_interactions_reset => reset
use procedures_short_interactions_visitor, only: short_interactions_visit => visit
use types_dipolar_interactions_static_wrapper, only: Dipolar_Interactions_Static_Wrapper
use procedures_dipolar_interactions_factory, only: dipolar_interactions_destroy => destroy
use procedures_dipolar_interactions_visitor, only: dipolar_interactions_visit => visit
use classes_dipolar_interactions_facade, only: Abstract_Dipolar_Interactions_Facade
use classes_changed_box_size_ratio, only: Abstract_Changed_Box_Size_Ratio
use procedures_triangle_observables, only: triangle_observables_diff
use types_observables_energies, only: Concrete_Observables_Energies
use procedures_triangle_observables, only: triangle_observables_sum
use procedures_observables_energies_factory, only: observables_energies_create => create
use types_exploring_observables_wrapper, only: Exploring_Observables_Wrapper

implicit none

private

    type, abstract, public :: Abstract_Volume_Change_Method
    private
        type(Environment_Wrapper), pointer :: environment => null()
        type(Component_Wrapper), pointer :: components(:, :) => null()
        type(Short_Interactions_Wrapper), pointer :: short_interactions => null()
        class(Abstract_Dipolar_Interactions_Facade), pointer :: dipolar_interactions_facades(:) => &
            null()
        class(Abstract_Changed_Box_Size_Ratio), pointer :: changed_boxes_size_ratio(:) => null()
        integer :: num_changes = 0
    contains
        procedure :: construct => Abstract_construct
        procedure :: destroy => Abstract_destroy
        procedure :: try => Abstract_try
        procedure, private :: set_delta_energy => Abstract_set_delta_energy
    end type Abstract_Volume_Change_Method

    type, extends(Abstract_Volume_Change_Method), public :: Concrete_Volume_Change_Method

    end type Concrete_Volume_Change_Method

    type, extends(Abstract_Volume_Change_Method), public :: Null_Volume_Change_Method
    contains
        procedure :: construct => Null_construct
        procedure :: destroy => Null_destroy
        procedure :: try => Null_try
    end type Null_Volume_Change_Method

contains

!implementation Abstract_Volume_Change_Method

    subroutine Abstract_construct(this, environment, components, short_interactions, &
        dipolar_interactions_facades, changed_boxes_size_ratio, num_changes)
        class(Abstract_Volume_Change_Method), intent(out) :: this
        type(Environment_Wrapper), target, intent(in) :: environment
        type(Component_Wrapper), target, intent(in) :: components(:, :)
        type(Short_Interactions_Wrapper), target, intent(in) :: short_interactions
        class(Abstract_Dipolar_Interactions_Facade), target, intent(in) :: &
            dipolar_interactions_facades(:)
        class(Abstract_Changed_Box_Size_Ratio), target, intent(in) :: changed_boxes_size_ratio(:)
        integer, intent(in) :: num_changes

        this%environment => environment
        this%components => components
        this%short_interactions => short_interactions
        this%dipolar_interactions_facades => dipolar_interactions_facades
        this%changed_boxes_size_ratio => changed_boxes_size_ratio
        call check_positive("Abstract_Volume_Change_Method: construct", "num_changes", num_changes)
        this%num_changes = num_changes
    end subroutine Abstract_construct

    subroutine Abstract_destroy(this)
        class(Abstract_Volume_Change_Method), intent(inout) :: this

        this%changed_boxes_size_ratio => null()
        this%dipolar_interactions_facades => null()
        this%short_interactions => null()
        this%components => null()
        this%environment => null()
    end subroutine Abstract_destroy

    !> @todo Test if [[procedures_dipolar_interactions_factory:destroy_static]] is needed,
    !> cf. [[classes_box_volume_change:Concrete_try]].
    subroutine Abstract_try(this, observables)
        class(Abstract_Volume_Change_Method), intent(in) :: this
        type(Exploring_Observables_Wrapper), intent(inout) :: observables !too much?

        logical :: overlap
        integer :: i_box
        real(DP) :: beta_pressure_excess_sum
        real(DP) :: contacts, delta_energy, delta_volume
        real(DP), dimension(num_dimensions) :: new_box_size, box_size, box_size_ratio
        type(Logical_Line), allocatable :: only_resized_triangle(:)
        type(Cells_Wrapper) :: cells
        type(Dipolar_Interactions_Static_Wrapper) :: dipolar_interactions_static
        logical :: reset_real_pair
        integer :: i_change

        do i_box = 1, size(this%environment%periodic_boxes)
            call short_interactions_visit(overlap, contacts, this%components(:, i_box), this%&
                short_interactions%cells(i_box)%visitable_cells)
            if (overlap) then
                call error_exit("Abstract_Volume_Change_Method: try: "//&
                    "short_interactions_visit: overlap")
            end if

            box_size = this%environment%periodic_boxes(i_box)%get_size()
            beta_pressure_excess_sum = 0._DP
            do i_change = 1, this%num_changes
                box_size_ratio = this%changed_boxes_size_ratio(i_box)%get()
                new_box_size = box_size * box_size_ratio
                call this%dipolar_interactions_facades(i_box)%save(dipolar_interactions_static, &
                    reset_real_pair, new_box_size)

                call this%environment%periodic_boxes(i_box)%set(box_size * box_size_ratio)
                call mixture_rescale_positions(this%components(:, i_box), box_size_ratio)
                call logical_create(only_resized_triangle, size(this%components, 1))
                call cells_memento_save(cells, only_resized_triangle, this%short_interactions%&
                    visitable_cells_memento, this%short_interactions%cells(i_box))
                call short_interactions_reset(this%short_interactions%cells(i_box)%neighbour_cells,&
                    only_resized_triangle, this%short_interactions%cells(i_box)%visitable_cells)
                call this%dipolar_interactions_facades(i_box)%reset(reset_real_pair)
                call this%set_delta_energy(overlap, delta_energy, i_box, box_size_ratio, &
                    observables%energies(i_box))
                if (overlap) call error_exit("Abstract_Volume_Change_Method: try: "//&
                    "set_delta_energy: overlap")
                delta_volume = product(this%environment%accessible_domains(i_box)%get_size()) * &
                    (product(box_size_ratio) - 1._DP)
                beta_pressure_excess_sum = beta_pressure_excess_sum - delta_energy / delta_volume /&
                    this%environment%temperature%get()

                call this%environment%periodic_boxes(i_box)%set(box_size)
                call mixture_rescale_positions(this%components(:, i_box), 1._DP / box_size_ratio)
                call cells_memento_restore(this%short_interactions%cells(i_box), &
                    only_resized_triangle, this%short_interactions%visitable_cells_memento, cells)
                call this%dipolar_interactions_facades(i_box)%restore(dipolar_interactions_static, &
                    reset_real_pair)
                call dipolar_interactions_destroy(dipolar_interactions_static)
            end do
            observables%beta_pressures_excess(i_box) = this%short_interactions%&
                beta_pressures_excess(i_box)%get(contacts) + &
                beta_pressure_excess_sum / real(this%num_changes, DP)
        end do
    end subroutine Abstract_try


    subroutine Abstract_set_delta_energy(this, overlap, delta_energy, i_box, box_size_ratio, &
        energies)
        class(Abstract_Volume_Change_Method), intent(in) :: this
        logical, intent(out) :: overlap
        real(DP), intent(out) :: delta_energy
        integer, intent(in) :: i_box
        real(DP), intent(in) :: box_size_ratio(:)
        type(Concrete_Observables_Energies), intent(in) :: energies

        type(Concrete_Observables_Energies) :: deltas, new_energies

        call observables_energies_create(deltas, size(this%components, 1))
        call observables_energies_create(new_energies, size(this%components, 1))
        call short_interactions_visit(overlap, new_energies%walls_energies, this%&
            components(:, i_box), this%short_interactions%walls_visitors(i_box), this%&
            short_interactions%wall_pairs)
        if (overlap) return
        deltas%walls_energies = new_energies%walls_energies - energies%walls_energies
        call short_interactions_visit(overlap, new_energies%short_energies, &
            this%components(:, i_box), this%short_interactions%cells(i_box)%visitable_cells)
        if (overlap) return
        call triangle_observables_diff(deltas%short_energies, new_energies%short_energies, &
            energies%short_energies)
        call dipolar_interactions_visit(new_energies%field_energies, this%environment%&
            external_fields(i_box), this%components(:, i_box))
        deltas%field_energies = new_energies%field_energies - energies%field_energies
        call this%dipolar_interactions_facades(i_box)%visit(new_energies%dipolar_energies, &
            new_energies%dipolar_shared_energy, product(box_size_ratio), energies%dipolar_energies,&
            energies%dipolar_shared_energy)
        call triangle_observables_diff(deltas%dipolar_energies, new_energies%dipolar_energies, &
            energies%dipolar_energies)
        deltas%dipolar_shared_energy = new_energies%dipolar_shared_energy - energies%&
            dipolar_shared_energy

        delta_energy = sum(deltas%walls_energies + deltas%field_energies) + &
            triangle_observables_sum(deltas%short_energies) + &
            triangle_observables_sum(deltas%dipolar_energies) + deltas%dipolar_shared_energy
    end subroutine Abstract_set_delta_energy

!end implementation Abstract_Volume_Change_Method

!implementation Null_Volume_Change_Method

    subroutine Null_construct(this, environment, components, short_interactions, &
        dipolar_interactions_facades, changed_boxes_size_ratio, num_changes)
        class(Null_Volume_Change_Method), intent(out) :: this
        type(Environment_Wrapper), target, intent(in) :: environment
        type(Component_Wrapper), target, intent(in) :: components(:, :)
        type(Short_Interactions_Wrapper), target, intent(in) :: short_interactions
        class(Abstract_Dipolar_Interactions_Facade), target, intent(in) :: &
            dipolar_interactions_facades(:)
        class(Abstract_Changed_Box_Size_Ratio), target, intent(in) :: changed_boxes_size_ratio(:)
        integer, intent(in) :: num_changes
    end subroutine Null_construct

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

    subroutine Null_try(this, observables)
        class(Null_Volume_Change_Method), intent(in) :: this
        type(Exploring_Observables_Wrapper), intent(inout) :: observables
    end subroutine Null_try

!end implementation Null_Volume_Change_Method

end module classes_volume_change_method

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