classes_floor_penetration.f90 Source File

This File Depends On

sourcefile~~classes_floor_penetration.f90~~EfferentGraph sourcefile~classes_floor_penetration.f90 classes_floor_penetration.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_checks.f90 procedures_checks.f90 sourcefile~procedures_checks.f90->sourcefile~classes_floor_penetration.f90 sourcefile~procedures_errors.f90 procedures_errors.f90 sourcefile~procedures_errors.f90->sourcefile~classes_floor_penetration.f90 sourcefile~procedures_errors.f90->sourcefile~procedures_checks.f90 sourcefile~data_constants.f90 data_constants.f90 sourcefile~data_constants.f90->sourcefile~classes_floor_penetration.f90 sourcefile~data_constants.f90->sourcefile~procedures_checks.f90 sourcefile~types_potential_domain.f90 types_potential_domain.f90 sourcefile~types_potential_domain.f90->sourcefile~procedures_checks.f90 sourcefile~classes_number_to_string.f90 classes_number_to_string.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~procedures_checks.f90 sourcefile~data_strings.f90 data_strings.f90 sourcefile~data_strings.f90->sourcefile~classes_number_to_string.f90
Help

Files Dependent On This One

sourcefile~~classes_floor_penetration.f90~~AfferentGraph sourcefile~classes_floor_penetration.f90 classes_floor_penetration.f90 sourcefile~procedures_visitable_walls_factory.f90 procedures_visitable_walls_factory.f90 sourcefile~classes_floor_penetration.f90->sourcefile~procedures_visitable_walls_factory.f90 sourcefile~procedures_floor_penetration_factory.f90 procedures_floor_penetration_factory.f90 sourcefile~classes_floor_penetration.f90->sourcefile~procedures_floor_penetration_factory.f90 sourcefile~classes_visitable_walls.f90 classes_visitable_walls.f90 sourcefile~classes_floor_penetration.f90->sourcefile~classes_visitable_walls.f90 sourcefile~procedures_environment_inquirers.f90 procedures_environment_inquirers.f90 sourcefile~classes_floor_penetration.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~density.f90 density.f90 sourcefile~classes_floor_penetration.f90->sourcefile~density.f90 sourcefile~procedures_environment_factory.f90 procedures_environment_factory.f90 sourcefile~classes_floor_penetration.f90->sourcefile~procedures_environment_factory.f90 sourcefile~classes_visitable_walls.f90->sourcefile~procedures_visitable_walls_factory.f90 sourcefile~classes_visitable_walls.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_visitable_walls.f90->sourcefile~density.f90 sourcefile~classes_visitable_walls.f90->sourcefile~procedures_environment_factory.f90 sourcefile~procedures_boxes_size_checker_factory.f90 procedures_boxes_size_checker_factory.f90 sourcefile~classes_visitable_walls.f90->sourcefile~procedures_boxes_size_checker_factory.f90 sourcefile~classes_walls_visitor.f90 classes_walls_visitor.f90 sourcefile~classes_visitable_walls.f90->sourcefile~classes_walls_visitor.f90 sourcefile~classes_parallelepiped_domain.f90 classes_parallelepiped_domain.f90 sourcefile~classes_visitable_walls.f90->sourcefile~classes_parallelepiped_domain.f90 sourcefile~procedures_density_explorer_factory.f90 procedures_density_explorer_factory.f90 sourcefile~classes_visitable_walls.f90->sourcefile~procedures_density_explorer_factory.f90 sourcefile~classes_box_size_checker.f90 classes_box_size_checker.f90 sourcefile~classes_visitable_walls.f90->sourcefile~classes_box_size_checker.f90 sourcefile~procedures_parallelepiped_domains_factory.f90 procedures_parallelepiped_domains_factory.f90 sourcefile~classes_visitable_walls.f90->sourcefile~procedures_parallelepiped_domains_factory.f90 sourcefile~procedures_transmutation_visitors.f90 procedures_transmutation_visitors.f90 sourcefile~classes_visitable_walls.f90->sourcefile~procedures_transmutation_visitors.f90 sourcefile~types_environment_wrapper.f90 types_environment_wrapper.f90 sourcefile~classes_visitable_walls.f90->sourcefile~types_environment_wrapper.f90 sourcefile~procedures_walls_visitors_factory.f90 procedures_walls_visitors_factory.f90 sourcefile~classes_visitable_walls.f90->sourcefile~procedures_walls_visitors_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_visitable_walls_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_floor_penetration_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~density.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_environment_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_density_explorer_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_parallelepiped_domains_factory.f90 sourcefile~procedures_short_interactions_factory.f90 procedures_short_interactions_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_short_interactions_factory.f90 sourcefile~procedures_dipolar_interactions_facades_factory.f90 procedures_dipolar_interactions_facades_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_dipolar_interactions_facades_factory.f90 sourcefile~procedures_box_volume_change_factory.f90 procedures_box_volume_change_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_box_volume_change_factory.f90 sourcefile~procedures_neighbour_cells_factory.f90 procedures_neighbour_cells_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_neighbour_cells_factory.f90 sourcefile~procedures_beta_pressures_excess_factory.f90 procedures_beta_pressures_excess_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_beta_pressures_excess_factory.f90 sourcefile~procedures_dipolar_interactions_factory.f90 procedures_dipolar_interactions_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~procedures_changes_factory.f90 procedures_changes_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_changes_factory.f90 sourcefile~procedures_line_writer_factory.f90 procedures_line_writer_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_line_writer_factory.f90 sourcefile~procedures_changed_boxes_size_ratio_factory.f90 procedures_changed_boxes_size_ratio_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_changed_boxes_size_ratio_factory.f90 sourcefile~procedures_reciprocal_lattices_factory.f90 procedures_reciprocal_lattices_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_reciprocal_lattices_factory.f90 sourcefile~procedures_move_tuner_factory.f90 procedures_move_tuner_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_move_tuner_factory.f90 sourcefile~procedures_maximum_box_compression_factory.f90 procedures_maximum_box_compression_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_maximum_box_compression_factory.f90 sourcefile~procedures_changed_boxes_size_factory.f90 procedures_changed_boxes_size_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_changed_boxes_size_factory.f90 sourcefile~procedures_exchanged_boxes_size_factory.f90 procedures_exchanged_boxes_size_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_exchanged_boxes_size_factory.f90 sourcefile~procedures_periodic_boxes_factory.f90 procedures_periodic_boxes_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_periodic_boxes_factory.f90 sourcefile~procedures_box_size_memento_factory.f90 procedures_box_size_memento_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_box_size_memento_factory.f90 sourcefile~procedures_real_writer_factory.f90 procedures_real_writer_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_real_writer_factory.f90 sourcefile~procedures_hard_contact_factory.f90 procedures_hard_contact_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_hard_contact_factory.f90 sourcefile~procedures_triangle_writer_factory.f90 procedures_triangle_writer_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_triangle_writer_factory.f90 sourcefile~radial.f90 radial.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~radial.f90 sourcefile~procedures_des_surf_mixture_factory.f90 procedures_des_surf_mixture_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_des_surf_mixture_factory.f90 sourcefile~procedures_dlc_weight_factory.f90 procedures_dlc_weight_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_dlc_weight_factory.f90 sourcefile~procedures_dlc_structures_factory.f90 procedures_dlc_structures_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_dlc_structures_factory.f90 sourcefile~procedures_permittivity_factory.f90 procedures_permittivity_factory.f90 sourcefile~procedures_environment_inquirers.f90->sourcefile~procedures_permittivity_factory.f90 sourcefile~procedures_physical_model_factory.f90 procedures_physical_model_factory.f90 sourcefile~procedures_environment_factory.f90->sourcefile~procedures_physical_model_factory.f90 sourcefile~procedures_complete_coordinates_reader_factory.f90 procedures_complete_coordinates_reader_factory.f90 sourcefile~procedures_boxes_size_checker_factory.f90->sourcefile~procedures_complete_coordinates_reader_factory.f90 sourcefile~classes_complete_coordinates_reader.f90 classes_complete_coordinates_reader.f90 sourcefile~procedures_boxes_size_checker_factory.f90->sourcefile~classes_complete_coordinates_reader.f90 sourcefile~classes_walls_visitor.f90->sourcefile~procedures_walls_visitors_factory.f90 sourcefile~types_short_interactions_wrapper.f90 types_short_interactions_wrapper.f90 sourcefile~classes_walls_visitor.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~procedures_short_interactions_visitor.f90 procedures_short_interactions_visitor.f90 sourcefile~classes_walls_visitor.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_environment_factory.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_boxes_size_checker_factory.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_density_explorer_factory.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_box_size_checker.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_parallelepiped_domains_factory.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_complete_coordinates_reader_factory.f90 sourcefile~procedures_readers_factory.f90 procedures_readers_factory.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_readers_factory.f90 sourcefile~types_markov_chain_explorer_wrapper.f90 types_markov_chain_explorer_wrapper.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~types_markov_chain_explorer_wrapper.f90 sourcefile~procedures_external_fields_factory.f90 procedures_external_fields_factory.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_external_fields_factory.f90 sourcefile~procedures_parallelepiped_domain_macro.f90 procedures_parallelepiped_domain_macro.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_parallelepiped_domain_macro.f90 sourcefile~classes_neighbour_cells.f90 classes_neighbour_cells.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_neighbour_cells.f90 sourcefile~classes_average_num_particles.f90 classes_average_num_particles.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_average_num_particles.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_neighbour_cells_factory.f90 sourcefile~procedures_average_nums_particles_factory.f90 procedures_average_nums_particles_factory.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_average_nums_particles_factory.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_density_explorer.f90 classes_density_explorer.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_density_explorer.f90 sourcefile~procedures_random_coordinates_factory.f90 procedures_random_coordinates_factory.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_random_coordinates_factory.f90 sourcefile~classes_random_position.f90 classes_random_position.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_random_position.f90 sourcefile~classes_external_field.f90 classes_external_field.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~classes_external_field.f90 sourcefile~classes_parallelepiped_domain.f90->sourcefile~procedures_beta_pressures_excess_factory.f90 sourcefile~procedures_density_explorer_factory.f90->sourcefile~density.f90 sourcefile~classes_box_size_checker.f90->sourcefile~procedures_boxes_size_checker_factory.f90 sourcefile~classes_box_size_checker.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_box_size_checker.f90->sourcefile~procedures_complete_coordinates_reader_factory.f90 sourcefile~classes_box_size_checker.f90->sourcefile~classes_complete_coordinates_reader.f90 sourcefile~classes_boxes_particles_swap.f90 classes_boxes_particles_swap.f90 sourcefile~procedures_transmutation_visitors.f90->sourcefile~classes_boxes_particles_swap.f90 sourcefile~classes_box_particles_swap.f90 classes_box_particles_swap.f90 sourcefile~procedures_transmutation_visitors.f90->sourcefile~classes_box_particles_swap.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_environment_factory.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_complete_coordinates_reader_factory.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_readers_factory.f90 sourcefile~classes_box_particle_exchange.f90 classes_box_particle_exchange.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_box_particle_exchange.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_boxes_particles_swap.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_box_particles_swap.f90 sourcefile~classes_particle_insertion_method.f90 classes_particle_insertion_method.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_particle_insertion_method.f90 sourcefile~types_physical_model_wrapper.f90 types_physical_model_wrapper.f90 sourcefile~types_environment_wrapper.f90->sourcefile~types_physical_model_wrapper.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_short_interactions_factory.f90 sourcefile~classes_boxes_volume_exchange.f90 classes_boxes_volume_exchange.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~classes_box_particle_move.f90 classes_box_particle_move.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_box_particle_move.f90 sourcefile~classes_volume_change_method.f90 classes_volume_change_method.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_volume_change_method.f90 sourcefile~classes_box_volume_change.f90 classes_box_volume_change.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_box_volume_change.f90 sourcefile~classes_boxes_particle_teleportation.f90 classes_boxes_particle_teleportation.f90 sourcefile~types_environment_wrapper.f90->sourcefile~classes_boxes_particle_teleportation.f90 sourcefile~procedures_exploring_writers_factory.f90 procedures_exploring_writers_factory.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_exploring_writers_factory.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_dipolar_interactions_facades_factory.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_changes_factory.f90 sourcefile~procedures_generating_writers_factory.f90 procedures_generating_writers_factory.f90 sourcefile~types_environment_wrapper.f90->sourcefile~procedures_generating_writers_factory.f90 sourcefile~procedures_complete_coordinates_reader_factory.f90->sourcefile~procedures_readers_factory.f90 sourcefile~classes_complete_coordinates_reader.f90->sourcefile~procedures_complete_coordinates_reader_factory.f90 sourcefile~types_readers_wrapper.f90 types_readers_wrapper.f90 sourcefile~classes_complete_coordinates_reader.f90->sourcefile~types_readers_wrapper.f90 sourcefile~types_readers_wrapper.f90->sourcefile~procedures_readers_factory.f90 sourcefile~types_exploring_io.f90 types_exploring_io.f90 sourcefile~types_readers_wrapper.f90->sourcefile~types_exploring_io.f90 sourcefile~types_generating_io.f90 types_generating_io.f90 sourcefile~types_readers_wrapper.f90->sourcefile~types_generating_io.f90 sourcefile~plmc_explore.f90 plmc_explore.f90 sourcefile~types_exploring_io.f90->sourcefile~plmc_explore.f90 sourcefile~plmc_generate.f90 plmc_generate.f90 sourcefile~types_generating_io.f90->sourcefile~plmc_generate.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_box_particle_exchange.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_boxes_particles_swap.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_box_particles_swap.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_particle_insertion_method.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~types_physical_model_wrapper.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~procedures_short_interactions_factory.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_box_particle_move.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_volume_change_method.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_box_volume_change.f90 sourcefile~types_short_interactions_wrapper.f90->sourcefile~classes_boxes_particle_teleportation.f90 sourcefile~procedures_short_interactions_visitor.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~procedures_short_interactions_visitor.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_short_interactions_visitor.f90->sourcefile~classes_box_volume_change.f90 sourcefile~procedures_plmc_visitor.f90 procedures_plmc_visitor.f90 sourcefile~procedures_short_interactions_visitor.f90->sourcefile~procedures_plmc_visitor.f90 sourcefile~classes_dipolar_neighbourhoods_visitor.f90 classes_dipolar_neighbourhoods_visitor.f90 sourcefile~procedures_short_interactions_visitor.f90->sourcefile~classes_dipolar_neighbourhoods_visitor.f90 sourcefile~classes_maximum_box_compression_explorer.f90 classes_maximum_box_compression_explorer.f90 sourcefile~procedures_short_interactions_visitor.f90->sourcefile~classes_maximum_box_compression_explorer.f90 sourcefile~procedures_box_particle_exchange_factory.f90 procedures_box_particle_exchange_factory.f90 sourcefile~classes_box_particle_exchange.f90->sourcefile~procedures_box_particle_exchange_factory.f90 sourcefile~procedures_boxes_particles_swap_factory.f90 procedures_boxes_particles_swap_factory.f90 sourcefile~classes_boxes_particles_swap.f90->sourcefile~procedures_boxes_particles_swap_factory.f90 sourcefile~procedures_box_particles_swap_factory.f90 procedures_box_particles_swap_factory.f90 sourcefile~classes_box_particles_swap.f90->sourcefile~procedures_box_particles_swap_factory.f90 sourcefile~classes_particle_insertion_method.f90->sourcefile~types_markov_chain_explorer_wrapper.f90 sourcefile~procedures_particle_insertion_method_factory.f90 procedures_particle_insertion_method_factory.f90 sourcefile~classes_particle_insertion_method.f90->sourcefile~procedures_particle_insertion_method_factory.f90 sourcefile~procedures_exploration_inquirers.f90 procedures_exploration_inquirers.f90 sourcefile~classes_particle_insertion_method.f90->sourcefile~procedures_exploration_inquirers.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~plmc_explore.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~plmc_generate.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_box_particle_exchange_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~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~types_physical_model_wrapper.f90->sourcefile~procedures_boxes_particles_swap_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_box_particles_swap_factory.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_particle_insertion_method_factory.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~types_physical_model_wrapper.f90->sourcefile~procedures_physical_model_factory.f90 sourcefile~procedures_plmc_resetter.f90 procedures_plmc_resetter.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_plmc_resetter.f90 sourcefile~types_physical_model_wrapper.f90->sourcefile~procedures_plmc_visitor.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_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~types_physical_model_wrapper.f90->sourcefile~procedures_box_volume_change_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_short_interactions_factory.f90->sourcefile~procedures_physical_model_factory.f90 sourcefile~classes_boxes_volume_exchange.f90->sourcefile~procedures_boxes_volume_exchange_factory.f90 sourcefile~classes_box_particle_move.f90->sourcefile~procedures_box_particle_move_factory.f90 sourcefile~classes_volume_change_method.f90->sourcefile~types_markov_chain_explorer_wrapper.f90 sourcefile~classes_volume_change_method.f90->sourcefile~procedures_exploration_inquirers.f90 sourcefile~classes_volume_change_method.f90->sourcefile~procedures_volume_change_method_factory.f90 sourcefile~classes_box_volume_change.f90->sourcefile~procedures_box_volume_change_factory.f90 sourcefile~classes_boxes_particle_teleportation.f90->sourcefile~procedures_boxes_particle_teleportation_factory.f90 sourcefile~procedures_box_particle_exchange_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_boxes_particles_swap_factory.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~procedures_box_particles_swap_factory.f90->sourcefile~procedures_generating_algorithms_factory.f90 sourcefile~types_markov_chain_explorer_wrapper.f90->sourcefile~plmc_explore.f90 sourcefile~types_markov_chain_explorer_wrapper.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~types_markov_chain_explorer_wrapper.f90->sourcefile~procedures_exploring_writers_factory.f90 sourcefile~procedures_particle_insertion_method_factory.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~plmc_explore.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~procedures_short_interactions_factory.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~procedures_exploring_writers_factory.f90 sourcefile~procedures_exploration_inquirers.f90->sourcefile~procedures_dipolar_interactions_facades_factory.f90 sourcefile~procedures_markov_chain_explorer_factory.f90->sourcefile~plmc_explore.f90 sourcefile~procedures_dipolar_interactions_facades_factory.f90->sourcefile~procedures_physical_model_factory.f90 sourcefile~procedures_plmc_resetter.f90->sourcefile~plmc_explore.f90 sourcefile~procedures_plmc_resetter.f90->sourcefile~plmc_generate.f90 sourcefile~procedures_plmc_visitor.f90->sourcefile~plmc_explore.f90 sourcefile~procedures_plmc_visitor.f90->sourcefile~plmc_generate.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_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_box_volume_change_factory.f90->sourcefile~procedures_generating_algorithms_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~classes_dipolar_neighbourhoods_visitor.f90->sourcefile~types_markov_chain_explorer_wrapper.f90 sourcefile~classes_dipolar_neighbourhoods_visitor.f90->sourcefile~procedures_exploration_inquirers.f90 sourcefile~classes_dipolar_neighbourhoods_visitor.f90->sourcefile~procedures_dipolar_neighbourhoods_visitors_factory.f90 sourcefile~classes_maximum_box_compression_explorer.f90->sourcefile~types_markov_chain_explorer_wrapper.f90 sourcefile~classes_maximum_box_compression_explorer.f90->sourcefile~procedures_maximum_boxes_compression_explorer_factory.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~procedures_neighbour_cells_factory.f90 sourcefile~classes_visitable_cells.f90 classes_visitable_cells.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~classes_visitable_cells.f90 sourcefile~procedures_short_interactions_resetter.f90 procedures_short_interactions_resetter.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~procedures_short_interactions_resetter.f90 sourcefile~classes_visitable_cells_memento.f90 classes_visitable_cells_memento.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~classes_visitable_cells_memento.f90 sourcefile~procedures_visitable_cells_factory.f90 procedures_visitable_cells_factory.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~procedures_visitable_cells_factory.f90 sourcefile~types_cells_wrapper.f90 types_cells_wrapper.f90 sourcefile~classes_neighbour_cells.f90->sourcefile~types_cells_wrapper.f90 sourcefile~classes_average_num_particles.f90->sourcefile~procedures_average_nums_particles_factory.f90 sourcefile~procedures_selectors_resetters.f90 procedures_selectors_resetters.f90 sourcefile~classes_average_num_particles.f90->sourcefile~procedures_selectors_resetters.f90 sourcefile~types_mixture_wrapper.f90 types_mixture_wrapper.f90 sourcefile~classes_average_num_particles.f90->sourcefile~types_mixture_wrapper.f90 sourcefile~classes_beta_pressure_excess.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~classes_beta_pressure_excess.f90->sourcefile~procedures_beta_pressures_excess_factory.f90 sourcefile~classes_density_explorer.f90->sourcefile~density.f90 sourcefile~classes_density_explorer.f90->sourcefile~procedures_density_explorer_factory.f90 sourcefile~procedures_random_coordinates_factory.f90->sourcefile~classes_particle_insertion_method.f90 sourcefile~procedures_random_coordinates_factory.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_random_coordinates_factory.f90->sourcefile~procedures_changes_factory.f90 sourcefile~classes_random_position.f90->sourcefile~procedures_random_coordinates_factory.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_environment_inquirers.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_transmutation_visitors.f90 sourcefile~classes_external_field.f90->sourcefile~types_environment_wrapper.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_external_fields_factory.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_line_writer_factory.f90 sourcefile~procedures_energies_writers_factory.f90 procedures_energies_writers_factory.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_energies_writers_factory.f90 sourcefile~procedures_dipolar_interactions_visitor.f90 procedures_dipolar_interactions_visitor.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~procedures_dipoles_field_interaction.f90 procedures_dipoles_field_interaction.f90 sourcefile~classes_external_field.f90->sourcefile~procedures_dipoles_field_interaction.f90 sourcefile~procedures_beta_pressures_excess_factory.f90->sourcefile~procedures_short_interactions_factory.f90 sourcefile~classes_visitable_cells.f90->sourcefile~procedures_short_interactions_visitor.f90 sourcefile~classes_visitable_cells.f90->sourcefile~classes_dipolar_neighbourhoods_visitor.f90 sourcefile~classes_visitable_cells.f90->sourcefile~classes_maximum_box_compression_explorer.f90 sourcefile~classes_visitable_cells.f90->sourcefile~procedures_short_interactions_resetter.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_visitable_cells.f90->sourcefile~types_cells_wrapper.f90 sourcefile~procedures_short_interactions_resetter.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~procedures_short_interactions_resetter.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_short_interactions_resetter.f90->sourcefile~classes_box_volume_change.f90 sourcefile~procedures_short_interactions_resetter.f90->sourcefile~procedures_plmc_resetter.f90 sourcefile~classes_visitable_cells_memento.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~procedures_visitable_cells_memento_factory.f90 procedures_visitable_cells_memento_factory.f90 sourcefile~classes_visitable_cells_memento.f90->sourcefile~procedures_visitable_cells_memento_factory.f90 sourcefile~procedures_cells_memento.f90 procedures_cells_memento.f90 sourcefile~classes_visitable_cells_memento.f90->sourcefile~procedures_cells_memento.f90 sourcefile~procedures_visitable_cells_factory.f90->sourcefile~classes_visitable_cells_memento.f90 sourcefile~types_cells_wrapper.f90->sourcefile~procedures_transmutation_visitors.f90 sourcefile~types_cells_wrapper.f90->sourcefile~types_short_interactions_wrapper.f90 sourcefile~types_cells_wrapper.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~types_cells_wrapper.f90->sourcefile~classes_volume_change_method.f90 sourcefile~types_cells_wrapper.f90->sourcefile~classes_box_volume_change.f90 sourcefile~types_cells_wrapper.f90->sourcefile~procedures_cells_memento.f90 sourcefile~procedures_exchange_visitors.f90 procedures_exchange_visitors.f90 sourcefile~types_cells_wrapper.f90->sourcefile~procedures_exchange_visitors.f90 sourcefile~procedures_transmutation_updaters.f90 procedures_transmutation_updaters.f90 sourcefile~types_cells_wrapper.f90->sourcefile~procedures_transmutation_updaters.f90 sourcefile~procedures_exchange_updaters.f90 procedures_exchange_updaters.f90 sourcefile~types_cells_wrapper.f90->sourcefile~procedures_exchange_updaters.f90 sourcefile~procedures_cells_memento.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~procedures_cells_memento.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_cells_memento.f90->sourcefile~classes_box_volume_change.f90 sourcefile~procedures_exchange_visitors.f90->sourcefile~classes_box_particle_exchange.f90 sourcefile~procedures_exchange_visitors.f90->sourcefile~classes_boxes_particle_teleportation.f90 sourcefile~procedures_transmutation_updaters.f90->sourcefile~classes_boxes_particles_swap.f90 sourcefile~procedures_transmutation_updaters.f90->sourcefile~classes_box_particles_swap.f90 sourcefile~procedures_exchange_updaters.f90->sourcefile~classes_box_particle_exchange.f90 sourcefile~procedures_exchange_updaters.f90->sourcefile~classes_boxes_particle_teleportation.f90 sourcefile~procedures_selectors_resetters.f90->sourcefile~classes_box_particle_exchange.f90 sourcefile~procedures_selectors_resetters.f90->sourcefile~classes_boxes_particles_swap.f90 sourcefile~procedures_selectors_resetters.f90->sourcefile~classes_box_particles_swap.f90 sourcefile~procedures_selectors_resetters.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~procedures_selectors_resetters.f90->sourcefile~classes_box_particle_move.f90 sourcefile~procedures_selectors_resetters.f90->sourcefile~classes_box_volume_change.f90 sourcefile~procedures_selectors_resetters.f90->sourcefile~classes_boxes_particle_teleportation.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~classes_box_particle_exchange.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~classes_boxes_particles_swap.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~classes_box_particles_swap.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~types_physical_model_wrapper.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~procedures_short_interactions_factory.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~classes_box_particle_move.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~classes_box_volume_change.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~classes_boxes_particle_teleportation.f90 sourcefile~types_mixture_wrapper.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~procedures_dipolar_interactions_factory.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~procedures_dipolar_interactions_factory.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_dipolar_interactions_factory.f90->sourcefile~classes_box_volume_change.f90 sourcefile~procedures_dipolar_interactions_factory.f90->sourcefile~procedures_physical_model_factory.f90 sourcefile~procedures_changes_factory.f90->sourcefile~procedures_markov_chain_generator_factory.f90 sourcefile~procedures_line_writer_factory.f90->sourcefile~procedures_exploring_writers_factory.f90 sourcefile~procedures_line_writer_factory.f90->sourcefile~procedures_energies_writers_factory.f90 sourcefile~procedures_line_writer_factory.f90->sourcefile~procedures_generating_writers_factory.f90 sourcefile~procedures_energies_writers_factory.f90->sourcefile~procedures_exploring_writers_factory.f90 sourcefile~procedures_energies_writers_factory.f90->sourcefile~procedures_generating_writers_factory.f90 sourcefile~procedures_dipolar_interactions_visitor.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~procedures_dipolar_interactions_visitor.f90->sourcefile~classes_volume_change_method.f90 sourcefile~procedures_dipolar_interactions_visitor.f90->sourcefile~classes_box_volume_change.f90 sourcefile~procedures_dipolar_interactions_visitor.f90->sourcefile~procedures_plmc_visitor.f90 sourcefile~classes_dipolar_interactions_facade.f90 classes_dipolar_interactions_facade.f90 sourcefile~procedures_dipolar_interactions_visitor.f90->sourcefile~classes_dipolar_interactions_facade.f90 sourcefile~procedures_dipoles_field_interaction.f90->sourcefile~procedures_transmutation_visitors.f90 sourcefile~procedures_dipoles_field_interaction.f90->sourcefile~classes_box_particle_exchange.f90 sourcefile~procedures_dipoles_field_interaction.f90->sourcefile~classes_boxes_particles_swap.f90 sourcefile~procedures_dipoles_field_interaction.f90->sourcefile~classes_box_particles_swap.f90 sourcefile~procedures_dipoles_field_interaction.f90->sourcefile~classes_particle_insertion_method.f90 sourcefile~procedures_dipoles_field_interaction.f90->sourcefile~classes_box_particle_move.f90 sourcefile~procedures_dipoles_field_interaction.f90->sourcefile~classes_boxes_particle_teleportation.f90 sourcefile~procedures_dipoles_field_interaction.f90->sourcefile~procedures_dipolar_interactions_visitor.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~types_physical_model_wrapper.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~classes_boxes_volume_exchange.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~classes_volume_change_method.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~classes_box_volume_change.f90 sourcefile~classes_dipolar_interactions_facade.f90->sourcefile~procedures_dipolar_interactions_facades_factory.f90 sourcefile~procedures_changed_boxes_size_ratio_factory.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_changed_boxes_size_ratio_factory.f90->sourcefile~procedures_changed_boxes_size_factory.f90 sourcefile~procedures_move_tuner_factory.f90->sourcefile~procedures_changes_factory.f90 sourcefile~procedures_changes_component_factory.f90 procedures_changes_component_factory.f90 sourcefile~procedures_move_tuner_factory.f90->sourcefile~procedures_changes_component_factory.f90 sourcefile~procedures_maximum_box_compression_factory.f90->sourcefile~procedures_markov_chain_explorer_factory.f90 sourcefile~procedures_maximum_box_compression_factory.f90->sourcefile~classes_maximum_box_compression_explorer.f90 sourcefile~procedures_changed_boxes_size_factory.f90->sourcefile~procedures_changes_factory.f90 sourcefile~procedures_exchanged_boxes_size_factory.f90->sourcefile~procedures_changes_factory.f90 sourcefile~procedures_real_writer_factory.f90->sourcefile~procedures_exploring_writers_factory.f90 sourcefile~procedures_real_writer_factory.f90->sourcefile~procedures_energies_writers_factory.f90 sourcefile~procedures_real_writer_factory.f90->sourcefile~procedures_generating_writers_factory.f90 sourcefile~procedures_hard_contact_factory.f90->sourcefile~procedures_short_interactions_factory.f90 sourcefile~procedures_triangle_writer_factory.f90->sourcefile~procedures_energies_writers_factory.f90 sourcefile~procedures_triangle_writer_factory.f90->sourcefile~procedures_generating_writers_factory.f90 sourcefile~procedures_des_surf_mixture_factory.f90->sourcefile~procedures_dipolar_interactions_factory.f90 sourcefile~procedures_permittivity_factory.f90->sourcefile~procedures_environment_factory.f90 sourcefile~procedures_changes_component_factory.f90->sourcefile~procedures_changes_factory.f90
Help


Source Code

module classes_floor_penetration

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_array_size, check_positive
use procedures_centered_block_micro, only: set_from_corner, set_from_wall

implicit none

private

    type, abstract, public :: Abstract_Floor_Penetration
    contains
        procedure(Abstract_get_height), deferred :: get_height
        procedure(Abstract_meet), deferred :: meet
    end type Abstract_Floor_Penetration

    abstract interface

        pure real(DP) function Abstract_get_height(this)
        import :: DP, Abstract_Floor_Penetration
            class(Abstract_Floor_Penetration), intent(in) :: this
        end function Abstract_get_height

        pure subroutine Abstract_meet(this, overlap, shortest_vector_from_floor, &
            position_from_floor)
        import :: DP, num_dimensions, Abstract_Floor_Penetration
            class(Abstract_Floor_Penetration), intent(in) :: this
            logical, intent(out) :: overlap
            real(DP), intent(out) :: shortest_vector_from_floor(num_dimensions)
            real(DP), intent(in) :: position_from_floor(num_dimensions)
        end subroutine Abstract_meet

    end interface

    type, extends(Abstract_Floor_Penetration), public :: Flat_Floor_Penetration
    contains
        procedure :: get_height => Flat_get_height
        procedure :: meet => Flat_meet
    end type Flat_Floor_Penetration

    !> This is a flat floor with a rounded block at the center, cf.
    !> modules/environment/walls/centered_block_penetration.tex which shows the right half.
    !> When using [[Block_meet]], if a position is in a blue area,
    !> shortestVectorFromFloor's origin will be on a rounder corner. Otherwise (i.e. white area),
    !> it will be on a flat portion.
    type, extends(Abstract_Floor_Penetration), public :: Centered_Block_Penetration
    private
        real(DP), dimension(2) :: size = 0._DP
        real(DP) :: radius = 0._DP
        real(DP), dimension(2) :: lower_in = 0._DP, lower_out = 0._DP, upper_in = 0._DP, &
            upper_out = 0._DP! right centers
    contains
        procedure :: set => Block_set
        procedure :: get_height => Block_get_height
        procedure :: meet => Block_meet
    end type Centered_Block_Penetration

    type, extends(Abstract_Floor_Penetration), public :: Null_Floor_Penetration
    contains
        procedure :: get_height => Null_get_height
        procedure :: meet => Null_meet
    end type Null_Floor_Penetration

contains

!implementation Flat_Floor_Penetration

    pure real(DP) function Flat_get_height(this) result(height)
        class(Flat_Floor_Penetration), intent(in) :: this

        height = 0._DP
    end function Flat_get_height

    pure subroutine Flat_meet(this, overlap, shortest_vector_from_floor, position_from_floor)
        class(Flat_Floor_Penetration), intent(in) :: this
        logical, intent(out) :: overlap
        real(DP), intent(out) :: shortest_vector_from_floor(num_dimensions)
        real(DP), intent(in) :: position_from_floor(num_dimensions)

        shortest_vector_from_floor = [0._DP, 0._DP, position_from_floor(3)]
        if (shortest_vector_from_floor(3) < 0._DP) then
            overlap = .true.
        else
            overlap = .false.
        end if
    end subroutine Flat_meet

!end implementation Flat_Floor_Penetration

!implementation Centered_Block_Penetration

    subroutine Block_set(this, size, radius)
        class(Centered_Block_Penetration), intent(out) :: this
        real(DP), intent(in) :: size(:), radius

        call check_array_size("Centered_Block_Penetration: set", "size", size, 2)
        call check_positive("Centered_Block_Penetration: set", "size", size)
        this%size = size
        call check_positive("Centered_Block_Penetration: set", "radius", radius)
        if (this%size(1) < 2.0_DP*radius) then
            call error_exit("Centered_Block_Penetration: set: 2*radius > size_x.")
        end if
        if (this%size(2) < 2.0_DP*radius) then
            call error_exit("Centered_Block_Penetration: set: 2*radius > size_z.")
        end if
        this%radius = radius

        this%upper_in = [this%size(1)/2._DP, this%size(2)]
        this%upper_out = [this%size(1)/2._DP - this%radius, this%size(2) - this%radius]
        this%lower_in  = [this%size(1)/2._DP + this%radius, this%radius]
        this%lower_out = [this%size(1)/2._DP, 0._DP]
    end subroutine Block_set

    pure real(DP) function Block_get_height(this) result(height)
        class(Centered_Block_Penetration), intent(in) :: this

        height = this%size(2)
    end function Block_get_height

    pure subroutine Block_meet(this, overlap, shortest_vector_from_floor, position_from_floor)
        class(Centered_Block_Penetration), intent(in) :: this
        logical, intent(out) :: overlap
        real(DP), intent(out) :: shortest_vector_from_floor(num_dimensions)
        real(DP), intent(in) :: position_from_floor(num_dimensions)

        real(DP), dimension(2) :: shortest_vector, position_13

        if (0._DP < position_from_floor(1)) then
            position_13 = [+position_from_floor(1), position_from_floor(3)]
        else
            position_13 = [-position_from_floor(1), position_from_floor(3)]
        end if

        if (all(this%upper_out < position_13)) then !
            call set_from_corner(shortest_vector, this%upper_out, this%radius, position_13)
        else if (all(position_13 < this%lower_in)) then
            call set_from_corner(shortest_vector, this%lower_in, this%radius, position_13)
        else if (position_13(2) < this%size(2)/2._DP) then
            !> Frame: (0, \vec{e}_x, \vec{e}_z)
            call set_from_wall(shortest_vector, this%lower_out, position_13)
        else
            !> Frame: (0^\prime, -\vec{e}_x, -\vec{e}_z)
            call set_from_wall(shortest_vector, -this%upper_in, -position_13)
            shortest_vector = -shortest_vector
        end if

        if (any(shortest_vector < 0._DP )) then
            overlap = .true.
        else
            overlap = .false.
        end if
        shortest_vector_from_floor = [shortest_vector(1), 0._DP, shortest_vector(2)]
    end subroutine Block_meet

!implementation Centered_Block_Penetration

!implementation Null_Floor_Penetration

    pure real(DP) function Null_get_height(this) result(height)
        class(Null_Floor_Penetration), intent(in) :: this
        height = 0._DP
    end function Null_get_height

    pure subroutine Null_meet(this, overlap, shortest_vector_from_floor, position_from_floor)
        class(Null_Floor_Penetration), intent(in) :: this
        logical, intent(out) :: overlap
        real(DP), intent(out) :: shortest_vector_from_floor(num_dimensions)
        real(DP), intent(in) :: position_from_floor(num_dimensions)
        shortest_vector_from_floor = 0._DP !Is it what I expect from a null object?
        overlap = .false.
    end subroutine Null_meet

!end implementation Null_Floor_Penetration

end module classes_floor_penetration

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