diff --git a/dev/.documenter-siteinfo.json b/dev/.documenter-siteinfo.json index eefb2df..dbe75b0 100644 --- a/dev/.documenter-siteinfo.json +++ b/dev/.documenter-siteinfo.json @@ -1 +1 @@ -{"documenter":{"julia_version":"1.10.4","generation_timestamp":"2024-07-24T04:32:52","documenter_version":"1.5.0"}} \ No newline at end of file +{"documenter":{"julia_version":"1.10.4","generation_timestamp":"2024-08-01T20:33:04","documenter_version":"1.5.0"}} \ No newline at end of file diff --git a/dev/authors/index.html b/dev/authors/index.html index edde8d5..1698f84 100644 --- a/dev/authors/index.html +++ b/dev/authors/index.html @@ -1,2 +1,2 @@ -Authors · P4est.jl

Authors

The development of P4est.jl is coordinated by a group of principal developers, who are also its main contributors and who can be contacted in case of questions about P4est.jl. In addition, there are contributors who have provided substantial additions or modifications. Together, these two groups form "The P4est.jl Authors" as mentioned in the License file.

Principal Developers

Contributors

The following people contributed major additions or modifications to P4est.jl and are listed in alphabetical order:

  • Alexander Astanin
  • Lars Christmann
  • Joshua Lampert
  • Hendrik Ranocha
  • Michael Schlottke-Lakemper
  • Lucas C Wilcox
+Authors · P4est.jl

Authors

The development of P4est.jl is coordinated by a group of principal developers, who are also its main contributors and who can be contacted in case of questions about P4est.jl. In addition, there are contributors who have provided substantial additions or modifications. Together, these two groups form "The P4est.jl Authors" as mentioned in the License file.

Principal Developers

Contributors

The following people contributed major additions or modifications to P4est.jl and are listed in alphabetical order:

  • Alexander Astanin
  • Lars Christmann
  • Joshua Lampert
  • Hendrik Ranocha
  • Michael Schlottke-Lakemper
  • Lucas C Wilcox
diff --git a/dev/code_of_conduct/index.html b/dev/code_of_conduct/index.html index beb6c6f..ae1d49e 100644 --- a/dev/code_of_conduct/index.html +++ b/dev/code_of_conduct/index.html @@ -1,2 +1,2 @@ -Code of conduct · P4est.jl

Code of Conduct

Contributor Covenant Code of Conduct

Our Pledge

We as members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone, regardless of age, body size, visible or invisible disability, ethnicity, sex characteristics, gender identity and expression, level of experience, education, socio-economic status, nationality, personal appearance, race, religion, or sexual identity and orientation.

We pledge to act and interact in ways that contribute to an open, welcoming, diverse, inclusive, and healthy community.

Our Standards

Examples of behavior that contributes to a positive environment for our community include:

  • Demonstrating empathy and kindness toward other people
  • Being respectful of differing opinions, viewpoints, and experiences
  • Giving and gracefully accepting constructive feedback
  • Accepting responsibility and apologizing to those affected by our mistakes, and learning from the experience
  • Focusing on what is best not just for us as individuals, but for the overall community

Examples of unacceptable behavior include:

  • The use of sexualized language or imagery, and sexual attention or advances of any kind
  • Trolling, insulting or derogatory comments, and personal or political attacks
  • Public or private harassment
  • Publishing others' private information, such as a physical or email address, without their explicit permission
  • Other conduct which could reasonably be considered inappropriate in a professional setting

Enforcement Responsibilities

Community leaders are responsible for clarifying and enforcing our standards of acceptable behavior and will take appropriate and fair corrective action in response to any behavior that they deem inappropriate, threatening, offensive, or harmful.

Community leaders have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, and will communicate reasons for moderation decisions when appropriate.

Scope

This Code of Conduct applies within all community spaces, and also applies when an individual is officially representing the community in public spaces. Examples of representing our community include using an official e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event.

Enforcement

Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to Joshua Lampert, Michael Schlottke-Lakemper, Hendrik Ranocha, or any other of the principal developers responsible for enforcement listed in Authors. All complaints will be reviewed and investigated promptly and fairly.

All community leaders are obligated to respect the privacy and security of the reporter of any incident.

Enforcement Guidelines

Community leaders will follow these Community Impact Guidelines in determining the consequences for any action they deem in violation of this Code of Conduct:

1. Correction

Community Impact: Use of inappropriate language or other behavior deemed unprofessional or unwelcome in the community.

Consequence: A private, written warning from community leaders, providing clarity around the nature of the violation and an explanation of why the behavior was inappropriate. A public apology may be requested.

2. Warning

Community Impact: A violation through a single incident or series of actions.

Consequence: A warning with consequences for continued behavior. No interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, for a specified period of time. This includes avoiding interactions in community spaces as well as external channels like social media. Violating these terms may lead to a temporary or permanent ban.

3. Temporary Ban

Community Impact: A serious violation of community standards, including sustained inappropriate behavior.

Consequence: A temporary ban from any sort of interaction or public communication with the community for a specified period of time. No public or private interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, is allowed during this period. Violating these terms may lead to a permanent ban.

4. Permanent Ban

Community Impact: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior, harassment of an individual, or aggression toward or disparagement of classes of individuals.

Consequence: A permanent ban from any sort of public interaction within the community.

Attribution

This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 2.0, available at https://www.contributor-covenant.org/version/2/0/codeofconduct.html.

Community Impact Guidelines were inspired by Mozilla's code of conduct enforcement ladder.

[homepage]: https://www.contributor-covenant.org

For answers to common questions about this code of conduct, see the FAQ at https://www.contributor-covenant.org/faq. Translations are available at https://www.contributor-covenant.org/translations.

+Code of conduct · P4est.jl

Code of Conduct

Contributor Covenant Code of Conduct

Our Pledge

We as members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone, regardless of age, body size, visible or invisible disability, ethnicity, sex characteristics, gender identity and expression, level of experience, education, socio-economic status, nationality, personal appearance, race, religion, or sexual identity and orientation.

We pledge to act and interact in ways that contribute to an open, welcoming, diverse, inclusive, and healthy community.

Our Standards

Examples of behavior that contributes to a positive environment for our community include:

  • Demonstrating empathy and kindness toward other people
  • Being respectful of differing opinions, viewpoints, and experiences
  • Giving and gracefully accepting constructive feedback
  • Accepting responsibility and apologizing to those affected by our mistakes, and learning from the experience
  • Focusing on what is best not just for us as individuals, but for the overall community

Examples of unacceptable behavior include:

  • The use of sexualized language or imagery, and sexual attention or advances of any kind
  • Trolling, insulting or derogatory comments, and personal or political attacks
  • Public or private harassment
  • Publishing others' private information, such as a physical or email address, without their explicit permission
  • Other conduct which could reasonably be considered inappropriate in a professional setting

Enforcement Responsibilities

Community leaders are responsible for clarifying and enforcing our standards of acceptable behavior and will take appropriate and fair corrective action in response to any behavior that they deem inappropriate, threatening, offensive, or harmful.

Community leaders have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, and will communicate reasons for moderation decisions when appropriate.

Scope

This Code of Conduct applies within all community spaces, and also applies when an individual is officially representing the community in public spaces. Examples of representing our community include using an official e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event.

Enforcement

Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to Joshua Lampert, Michael Schlottke-Lakemper, Hendrik Ranocha, or any other of the principal developers responsible for enforcement listed in Authors. All complaints will be reviewed and investigated promptly and fairly.

All community leaders are obligated to respect the privacy and security of the reporter of any incident.

Enforcement Guidelines

Community leaders will follow these Community Impact Guidelines in determining the consequences for any action they deem in violation of this Code of Conduct:

1. Correction

Community Impact: Use of inappropriate language or other behavior deemed unprofessional or unwelcome in the community.

Consequence: A private, written warning from community leaders, providing clarity around the nature of the violation and an explanation of why the behavior was inappropriate. A public apology may be requested.

2. Warning

Community Impact: A violation through a single incident or series of actions.

Consequence: A warning with consequences for continued behavior. No interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, for a specified period of time. This includes avoiding interactions in community spaces as well as external channels like social media. Violating these terms may lead to a temporary or permanent ban.

3. Temporary Ban

Community Impact: A serious violation of community standards, including sustained inappropriate behavior.

Consequence: A temporary ban from any sort of interaction or public communication with the community for a specified period of time. No public or private interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, is allowed during this period. Violating these terms may lead to a permanent ban.

4. Permanent Ban

Community Impact: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior, harassment of an individual, or aggression toward or disparagement of classes of individuals.

Consequence: A permanent ban from any sort of public interaction within the community.

Attribution

This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 2.0, available at https://www.contributor-covenant.org/version/2/0/codeofconduct.html.

Community Impact Guidelines were inspired by Mozilla's code of conduct enforcement ladder.

[homepage]: https://www.contributor-covenant.org

For answers to common questions about this code of conduct, see the FAQ at https://www.contributor-covenant.org/faq. Translations are available at https://www.contributor-covenant.org/translations.

diff --git a/dev/contributing/index.html b/dev/contributing/index.html index 4cb3d2b..8b06210 100644 --- a/dev/contributing/index.html +++ b/dev/contributing/index.html @@ -35,4 +35,4 @@ are public and that a record of the contribution (including all personal information I submit with it, including my sign-off) is maintained indefinitely and may be redistributed consistent with - this project or the open source license(s) involved. + this project or the open source license(s) involved. diff --git a/dev/index.html b/dev/index.html index 7035993..603a524 100644 --- a/dev/index.html +++ b/dev/index.html @@ -105,4 +105,4 @@ P4est.init(C_NULL, SC_LP_ERROR) - before calling other functions from p4est.

For more information on how to use p4est, please refer to the documentation for p4est itself or to the header files (*.h) in the p4est repository.

For more information on how to use the Julia wrapper P4est.jl, please consult the documentation.

Authors

P4est.jl is mainly maintained by Joshua Lampert (University of Hamburg, Germany), Michael Schlottke-Lakemper (University of Augsburg, Germany), and Hendrik Ranocha (Johannes Gutenberg University Mainz, Germany). The full list of contributors can be found in Authors. The p4est library itself is written by Carsten Burstedde, Lucas C. Wilcox, and Tobin Isaac.

License and contributing

P4est.jl is licensed under the MIT license (see License). p4est itself is licensed under the GNU General Public License, version 2.

+ before calling other functions from p4est.

For more information on how to use p4est, please refer to the documentation for p4est itself or to the header files (*.h) in the p4est repository.

For more information on how to use the Julia wrapper P4est.jl, please consult the documentation.

Authors

P4est.jl is mainly maintained by Joshua Lampert (University of Hamburg, Germany), Michael Schlottke-Lakemper (University of Augsburg, Germany), and Hendrik Ranocha (Johannes Gutenberg University Mainz, Germany). The full list of contributors can be found in Authors. The p4est library itself is written by Carsten Burstedde, Lucas C. Wilcox, and Tobin Isaac.

License and contributing

P4est.jl is licensed under the MIT license (see License). p4est itself is licensed under the GNU General Public License, version 2.

diff --git a/dev/introduction/index.html b/dev/introduction/index.html index fe1f67f..469685b 100644 --- a/dev/introduction/index.html +++ b/dev/introduction/index.html @@ -1,5 +1,5 @@ -Introduction · P4est.jl

Introduction

Installation instructions and first usage examples are shown on the main page. This page collects some additional examples and translation guidelines from the C library p4est to its Julia wrapper P4est.jl.

High-level overview of the setup

The Julia bindings of p4est are generated using Clang.jl. This process is described in the dev folder of P4est.jl. Since all MPI datatypes are mapped to types from MPI.jl, the generated bindings are agnostic of the local MPI installation. Hence, there should be no need to generate new bindings as a user. If there are problems, please let us know, e.g., by creating on issue on GitHub. New bindings only need to be generated for a new version of p4est that comes with a different API. We will probably provide some new bindings when we learn about this.

Translation guidelines

Many functions of p4est work with pointers, e.g.,

int p4est_connectivity_is_valid (p4est_connectivity_t * connectivity);

or return pointers to newly created structs, e.g.,

p4est_connectivity_t *p4est_connectivity_new_periodic (void);

P4est.jl wraps these C functions accordingly and works with pointers. For a convenient alternative to using raw pointers directly, see the next section on PointerWrappers. We also follow the naming scheme of p4est. For example, we use connectivity::Ptr{p4est_connectivity}. However, it is sometimes useful/required to also load the wrappers of the C structs from their pointers. In this case, we use the naming convention to append _obj, e.g., connectivity_obj = unsafe_load(connectivity). A full example is given here:

julia> using P4est, MPI; MPI.Init()MPI.ThreadLevel(2)
julia> connectivity = p4est_connectivity_new_periodic()Ptr{p4est_connectivity} @0x0000000002516120
julia> @doc(p4est_connectivity) p4est_connectivity +Introduction · P4est.jl

Introduction

Installation instructions and first usage examples are shown on the main page. This page collects some additional examples and translation guidelines from the C library p4est to its Julia wrapper P4est.jl.

High-level overview of the setup

The Julia bindings of p4est are generated using Clang.jl. This process is described in the dev folder of P4est.jl. Since all MPI datatypes are mapped to types from MPI.jl, the generated bindings are agnostic of the local MPI installation. Hence, there should be no need to generate new bindings as a user. If there are problems, please let us know, e.g., by creating on issue on GitHub. New bindings only need to be generated for a new version of p4est that comes with a different API. We will probably provide some new bindings when we learn about this.

Translation guidelines

Many functions of p4est work with pointers, e.g.,

int p4est_connectivity_is_valid (p4est_connectivity_t * connectivity);

or return pointers to newly created structs, e.g.,

p4est_connectivity_t *p4est_connectivity_new_periodic (void);

P4est.jl wraps these C functions accordingly and works with pointers. For a convenient alternative to using raw pointers directly, see the next section on PointerWrappers. We also follow the naming scheme of p4est. For example, we use connectivity::Ptr{p4est_connectivity}. However, it is sometimes useful/required to also load the wrappers of the C structs from their pointers. In this case, we use the naming convention to append _obj, e.g., connectivity_obj = unsafe_load(connectivity). A full example is given here:

julia> using P4est, MPI; MPI.Init()MPI.ThreadLevel(2)
julia> connectivity = p4est_connectivity_new_periodic()Ptr{p4est_connectivity} @0x000000000297e790
julia> @doc(p4est_connectivity) p4est_connectivity This structure holds the 2D inter-tree connectivity information. Identification of arbitrary faces and corners is possible. @@ -44,22 +44,22 @@ tree_to_corner (4 * num_trees) or NULL (see description) ctt_offset corner to offset in cornertotree and cornertocorner corner_to_tree list of trees that meet at a corner - corner_to_corner list of tree-corners that meet at a corner
julia> connectivity_obj = unsafe_load(connectivity)p4est_connectivity(4, 1, 1, Ptr{Float64} @0x0000000001c4cd50, Ptr{Int32} @0x00000000014235f0, 0x0000000000000000, Cstring(0x0000000000000000), Ptr{Int32} @0x000000000187df10, Ptr{Int8} @0x0000000001529070, Ptr{Int32} @0x00000000019ebe50, Ptr{Int32} @0x0000000002370bf0, Ptr{Int32} @0x00000000017117d0, Ptr{Int8} @0x0000000001895060)
julia> connectivity_obj.num_vertices4
julia> connectivity_obj.num_trees1
julia> connectivity_obj.num_corners1
julia> p4est_connectivity_destroy(connectivity)

PointerWrappers

As we have seen in the previous section on translation guidelines, many functions provided by p4est return pointers to structs, which requires one to unsafe_load the pointer in order to access the underlying data. P4est.jl offers a convenient alternative to directly using unsafe_load by providing the PointerWrapper data type. If you, e.g., have a pointer to a p4est_connectivity (i.e., an object of type Ptr{p4est_connectivity}) called connectivity, you can use connectivity_pw = PointerWrapper(connectivity) to obtain a wrapped version of the pointer, where the underlying data can be accessed simply by connectivity_pw.num_trees[] without the need to call unsafe_load manually. This works even for nested structures, e.g, where the named field of a struct is a pointer to a struct. A full example on how to use the PointerWrapper is given here (note the nested access at p4est_pw.connectivity.num_trees[] compared to unsafe_load(unsafe_load(p4est).connectivity).num_trees without a PointerWrapper):

julia> using P4est, MPI; MPI.Init()MPI.ThreadLevel(2)
julia> connectivity = p4est_connectivity_new_periodic()Ptr{p4est_connectivity} @0x0000000001d13450
julia> connectivity_pw = PointerWrapper(connectivity)PointerWrapper{p4est_connectivity}(Ptr{p4est_connectivity} @0x0000000001d13450)
julia> connectivity_pw.num_trees[]1
julia> p4est = p4est_new_ext(MPI.COMM_WORLD, connectivity, 0, 0, true, 0, C_NULL, C_NULL)Into p4est_new with min quadrants 0 level 0 uniform 1 + corner_to_corner list of tree-corners that meet at a corner
julia> connectivity_obj = unsafe_load(connectivity)p4est_connectivity(4, 1, 1, Ptr{Float64} @0x0000000001f16280, Ptr{Int32} @0x0000000001072040, 0x0000000000000000, Cstring(0x0000000000000000), Ptr{Int32} @0x0000000001b4abd0, Ptr{Int8} @0x0000000001aeaf10, Ptr{Int32} @0x00000000029a0850, Ptr{Int32} @0x0000000001adc1d0, Ptr{Int32} @0x000000000183b780, Ptr{Int8} @0x0000000001ac1190)
julia> connectivity_obj.num_vertices4
julia> connectivity_obj.num_trees1
julia> connectivity_obj.num_corners1
julia> p4est_connectivity_destroy(connectivity)

PointerWrappers

As we have seen in the previous section on translation guidelines, many functions provided by p4est return pointers to structs, which requires one to unsafe_load the pointer in order to access the underlying data. P4est.jl offers a convenient alternative to directly using unsafe_load by providing the PointerWrapper data type. If you, e.g., have a pointer to a p4est_connectivity (i.e., an object of type Ptr{p4est_connectivity}) called connectivity, you can use connectivity_pw = PointerWrapper(connectivity) to obtain a wrapped version of the pointer, where the underlying data can be accessed simply by connectivity_pw.num_trees[] without the need to call unsafe_load manually. This works even for nested structures, e.g, where the named field of a struct is a pointer to a struct. A full example on how to use the PointerWrapper is given here (note the nested access at p4est_pw.connectivity.num_trees[] compared to unsafe_load(unsafe_load(p4est).connectivity).num_trees without a PointerWrapper):

julia> using P4est, MPI; MPI.Init()MPI.ThreadLevel(2)
julia> connectivity = p4est_connectivity_new_periodic()Ptr{p4est_connectivity} @0x000000000228ecd0
julia> connectivity_pw = PointerWrapper(connectivity)PointerWrapper{p4est_connectivity}(Ptr{p4est_connectivity} @0x000000000228ecd0)
julia> connectivity_pw.num_trees[]1
julia> p4est = p4est_new_ext(MPI.COMM_WORLD, connectivity, 0, 0, true, 0, C_NULL, C_NULL)Into p4est_new with min quadrants 0 level 0 uniform 1 New p4est with 1 trees on 1 processors Initial level 0 potential global quadrants 1 per tree 1 Done p4est_new with 1 total quadrants -Ptr{P4est.LibP4est.p4est} @0x0000000001c86ec0
julia> p4est_pw = PointerWrapper(p4est)PointerWrapper{P4est.LibP4est.p4est}(Ptr{P4est.LibP4est.p4est} @0x0000000001c86ec0)
julia> p4est_pw.connectivity.num_trees[]1
julia> p4est_destroy(p4est)
julia> p4est_connectivity_destroy(connectivity)

You may also use the PointerWrapper to set variables in structs. Here we set the user data pointer in the p4est_t struct to point to some data:

julia> using P4est, MPI; MPI.Init()MPI.ThreadLevel(2)
julia> connectivity = p4est_connectivity_new_periodic()Ptr{p4est_connectivity} @0x0000000001c35a60
julia> p4est = p4est_new_ext(MPI.COMM_WORLD, connectivity, 0, 0, true, 0, C_NULL, C_NULL)Into p4est_new with min quadrants 0 level 0 uniform 1 +Ptr{P4est.LibP4est.p4est} @0x0000000001e536b0
julia> p4est_pw = PointerWrapper(p4est)PointerWrapper{P4est.LibP4est.p4est}(Ptr{P4est.LibP4est.p4est} @0x0000000001e536b0)
julia> p4est_pw.connectivity.num_trees[]1
julia> p4est_destroy(p4est)
julia> p4est_connectivity_destroy(connectivity)

You may also use the PointerWrapper to set variables in structs. Here we set the user data pointer in the p4est_t struct to point to some data:

julia> using P4est, MPI; MPI.Init()MPI.ThreadLevel(2)
julia> connectivity = p4est_connectivity_new_periodic()Ptr{p4est_connectivity} @0x000000000286e380
julia> p4est = p4est_new_ext(MPI.COMM_WORLD, connectivity, 0, 0, true, 0, C_NULL, C_NULL)Into p4est_new with min quadrants 0 level 0 uniform 1 New p4est with 1 trees on 1 processors Initial level 0 potential global quadrants 1 per tree 1 Done p4est_new with 1 total quadrants -Ptr{P4est.LibP4est.p4est} @0x000000000213abd0
julia> p4est_pw = PointerWrapper(p4est)PointerWrapper{P4est.LibP4est.p4est}(Ptr{P4est.LibP4est.p4est} @0x000000000213abd0)
julia> data = Ref((rand(4), rand(5)))Base.RefValue{Tuple{Vector{Float64}, Vector{Float64}}}(([0.7539559002118178, 0.3127267285358587, 0.6586816617006763, 0.37450796807398545], [0.497753086055835, 0.7747822248222774, 0.18071907446486157, 0.7942489911930843, 0.8867072469488873]))
julia> GC.@preserve data begin +Ptr{P4est.LibP4est.p4est} @0x00000000023546f0
julia> p4est_pw = PointerWrapper(p4est)PointerWrapper{P4est.LibP4est.p4est}(Ptr{P4est.LibP4est.p4est} @0x00000000023546f0)
julia> data = Ref((rand(4), rand(5)))Base.RefValue{Tuple{Vector{Float64}, Vector{Float64}}}(([0.24305142464033969, 0.013044453083708718, 0.5576176617503062, 0.6353016559587258], [0.22765246099575753, 0.19415962302056855, 0.08828715837931156, 0.4521277709891388, 0.684889207095517]))
julia> GC.@preserve data begin p4est_pw.user_pointer = pointer_from_objref(data) # Call p4est function with callback that uses p4est_pw.user_pointer here. # You may retrieve the data `Ref` in the callback with # data = unsafe_pointer_to_objref(pointer(p4est_pw.user_pointer)) - endPtr{Nothing} @0x00007fe9fdda4c70
julia> p4est_destroy(p4est)
julia> p4est_connectivity_destroy(connectivity)

In addition, you can use a PointerWrapper as an array if the underlying datastructure is an array, i.e. you can access the i-th element of the underlying array by pw[i] for a PointerWrapper pw. See the following code for a full example:

julia> using P4est, MPI; MPI.Init()MPI.ThreadLevel(2)
julia> connectivity = p4est_connectivity_new_periodic()Ptr{p4est_connectivity} @0x000000000236dc40
julia> p4est = p4est_new_ext(MPI.COMM_WORLD, connectivity, 0, 0, true, 0, C_NULL, C_NULL)Into p4est_new with min quadrants 0 level 0 uniform 1 + endPtr{Nothing} @0x00007fbaaa94c450
julia> p4est_destroy(p4est)
julia> p4est_connectivity_destroy(connectivity)

In addition, you can use a PointerWrapper as an array if the underlying datastructure is an array, i.e. you can access the i-th element of the underlying array by pw[i] for a PointerWrapper pw. See the following code for a full example:

julia> using P4est, MPI; MPI.Init()MPI.ThreadLevel(2)
julia> connectivity = p4est_connectivity_new_periodic()Ptr{p4est_connectivity} @0x00000000021c39c0
julia> p4est = p4est_new_ext(MPI.COMM_WORLD, connectivity, 0, 0, true, 0, C_NULL, C_NULL)Into p4est_new with min quadrants 0 level 0 uniform 1 New p4est with 1 trees on 1 processors Initial level 0 potential global quadrants 1 per tree 1 Done p4est_new with 1 total quadrants -Ptr{P4est.LibP4est.p4est} @0x0000000002018830
julia> p4est_pw = PointerWrapper(p4est)PointerWrapper{P4est.LibP4est.p4est}(Ptr{P4est.LibP4est.p4est} @0x0000000002018830)
julia> p4est_pw.global_first_quadrant[2]1
julia> p4est_destroy(p4est)
julia> p4est_connectivity_destroy(connectivity)

Note on MPI datatypes

MPI types used by p4est are mapped to the types provided by MPI.jl.

p4estP4est.jl
sc_MPI_CommMPI.MPI_Comm
MPI_DatatypeMPI.MPI_Datatype
MPI_FileMPI.MPI_File

In particular, it is currently not possible to use p4est without MPI support.

+Ptr{P4est.LibP4est.p4est} @0x0000000002775cf0

julia> p4est_pw = PointerWrapper(p4est)PointerWrapper{P4est.LibP4est.p4est}(Ptr{P4est.LibP4est.p4est} @0x0000000002775cf0)
julia> p4est_pw.global_first_quadrant[2]1
julia> p4est_destroy(p4est)
julia> p4est_connectivity_destroy(connectivity)

Note on MPI datatypes

MPI types used by p4est are mapped to the types provided by MPI.jl.

p4estP4est.jl
sc_MPI_CommMPI.MPI_Comm
MPI_DatatypeMPI.MPI_Datatype
MPI_FileMPI.MPI_File

In particular, it is currently not possible to use p4est without MPI support.

diff --git a/dev/license/index.html b/dev/license/index.html index 4b8ac61..b8878ae 100644 --- a/dev/license/index.html +++ b/dev/license/index.html @@ -1,2 +1,2 @@ -License · P4est.jl

License

MIT License

Copyright (c) 2020-present The P4est.jl Authors (see Authors)

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

+License · P4est.jl

License

MIT License

Copyright (c) 2020-present The P4est.jl Authors (see Authors)

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

diff --git a/dev/reference/index.html b/dev/reference/index.html index 3f9375d..776284c 100644 --- a/dev/reference/index.html +++ b/dev/reference/index.html @@ -1,5 +1,5 @@ -API reference · P4est.jl

API reference

Higher-level API provided by P4est.jl

P4est.initMethod
P4est.init(log_handler, log_threshold)

Calls p4est_init if it has not already been called, otherwise do nothing. Thus, P4est.init can safely be called multiple times.

To use the default log handler and suppress most output created by default by p4est, call this function as

P4est.init(C_NULL, SC_LP_ERROR)

before calling other functions from p4est.

source
P4est.package_idMethod
P4est.package_id()

Returns the value of the global variable p4est_package_id which can be used to check whether p4est has been initialized.

source
P4est.path_p4est_libraryMethod
P4est.path_p4est_library()

Return the path of the p4est library that is used, when a system-provided library is configured via the preferences. Otherwise P4est_jll is returned, which means that the default p4est version from P4est_jll.jl is used.

source
P4est.path_sc_libraryMethod
P4est.path_sc_library()

Return the path of the sc library that is used, when a system-provided library is configured via the preferences. Otherwise P4est_jll is returned, which means that the default sc version from P4est_jll.jl is used.

source
P4est.preferences_set_correctlyMethod
P4est.preferences_set_correctly()

Returns false if a system-provided MPI installation is set via the MPIPreferences, but not a system-provided p4est installation. In this case, P4est.jl is not usable.

source
P4est.set_library_p4est!Function
P4est.set_library_p4est!(path; force = true)

Set the path to a system-provided p4est installation. Restart the Julia session after executing this function so that the changes take effect. Calling this function is necessary when you want to use a system-provided p4est installation.

source
P4est.set_library_sc!Function
P4est.set_library_sc!(path; force = true)

Set the path to a system-provided sc installation. Restart the Julia session after executing this function so that the changes take effect. Calling this function is necessary, when you want to use a system-provided p4est installation on Windows or when you want to use another sc installation than the one that libp4est.so already links to.

source
P4est.uses_mpiMethod
P4est.uses_mpi()

Is intended to return trueif thep4estlibrary was compiled with MPI enabled. Since P4est.jl currently only supportsp4estwith MPI enabled, this may always returntrue`.

source
P4est.versionMethod
P4est.version()

Returns the version of the underlying p4est library (not of P4est.jl).

source

PointerWrapper provided by P4est.jl

Everything documented here is also exported from P4est.jl and available when using P4est.

P4est.PointerWrappers.PointerWrapperType
PointerWrapper(p::Ptr)

Wrap the pointer p to conveniently access the data of the underlying struct. Fields of the struct (or the struct itself) can be dereferenced for reading/writing using []. As opposed to using unsafe_load/unsafe_store on the struct directly, the [] operator only accesses the memory for the requested field, thereby avoiding to having to load/store the entire struct when accessing only a single field. This can be helpful especially when accessing data in nested structures.

Example

julia> using P4est, MPI
+API reference · P4est.jl

API reference

Higher-level API provided by P4est.jl

P4est.initMethod
P4est.init(log_handler, log_threshold)

Calls p4est_init if it has not already been called, otherwise do nothing. Thus, P4est.init can safely be called multiple times.

To use the default log handler and suppress most output created by default by p4est, call this function as

P4est.init(C_NULL, SC_LP_ERROR)

before calling other functions from p4est.

source
P4est.package_idMethod
P4est.package_id()

Returns the value of the global variable p4est_package_id which can be used to check whether p4est has been initialized.

source
P4est.path_p4est_libraryMethod
P4est.path_p4est_library()

Return the path of the p4est library that is used, when a system-provided library is configured via the preferences. Otherwise P4est_jll is returned, which means that the default p4est version from P4est_jll.jl is used.

source
P4est.path_sc_libraryMethod
P4est.path_sc_library()

Return the path of the sc library that is used, when a system-provided library is configured via the preferences. Otherwise P4est_jll is returned, which means that the default sc version from P4est_jll.jl is used.

source
P4est.preferences_set_correctlyMethod
P4est.preferences_set_correctly()

Returns false if a system-provided MPI installation is set via the MPIPreferences, but not a system-provided p4est installation. In this case, P4est.jl is not usable.

source
P4est.set_library_p4est!Function
P4est.set_library_p4est!(path; force = true)

Set the path to a system-provided p4est installation. Restart the Julia session after executing this function so that the changes take effect. Calling this function is necessary when you want to use a system-provided p4est installation.

source
P4est.set_library_sc!Function
P4est.set_library_sc!(path; force = true)

Set the path to a system-provided sc installation. Restart the Julia session after executing this function so that the changes take effect. Calling this function is necessary, when you want to use a system-provided p4est installation on Windows or when you want to use another sc installation than the one that libp4est.so already links to.

source
P4est.uses_mpiMethod
P4est.uses_mpi()

Is intended to return trueif thep4estlibrary was compiled with MPI enabled. Since P4est.jl currently only supportsp4estwith MPI enabled, this may always returntrue`.

source
P4est.versionMethod
P4est.version()

Returns the version of the underlying p4est library (not of P4est.jl).

source

PointerWrapper provided by P4est.jl

Everything documented here is also exported from P4est.jl and available when using P4est.

P4est.PointerWrappers.PointerWrapperType
PointerWrapper(p::Ptr)

Wrap the pointer p to conveniently access the data of the underlying struct. Fields of the struct (or the struct itself) can be dereferenced for reading/writing using []. As opposed to using unsafe_load/unsafe_store on the struct directly, the [] operator only accesses the memory for the requested field, thereby avoiding to having to load/store the entire struct when accessing only a single field. This can be helpful especially when accessing data in nested structures.

Example

julia> using P4est, MPI
 
 julia> MPI.Init()
 MPI.ThreadLevel(2)
@@ -18,7 +18,7 @@
 PointerWrapper{P4est.LibP4est.p4est}(Ptr{P4est.LibP4est.p4est} @0x0000600002b9d7b0)
 
 julia> p4est_pw.connectivity.num_trees[]
-4
source

Wrapper of the C API of p4est

Everything documented here is also exported from P4est.jl and available when using P4est.

P4est.LibP4est.p4est_coarsen_tType

Callback function prototype to decide for coarsening.

Parameters

  • p4est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrants:[in] Pointers to 4 siblings in Morton ordering.

Returns

nonzero if the quadrants shall be replaced with their parent.

source
P4est.LibP4est.p4est_connect_type_tType
p4est_connect_type_t

Characterize a type of adjacency.

Several functions involve relationships between neighboring trees and/or quadrants, and their behavior depends on how one defines adjacency: 1) entities are adjacent if they share a face, or 2) entities are adjacent if they share a face or corner. p4est_connect_type_t is used to choose the desired behavior. This enum must fit into an int8_t.

source
P4est.LibP4est.p4est_connectivityType
p4est_connectivity

This structure holds the 2D inter-tree connectivity information. Identification of arbitrary faces and corners is possible.

The arrays tree_to_* are stored in z ordering. For corners the order wrt. yx is 00 01 10 11. For faces the order is -x +x -y +y. They are allocated [0][0]..[0][3]..[num_trees-1][0]..[num_trees-1][3].

The values for tree_to_face are 0..7 where ttf % 4 gives the face number and ttf / 4 the face orientation code. The orientation is 0 for edges that are aligned in z-order, and 1 for edges that are running opposite in z-order.

It is valid to specify num_vertices as 0. In this case vertices and tree_to_vertex are set to NULL. Otherwise the vertex coordinates are stored in the array vertices as [0][0]..[0][2]..[num_vertices-1][0]..[num_vertices-1][2].

The corners are only stored when they connect trees. In this case tree_to_corner indexes into ctt_offset. Otherwise the tree_to_corner entry must be -1 and this corner is ignored. If num_corners == 0, tree_to_corner and corner_to_* arrays are set to NULL.

The arrays corner_to_* store a variable number of entries per corner. For corner c these are at position [ctt_offset[c]]..[ctt_offset[c+1]-1]. Their number for corner c is ctt_offset[c+1] - ctt_offset[c]. The entries encode all trees adjacent to corner c. The size of the corner_to_* arrays is num_ctt = ctt_offset[num_corners].

The *_to_attr arrays may have arbitrary contents defined by the user.

FieldNote
num_verticesthe number of vertices that define the embedding of the forest (not the topology)
num_treesthe number of trees
num_cornersthe number of corners that help define topology
verticesan array of size (3 * num_vertices)
tree_to_vertexembed each tree into c++ R^3 for e.g. visualization (see p4est_vtk.h)
tree_attr_bytesbytes per tree in tree_to_attr
tree_to_attrnot touched by p4est
tree_to_tree(4 * num_trees) neighbors across faces
tree_to_face(4 * num_trees) face to face+orientation (see description)
tree_to_corner(4 * num_trees) or NULL (see description)
ctt_offsetcorner to offset in cornertotree and cornertocorner
corner_to_treelist of trees that meet at a corner
corner_to_cornerlist of tree-corners that meet at a corner
source
P4est.LibP4est.p4est_connectivity_tType

This structure holds the 2D inter-tree connectivity information. Identification of arbitrary faces and corners is possible.

The arrays tree_to_* are stored in z ordering. For corners the order wrt. yx is 00 01 10 11. For faces the order is -x +x -y +y. They are allocated [0][0]..[0][3]..[num_trees-1][0]..[num_trees-1][3].

The values for tree_to_face are 0..7 where ttf % 4 gives the face number and ttf / 4 the face orientation code. The orientation is 0 for edges that are aligned in z-order, and 1 for edges that are running opposite in z-order.

It is valid to specify num_vertices as 0. In this case vertices and tree_to_vertex are set to NULL. Otherwise the vertex coordinates are stored in the array vertices as [0][0]..[0][2]..[num_vertices-1][0]..[num_vertices-1][2].

The corners are only stored when they connect trees. In this case tree_to_corner indexes into ctt_offset. Otherwise the tree_to_corner entry must be -1 and this corner is ignored. If num_corners == 0, tree_to_corner and corner_to_* arrays are set to NULL.

The arrays corner_to_* store a variable number of entries per corner. For corner c these are at position [ctt_offset[c]]..[ctt_offset[c+1]-1]. Their number for corner c is ctt_offset[c+1] - ctt_offset[c]. The entries encode all trees adjacent to corner c. The size of the corner_to_* arrays is num_ctt = ctt_offset[num_corners].

The *_to_attr arrays may have arbitrary contents defined by the user.

source
P4est.LibP4est.p4est_ghost_tType
p4est_ghost_t

quadrants that neighbor the local domain

FieldNote
btypewhich neighbors are in the ghost layer
ghostsarray of p4est_quadrant_t type
tree_offsetsnum_trees + 1 ghost indices
proc_offsetsmpisize + 1 ghost indices
mirrorsarray of p4est_quadrant_t type
mirror_tree_offsetsnum_trees + 1 mirror indices
mirror_proc_mirrorsindices into mirrors grouped by outside processor rank and ascending within each rank
mirror_proc_offsetsmpisize + 1 indices into mirror_proc_mirrors
mirror_proc_frontslike mirror_proc_mirrors, but limited to the outermost octants. This is NULL until p4est_ghost_expand is called
mirror_proc_front_offsetsNULL until p4est_ghost_expand is called
source
P4est.LibP4est.p4est_init_tType

Callback function prototype to initialize the quadrant's user data.

Parameters

  • p4est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrant:[in,out] the quadrant to be initialized: if data_size > 0, the data to be initialized is at quadrant->p.userdata; otherwise, the non-pointer user data (such as quadrant->p.userint) can be initialized
source
P4est.LibP4est.p4est_inspectType
p4est_inspect

Data pertaining to selecting, inspecting, and profiling algorithms. A pointer to this structure is hooked into the p4est main structure.

The balance_ranges and balance_notify* times are collected whenever an inspect structure is present in p4est.

FieldNote
use_balance_rangesUse sc_ranges to determine the asymmetric communication pattern. If usebalanceranges is false (the default), sc_notify is used.
use_balance_ranges_notifyIf true, call both sc_ranges and sc_notify and verify consistency. Which is actually used is still determined by usebalanceranges.
use_balance_verifyVerify sc_ranges and/or sc_notify as applicable.
balance_max_rangesIf positive and smaller than p4est_num ranges, overrides it
balance_rangestime spent in sc_ranges
balance_notifytime spent in sc_notify
balance_notify_allgathertime spent in sc_notify_allgather
source
P4est.LibP4est.p4est_inspect_tType

Data pertaining to selecting, inspecting, and profiling algorithms. A pointer to this structure is hooked into the p4est main structure. Declared in p4est_extended.h. Used to profile important algorithms.

source
P4est.LibP4est.p4est_iter_corner_infoType
p4est_iter_corner_info

The information that is available to the user-defined p4est_iter_corner_t callback.

If tree_boundary is false, the corner is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the corner. When tree_boundary is true, its value is P4EST_CONNECT_FACE/CORNER depending on the location of the corner relative to the tree.

FieldNote
tree_boundaryboolean: interior face (0), tree boundary face (true)
sidesarray of type p4est_iter_corner_side_t type
source
P4est.LibP4est.p4est_iter_corner_info_tType

The information that is available to the user-defined p4est_iter_corner_t callback.

If tree_boundary is false, the corner is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the corner. When tree_boundary is true, its value is P4EST_CONNECT_FACE/CORNER depending on the location of the corner relative to the tree.

source
P4est.LibP4est.p4est_iter_corner_sideType
p4est_iter_corner_side

Information about one side of a corner in the forest. If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

the faces field provides some additional information about the local topology: if side[i]->faces[j] == side[k]->faces[l], this indicates that there is a common face between these two sides of the corner.

FieldNote
treeidthe tree that contains quad
cornerwhich of the quadrant's corners touches this corner
is_ghostboolean: local (0) or ghost (1)
quadidthe index in the tree or ghost array
facesinternal work data
source
P4est.LibP4est.p4est_iter_corner_side_tType

Information about one side of a corner in the forest. If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

the faces field provides some additional information about the local topology: if side[i]->faces[j] == side[k]->faces[l], this indicates that there is a common face between these two sides of the corner.

source
P4est.LibP4est.p4est_iter_corner_tType

The prototype for a function that p4est_iterate will execute wherever quadrants meet at a conformal corner

i.e. the callback will not execute on a hanging corner.

Note

the forest does not need to be corner balanced for p4est_iterate() to correctly execute a callback function at corners, only face balanced (see p4est_balance()).

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p4est_iterate()
source
P4est.LibP4est.p4est_iter_face_infoType
p4est_iter_face_info

The information that is available to the user-defined p4est_iter_face_t callback.

The orientation is 0 if the face is within one tree; otherwise, it is the same as the orientation value between the two trees given in the connectivity. If the face is on the outside boundary of the forest, then there is only one side. If tree_boundary is false, the face is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the face. When tree_boundary is true, its value is P4EST_CONNECT_FACE.

FieldNote
orientationthe orientation of the sides to each other, as in the definition of p4est_connectivity_t
tree_boundaryboolean: interior face (0), tree boundary face (true)
source
P4est.LibP4est.p4est_iter_face_info_tType

The information that is available to the user-defined p4est_iter_face_t callback.

The orientation is 0 if the face is within one tree; otherwise, it is the same as the orientation value between the two trees given in the connectivity. If the face is on the outside boundary of the forest, then there is only one side. If tree_boundary is false, the face is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the face. When tree_boundary is true, its value is P4EST_CONNECT_FACE.

source
P4est.LibP4est.p4est_iter_face_sideType
p4est_iter_face_side

Information about one side of a face in the forest.

If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If the face is hanging, then the quadrants are listed in z-order. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

FieldNote
treeidthe tree on this side
facewhich quadrant side the face touches
is_hangingboolean: one full quad (0) or two smaller quads (1)
source
P4est.LibP4est.p4est_iter_face_side_tType

Information about one side of a face in the forest.

If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If the face is hanging, then the quadrants are listed in z-order. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

source
P4est.LibP4est.p4est_iter_face_tType

The prototype for a function that p4est_iterate will execute wherever two quadrants share a face: the face can be a 2:1 hanging face, it does not have to be conformal.

Note

the forest must be face balanced for p4est_iterate() to execute a callback function on faces (see p4est_balance()).

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p4est_iterate()
source
P4est.LibP4est.p4est_iter_volume_infoType
p4est_iter_volume_info

The information that is available to the user-defined p4est_iter_volume_t callback function.

treeid gives the index in p4est->trees of the tree to which quad belongs. quadid gives the index of quad within tree's quadrants array.

FieldNote
quadthe quadrant of the callback
quadidid in quad's tree array (see p4est_tree_t)
treeidthe tree containing quad
source
P4est.LibP4est.p4est_lnodes_bufferType
p4est_lnodes_buffer

p4est_lnodes_buffer_t handles the communication of data associated with nodes.

send_buffers is an array of arrays: one buffer for each process to which the current process sends node-data. It should not be altered between a shared__begin and a shared__end call.

recv_buffers is an array of arrays that is used in lnodes_share_all_. *recv_buffers[j] corresponds with lnodes->sharers[j]: it is the same length as lnodes->sharers[j]->sharednodes. At the completion of lnodes\share_all or lnodes_share_all_end, recv_buffers[j] contains the node-data from the process lnodes->sharers[j]->rank (unless j is the current rank, in which case recv_buffers[j] is empty).

source
P4est.LibP4est.p4est_lnodes_buffer_tType

p4est_lnodes_buffer_t handles the communication of data associated with nodes.

send_buffers is an array of arrays: one buffer for each process to which the current process sends node-data. It should not be altered between a shared__begin and a shared__end call.

recv_buffers is an array of arrays that is used in lnodes_share_all_. *recv_buffers[j] corresponds with lnodes->sharers[j]: it is the same length as lnodes->sharers[j]->sharednodes. At the completion of lnodes\share_all or lnodes_share_all_end, recv_buffers[j] contains the node-data from the process lnodes->sharers[j]->rank (unless j is the current rank, in which case recv_buffers[j] is empty).

source
P4est.LibP4est.p4est_lnodes_rankType
p4est_lnodes_rank

The structure stored in the sharers array.

shared_nodes is a sorted array of p4est_locidx_t that indexes into local nodes. The shared_nodes array has a contiguous (or empty) section of nodes owned by the current rank. shared_mine_offset and shared_mine_count identify this section by indexing the shared_nodes array, not the local nodes array. owned_offset and owned_count define the section of local nodes that is owned by the listed rank (the section may be empty). For the current process these coincide with those in p4est_lnodes_t.

source
P4est.LibP4est.p4est_lnodes_rank_tType

The structure stored in the sharers array.

shared_nodes is a sorted array of p4est_locidx_t that indexes into local nodes. The shared_nodes array has a contiguous (or empty) section of nodes owned by the current rank. shared_mine_offset and shared_mine_count identify this section by indexing the shared_nodes array, not the local nodes array. owned_offset and owned_count define the section of local nodes that is owned by the listed rank (the section may be empty). For the current process these coincide with those in p4est_lnodes_t.

source
P4est.LibP4est.p4est_lnodes_tType

Store a parallel numbering of Lobatto points of a given degree > 0.

Each element has degree+1 nodes per face and vnodes = (degree+1)^2 nodes per volume. num_local_elements is the number of local quadrants in the p4est. element_nodes is of dimension vnodes * num_local_elements and lists the nodes of each element in lexicographic yx-order (x varies fastest); so for degree == 2, this is the layout of nodes:

f_3 c_2 c_3 6–-7–-8 | | f_0 3 4 5 f_1 | | 0–-1–-2 c_0 c_1 f_2

element_nodes indexes into the set of local nodes, layed out as follows: local nodes = [<––-owned_count––->|<––-nonlocal_nodes––->] = [<––––––––num_local_nodes––––––––->] nonlocal_nodes contains the globally unique numbers for independent nodes that are owned by other processes; for local nodes, the globally unique numbers are given by i + global_offset, where i is the local number. Hanging nodes are always local and don't have a global number. They index the geometrically corresponding independent nodes of a neighbor.

Whether nodes are hanging or not is decided based on the element faces. This information is encoded in face_code with one int8_t per element. If no faces are hanging, the value is zero, otherwise the face_code is interpreted by p4est_lnodes_decode.

Independent nodes can be shared by multiple MPI ranks. The owner rank of a node is the one from the lowest numbered element on the lowest numbered octree touching the node.

What is meant by touching? A quadrant is said to touch all faces/corners that are incident on it, and by extension all nodes that are contained in those faces/corners.

X +–––––-+ o | | o | | +––-+ o | p | | q | o | | | | o | | +––-+ O +–––––-+

In this example degree = 6. There are 5 nodes that live on the face between q and p, and one at each corner of that face. The face is incident on q, so q owns the nodes on the face (provided q is from a lower tree or has a lower index than p). The lower corner is incident on q, so q owns it as well. The upper corner is not incident on q, so q cannot own it.

global_owned_count contains the number of independent nodes owned by each process.

The sharers array contains items of type p4est_lnodes_rank_t that hold the ranks that own or share independent local nodes. If there are no shared nodes on this processor, it is empty. Otherwise, it is sorted by rank and the current process is included.

degree < 0 indicates that the lnodes data structure is being used to number the quadrant boundary object (faces and corners) rather than the $C^0$ Lobatto nodes:

if degree == -1, then one node is assigned per face, and no nodes are assigned per volume or per corner: this numbering can be used for low-order Raviart-Thomas elements. In this case, vnodes == 4, and the nodes are listed in face-order:

f_3 c_2 c_3 +–-3–-+ | | f_0 0 1 f_1 | | +–-2–-+ c_0 c_1 f_2

if degree == -2, then one node is assigned per face and per corner and no nodes are assigned per volume. In this case, vnodes == 8, and the nodes are listed in face-order, followed by corner-order:

f_3 c_2 c_3 6–-3–-7 | | f_0 0 1 f_1 | | 4–-2–-5 c_0 c_1 f_2

source
P4est.LibP4est.p4est_mesh_tType
p4est_mesh_t

This structure contains complete mesh information on a 2:1 balanced forest. It stores the locally relevant neighborhood, that is, all locally owned quadrants and one layer of adjacent ghost quadrants and their owners.

For each local quadrant, its tree number is stored in quad_to_tree. The quad_to_tree array is NULL by default and can be enabled using p4estmeshnewext. For each ghost quadrant, its owner rank is stored in ghost\to_proc. For each level, an array of local quadrant numbers is stored in quad_level. The quad_level array is NULL by default and can be enabled using p4estmeshnew_ext.

The quad_to_quad list stores one value for each local quadrant's face. This value is in 0..local_num_quadrants-1 for local quadrants, or in local_num_quadrants + (0..ghost_num_quadrants-1) for ghost quadrants.

The quad_to_face list has equally many entries that are either: 1. A value of v = 0..7 indicates one same-size neighbor. This value is decoded as v = r * 4 + nf, where nf = 0..3 is the neighbor's connecting face number and r = 0..1 is the relative orientation of the neighbor's face; see p4est_connectivity.h. 2. A value of v = 8..23 indicates a double-size neighbor. This value is decoded as v = 8 + h * 8 + r * 4 + nf, where r and nf are as above and h = 0..1 is the number of the subface. h designates the subface of the large neighbor that the quadrant touches (this is the same as the large neighbor's face corner). 3. A value of v = -8..-1 indicates two half-size neighbors. In this case the corresponding quad_to_quad index points into the quad_to_half array that stores two quadrant numbers per index, and the orientation of the smaller faces follows from 8 + v. The entries of quad_to_half encode between local and ghost quadrant in the same way as the quad_to_quad values described above. The small neighbors in quad_to_half are stored in the sequence of the face corners of this, i.e., the large quadrant.

A quadrant on the boundary of the forest sees itself and its face number.

The quad_to_corner list stores corner neighbors that are not face neighbors. On the inside of a tree, there is precisely one such neighbor per corner. In this case, its index is encoded as described above for quad_to_quad. The neighbor's matching corner number is always diagonally opposite, that is, corner number ^ 3.

On the inside of an inter-tree face, we have precisely one corner neighbor. If a corner is an inter-tree corner, then the number of corner neighbors may be any non-negative number. In both cases, the quad_to_corner value is in local_num_quadrants + local_num_ghosts + [0 .. local_num_corners - 1]. After subtracting the number of local and ghost quadrants, it indexes into corner_offset, which encodes a group of corner neighbors. Each group contains the quadrant numbers encoded as usual for quad_to_quad in corner_quad, and the corner number from the neighbor as corner_corner.

Corners with no diagonal neighbor at all are assigned the value -3. This only happens on the domain boundary, which is necessarily a tree boundary. Corner-neighbors for hanging nodes are assigned the value -1.

TODO: In case of an inter-tree corner neighbor relation in a brick-like situation (exactly one neighbor, diagonally opposite corner number), use the same encoding as for corners within a tree.

FieldNote
quad_to_treetree index for each local quad. Is NULL by default, but may be enabled by p4estmeshnew_ext.
ghost_to_procprocessor for each ghost quad
quad_to_quadone index for each of the 4 faces
quad_to_faceencodes orientation/2:1 status
quad_to_halfstores half-size neighbors
quad_levelStores lists of per-level quads. The array has entries indexed by 0..P4EST_QMAXLEVEL inclusive that are arrays of local quadrant ids. Is NULL by default, but may be enabled by p4estmeshnew_ext.
source
P4est.LibP4est.p4est_quadrantType
p4est_quadrant

The 2D quadrant datatype

FieldNote
xcoordinates
y
levellevel of refinement
pad8padding
pad16
pa union of additional data attached to a quadrant
source
P4est.LibP4est.p4est_refine_tType

Callback function prototype to decide for refinement.

Parameters

  • p4est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrant:[in] the quadrant that may be refined

Returns

nonzero if the quadrant shall be refined.

source
P4est.LibP4est.p4est_replace_tType

Callback function prototype to replace one set of quadrants with another.

This is used by extended routines when the quadrants of an existing, valid p4est are changed. The callback allows the user to make changes to newly initialized quadrants before the quadrants that they replace are destroyed.

If the mesh is being refined, num_outgoing will be 1 and num_incoming will be 4, and vice versa if the mesh is being coarsened.

Parameters

  • num_outgoing:[in] The number of outgoing quadrants.
  • outgoing:[in] The outgoing quadrants: after the callback, the user_data, if p4est->data_size is nonzero, will be destroyed.
  • num_incoming:[in] The number of incoming quadrants.
  • incoming:[in,out] The incoming quadrants: prior to the callback, the user_data, if p4est->datasize is nonzero, is allocated, and the [`p4estinit_t`](@ref) callback, if it has been provided, will be called.
source
P4est.LibP4est.p4est_search_all_tType

Callback function for the top-down search through the whole forest.

Parameters

  • p4est:[in] The forest to search. We recurse through the trees one after another.
  • which_tree:[in] The current tree number.
  • quadrant:[in] The current quadrant in the recursion. This quadrant is either a non-leaf tree branch or a leaf. If the quadrant is contained in the local partition, we know which, otherwise we don't. Let us first consider the situation when quadrant is local, which is indicated by both pfirst and plast being equal to p4est->mpirank. Then the parameter local_num is negative for non-leaves and the number of the quadrant as a leaf in local storage otherwise. Only if the quadrant is a local leaf, it points to the actual local storage and can be used to access user data etc., and the recursion terminates. The other possibility is that pfirst < plast, in which case we proceed with the recursion, or both are equal to the same remote rank, in which case the recursion terminates. Either way, the quadrant is not from local forest storage.
  • pfirst:[in] The lowest processor that owns part of quadrant. Guaranteed to be non-empty.
  • plast:[in] The highest processor that owns part of quadrant. Guaranteed to be non-empty.
  • local_num:[in] If quadrant is a local leaf, this number is the index of the leaf in local quadrant storage. Else, this is a negative value.
  • point:[in,out] User-defined representation of a point. This parameter distinguishes two uses of the callback. For each quadrant, the callback is first called with a NULL point, and if this callback returns true, once for each point tracked in this branch. The return value for a point determines whether it shall be tracked further down the branch or not, and has no effect on a local leaf. The call with a NULL point is intended to prepare quadrant-related search meta data that is common to all points, and/or to efficiently terminate the recursion for all points in the branch in one call.

Returns

If false, the recursion at quadrant terminates. If true, it continues if pfirst < plast or if they are both equal to p4est->mpirank and the recursion has not reached a leaf yet.

source
P4est.LibP4est.p4est_search_local_tType

Callback function to query the match of a "point" with a quadrant.

This function can be called in two roles: Per-quadrant, in which case the parameter point is NULL, or per-point, possibly many times per quadrant.

Parameters

  • p4est:[in] The forest to be queried.
  • which_tree:[in] The tree id under consideration.
  • quadrant:[in] The quadrant under consideration. This quadrant may be coarser than the quadrants that are contained in the forest (an ancestor), in which case it is a temporary variable and not part of the forest storage. Otherwise, it is a leaf and points directly into the forest storage.
  • local_num:[in] If the quadrant is not a leaf, this is < 0. Otherwise it is the (non-negative) index of the quadrant relative to the processor-local storage.
  • point:[in] Representation of a "point"; user-defined. If point is NULL, the callback may be used to prepare quadrant-related search meta data.

Returns

If point is NULL, true if the search confined to quadrant should be executed, false to skip it. Else, true if point may be contained in the quadrant and false otherwise; the return value has no effect on a leaf.

source
P4est.LibP4est.p4est_search_partition_tType

Callback function for the partition recursion.

Parameters

  • p4est:[in] The forest to traverse. Its local quadrants are never accessed.
  • which_tree:[in] The tree number under consideration.
  • quadrant:[in] This quadrant is not from local forest storage, and its user data is undefined. It represents the branch of the forest in the top-down recursion.
  • pfirst:[in] The lowest processor that owns part of quadrant. Guaranteed to be non-empty.
  • plast:[in] The highest processor that owns part of quadrant. Guaranteed to be non-empty. If this is equal to pfirst, then the recursion will stop for quadrant's branch after this function returns.
  • point:[in,out] Pointer to a user-defined point object. If called per-quadrant, this is NULL.

Returns

If false, the recursion at quadrant is terminated. If true, it continues if pfirst < plast.

source
P4est.LibP4est.p4est_treeType
p4est_tree

The p4est tree datatype

FieldNote
quadrantslocally stored quadrants
first_descfirst local descendant
last_desclast local descendant
quadrants_offsetcumulative sum over earlier trees on this processor (locals only)
maxlevelhighest local quadrant level
source
P4est.LibP4est.p4est_weight_tType

Callback function prototype to calculate weights for partitioning.

Note

Global sum of weights must fit into a 64bit integer.

Parameters

  • p4est:[in] the forest
  • which_tree:[in] the tree containing quadrant

Returns

a 32bit integer >= 0 as the quadrant weight.

source
P4est.LibP4est.p6est_coarsen_column_tType

Callback function prototype to decide for horizontal coarsening.

Parameters

  • columns:[in] Pointers to 4 sibling columns.

Returns

nonzero if the columns shall be replaced with their parent.

source
P4est.LibP4est.p6est_coarsen_layer_tType

Callback function prototype to decide for vertical coarsening.

Parameters

  • layers:[in] Pointers to 2 vertical sibling layers.

Returns

nonzero if the layers shall be replaced with their parent.

source
P4est.LibP4est.p6est_connectivityType
p6est_connectivity

This structure holds the 2D+1D inter-tree connectivity information. It is essentially a wrapper of the 2D p4est_connecitivity_t datatype, with some additional information about how the third dimension is embedded.

FieldNote
conn4the 2D connecitvity; owned; vertices interpreted as the vertices of the bottom of the sheet
top_verticesif NULL, uniform vertical profile, otherwise the vertices of the top of the sheet: should be the same size as conn4->treetovertex; owned.
heightif top_vertices == NULL, this gives the offset from the bottom of the sheet to the top
source
P4est.LibP4est.p6est_connectivity_tType

This structure holds the 2D+1D inter-tree connectivity information. It is essentially a wrapper of the 2D p4est_connecitivity_t datatype, with some additional information about how the third dimension is embedded.

source
P4est.LibP4est.p6est_init_tType

Callback function prototype to initialize the layers's user data.

Parameters

  • p6est:[in] the forest
  • which_tree:[in] the tree in the forest
  • column:[in] the column in the tree in the forest
  • layer:[in] the layer in the column in the tree in the forest, whose user_data is to be initialized
source
P4est.LibP4est.p6est_refine_column_tType

Callback function prototype to decide whether to horizontally refine a column, i.e., horizontally refine all of the layers in the column.

Returns

nonzero if the layer shall be refined.

source
P4est.LibP4est.p6est_replace_tType

Callback function prototype to transfer information from outgoing layers to incoming layers.

This is used by extended routines when the layers of an existing, valid p6est are changed. The callback allows the user to make changes to newly initialized layers before the layers that they replace are destroyed.

Parameters

  • num_outcolumns:[in] The number of columns that contain the outgoing layers: will be either 1 or 4.
  • num_outlayers:[in] The number of outgoing layers: will be either 1 (a single layer is being refined), 2 (two layers are being vertically coarsened), or 4 (four layers are being horizontally coarsened).
  • outcolumns:[in] The columns of the outgoing layers
  • outlayers:[in] The outgoing layers: after the callback, the user_data, if p6est->data_size is nonzero, will be destroyed.
  • num_incolumns:[in] The number of columns that contain the outgoing layers: will be either 1 or 4.
  • num_inlayers:[in] The number of incoming layers: will be either 1 (coarsening), 2 (vertical refinement), or 4 (horizontal refinement)
  • incolumns:[in] The columns of the incoming layers
  • inlayers:[in,out] The incoming layers: prior to the callback, the user_data, if p6est->datasize is nonzero, is allocated, and the [`p6estinit_t`](@ref) callback, if it has been provided, will be called.
source
P4est.LibP4est.p6est_weight_tType

Callback function prototype to calculate weights for partitioning.

Note

Global sum of weights must fit into a 64bit integer.

Returns

a 32bit integer >= 0 as the quadrant weight.

source
P4est.LibP4est.p8est_coarsen_tType

Callback function prototype to decide for coarsening.

Parameters

  • p8est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrants:[in] Pointers to 8 siblings in Morton ordering.

Returns

nonzero if the quadrants shall be replaced with their parent.

source
P4est.LibP4est.p8est_connect_type_tType
p8est_connect_type_t

Characterize a type of adjacency.

Several functions involve relationships between neighboring trees and/or quadrants, and their behavior depends on how one defines adjacency: 1) entities are adjacent if they share a face, or 2) entities are adjacent if they share a face or corner, or 3) entities are adjacent if they share a face, corner or edge. p8est_connect_type_t is used to choose the desired behavior. This enum must fit into an int8_t.

source
P4est.LibP4est.p8est_connectivityType
p8est_connectivity

This structure holds the 3D inter-tree connectivity information. Identification of arbitrary faces, edges and corners is possible.

The arrays tree_to_* are stored in z ordering. For corners the order wrt. zyx is 000 001 010 011 100 101 110 111. For faces the order is -x +x -y +y -z +z. They are allocated [0][0]..[0][N-1]..[num_trees-1][0]..[num_trees-1][N-1]. where N is 6 for tree and face, 8 for corner, 12 for edge.

The values for tree_to_face are in 0..23 where ttf % 6 gives the face number and ttf / 6 the face orientation code. The orientation is determined as follows. Let my_face and other_face be the two face numbers of the connecting trees in 0..5. Then the first face corner of the lower of my_face and other_face connects to a face corner numbered 0..3 in the higher of my_face and other_face. The face orientation is defined as this number. If my_face == other_face, treating either of both faces as the lower one leads to the same result.

It is valid to specify num_vertices as 0. In this case vertices and tree_to_vertex are set to NULL. Otherwise the vertex coordinates are stored in the array vertices as [0][0]..[0][2]..[num_vertices-1][0]..[num_vertices-1][2].

The edges are only stored when they connect trees. In this case tree_to_edge indexes into ett_offset. Otherwise the tree_to_edge entry must be -1 and this edge is ignored. If num_edges == 0, tree_to_edge and edge_to_* arrays are set to NULL.

The arrays edge_to_* store a variable number of entries per edge. For edge e these are at position [ett_offset[e]]..[ett_offset[e+1]-1]. Their number for edge e is ett_offset[e+1] - ett_offset[e]. The entries encode all trees adjacent to edge e. The size of the edge_to_* arrays is num_ett = ett_offset[num_edges]. The edge_to_edge array holds values in 0..23, where the lower 12 indicate one edge orientation and the higher 12 the opposite edge orientation.

The corners are only stored when they connect trees. In this case tree_to_corner indexes into ctt_offset. Otherwise the tree_to_corner entry must be -1 and this corner is ignored. If num_corners == 0, tree_to_corner and corner_to_* arrays are set to NULL.

The arrays corner_to_* store a variable number of entries per corner. For corner c these are at position [ctt_offset[c]]..[ctt_offset[c+1]-1]. Their number for corner c is ctt_offset[c+1] - ctt_offset[c]. The entries encode all trees adjacent to corner c. The size of the corner_to_* arrays is num_ctt = ctt_offset[num_corners].

The *_to_attr arrays may have arbitrary contents defined by the user.

FieldNote
num_verticesthe number of vertices that define the embedding of the forest (not the topology)
num_treesthe number of trees
num_edgesthe number of edges that help define the topology
num_cornersthe number of corners that help define the topology
verticesan array of size (3 * num_vertices)
tree_to_vertexembed each tree into c++ R^3 for e.g. visualization (see p8est_vtk.h)
tree_attr_bytesbytes per tree in tree_to_attr
tree_to_attrnot touched by p4est
tree_to_tree(6 * num_trees) neighbors across faces
tree_to_face(6 * num_trees) face to face+orientation (see description)
tree_to_edge(12 * num_trees) or NULL (see description)
ett_offsetedge to offset in edgetotree and edgetoedge
edge_to_treelist of trees that meet at an edge
edge_to_edgelist of tree-edges+orientations that meet at an edge (see description)
tree_to_corner(8 * num_trees) or NULL (see description)
ctt_offsetcorner to offset in cornertotree and cornertocorner
corner_to_treelist of trees that meet at a corner
corner_to_cornerlist of tree-corners that meet at a corner
source
P4est.LibP4est.p8est_connectivity_tType

This structure holds the 3D inter-tree connectivity information. Identification of arbitrary faces, edges and corners is possible.

The arrays tree_to_* are stored in z ordering. For corners the order wrt. zyx is 000 001 010 011 100 101 110 111. For faces the order is -x +x -y +y -z +z. They are allocated [0][0]..[0][N-1]..[num_trees-1][0]..[num_trees-1][N-1]. where N is 6 for tree and face, 8 for corner, 12 for edge.

The values for tree_to_face are in 0..23 where ttf % 6 gives the face number and ttf / 6 the face orientation code. The orientation is determined as follows. Let my_face and other_face be the two face numbers of the connecting trees in 0..5. Then the first face corner of the lower of my_face and other_face connects to a face corner numbered 0..3 in the higher of my_face and other_face. The face orientation is defined as this number. If my_face == other_face, treating either of both faces as the lower one leads to the same result.

It is valid to specify num_vertices as 0. In this case vertices and tree_to_vertex are set to NULL. Otherwise the vertex coordinates are stored in the array vertices as [0][0]..[0][2]..[num_vertices-1][0]..[num_vertices-1][2].

The edges are only stored when they connect trees. In this case tree_to_edge indexes into ett_offset. Otherwise the tree_to_edge entry must be -1 and this edge is ignored. If num_edges == 0, tree_to_edge and edge_to_* arrays are set to NULL.

The arrays edge_to_* store a variable number of entries per edge. For edge e these are at position [ett_offset[e]]..[ett_offset[e+1]-1]. Their number for edge e is ett_offset[e+1] - ett_offset[e]. The entries encode all trees adjacent to edge e. The size of the edge_to_* arrays is num_ett = ett_offset[num_edges]. The edge_to_edge array holds values in 0..23, where the lower 12 indicate one edge orientation and the higher 12 the opposite edge orientation.

The corners are only stored when they connect trees. In this case tree_to_corner indexes into ctt_offset. Otherwise the tree_to_corner entry must be -1 and this corner is ignored. If num_corners == 0, tree_to_corner and corner_to_* arrays are set to NULL.

The arrays corner_to_* store a variable number of entries per corner. For corner c these are at position [ctt_offset[c]]..[ctt_offset[c+1]-1]. Their number for corner c is ctt_offset[c+1] - ctt_offset[c]. The entries encode all trees adjacent to corner c. The size of the corner_to_* arrays is num_ctt = ctt_offset[num_corners].

The *_to_attr arrays may have arbitrary contents defined by the user.

source
P4est.LibP4est.p8est_ghost_tType
p8est_ghost_t

quadrants that neighbor the local domain

FieldNote
btypewhich neighbors are in the ghost layer
ghostsarray of p8est_quadrant_t type
tree_offsetsnum_trees + 1 ghost indices
proc_offsetsmpisize + 1 ghost indices
mirrorsarray of p8est_quadrant_t type
mirror_tree_offsetsnum_trees + 1 mirror indices
mirror_proc_mirrorsindices into mirrors grouped by outside processor rank and ascending within each rank
mirror_proc_offsetsmpisize + 1 indices into mirror_proc_mirrors
mirror_proc_frontslike mirror_proc_mirrors, but limited to the outermost octants. This is NULL until p8est_ghost_expand is called
mirror_proc_front_offsetsNULL until p8est_ghost_expand is called
source
P4est.LibP4est.p8est_init_tType

Callback function prototype to initialize the quadrant's user data.

Parameters

  • p8est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrant:[in,out] the quadrant to be initialized: if data_size > 0, the data to be initialized is at quadrant->p.userdata; otherwise, the non-pointer user data (such as quadrant->p.userint) can be initialized
source
P4est.LibP4est.p8est_inspectType
p8est_inspect
FieldNote
use_balance_rangesUse sc_ranges to determine the asymmetric communication pattern. If usebalanceranges is false (the default), sc_notify is used.
use_balance_ranges_notifyIf true, call both sc_ranges and sc_notify and verify consistency. Which is actually used is still determined by usebalanceranges.
use_balance_verifyVerify sc_ranges and/or sc_notify as applicable.
balance_max_rangesIf positive and smaller than p8est_num ranges, overrides it
balance_rangestime spent in sc_ranges
balance_notifytime spent in sc_notify
balance_notify_allgathertime spent in sc_notify_allgather
source
P4est.LibP4est.p8est_inspect_tType

Data pertaining to selecting, inspecting, and profiling algorithms. A pointer to this structure is hooked into the p8est main structure. Declared in p8est_extended.h. Used to profile important algorithms.

source
P4est.LibP4est.p8est_iter_corner_infoType
p8est_iter_corner_info

The information that is availalbe to the user-defined p8est_iter_corner_t callback.

If tree_boundary is false, the corner is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the corner. When tree_boundary is true, its value is P8EST_CONNECT_FACE/EDGE/CORNER depending on the location of the corner relative to the tree.

FieldNote
tree_boundaryboolean: interior face (0), tree boundary face (true)
sidesarray of p8est_iter_corner_side_t type
source
P4est.LibP4est.p8est_iter_corner_info_tType

The information that is availalbe to the user-defined p8est_iter_corner_t callback.

If tree_boundary is false, the corner is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the corner. When tree_boundary is true, its value is P8EST_CONNECT_FACE/EDGE/CORNER depending on the location of the corner relative to the tree.

source
P4est.LibP4est.p8est_iter_corner_sideType
p8est_iter_corner_side
FieldNote
treeidthe tree that contains quad
cornerwhich of the quadrant's corners touches this corner
is_ghostboolean: local (0) or ghost (1)
quadidthe index in the tree or ghost array
facesinternal work data
edges
source
P4est.LibP4est.p8est_iter_corner_tType

The prototype for a function that p8est_iterate will execute wherever the corner is a corner for all quadrants that touch it

i.e. the callback will not execute on a corner that sits on a hanging face or edge.

Note

the forest does not need to be corner balanced for p8est_iterate() to execute a callback function at corners, only face and edge balanced.

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p8est_iterate()
source
P4est.LibP4est.p8est_iter_edge_infoType
p8est_iter_edge_info

The information about all sides of an edge in the forest. If tree_boundary is false, the edge is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the edge. When tree_boundary is true, its value is P8EST_CONNECT_FACE/EDGE depending on the location of the edge relative to the tree.

FieldNote
tree_boundaryboolean: interior face (0), tree boundary face (true)
sidesarray of p8est_iter_edge_side_t type
source
P4est.LibP4est.p8est_iter_edge_info_tType

The information about all sides of an edge in the forest. If tree_boundary is false, the edge is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the edge. When tree_boundary is true, its value is P8EST_CONNECT_FACE/EDGE depending on the location of the edge relative to the tree.

source
P4est.LibP4est.p8est_iter_edge_sideType
p8est_iter_edge_side
FieldNote
treeidthe tree on this side
edgewhich quadrant side the edge touches
orientationthe orientation of each quadrant relative to this edge, as in the definition of p8est_connectivity_t
is_hangingboolean: one full quad (0) or two smaller quads (1)
source
P4est.LibP4est.p8est_iter_edge_tType

The prototype for a function that p8est_iterate will execute wherever the edge is an edge of all quadrants that touch it i.e. the callback will not execute on an edge the sits on a hanging face.

Note

the forest must be edge balanced for p8est_iterate() to execute a callback function on edges.

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p8est_iterate()
source
P4est.LibP4est.p8est_iter_face_infoType
p8est_iter_face_info

The information that is available to the user-defined p8est_iter_face_t callback.

The orientation is 0 if the face is within one tree; otherwise, it is the same as the orientation value between the two trees given in the connectivity. If the face is on the outside of the forest, then there is only one side. If tree_boundary is false, the face is on the interior of a tree. When tree_boundary false, sides[0] contains the lowest z-order quadrant that touches the face. When tree_boundary is true, its value is P8EST_CONNECT_FACE.

FieldNote
orientationthe orientation of the sides to each other, as in the definition of p8est_connectivity_t
tree_boundaryboolean: interior face (0), tree boundary face (true)
source
P4est.LibP4est.p8est_iter_face_info_tType

The information that is available to the user-defined p8est_iter_face_t callback.

The orientation is 0 if the face is within one tree; otherwise, it is the same as the orientation value between the two trees given in the connectivity. If the face is on the outside of the forest, then there is only one side. If tree_boundary is false, the face is on the interior of a tree. When tree_boundary false, sides[0] contains the lowest z-order quadrant that touches the face. When tree_boundary is true, its value is P8EST_CONNECT_FACE.

source
P4est.LibP4est.p8est_iter_face_sideType
p8est_iter_face_side

Information about one side of a face in the forest. If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If the face is hanging, then the quadrants are listed in z-order. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

FieldNote
treeidthe tree on this side
facewhich quadrant side the face touches
is_hangingboolean: one full quad (0) or four smaller quads (1)
source
P4est.LibP4est.p8est_iter_face_side_tType

Information about one side of a face in the forest. If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If the face is hanging, then the quadrants are listed in z-order. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

source
P4est.LibP4est.p8est_iter_face_tType

The prototype for a function that p8est_iterate() will execute wherever two quadrants share a face: the face can be a 2:1 hanging face, it does not have to be conformal.

Note

the forest must be face balanced for p8est_iterate() to execute a callback function on faces (see p8est_balance()).

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p8est_iterate()
source
P4est.LibP4est.p8est_iter_volume_infoType
p8est_iter_volume_info

The information that is available to the user-defined p8est_iter_volume_t callback function.

treeid gives the index in p4est->trees of the tree to which quad belongs. quadid gives the index of quad within tree's quadrants array.

FieldNote
quadthe quadrant of the callback
quadidid in quad's tree array (see p8est_tree_t)
treeidthe tree containing quad
source
P4est.LibP4est.p8est_lid_tType

A datatype to handle the linear id in 3D. We use the implementation of unsigned 128 bit integer in libsc, i.e., a struct with the members high_bits and low_bits (both uint64_t).

source
P4est.LibP4est.p8est_lnodes_bufferType
p8est_lnodes_buffer

p8est_lnodes_buffer_t handles the communication of data associated with nodes.

send_buffers is an array of arrays: one buffer for each process to which the current process sends node-data. It should not be altered between a shared__begin and a shared__end call.

recv_buffers is an array of arrays that is used in lnodes_share_all_. *recv_buffers[j] corresponds with lnodes->sharers[j]: it is the same length as lnodes->sharers[j]->sharednodes. At the completion of lnodes\share_all or lnodes_share_all_end, recv_buffers[j] contains the node-data from the process lnodes->sharers[j]->rank (unless j is the current rank, in which case recv_buffers[j] is empty).

source
P4est.LibP4est.p8est_lnodes_buffer_tType

p8est_lnodes_buffer_t handles the communication of data associated with nodes.

send_buffers is an array of arrays: one buffer for each process to which the current process sends node-data. It should not be altered between a shared__begin and a shared__end call.

recv_buffers is an array of arrays that is used in lnodes_share_all_. *recv_buffers[j] corresponds with lnodes->sharers[j]: it is the same length as lnodes->sharers[j]->sharednodes. At the completion of lnodes\share_all or lnodes_share_all_end, recv_buffers[j] contains the node-data from the process lnodes->sharers[j]->rank (unless j is the current rank, in which case recv_buffers[j] is empty).

source
P4est.LibP4est.p8est_lnodes_rankType
p8est_lnodes_rank

The structure stored in the sharers array.

shared_nodes is a sorted array of p4est_locidx_t that indexes into local nodes. The shared_nodes array has a contiguous (or empty) section of nodes owned by the current rank. shared_mine_offset and shared_mine_count identify this section by indexing the shared_nodes array, not the local nodes array. owned_offset and owned_count define the section of local nodes that is owned by the listed rank (the section may be empty). For the current process these coincide with those in p8est_lnodes_t.

source
P4est.LibP4est.p8est_lnodes_rank_tType

The structure stored in the sharers array.

shared_nodes is a sorted array of p4est_locidx_t that indexes into local nodes. The shared_nodes array has a contiguous (or empty) section of nodes owned by the current rank. shared_mine_offset and shared_mine_count identify this section by indexing the shared_nodes array, not the local nodes array. owned_offset and owned_count define the section of local nodes that is owned by the listed rank (the section may be empty). For the current process these coincide with those in p8est_lnodes_t.

source
P4est.LibP4est.p8est_lnodes_tType

Store a parallel numbering of Lobatto points of a given degree > 0.

Each element has degree+1 nodes per edge and vnodes = (degree+1)^3 nodes per volume. element_nodes is of dimension vnodes * num_local_elements and lists the nodes of each element in lexicographic yx-order (x varies fastest); element_nodes indexes into the set of local nodes, layed out as follows: local nodes = [<––-owned_count––->|<––-nonlocal_nodes––->] = [<––––––––num_local_nodes––––––––->] nonlocal_nodes contains the globally unique numbers for independent nodes that are owned by other processes; for local nodes, the globally unique numbers are given by i + global_offset, where i is the local number. Hanging nodes are always local and don't have a global number. They index the geometrically corresponding independent nodes of a neighbor.

Whether nodes are hanging or not is decided based on the element faces and edges. This information is encoded in face_code with one int16_t per element. If no faces or edges are hanging, the value is zero, otherwise the face_code is interpreted by p8est_lnodes_decode.

Independent nodes can be shared by multiple MPI ranks. The owner rank of a node is the one from the lowest numbered element on the lowest numbered octree touching the node.

What is meant by touching? A quadrant is said to touch all faces/edges/corners that are incident on it, and by extension all nodes that are contained in those faces/edges/corners.

X +–––––-+ x |\ \ x | \ \ . x | \ \ x X | +–––––-+ +––-+ . . | | | |\ \ X o + | | | +––-+ o . \ | p | + | q | o \ | | \| | o \| | +––-+ O +–––––-+

In this example degree = 3. There are 4 nodes that live on the face between q and p, two on each edge and one at each corner of that face. The face is incident on q, so q owns the nodes marked '.' on the face (provided q is from a lower tree or has a lower index than p). The bottom and front edges are incident on q, so q owns its nodes marked 'o' as well. The front lower corner is incident on q, so q owns its node 'O' as well. The other edges and corners are not incident on q, so q cannot own their nodes, marked 'x' and 'X'.

global_owned_count contains the number of independent nodes owned by each process.

The sharers array contains items of type p8est_lnodes_rank_t that hold the ranks that own or share independent local nodes. If there are no shared nodes on this processor, it is empty. Otherwise, it is sorted by rank and the current process is included.

degree < 0 indicates that the lnodes data structure is being used to number the quadrant boundary object (faces, edge and corners) rather than the $C^0$ Lobatto nodes:

if degree == -1, then one node is assigned per face, and no nodes are assigned per volume, per edge, or per corner: this numbering can be used for low-order Raviart-Thomas elements. In this case, vnodes == 6, and the nodes are listed in face-order.

if degree == -2, then one node is assigned per face and per edge and no nodes are assigned per volume or per corner. In this case, vnodes == 18, and the nodes are listed in face-order, followed by edge-order.

if degree == -3, then one node is assigned per face, per edge and per corner and no nodes are assigned per volume. In this case, vnodes == 26, and the nodes are listed in face-order, followed by edge-order, followed by corner-order.

source
P4est.LibP4est.p8est_mesh_tType
p8est_mesh_t

This structure contains complete mesh information on a 2:1 balanced forest. It stores the locally relevant neighborhood, that is, all locally owned quadrants and one layer of adjacent ghost quadrants and their owners.

For each local quadrant, its tree number is stored in quad_to_tree. The quad_to_tree array is NULL by default and can be enabled using p8estmeshnewext. For each ghost quadrant, its owner rank is stored in ghost\to_proc. For each level, an array of local quadrant numbers is stored in quad_level. The quad_level array is NULL by default and can be enabled using p8estmeshnew_ext.

The quad_to_quad list stores one value for each local quadrant's face. This value is in 0..local_num_quadrants-1 for local quadrants, or in local_num_quadrants + (0..ghost_num_quadrants-1) for ghost quadrants.

The quad_to_face list has equally many entries that are either: 1. A value of v = 0..23 indicates one same-size neighbor. This value is decoded as v = r * 6 + nf, where nf = 0..5 is the neighbor's connecting face number and r = 0..3 is the relative orientation of the neighbor's face; see p8est_connectivity.h. 2. A value of v = 24..119 indicates a double-size neighbor. This value is decoded as v = 24 + h * 24 + r * 6 + nf, where r and nf are as above and h = 0..3 is the number of the subface. h designates the subface of the large neighbor that the quadrant touches (this is the same as the large neighbor's face corner). 3. A value of v = -24..-1 indicates four half-size neighbors. In this case the corresponding quad_to_quad index points into the quad_to_half array that stores four quadrant numbers per index, and the orientation of the smaller faces follows from 24 + v. The entries of quad_to_half encode between local and ghost quadrant in the same way as the quad_to_quad values described above. The small neighbors in quad_to_half are stored in the sequence of the face corners of this, i.e., the large quadrant.

A quadrant on the boundary of the forest sees itself and its face number.

The quad_to_edge list stores edge neighbors that are not face neighbors. On the inside of a tree, there are one or two of those depending on size. Between trees, there can be any number of same- or different-sized neighbors. For same-tree same-size neighbors, we record their number in quad_to_edge by the same convention as described for quad_to_quad above. In this case, the neighbor's matching edge number is always diagonally opposite, that is, edge number ^ 3.

For half- and double-size and all inter-tree edge neighbors, the quad_to_edge value is in local_num_quadrants + local_num_ghosts + [0 .. local_num_edges - 1]. After subtracting the number of local and ghost quadrants, it indexes into edge_offset, which encodes a group of edge neighbors. Each member of a group may be one same/double-size quadrant or two half-size quadrants; this is determined by the value of the edge_edge field as follows. 1. A value of e = 0..23 indicates one same-size neighbor. This value is encoded as e = r * 12 + ne, where ne = 0..11 is the neighbor's connecting edge number and r = 0..1 indicates an edge flip. 2. A value of e = 24..71 indicates a double-size neighbor. This value is decoded as e = 24 + h * 24 + r * 12 + ne, where r and ne are as above and h = 0..1 is the number of the subedge. h designates the subedge of the large neighbor that the quadrant touches (this is the same as the large neighbor's edge corner). 3. A value of e = -24..-1 indicates two half-size neighbors. They are represented by two consecutive entries of the edge_quad and edge_edge arrays with identical values for edge_edge. The orientation of the smaller edges follows from 24 + e. The small neighbors in edge_quad are stored in the sequence of the edge corners of this, i.e., the large quadrant.

Edges with no diagonal neighbor at all are assigned the value -3. This only happens on the domain boundary, which is necessarily a tree boundary. Edge neighbors for face-hanging nodes are assigned the value -1.

The quad_to_corner list stores corner neighbors that are not face or edge neighbors. On the inside of a tree, there is precisely one such neighbor per corner. In this case, its index is encoded as described above for quad_to_quad. The neighbor's matching corner number is always diagonally opposite, that is, corner number ^ 7.

On the inside of an inter-tree face, we have precisely one corner neighbor. If a corner is across an inter-tree edge or corner, then the number of corner neighbors may be any non-negative number. In all three cases, the quad_to_corner value is in local_num_quadrants + local_num_ghosts + [0 .. local_num_corners - 1]. After subtracting the number of local and ghost quadrants, it indexes into corner_offset, which encodes a group of corner neighbors. Each group contains the quadrant numbers encoded as usual for quad_to_quad in corner_quad, and the corner number from the neighbor as corner_corner.

Corners with no diagonal neighbor at all are assigned the value -3. This only happens on the domain boundary, which is necessarily a tree boundary. Corner-neighbors for face- and edge-hanging nodes are assigned the value -1.

TODO: In case of an inter-tree neighbor relation in a brick-like situation (one same-size neighbor, diagonally opposite edge/corner), use the same encoding as for edges/corners within a tree.

FieldNote
quad_to_treetree index for each local quad. Is NULL by default, but may be enabled by p8estmeshnew_ext.
ghost_to_procprocessor for each ghost quad
quad_to_quadone index for each of the 6 faces
quad_to_faceencodes orientation/2:1 status
quad_to_halfstores half-size neighbors
quad_levelStores lists of per-level quads. The array has entries indexed by 0..P4EST_QMAXLEVEL inclusive that are arrays of local quadrant ids. Is NULL by default, but may be enabled by p8estmeshnew_ext.
local_num_edgesunsame-size and tree-boundary edges
quad_to_edge12 indices for each local quad
edge_offsetlocal_num_edges + 1 entries
edge_quadedge_offset indexes into this
edge_edgeand this one too (type int8_t)
source
P4est.LibP4est.p8est_quadrantType
p8est_quadrant

The 3D quadrant (i.e., octant) datatype

FieldNote
xcoordinates
y
z
levellevel of refinement
pad8padding
pad16
pa union of additional data attached to a quadrant
source
P4est.LibP4est.p8est_refine_tType

Callback function prototype to decide for refinement.

Parameters

  • p8est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrant:[in] the quadrant that may be refined

Returns

nonzero if the quadrant shall be refined.

source
P4est.LibP4est.p8est_replace_tType

Callback function prototype to replace one set of quadrants with another.

This is used by extended routines when the quadrants of an existing, valid p8est are changed. The callback allows the user to make changes to newly initialized quadrants before the quadrants that they replace are destroyed.

If the mesh is being refined, num_outgoing will be 1 and num_incoming will be 8, and vice versa if the mesh is being coarsened.

Parameters

  • num_outgoing:[in] The number of outgoing quadrants.
  • outgoing:[in] The outgoing quadrants: after the callback, the user_data, if p8est->data_size is nonzero, will be destroyed.
  • num_incoming:[in] The number of incoming quadrants.
  • incoming:[in,out] The incoming quadrants: prior to the callback, the user_data, if p8est->datasize is nonzero, is allocated, and the [`p8estinit_t`](@ref) callback, if it has been provided, will be called.
source
P4est.LibP4est.p8est_search_all_tType

Callback function for the top-down search through the whole forest.

Parameters

  • p4est:[in] The forest to search. We recurse through the trees one after another.
  • which_tree:[in] The current tree number.
  • quadrant:[in] The current quadrant in the recursion. This quadrant is either a non-leaf tree branch or a leaf. If the quadrant is contained in the local partition, we know which, otherwise we don't. Let us first consider the situation when quadrant is local, which is indicated by both pfirst and plast being equal to p4est->mpirank. Then the parameter local_num is negative for non-leaves and the number of the quadrant as a leaf in local storage otherwise. Only if the quadrant is a local leaf, it points to the actual local storage and can be used to access user data etc., and the recursion terminates. The other possibility is that pfirst < plast, in which case we proceed with the recursion, or both are equal to the same remote rank, in which case the recursion terminates. Either way, the quadrant is not from local forest storage.
  • pfirst:[in] The lowest processor that owns part of quadrant. Guaranteed to be non-empty.
  • plast:[in] The highest processor that owns part of quadrant. Guaranteed to be non-empty.
  • local_num:[in] If quadrant is a local leaf, this number is the index of the leaf in local quadrant storage. Else, this is a negative value.
  • point:[in,out] User-defined representation of a point. This parameter distinguishes two uses of the callback. For each quadrant, the callback is first called with a NULL point, and if this callback returns true, once for each point tracked in this branch. The return value for a point determines whether it shall be tracked further down the branch or not, and has no effect on a local leaf. The call with a NULL point is intended to prepare quadrant-related search meta data that is common to all points, and/or to efficiently terminate the recursion for all points in the branch in one call.

Returns

If false, the recursion at quadrant terminates. If true, it continues if pfirst < plast or if they are both equal to p4est->mpirank and the recursion has not reached a leaf yet.

source
P4est.LibP4est.p8est_search_local_tType

Callback function to query the match of a "point" with a quadrant.

This function can be called in two roles: Per-quadrant, in which case the parameter point is NULL, or per-point, possibly many times per quadrant.

Parameters

  • p4est:[in] The forest to be queried.
  • which_tree:[in] The tree id under consideration.
  • quadrant:[in] The quadrant under consideration. This quadrant may be coarser than the quadrants that are contained in the forest (an ancestor), in which case it is a temporary variable and not part of the forest storage. Otherwise, it is a leaf and points directly into the forest storage.
  • local_num:[in] If the quadrant is not a leaf, this is < 0. Otherwise it is the (non-negative) index of the quadrant relative to the processor-local storage.
  • point:[in] Representation of a "point"; user-defined. If point is NULL, the callback may be used to prepare quadrant-related search meta data.

Returns

If point is NULL, true if the search confined to quadrant should be executed, false to skip it. Else, true if point may be contained in the quadrant and false otherwise; the return value has no effect on a leaf.

source
P4est.LibP4est.p8est_search_partition_tType

Callback function for the partition recursion.

Parameters

  • p4est:[in] The forest to traverse. Its local quadrants are never accessed.
  • which_tree:[in] The tree number under consideration.
  • quadrant:[in] This quadrant is not from local forest storage, and its user data is undefined. It represents the branch of the forest in the top-down recursion.
  • pfirst:[in] The lowest processor that owns part of quadrant. Guaranteed to be non-empty.
  • plast:[in] The highest processor that owns part of quadrant. Guaranteed to be non-empty. If this is equal to pfirst, then the recursion will stop for quadrant's branch after this function returns.
  • point:[in,out] Pointer to a user-defined point object. If called per-quadrant, this is NULL.

Returns

If false, the recursion at quadrant is terminated. If true, it continues if pfirst < plast.

source
P4est.LibP4est.p8est_treeType
p8est_tree

The p8est tree datatype

FieldNote
quadrantslocally stored quadrants
first_descfirst local descendant
last_desclast local descendant
quadrants_offsetcumulative sum over earlier trees on this processor (locals only)
maxlevelhighest local quadrant level
source
P4est.LibP4est.p8est_weight_tType

Callback function prototype to calculate weights for partitioning.

Note

Global sum of weights must fit into a 64bit integer.

Parameters

  • p8est:[in] the forest
  • which_tree:[in] the tree containing quadrant

Returns

a 32bit integer >= 0 as the quadrant weight.

source
P4est.LibP4est.sc_arrayType
sc_array

The sc_array object provides a dynamic array of equal-size elements. Elements are accessed by their 0-based index. Their address may change. The number of elements (== elem_count) of the array can be changed by scarrayresize and scarrayrewind. Elements can be sorted with scarraysort. If the array is sorted, it can be searched with scarraybsearch. A priority queue is implemented with pqueue_add and pqueue_pop (untested).

FieldNote
elem_sizesize of a single element
elem_countnumber of valid elements
byte_allocnumber of allocated bytes or -(number of viewed bytes + 1) if this is a view: the "+ 1" distinguishes an array of size 0 from a view of size 0
arraylinear array to store elements
source
P4est.LibP4est.sc_array_tType

The sc_array object provides a dynamic array of equal-size elements. Elements are accessed by their 0-based index. Their address may change. The number of elements (== elem_count) of the array can be changed by scarrayresize and scarrayrewind. Elements can be sorted with scarraysort. If the array is sorted, it can be searched with scarraybsearch. A priority queue is implemented with pqueue_add and pqueue_pop (untested).

source
P4est.LibP4est.sc_array_type_tType

Function to determine the enumerable type of an object in an array.

Parameters

  • array:[in] Array containing the object.
  • index:[in] The location of the object.
  • data:[in] Arbitrary user data.
source
P4est.LibP4est.sc_hashType
sc_hash

The sc_hash implements a hash table. It uses an array which has linked lists as elements.

FieldNote
elem_counttotal number of objects contained
slotsthe slot count is slots->elem_count
user_datauser data passed to hash function
allocatormust allocate sc_link_t
source
P4est.LibP4est.sc_hash_foreach_tType

Function to call on every data item of a hash table.

Parameters

  • v:[in] The address of the pointer to the current object.
  • u:[in] Arbitrary user data.

Returns

Return true if the traversal should continue, false to stop.

source
P4est.LibP4est.sc_io_error_tType
sc_io_error_t

Error values for io.

EnumeratorNote
SC_IO_ERROR_NONEThe value of zero means no error.
SC_IO_ERROR_FATALThe io object is now disfunctional.
SC_IO_ERROR_AGAINAnother io operation may resolve it. The function just returned was a noop.
source
P4est.LibP4est.sc_io_mode_tType
sc_io_mode_t
EnumeratorNote
SC_IO_MODE_WRITESemantics as "w" in fopen.
SC_IO_MODE_APPENDSemantics as "a" in fopen.
SC_IO_MODE_LASTInvalid entry to close list
source
P4est.LibP4est.sc_mempoolType
sc_mempool

The sc_mempool object provides a large pool of equal-size elements. The pool grows dynamically for element allocation. Elements are referenced by their address which never changes. Elements can be freed (that is, returned to the pool) and are transparently reused. If the zero_and_persist option is selected, new elements are initialized to all zeros on creation, and the contents of an element are not touched between freeing and re-returning it.

FieldNote
elem_sizesize of a single element
elem_countnumber of valid elements
zero_and_persistBoolean; is set in constructor.
mstampfixed-size chunk allocator
freedbuffers the freed elements
source
P4est.LibP4est.sc_mempool_tType

The sc_mempool object provides a large pool of equal-size elements. The pool grows dynamically for element allocation. Elements are referenced by their address which never changes. Elements can be freed (that is, returned to the pool) and are transparently reused. If the zero_and_persist option is selected, new elements are initialized to all zeros on creation, and the contents of an element are not touched between freeing and re-returning it.

source
P4est.LibP4est.sc_mstampType
sc_mstamp

A data container to create memory items of the same size. Allocations are bundled so it's fast for small memory sizes. The items created will remain valid until the container is destroyed. There is no option to return an item to the container. See scmempoolt for that purpose.

FieldNote
elem_sizeInput parameter: size per item
per_stampNumber of items per stamp
stamp_sizeBytes allocated in a stamp
cur_snextNext number within a stamp
currentMemory of current stamp
rememberCollects all stamps
source
P4est.LibP4est.sc_mstamp_tType

A data container to create memory items of the same size. Allocations are bundled so it's fast for small memory sizes. The items created will remain valid until the container is destroyed. There is no option to return an item to the container. See scmempoolt for that purpose.

source
P4est.LibP4est.sc_uint128Type
sc_uint128

An unsigned 128 bit integer represented as two uint64_t.

FieldNote
high_bitsThe more significant 64 bits.
low_bitsThe less significant 64 bits.
source
P4est.LibP4est.p4est_balanceMethod
p4est_balance(p4est_, btype, init_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p4est:[in,out] The p4est to be worked on.
  • btype:[in] Balance type (face or corner/full). Corner balance is almost never required when discretizing a PDE; just causes smoother mesh grading.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p4est_balance (p4est_t * p4est, p4est_connect_type_t btype, p4est_init_t init_fn);
source
P4est.LibP4est.p4est_balance_extMethod
p4est_balance_ext(p4est_, btype, init_fn, replace_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p4est:[in,out] The p4est to be worked on.
  • btype:[in] Balance type (face or corner/full). Corner balance is almost never required when discretizing a PDE; just causes smoother mesh grading.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p4est_balance_ext (p4est_t * p4est, p4est_connect_type_t btype, p4est_init_t init_fn, p4est_replace_t replace_fn);
source
P4est.LibP4est.p4est_balance_subtree_extMethod
p4est_balance_subtree_ext(p4est_, btype, which_tree, init_fn, replace_fn)

Prototype

void p4est_balance_subtree_ext (p4est_t * p4est, p4est_connect_type_t btype, p4est_topidx_t which_tree, p4est_init_t init_fn, p4est_replace_t replace_fn);
source
P4est.LibP4est.p4est_checksumMethod
p4est_checksum(p4est_)

Compute the checksum for a forest. Based on quadrant arrays only. It is independent of partition and mpisize.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p4est_checksum (p4est_t * p4est);
source
P4est.LibP4est.p4est_checksum_partitionMethod
p4est_checksum_partition(p4est_)

Compute a partition-dependent checksum for a forest.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p4est_checksum_partition (p4est_t * p4est);
source
P4est.LibP4est.p4est_coarsenMethod
p4est_coarsen(p4est_, coarsen_recursive, coarsen_fn, init_fn)

Coarsen a forest.

Parameters

  • p4est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p4est_coarsen (p4est_t * p4est, int coarsen_recursive, p4est_coarsen_t coarsen_fn, p4est_init_t init_fn);
source
P4est.LibP4est.p4est_coarsen_extMethod
p4est_coarsen_ext(p4est_, coarsen_recursive, callback_orphans, coarsen_fn, init_fn, replace_fn)

Coarsen a forest.

Parameters

  • p4est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • callback_orphans:[in] Boolean to enable calling coarsen_fn even on non-families. In this case, the second quadrant pointer in the argument list of the callback is NULL, subsequent pointers are undefined, and the return value is ignored. If coarsen_recursive is true, it is possible that a quadrant is called once or more as an orphan and eventually becomes part of a family. With coarsen_recursive false and callback_orphans true, it is guaranteed that every quadrant is passed exactly once into the coarsen_fn callback.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p4est_coarsen_ext (p4est_t * p4est, int coarsen_recursive, int callback_orphans, p4est_coarsen_t coarsen_fn, p4est_init_t init_fn, p4est_replace_t replace_fn);
source
P4est.LibP4est.p4est_connectivity_completeMethod
p4est_connectivity_complete(conn)

Internally connect a connectivity based on tree_to_vertex information. Periodicity that is not inherent in the list of vertices will be lost.

Parameters

  • conn:[in,out] The connectivity needs to have proper vertices and tree_to_vertex fields. The tree_to_tree and tree_to_face fields must be allocated and satisfy p4est_connectivity_is_valid (conn) but will be overwritten. The corner fields will be freed and allocated anew.

Prototype

void p4est_connectivity_complete (p4est_connectivity_t * conn);
source
P4est.LibP4est.p4est_connectivity_deflateMethod
p4est_connectivity_deflate(conn, code)

Allocate memory and store the connectivity information there.

Parameters

  • conn:[in] The connectivity structure to be exported to memory.
  • code:[in] Encoding and compression method for serialization.

Returns

Newly created array that contains the information.

Prototype

sc_array_t *p4est_connectivity_deflate (p4est_connectivity_t * conn, p4est_connectivity_encode_t code);
source
P4est.LibP4est.p4est_connectivity_destroyMethod
p4est_connectivity_destroy(connectivity)

Destroy a connectivity structure. Also destroy all attributes.

Prototype

void p4est_connectivity_destroy (p4est_connectivity_t * connectivity);
source
P4est.LibP4est.p4est_connectivity_face_neighbor_cornerMethod
p4est_connectivity_face_neighbor_corner(c, f, nf, o)

Transform a corner across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • c:[in] A corner number in 0..3.
  • f:[in] A face number that touches the corner c.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The number of the corner seen from the neighbor tree.

Prototype

int p4est_connectivity_face_neighbor_corner (int c, int f, int nf, int o);
source
P4est.LibP4est.p4est_connectivity_face_neighbor_face_cornerMethod
p4est_connectivity_face_neighbor_face_corner(fc, f, nf, o)

Transform a face corner across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • fc:[in] A face corner number in 0..1.
  • f:[in] A face that the face corner number fc is relative to.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The face corner number relative to the neighbor's face.

Prototype

int p4est_connectivity_face_neighbor_face_corner (int fc, int f, int nf, int o);
source
P4est.LibP4est.p4est_connectivity_inflateMethod
p4est_connectivity_inflate(buffer)

Create new connectivity from a memory buffer.

Parameters

  • buffer:[in] The connectivity is created from this memory buffer.

Returns

The newly created connectivity, or NULL on error.

Prototype

p4est_connectivity_t *p4est_connectivity_inflate (sc_array_t * buffer);
source
P4est.LibP4est.p4est_connectivity_is_equalMethod
p4est_connectivity_is_equal(conn1, conn2)

Check two connectivity structures for equality.

Returns

Returns true if structures are equal, false otherwise.

Prototype

int p4est_connectivity_is_equal (p4est_connectivity_t * conn1, p4est_connectivity_t * conn2);
source
P4est.LibP4est.p4est_connectivity_is_equivalentMethod
p4est_connectivity_is_equivalent(conn1, conn2)

p4est_connectivity_is_equivalent This function compares two connectivities for equivalence: it returns true if they are the same connectivity, or if they have the same topology. The definition of topological sameness is strict: there is no attempt made to determine whether permutation and/or rotation of the trees makes the connectivities equivalent.

Parameters

  • conn1:[in] a valid connectivity
  • conn2:[out] a valid connectivity

Prototype

int p4est_connectivity_is_equivalent (p4est_connectivity_t * conn1, p4est_connectivity_t * conn2);
source
P4est.LibP4est.p4est_connectivity_is_validMethod
p4est_connectivity_is_valid(connectivity)

Examine a connectivity structure.

Returns

Returns true if structure is valid, false otherwise.

Prototype

int p4est_connectivity_is_valid (p4est_connectivity_t * connectivity);
source
P4est.LibP4est.p4est_connectivity_join_facesMethod
p4est_connectivity_join_faces(conn, tree_left, tree_right, face_left, face_right, orientation)

p4est_connectivity_join_faces This function takes an existing valid connectivity conn and modifies it by joining two tree faces that are currently boundary faces.

Parameters

  • conn:[in,out] connectivity that will be altered.
  • tree_left:[in] tree that will be on the left side of the joined faces.
  • tree_right:[in] tree that will be on the right side of the joined faces.
  • face_left:[in] face of tree_left that will be joined.
  • face_right:[in] face of tree_right that will be joined.
  • orientation:[in] the orientation of face_left and face_right once joined (see the description of p4est_connectivity_t to understand orientation).

Prototype

void p4est_connectivity_join_faces (p4est_connectivity_t * conn, p4est_topidx_t tree_left, p4est_topidx_t tree_right, int face_left, int face_right, int orientation);
source
P4est.LibP4est.p4est_connectivity_loadMethod
p4est_connectivity_load(filename, bytes)

Load a connectivity structure from disk.

Parameters

  • filename:[in] Name of the file to read.
  • bytes:[in,out] Size in bytes of connectivity on disk or NULL.

Returns

Returns valid connectivity, or NULL on file error.

Prototype

p4est_connectivity_t *p4est_connectivity_load (const char *filename, size_t *bytes);
source
P4est.LibP4est.p4est_connectivity_memory_usedMethod
p4est_connectivity_memory_used(conn)

Calculate memory usage of a connectivity structure.

Parameters

  • conn:[in] Connectivity structure.

Returns

Memory used in bytes.

Prototype

size_t p4est_connectivity_memory_used (p4est_connectivity_t * conn);
source
P4est.LibP4est.p4est_connectivity_newMethod
p4est_connectivity_new(num_vertices, num_trees, num_corners, num_ctt)

Allocate a connectivity structure. The attribute fields are initialized to NULL.

Parameters

  • num_vertices:[in] Number of total vertices (i.e. geometric points).
  • num_trees:[in] Number of trees in the forest.
  • num_corners:[in] Number of tree-connecting corners.
  • num_ctt:[in] Number of total trees in corner_to_tree array.

Returns

A connectivity structure with allocated arrays.

Prototype

p4est_connectivity_t *p4est_connectivity_new (p4est_topidx_t num_vertices, p4est_topidx_t num_trees, p4est_topidx_t num_corners, p4est_topidx_t num_ctt);
source
P4est.LibP4est.p4est_connectivity_new_brickMethod
p4est_connectivity_new_brick(mi, ni, periodic_a, periodic_b)

A rectangular m by n array of trees with configurable periodicity. The brick is periodic in x and y if periodic_a and periodic_b are true, respectively.

Prototype

p4est_connectivity_t *p4est_connectivity_new_brick (int mi, int ni, int periodic_a, int periodic_b);
source
P4est.LibP4est.p4est_connectivity_new_bynameMethod
p4est_connectivity_new_byname(name)

Create connectivity structure from predefined catalogue.

Parameters

  • name:[in] Invokes connectivity_new_* function. brick23 brick (2, 3, 0, 0) corner corner cubed cubed disk disk moebius moebius periodic periodic pillow pillow rotwrap rotwrap star star unit unitsquare

Returns

An initialized connectivity if name is defined, NULL else.

Prototype

p4est_connectivity_t *p4est_connectivity_new_byname (const char *name);
source
P4est.LibP4est.p4est_connectivity_new_copyMethod
p4est_connectivity_new_copy(num_vertices, num_trees, num_corners, vertices, ttv, ttt, ttf, ttc, coff, ctt, ctc)

Allocate a connectivity structure and populate from constants. The attribute fields are initialized to NULL.

Parameters

  • num_vertices:[in] Number of total vertices (i.e. geometric points).
  • num_trees:[in] Number of trees in the forest.
  • num_corners:[in] Number of tree-connecting corners.
  • coff:[in] Corner-to-tree offsets (num_corners + 1 values). This must always be non-NULL; in trivial cases it is just a pointer to a p4est_topix value of 0.

Returns

The connectivity is checked for validity.

Prototype

p4est_connectivity_t *p4est_connectivity_new_copy (p4est_topidx_t num_vertices, p4est_topidx_t num_trees, p4est_topidx_t num_corners, const double *vertices, const p4est_topidx_t * ttv, const p4est_topidx_t * ttt, const int8_t * ttf, const p4est_topidx_t * ttc, const p4est_topidx_t * coff, const p4est_topidx_t * ctt, const int8_t * ctc);
source
P4est.LibP4est.p4est_connectivity_new_cubedMethod
p4est_connectivity_new_cubed()

Create a connectivity structure for the six sides of a unit cube. The ordering of the trees is as follows: 0 1 2 3 <– 3: axis-aligned top side 4 5. This choice has been made for maximum symmetry (see tree_to_* in .c file).

Prototype

p4est_connectivity_t *p4est_connectivity_new_cubed (void);
source
P4est.LibP4est.p4est_connectivity_new_diskMethod
p4est_connectivity_new_disk(periodic_a, periodic_b)

Create a connectivity structure for a five-tree flat spherical disk. This disk can just as well be used as a square to test non-Cartesian maps. Without any mapping this connectivity covers the square [-3, 3]**2.

Note

The API of this function has changed to accept two arguments. You can query the #define P4EST_CONN_DISK_PERIODIC to check whether the new version with the argument is in effect.

The ordering of the trees is as follows: 4 1 2 3 0.

The outside x faces may be identified topologically. The outside y faces may be identified topologically. Both identifications may be specified simultaneously. The general shape and periodicity are the same as those obtained with p4estconnectivitynewbrick (1, 1, periodic\a, periodic_b).

When setting periodic_a and periodic_b to false, the result is the same as that of p4estconnectivitynewdisknonperiodic.

Parameters

  • periodic_a:[in] Bool to make disk periodic in x direction.
  • periodic_b:[in] Bool to make disk periodic in y direction.

Returns

Initialized and usable connectivity.

Prototype

p4est_connectivity_t *p4est_connectivity_new_disk (int periodic_a, int periodic_b);
source
P4est.LibP4est.p4est_connectivity_new_disk2dMethod
p4est_connectivity_new_disk2d()

Create a connectivity structure that maps a 2d disk.

This is a 5 trees connectivity meant to be used together with p4estgeometrynew_disk2d to map the disk.

Prototype

p4est_connectivity_t *p4est_connectivity_new_disk2d (void);
source
P4est.LibP4est.p4est_connectivity_new_disk_nonperiodicMethod
p4est_connectivity_new_disk_nonperiodic()

Create a connectivity structure for a five-tree flat spherical disk. This disk can just as well be used as a square to test non-Cartesian maps. Without any mapping this connectivity covers the square [-3, 3]**2.

Returns

Initialized and usable connectivity.

Prototype

p4est_connectivity_t *p4est_connectivity_new_disk_nonperiodic (void);
source
P4est.LibP4est.p4est_connectivity_new_icosahedronMethod
p4est_connectivity_new_icosahedron()

Create a connectivity for mapping the sphere using an icosahedron.

The regular icosadron is a polyhedron with 20 faces, each of which is an equilateral triangle. To build the p4est connectivity, we group faces 2 by 2 to from 10 quadrangles, and thus 10 trees.

This connectivity is meant to be used together with p4estgeometrynew_icosahedron to map the sphere.

The flat connectivity looks like that: Vextex numbering:

A00 A01 A02 A03 A04 / \ / \ / \ / \ / \ A05–-A06–-A07–-A08–-A09–-A10 \ / \ / \ / \ / \ / \ A11–-A12–-A13–-A14–-A15–-A16 \ / \ / \ / \ / \ / A17 A18 A19 A20 A21

Origin in A05.

Tree numbering:

0 2 4 6 8 1 3 5 7 9

Prototype

p4est_connectivity_t *p4est_connectivity_new_icosahedron ();
source
P4est.LibP4est.p4est_connectivity_new_rotwrapMethod
p4est_connectivity_new_rotwrap()

Create a connectivity structure for a periodic unit square. The left and right faces are identified, and bottom and top opposite.

Prototype

p4est_connectivity_t *p4est_connectivity_new_rotwrap (void);
source
P4est.LibP4est.p4est_connectivity_new_shell2dMethod
p4est_connectivity_new_shell2d()

Create a connectivity structure that builds a 2d spherical shell. p8estconnectivitynew_shell

Prototype

p4est_connectivity_t *p4est_connectivity_new_shell2d (void);
source
P4est.LibP4est.p4est_connectivity_new_twotreesMethod
p4est_connectivity_new_twotrees(l_face, r_face, orientation)

Create a connectivity structure for two trees being rotated w.r.t. each other in a user-defined way

Parameters

  • l_face:[in] index of left face
  • r_face:[in] index of right face
  • orientation:[in] orientation of trees w.r.t. each other

Prototype

p4est_connectivity_t *p4est_connectivity_new_twotrees (int l_face, int r_face, int orientation);
source
P4est.LibP4est.p4est_connectivity_permuteMethod
p4est_connectivity_permute(conn, perm, is_current_to_new)

p4est_connectivity_permute Given a permutation perm of the trees in a connectivity conn, permute the trees of conn in place and update conn to match.

Parameters

  • conn:[in,out] The connectivity whose trees are permuted.
  • perm:[in] A permutation array, whose elements are size_t's.
  • is_current_to_new:[in] if true, the jth entry of perm is the new index for the entry whose current index is j, otherwise the jth entry of perm is the current index of the tree whose index will be j after the permutation.

Prototype

void p4est_connectivity_permute (p4est_connectivity_t * conn, sc_array_t * perm, int is_current_to_new);
source
P4est.LibP4est.p4est_connectivity_read_inpMethod
p4est_connectivity_read_inp(filename)

Create a p4est connectivity from an ABAQUS input file.

This utility function reads a basic ABAQUS file supporting element type with the prefix C2D4, CPS4, and S4 in 2D and of type C3D8 reading them as bilinear quadrilateral and trilinear hexahedral trees respectively.

A basic 2D mesh is given below. The *Node section gives the vertex number and x, y, and z components for each vertex. The *Element section gives the 4 vertices in 2D (8 vertices in 3D) of each element in counter clockwise order. So in 2D the nodes are given as:

4 3 +–––––––––-+ | | | | | | | | | | | | +–––––––––-+ 1 2

and in 3D they are given as:

8 7 +––––––––––-+ |\ |\ | \ | \ | \ | \ | \ | \ | 5+––––––––––-+6 | | | | +––|––––––––+ | 4\ | 3 \ | \ | \ | \ | \ | \| \| +––––––––––-+ 1 2

 *Heading
+4
source

Wrapper of the C API of p4est

Everything documented here is also exported from P4est.jl and available when using P4est.

P4est.LibP4est.p4est_coarsen_tType

Callback function prototype to decide for coarsening.

Parameters

  • p4est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrants:[in] Pointers to 4 siblings in Morton ordering.

Returns

nonzero if the quadrants shall be replaced with their parent.

source
P4est.LibP4est.p4est_connect_type_tType
p4est_connect_type_t

Characterize a type of adjacency.

Several functions involve relationships between neighboring trees and/or quadrants, and their behavior depends on how one defines adjacency: 1) entities are adjacent if they share a face, or 2) entities are adjacent if they share a face or corner. p4est_connect_type_t is used to choose the desired behavior. This enum must fit into an int8_t.

source
P4est.LibP4est.p4est_connectivityType
p4est_connectivity

This structure holds the 2D inter-tree connectivity information. Identification of arbitrary faces and corners is possible.

The arrays tree_to_* are stored in z ordering. For corners the order wrt. yx is 00 01 10 11. For faces the order is -x +x -y +y. They are allocated [0][0]..[0][3]..[num_trees-1][0]..[num_trees-1][3].

The values for tree_to_face are 0..7 where ttf % 4 gives the face number and ttf / 4 the face orientation code. The orientation is 0 for edges that are aligned in z-order, and 1 for edges that are running opposite in z-order.

It is valid to specify num_vertices as 0. In this case vertices and tree_to_vertex are set to NULL. Otherwise the vertex coordinates are stored in the array vertices as [0][0]..[0][2]..[num_vertices-1][0]..[num_vertices-1][2].

The corners are only stored when they connect trees. In this case tree_to_corner indexes into ctt_offset. Otherwise the tree_to_corner entry must be -1 and this corner is ignored. If num_corners == 0, tree_to_corner and corner_to_* arrays are set to NULL.

The arrays corner_to_* store a variable number of entries per corner. For corner c these are at position [ctt_offset[c]]..[ctt_offset[c+1]-1]. Their number for corner c is ctt_offset[c+1] - ctt_offset[c]. The entries encode all trees adjacent to corner c. The size of the corner_to_* arrays is num_ctt = ctt_offset[num_corners].

The *_to_attr arrays may have arbitrary contents defined by the user.

FieldNote
num_verticesthe number of vertices that define the embedding of the forest (not the topology)
num_treesthe number of trees
num_cornersthe number of corners that help define topology
verticesan array of size (3 * num_vertices)
tree_to_vertexembed each tree into c++ R^3 for e.g. visualization (see p4est_vtk.h)
tree_attr_bytesbytes per tree in tree_to_attr
tree_to_attrnot touched by p4est
tree_to_tree(4 * num_trees) neighbors across faces
tree_to_face(4 * num_trees) face to face+orientation (see description)
tree_to_corner(4 * num_trees) or NULL (see description)
ctt_offsetcorner to offset in cornertotree and cornertocorner
corner_to_treelist of trees that meet at a corner
corner_to_cornerlist of tree-corners that meet at a corner
source
P4est.LibP4est.p4est_connectivity_tType

This structure holds the 2D inter-tree connectivity information. Identification of arbitrary faces and corners is possible.

The arrays tree_to_* are stored in z ordering. For corners the order wrt. yx is 00 01 10 11. For faces the order is -x +x -y +y. They are allocated [0][0]..[0][3]..[num_trees-1][0]..[num_trees-1][3].

The values for tree_to_face are 0..7 where ttf % 4 gives the face number and ttf / 4 the face orientation code. The orientation is 0 for edges that are aligned in z-order, and 1 for edges that are running opposite in z-order.

It is valid to specify num_vertices as 0. In this case vertices and tree_to_vertex are set to NULL. Otherwise the vertex coordinates are stored in the array vertices as [0][0]..[0][2]..[num_vertices-1][0]..[num_vertices-1][2].

The corners are only stored when they connect trees. In this case tree_to_corner indexes into ctt_offset. Otherwise the tree_to_corner entry must be -1 and this corner is ignored. If num_corners == 0, tree_to_corner and corner_to_* arrays are set to NULL.

The arrays corner_to_* store a variable number of entries per corner. For corner c these are at position [ctt_offset[c]]..[ctt_offset[c+1]-1]. Their number for corner c is ctt_offset[c+1] - ctt_offset[c]. The entries encode all trees adjacent to corner c. The size of the corner_to_* arrays is num_ctt = ctt_offset[num_corners].

The *_to_attr arrays may have arbitrary contents defined by the user.

source
P4est.LibP4est.p4est_ghost_tType
p4est_ghost_t

quadrants that neighbor the local domain

FieldNote
btypewhich neighbors are in the ghost layer
ghostsarray of p4est_quadrant_t type
tree_offsetsnum_trees + 1 ghost indices
proc_offsetsmpisize + 1 ghost indices
mirrorsarray of p4est_quadrant_t type
mirror_tree_offsetsnum_trees + 1 mirror indices
mirror_proc_mirrorsindices into mirrors grouped by outside processor rank and ascending within each rank
mirror_proc_offsetsmpisize + 1 indices into mirror_proc_mirrors
mirror_proc_frontslike mirror_proc_mirrors, but limited to the outermost octants. This is NULL until p4est_ghost_expand is called
mirror_proc_front_offsetsNULL until p4est_ghost_expand is called
source
P4est.LibP4est.p4est_init_tType

Callback function prototype to initialize the quadrant's user data.

Parameters

  • p4est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrant:[in,out] the quadrant to be initialized: if data_size > 0, the data to be initialized is at quadrant->p.userdata; otherwise, the non-pointer user data (such as quadrant->p.userint) can be initialized
source
P4est.LibP4est.p4est_inspectType
p4est_inspect

Data pertaining to selecting, inspecting, and profiling algorithms. A pointer to this structure is hooked into the p4est main structure.

The balance_ranges and balance_notify* times are collected whenever an inspect structure is present in p4est.

FieldNote
use_balance_rangesUse sc_ranges to determine the asymmetric communication pattern. If usebalanceranges is false (the default), sc_notify is used.
use_balance_ranges_notifyIf true, call both sc_ranges and sc_notify and verify consistency. Which is actually used is still determined by usebalanceranges.
use_balance_verifyVerify sc_ranges and/or sc_notify as applicable.
balance_max_rangesIf positive and smaller than p4est_num ranges, overrides it
balance_rangestime spent in sc_ranges
balance_notifytime spent in sc_notify
balance_notify_allgathertime spent in sc_notify_allgather
source
P4est.LibP4est.p4est_inspect_tType

Data pertaining to selecting, inspecting, and profiling algorithms. A pointer to this structure is hooked into the p4est main structure. Declared in p4est_extended.h. Used to profile important algorithms.

source
P4est.LibP4est.p4est_iter_corner_infoType
p4est_iter_corner_info

The information that is available to the user-defined p4est_iter_corner_t callback.

If tree_boundary is false, the corner is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the corner. When tree_boundary is true, its value is P4EST_CONNECT_FACE/CORNER depending on the location of the corner relative to the tree.

FieldNote
tree_boundaryboolean: interior face (0), tree boundary face (true)
sidesarray of type p4est_iter_corner_side_t type
source
P4est.LibP4est.p4est_iter_corner_info_tType

The information that is available to the user-defined p4est_iter_corner_t callback.

If tree_boundary is false, the corner is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the corner. When tree_boundary is true, its value is P4EST_CONNECT_FACE/CORNER depending on the location of the corner relative to the tree.

source
P4est.LibP4est.p4est_iter_corner_sideType
p4est_iter_corner_side

Information about one side of a corner in the forest. If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

the faces field provides some additional information about the local topology: if side[i]->faces[j] == side[k]->faces[l], this indicates that there is a common face between these two sides of the corner.

FieldNote
treeidthe tree that contains quad
cornerwhich of the quadrant's corners touches this corner
is_ghostboolean: local (0) or ghost (1)
quadidthe index in the tree or ghost array
facesinternal work data
source
P4est.LibP4est.p4est_iter_corner_side_tType

Information about one side of a corner in the forest. If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

the faces field provides some additional information about the local topology: if side[i]->faces[j] == side[k]->faces[l], this indicates that there is a common face between these two sides of the corner.

source
P4est.LibP4est.p4est_iter_corner_tType

The prototype for a function that p4est_iterate will execute wherever quadrants meet at a conformal corner

i.e. the callback will not execute on a hanging corner.

Note

the forest does not need to be corner balanced for p4est_iterate() to correctly execute a callback function at corners, only face balanced (see p4est_balance()).

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p4est_iterate()
source
P4est.LibP4est.p4est_iter_face_infoType
p4est_iter_face_info

The information that is available to the user-defined p4est_iter_face_t callback.

The orientation is 0 if the face is within one tree; otherwise, it is the same as the orientation value between the two trees given in the connectivity. If the face is on the outside boundary of the forest, then there is only one side. If tree_boundary is false, the face is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the face. When tree_boundary is true, its value is P4EST_CONNECT_FACE.

FieldNote
orientationthe orientation of the sides to each other, as in the definition of p4est_connectivity_t
tree_boundaryboolean: interior face (0), tree boundary face (true)
source
P4est.LibP4est.p4est_iter_face_info_tType

The information that is available to the user-defined p4est_iter_face_t callback.

The orientation is 0 if the face is within one tree; otherwise, it is the same as the orientation value between the two trees given in the connectivity. If the face is on the outside boundary of the forest, then there is only one side. If tree_boundary is false, the face is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the face. When tree_boundary is true, its value is P4EST_CONNECT_FACE.

source
P4est.LibP4est.p4est_iter_face_sideType
p4est_iter_face_side

Information about one side of a face in the forest.

If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If the face is hanging, then the quadrants are listed in z-order. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

FieldNote
treeidthe tree on this side
facewhich quadrant side the face touches
is_hangingboolean: one full quad (0) or two smaller quads (1)
source
P4est.LibP4est.p4est_iter_face_side_tType

Information about one side of a face in the forest.

If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If the face is hanging, then the quadrants are listed in z-order. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

source
P4est.LibP4est.p4est_iter_face_tType

The prototype for a function that p4est_iterate will execute wherever two quadrants share a face: the face can be a 2:1 hanging face, it does not have to be conformal.

Note

the forest must be face balanced for p4est_iterate() to execute a callback function on faces (see p4est_balance()).

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p4est_iterate()
source
P4est.LibP4est.p4est_iter_volume_infoType
p4est_iter_volume_info

The information that is available to the user-defined p4est_iter_volume_t callback function.

treeid gives the index in p4est->trees of the tree to which quad belongs. quadid gives the index of quad within tree's quadrants array.

FieldNote
quadthe quadrant of the callback
quadidid in quad's tree array (see p4est_tree_t)
treeidthe tree containing quad
source
P4est.LibP4est.p4est_lnodes_bufferType
p4est_lnodes_buffer

p4est_lnodes_buffer_t handles the communication of data associated with nodes.

send_buffers is an array of arrays: one buffer for each process to which the current process sends node-data. It should not be altered between a shared__begin and a shared__end call.

recv_buffers is an array of arrays that is used in lnodes_share_all_. *recv_buffers[j] corresponds with lnodes->sharers[j]: it is the same length as lnodes->sharers[j]->sharednodes. At the completion of lnodes\share_all or lnodes_share_all_end, recv_buffers[j] contains the node-data from the process lnodes->sharers[j]->rank (unless j is the current rank, in which case recv_buffers[j] is empty).

source
P4est.LibP4est.p4est_lnodes_buffer_tType

p4est_lnodes_buffer_t handles the communication of data associated with nodes.

send_buffers is an array of arrays: one buffer for each process to which the current process sends node-data. It should not be altered between a shared__begin and a shared__end call.

recv_buffers is an array of arrays that is used in lnodes_share_all_. *recv_buffers[j] corresponds with lnodes->sharers[j]: it is the same length as lnodes->sharers[j]->sharednodes. At the completion of lnodes\share_all or lnodes_share_all_end, recv_buffers[j] contains the node-data from the process lnodes->sharers[j]->rank (unless j is the current rank, in which case recv_buffers[j] is empty).

source
P4est.LibP4est.p4est_lnodes_rankType
p4est_lnodes_rank

The structure stored in the sharers array.

shared_nodes is a sorted array of p4est_locidx_t that indexes into local nodes. The shared_nodes array has a contiguous (or empty) section of nodes owned by the current rank. shared_mine_offset and shared_mine_count identify this section by indexing the shared_nodes array, not the local nodes array. owned_offset and owned_count define the section of local nodes that is owned by the listed rank (the section may be empty). For the current process these coincide with those in p4est_lnodes_t.

source
P4est.LibP4est.p4est_lnodes_rank_tType

The structure stored in the sharers array.

shared_nodes is a sorted array of p4est_locidx_t that indexes into local nodes. The shared_nodes array has a contiguous (or empty) section of nodes owned by the current rank. shared_mine_offset and shared_mine_count identify this section by indexing the shared_nodes array, not the local nodes array. owned_offset and owned_count define the section of local nodes that is owned by the listed rank (the section may be empty). For the current process these coincide with those in p4est_lnodes_t.

source
P4est.LibP4est.p4est_lnodes_tType

Store a parallel numbering of Lobatto points of a given degree > 0.

Each element has degree+1 nodes per face and vnodes = (degree+1)^2 nodes per volume. num_local_elements is the number of local quadrants in the p4est. element_nodes is of dimension vnodes * num_local_elements and lists the nodes of each element in lexicographic yx-order (x varies fastest); so for degree == 2, this is the layout of nodes:

f_3 c_2 c_3 6–-7–-8 | | f_0 3 4 5 f_1 | | 0–-1–-2 c_0 c_1 f_2

element_nodes indexes into the set of local nodes, layed out as follows: local nodes = [<––-owned_count––->|<––-nonlocal_nodes––->] = [<––––––––num_local_nodes––––––––->] nonlocal_nodes contains the globally unique numbers for independent nodes that are owned by other processes; for local nodes, the globally unique numbers are given by i + global_offset, where i is the local number. Hanging nodes are always local and don't have a global number. They index the geometrically corresponding independent nodes of a neighbor.

Whether nodes are hanging or not is decided based on the element faces. This information is encoded in face_code with one int8_t per element. If no faces are hanging, the value is zero, otherwise the face_code is interpreted by p4est_lnodes_decode.

Independent nodes can be shared by multiple MPI ranks. The owner rank of a node is the one from the lowest numbered element on the lowest numbered octree touching the node.

What is meant by touching? A quadrant is said to touch all faces/corners that are incident on it, and by extension all nodes that are contained in those faces/corners.

X +–––––-+ o | | o | | +––-+ o | p | | q | o | | | | o | | +––-+ O +–––––-+

In this example degree = 6. There are 5 nodes that live on the face between q and p, and one at each corner of that face. The face is incident on q, so q owns the nodes on the face (provided q is from a lower tree or has a lower index than p). The lower corner is incident on q, so q owns it as well. The upper corner is not incident on q, so q cannot own it.

global_owned_count contains the number of independent nodes owned by each process.

The sharers array contains items of type p4est_lnodes_rank_t that hold the ranks that own or share independent local nodes. If there are no shared nodes on this processor, it is empty. Otherwise, it is sorted by rank and the current process is included.

degree < 0 indicates that the lnodes data structure is being used to number the quadrant boundary object (faces and corners) rather than the $C^0$ Lobatto nodes:

if degree == -1, then one node is assigned per face, and no nodes are assigned per volume or per corner: this numbering can be used for low-order Raviart-Thomas elements. In this case, vnodes == 4, and the nodes are listed in face-order:

f_3 c_2 c_3 +–-3–-+ | | f_0 0 1 f_1 | | +–-2–-+ c_0 c_1 f_2

if degree == -2, then one node is assigned per face and per corner and no nodes are assigned per volume. In this case, vnodes == 8, and the nodes are listed in face-order, followed by corner-order:

f_3 c_2 c_3 6–-3–-7 | | f_0 0 1 f_1 | | 4–-2–-5 c_0 c_1 f_2

source
P4est.LibP4est.p4est_mesh_tType
p4est_mesh_t

This structure contains complete mesh information on a 2:1 balanced forest. It stores the locally relevant neighborhood, that is, all locally owned quadrants and one layer of adjacent ghost quadrants and their owners.

For each local quadrant, its tree number is stored in quad_to_tree. The quad_to_tree array is NULL by default and can be enabled using p4estmeshnewext. For each ghost quadrant, its owner rank is stored in ghost\to_proc. For each level, an array of local quadrant numbers is stored in quad_level. The quad_level array is NULL by default and can be enabled using p4estmeshnew_ext.

The quad_to_quad list stores one value for each local quadrant's face. This value is in 0..local_num_quadrants-1 for local quadrants, or in local_num_quadrants + (0..ghost_num_quadrants-1) for ghost quadrants.

The quad_to_face list has equally many entries that are either: 1. A value of v = 0..7 indicates one same-size neighbor. This value is decoded as v = r * 4 + nf, where nf = 0..3 is the neighbor's connecting face number and r = 0..1 is the relative orientation of the neighbor's face; see p4est_connectivity.h. 2. A value of v = 8..23 indicates a double-size neighbor. This value is decoded as v = 8 + h * 8 + r * 4 + nf, where r and nf are as above and h = 0..1 is the number of the subface. h designates the subface of the large neighbor that the quadrant touches (this is the same as the large neighbor's face corner). 3. A value of v = -8..-1 indicates two half-size neighbors. In this case the corresponding quad_to_quad index points into the quad_to_half array that stores two quadrant numbers per index, and the orientation of the smaller faces follows from 8 + v. The entries of quad_to_half encode between local and ghost quadrant in the same way as the quad_to_quad values described above. The small neighbors in quad_to_half are stored in the sequence of the face corners of this, i.e., the large quadrant.

A quadrant on the boundary of the forest sees itself and its face number.

The quad_to_corner list stores corner neighbors that are not face neighbors. On the inside of a tree, there is precisely one such neighbor per corner. In this case, its index is encoded as described above for quad_to_quad. The neighbor's matching corner number is always diagonally opposite, that is, corner number ^ 3.

On the inside of an inter-tree face, we have precisely one corner neighbor. If a corner is an inter-tree corner, then the number of corner neighbors may be any non-negative number. In both cases, the quad_to_corner value is in local_num_quadrants + local_num_ghosts + [0 .. local_num_corners - 1]. After subtracting the number of local and ghost quadrants, it indexes into corner_offset, which encodes a group of corner neighbors. Each group contains the quadrant numbers encoded as usual for quad_to_quad in corner_quad, and the corner number from the neighbor as corner_corner.

Corners with no diagonal neighbor at all are assigned the value -3. This only happens on the domain boundary, which is necessarily a tree boundary. Corner-neighbors for hanging nodes are assigned the value -1.

TODO: In case of an inter-tree corner neighbor relation in a brick-like situation (exactly one neighbor, diagonally opposite corner number), use the same encoding as for corners within a tree.

FieldNote
quad_to_treetree index for each local quad. Is NULL by default, but may be enabled by p4estmeshnew_ext.
ghost_to_procprocessor for each ghost quad
quad_to_quadone index for each of the 4 faces
quad_to_faceencodes orientation/2:1 status
quad_to_halfstores half-size neighbors
quad_levelStores lists of per-level quads. The array has entries indexed by 0..P4EST_QMAXLEVEL inclusive that are arrays of local quadrant ids. Is NULL by default, but may be enabled by p4estmeshnew_ext.
source
P4est.LibP4est.p4est_quadrantType
p4est_quadrant

The 2D quadrant datatype

FieldNote
xcoordinates
y
levellevel of refinement
pad8padding
pad16
pa union of additional data attached to a quadrant
source
P4est.LibP4est.p4est_refine_tType

Callback function prototype to decide for refinement.

Parameters

  • p4est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrant:[in] the quadrant that may be refined

Returns

nonzero if the quadrant shall be refined.

source
P4est.LibP4est.p4est_replace_tType

Callback function prototype to replace one set of quadrants with another.

This is used by extended routines when the quadrants of an existing, valid p4est are changed. The callback allows the user to make changes to newly initialized quadrants before the quadrants that they replace are destroyed.

If the mesh is being refined, num_outgoing will be 1 and num_incoming will be 4, and vice versa if the mesh is being coarsened.

Parameters

  • num_outgoing:[in] The number of outgoing quadrants.
  • outgoing:[in] The outgoing quadrants: after the callback, the user_data, if p4est->data_size is nonzero, will be destroyed.
  • num_incoming:[in] The number of incoming quadrants.
  • incoming:[in,out] The incoming quadrants: prior to the callback, the user_data, if p4est->datasize is nonzero, is allocated, and the [`p4estinit_t`](@ref) callback, if it has been provided, will be called.
source
P4est.LibP4est.p4est_search_all_tType

Callback function for the top-down search through the whole forest.

Parameters

  • p4est:[in] The forest to search. We recurse through the trees one after another.
  • which_tree:[in] The current tree number.
  • quadrant:[in] The current quadrant in the recursion. This quadrant is either a non-leaf tree branch or a leaf. If the quadrant is contained in the local partition, we know which, otherwise we don't. Let us first consider the situation when quadrant is local, which is indicated by both pfirst and plast being equal to p4est->mpirank. Then the parameter local_num is negative for non-leaves and the number of the quadrant as a leaf in local storage otherwise. Only if the quadrant is a local leaf, it points to the actual local storage and can be used to access user data etc., and the recursion terminates. The other possibility is that pfirst < plast, in which case we proceed with the recursion, or both are equal to the same remote rank, in which case the recursion terminates. Either way, the quadrant is not from local forest storage.
  • pfirst:[in] The lowest processor that owns part of quadrant. Guaranteed to be non-empty.
  • plast:[in] The highest processor that owns part of quadrant. Guaranteed to be non-empty.
  • local_num:[in] If quadrant is a local leaf, this number is the index of the leaf in local quadrant storage. Else, this is a negative value.
  • point:[in,out] User-defined representation of a point. This parameter distinguishes two uses of the callback. For each quadrant, the callback is first called with a NULL point, and if this callback returns true, once for each point tracked in this branch. The return value for a point determines whether it shall be tracked further down the branch or not, and has no effect on a local leaf. The call with a NULL point is intended to prepare quadrant-related search meta data that is common to all points, and/or to efficiently terminate the recursion for all points in the branch in one call.

Returns

If false, the recursion at quadrant terminates. If true, it continues if pfirst < plast or if they are both equal to p4est->mpirank and the recursion has not reached a leaf yet.

source
P4est.LibP4est.p4est_search_local_tType

Callback function to query the match of a "point" with a quadrant.

This function can be called in two roles: Per-quadrant, in which case the parameter point is NULL, or per-point, possibly many times per quadrant.

Parameters

  • p4est:[in] The forest to be queried.
  • which_tree:[in] The tree id under consideration.
  • quadrant:[in] The quadrant under consideration. This quadrant may be coarser than the quadrants that are contained in the forest (an ancestor), in which case it is a temporary variable and not part of the forest storage. Otherwise, it is a leaf and points directly into the forest storage.
  • local_num:[in] If the quadrant is not a leaf, this is < 0. Otherwise it is the (non-negative) index of the quadrant relative to the processor-local storage.
  • point:[in] Representation of a "point"; user-defined. If point is NULL, the callback may be used to prepare quadrant-related search meta data.

Returns

If point is NULL, true if the search confined to quadrant should be executed, false to skip it. Else, true if point may be contained in the quadrant and false otherwise; the return value has no effect on a leaf.

source
P4est.LibP4est.p4est_search_partition_tType

Callback function for the partition recursion.

Parameters

  • p4est:[in] The forest to traverse. Its local quadrants are never accessed.
  • which_tree:[in] The tree number under consideration.
  • quadrant:[in] This quadrant is not from local forest storage, and its user data is undefined. It represents the branch of the forest in the top-down recursion.
  • pfirst:[in] The lowest processor that owns part of quadrant. Guaranteed to be non-empty.
  • plast:[in] The highest processor that owns part of quadrant. Guaranteed to be non-empty. If this is equal to pfirst, then the recursion will stop for quadrant's branch after this function returns.
  • point:[in,out] Pointer to a user-defined point object. If called per-quadrant, this is NULL.

Returns

If false, the recursion at quadrant is terminated. If true, it continues if pfirst < plast.

source
P4est.LibP4est.p4est_treeType
p4est_tree

The p4est tree datatype

FieldNote
quadrantslocally stored quadrants
first_descfirst local descendant
last_desclast local descendant
quadrants_offsetcumulative sum over earlier trees on this processor (locals only)
maxlevelhighest local quadrant level
source
P4est.LibP4est.p4est_weight_tType

Callback function prototype to calculate weights for partitioning.

Note

Global sum of weights must fit into a 64bit integer.

Parameters

  • p4est:[in] the forest
  • which_tree:[in] the tree containing quadrant

Returns

a 32bit integer >= 0 as the quadrant weight.

source
P4est.LibP4est.p6est_coarsen_column_tType

Callback function prototype to decide for horizontal coarsening.

Parameters

  • columns:[in] Pointers to 4 sibling columns.

Returns

nonzero if the columns shall be replaced with their parent.

source
P4est.LibP4est.p6est_coarsen_layer_tType

Callback function prototype to decide for vertical coarsening.

Parameters

  • layers:[in] Pointers to 2 vertical sibling layers.

Returns

nonzero if the layers shall be replaced with their parent.

source
P4est.LibP4est.p6est_connectivityType
p6est_connectivity

This structure holds the 2D+1D inter-tree connectivity information. It is essentially a wrapper of the 2D p4est_connecitivity_t datatype, with some additional information about how the third dimension is embedded.

FieldNote
conn4the 2D connecitvity; owned; vertices interpreted as the vertices of the bottom of the sheet
top_verticesif NULL, uniform vertical profile, otherwise the vertices of the top of the sheet: should be the same size as conn4->treetovertex; owned.
heightif top_vertices == NULL, this gives the offset from the bottom of the sheet to the top
source
P4est.LibP4est.p6est_connectivity_tType

This structure holds the 2D+1D inter-tree connectivity information. It is essentially a wrapper of the 2D p4est_connecitivity_t datatype, with some additional information about how the third dimension is embedded.

source
P4est.LibP4est.p6est_init_tType

Callback function prototype to initialize the layers's user data.

Parameters

  • p6est:[in] the forest
  • which_tree:[in] the tree in the forest
  • column:[in] the column in the tree in the forest
  • layer:[in] the layer in the column in the tree in the forest, whose user_data is to be initialized
source
P4est.LibP4est.p6est_refine_column_tType

Callback function prototype to decide whether to horizontally refine a column, i.e., horizontally refine all of the layers in the column.

Returns

nonzero if the layer shall be refined.

source
P4est.LibP4est.p6est_replace_tType

Callback function prototype to transfer information from outgoing layers to incoming layers.

This is used by extended routines when the layers of an existing, valid p6est are changed. The callback allows the user to make changes to newly initialized layers before the layers that they replace are destroyed.

Parameters

  • num_outcolumns:[in] The number of columns that contain the outgoing layers: will be either 1 or 4.
  • num_outlayers:[in] The number of outgoing layers: will be either 1 (a single layer is being refined), 2 (two layers are being vertically coarsened), or 4 (four layers are being horizontally coarsened).
  • outcolumns:[in] The columns of the outgoing layers
  • outlayers:[in] The outgoing layers: after the callback, the user_data, if p6est->data_size is nonzero, will be destroyed.
  • num_incolumns:[in] The number of columns that contain the outgoing layers: will be either 1 or 4.
  • num_inlayers:[in] The number of incoming layers: will be either 1 (coarsening), 2 (vertical refinement), or 4 (horizontal refinement)
  • incolumns:[in] The columns of the incoming layers
  • inlayers:[in,out] The incoming layers: prior to the callback, the user_data, if p6est->datasize is nonzero, is allocated, and the [`p6estinit_t`](@ref) callback, if it has been provided, will be called.
source
P4est.LibP4est.p6est_weight_tType

Callback function prototype to calculate weights for partitioning.

Note

Global sum of weights must fit into a 64bit integer.

Returns

a 32bit integer >= 0 as the quadrant weight.

source
P4est.LibP4est.p8est_coarsen_tType

Callback function prototype to decide for coarsening.

Parameters

  • p8est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrants:[in] Pointers to 8 siblings in Morton ordering.

Returns

nonzero if the quadrants shall be replaced with their parent.

source
P4est.LibP4est.p8est_connect_type_tType
p8est_connect_type_t

Characterize a type of adjacency.

Several functions involve relationships between neighboring trees and/or quadrants, and their behavior depends on how one defines adjacency: 1) entities are adjacent if they share a face, or 2) entities are adjacent if they share a face or corner, or 3) entities are adjacent if they share a face, corner or edge. p8est_connect_type_t is used to choose the desired behavior. This enum must fit into an int8_t.

source
P4est.LibP4est.p8est_connectivityType
p8est_connectivity

This structure holds the 3D inter-tree connectivity information. Identification of arbitrary faces, edges and corners is possible.

The arrays tree_to_* are stored in z ordering. For corners the order wrt. zyx is 000 001 010 011 100 101 110 111. For faces the order is -x +x -y +y -z +z. They are allocated [0][0]..[0][N-1]..[num_trees-1][0]..[num_trees-1][N-1]. where N is 6 for tree and face, 8 for corner, 12 for edge.

The values for tree_to_face are in 0..23 where ttf % 6 gives the face number and ttf / 6 the face orientation code. The orientation is determined as follows. Let my_face and other_face be the two face numbers of the connecting trees in 0..5. Then the first face corner of the lower of my_face and other_face connects to a face corner numbered 0..3 in the higher of my_face and other_face. The face orientation is defined as this number. If my_face == other_face, treating either of both faces as the lower one leads to the same result.

It is valid to specify num_vertices as 0. In this case vertices and tree_to_vertex are set to NULL. Otherwise the vertex coordinates are stored in the array vertices as [0][0]..[0][2]..[num_vertices-1][0]..[num_vertices-1][2].

The edges are only stored when they connect trees. In this case tree_to_edge indexes into ett_offset. Otherwise the tree_to_edge entry must be -1 and this edge is ignored. If num_edges == 0, tree_to_edge and edge_to_* arrays are set to NULL.

The arrays edge_to_* store a variable number of entries per edge. For edge e these are at position [ett_offset[e]]..[ett_offset[e+1]-1]. Their number for edge e is ett_offset[e+1] - ett_offset[e]. The entries encode all trees adjacent to edge e. The size of the edge_to_* arrays is num_ett = ett_offset[num_edges]. The edge_to_edge array holds values in 0..23, where the lower 12 indicate one edge orientation and the higher 12 the opposite edge orientation.

The corners are only stored when they connect trees. In this case tree_to_corner indexes into ctt_offset. Otherwise the tree_to_corner entry must be -1 and this corner is ignored. If num_corners == 0, tree_to_corner and corner_to_* arrays are set to NULL.

The arrays corner_to_* store a variable number of entries per corner. For corner c these are at position [ctt_offset[c]]..[ctt_offset[c+1]-1]. Their number for corner c is ctt_offset[c+1] - ctt_offset[c]. The entries encode all trees adjacent to corner c. The size of the corner_to_* arrays is num_ctt = ctt_offset[num_corners].

The *_to_attr arrays may have arbitrary contents defined by the user.

FieldNote
num_verticesthe number of vertices that define the embedding of the forest (not the topology)
num_treesthe number of trees
num_edgesthe number of edges that help define the topology
num_cornersthe number of corners that help define the topology
verticesan array of size (3 * num_vertices)
tree_to_vertexembed each tree into c++ R^3 for e.g. visualization (see p8est_vtk.h)
tree_attr_bytesbytes per tree in tree_to_attr
tree_to_attrnot touched by p4est
tree_to_tree(6 * num_trees) neighbors across faces
tree_to_face(6 * num_trees) face to face+orientation (see description)
tree_to_edge(12 * num_trees) or NULL (see description)
ett_offsetedge to offset in edgetotree and edgetoedge
edge_to_treelist of trees that meet at an edge
edge_to_edgelist of tree-edges+orientations that meet at an edge (see description)
tree_to_corner(8 * num_trees) or NULL (see description)
ctt_offsetcorner to offset in cornertotree and cornertocorner
corner_to_treelist of trees that meet at a corner
corner_to_cornerlist of tree-corners that meet at a corner
source
P4est.LibP4est.p8est_connectivity_tType

This structure holds the 3D inter-tree connectivity information. Identification of arbitrary faces, edges and corners is possible.

The arrays tree_to_* are stored in z ordering. For corners the order wrt. zyx is 000 001 010 011 100 101 110 111. For faces the order is -x +x -y +y -z +z. They are allocated [0][0]..[0][N-1]..[num_trees-1][0]..[num_trees-1][N-1]. where N is 6 for tree and face, 8 for corner, 12 for edge.

The values for tree_to_face are in 0..23 where ttf % 6 gives the face number and ttf / 6 the face orientation code. The orientation is determined as follows. Let my_face and other_face be the two face numbers of the connecting trees in 0..5. Then the first face corner of the lower of my_face and other_face connects to a face corner numbered 0..3 in the higher of my_face and other_face. The face orientation is defined as this number. If my_face == other_face, treating either of both faces as the lower one leads to the same result.

It is valid to specify num_vertices as 0. In this case vertices and tree_to_vertex are set to NULL. Otherwise the vertex coordinates are stored in the array vertices as [0][0]..[0][2]..[num_vertices-1][0]..[num_vertices-1][2].

The edges are only stored when they connect trees. In this case tree_to_edge indexes into ett_offset. Otherwise the tree_to_edge entry must be -1 and this edge is ignored. If num_edges == 0, tree_to_edge and edge_to_* arrays are set to NULL.

The arrays edge_to_* store a variable number of entries per edge. For edge e these are at position [ett_offset[e]]..[ett_offset[e+1]-1]. Their number for edge e is ett_offset[e+1] - ett_offset[e]. The entries encode all trees adjacent to edge e. The size of the edge_to_* arrays is num_ett = ett_offset[num_edges]. The edge_to_edge array holds values in 0..23, where the lower 12 indicate one edge orientation and the higher 12 the opposite edge orientation.

The corners are only stored when they connect trees. In this case tree_to_corner indexes into ctt_offset. Otherwise the tree_to_corner entry must be -1 and this corner is ignored. If num_corners == 0, tree_to_corner and corner_to_* arrays are set to NULL.

The arrays corner_to_* store a variable number of entries per corner. For corner c these are at position [ctt_offset[c]]..[ctt_offset[c+1]-1]. Their number for corner c is ctt_offset[c+1] - ctt_offset[c]. The entries encode all trees adjacent to corner c. The size of the corner_to_* arrays is num_ctt = ctt_offset[num_corners].

The *_to_attr arrays may have arbitrary contents defined by the user.

source
P4est.LibP4est.p8est_ghost_tType
p8est_ghost_t

quadrants that neighbor the local domain

FieldNote
btypewhich neighbors are in the ghost layer
ghostsarray of p8est_quadrant_t type
tree_offsetsnum_trees + 1 ghost indices
proc_offsetsmpisize + 1 ghost indices
mirrorsarray of p8est_quadrant_t type
mirror_tree_offsetsnum_trees + 1 mirror indices
mirror_proc_mirrorsindices into mirrors grouped by outside processor rank and ascending within each rank
mirror_proc_offsetsmpisize + 1 indices into mirror_proc_mirrors
mirror_proc_frontslike mirror_proc_mirrors, but limited to the outermost octants. This is NULL until p8est_ghost_expand is called
mirror_proc_front_offsetsNULL until p8est_ghost_expand is called
source
P4est.LibP4est.p8est_init_tType

Callback function prototype to initialize the quadrant's user data.

Parameters

  • p8est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrant:[in,out] the quadrant to be initialized: if data_size > 0, the data to be initialized is at quadrant->p.userdata; otherwise, the non-pointer user data (such as quadrant->p.userint) can be initialized
source
P4est.LibP4est.p8est_inspectType
p8est_inspect
FieldNote
use_balance_rangesUse sc_ranges to determine the asymmetric communication pattern. If usebalanceranges is false (the default), sc_notify is used.
use_balance_ranges_notifyIf true, call both sc_ranges and sc_notify and verify consistency. Which is actually used is still determined by usebalanceranges.
use_balance_verifyVerify sc_ranges and/or sc_notify as applicable.
balance_max_rangesIf positive and smaller than p8est_num ranges, overrides it
balance_rangestime spent in sc_ranges
balance_notifytime spent in sc_notify
balance_notify_allgathertime spent in sc_notify_allgather
source
P4est.LibP4est.p8est_inspect_tType

Data pertaining to selecting, inspecting, and profiling algorithms. A pointer to this structure is hooked into the p8est main structure. Declared in p8est_extended.h. Used to profile important algorithms.

source
P4est.LibP4est.p8est_iter_corner_infoType
p8est_iter_corner_info

The information that is availalbe to the user-defined p8est_iter_corner_t callback.

If tree_boundary is false, the corner is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the corner. When tree_boundary is true, its value is P8EST_CONNECT_FACE/EDGE/CORNER depending on the location of the corner relative to the tree.

FieldNote
tree_boundaryboolean: interior face (0), tree boundary face (true)
sidesarray of p8est_iter_corner_side_t type
source
P4est.LibP4est.p8est_iter_corner_info_tType

The information that is availalbe to the user-defined p8est_iter_corner_t callback.

If tree_boundary is false, the corner is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the corner. When tree_boundary is true, its value is P8EST_CONNECT_FACE/EDGE/CORNER depending on the location of the corner relative to the tree.

source
P4est.LibP4est.p8est_iter_corner_sideType
p8est_iter_corner_side
FieldNote
treeidthe tree that contains quad
cornerwhich of the quadrant's corners touches this corner
is_ghostboolean: local (0) or ghost (1)
quadidthe index in the tree or ghost array
facesinternal work data
edges
source
P4est.LibP4est.p8est_iter_corner_tType

The prototype for a function that p8est_iterate will execute wherever the corner is a corner for all quadrants that touch it

i.e. the callback will not execute on a corner that sits on a hanging face or edge.

Note

the forest does not need to be corner balanced for p8est_iterate() to execute a callback function at corners, only face and edge balanced.

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p8est_iterate()
source
P4est.LibP4est.p8est_iter_edge_infoType
p8est_iter_edge_info

The information about all sides of an edge in the forest. If tree_boundary is false, the edge is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the edge. When tree_boundary is true, its value is P8EST_CONNECT_FACE/EDGE depending on the location of the edge relative to the tree.

FieldNote
tree_boundaryboolean: interior face (0), tree boundary face (true)
sidesarray of p8est_iter_edge_side_t type
source
P4est.LibP4est.p8est_iter_edge_info_tType

The information about all sides of an edge in the forest. If tree_boundary is false, the edge is on the interior of a tree. When tree_boundary is false, sides[0] contains the lowest z-order quadrant that touches the edge. When tree_boundary is true, its value is P8EST_CONNECT_FACE/EDGE depending on the location of the edge relative to the tree.

source
P4est.LibP4est.p8est_iter_edge_sideType
p8est_iter_edge_side
FieldNote
treeidthe tree on this side
edgewhich quadrant side the edge touches
orientationthe orientation of each quadrant relative to this edge, as in the definition of p8est_connectivity_t
is_hangingboolean: one full quad (0) or two smaller quads (1)
source
P4est.LibP4est.p8est_iter_edge_tType

The prototype for a function that p8est_iterate will execute wherever the edge is an edge of all quadrants that touch it i.e. the callback will not execute on an edge the sits on a hanging face.

Note

the forest must be edge balanced for p8est_iterate() to execute a callback function on edges.

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p8est_iterate()
source
P4est.LibP4est.p8est_iter_face_infoType
p8est_iter_face_info

The information that is available to the user-defined p8est_iter_face_t callback.

The orientation is 0 if the face is within one tree; otherwise, it is the same as the orientation value between the two trees given in the connectivity. If the face is on the outside of the forest, then there is only one side. If tree_boundary is false, the face is on the interior of a tree. When tree_boundary false, sides[0] contains the lowest z-order quadrant that touches the face. When tree_boundary is true, its value is P8EST_CONNECT_FACE.

FieldNote
orientationthe orientation of the sides to each other, as in the definition of p8est_connectivity_t
tree_boundaryboolean: interior face (0), tree boundary face (true)
source
P4est.LibP4est.p8est_iter_face_info_tType

The information that is available to the user-defined p8est_iter_face_t callback.

The orientation is 0 if the face is within one tree; otherwise, it is the same as the orientation value between the two trees given in the connectivity. If the face is on the outside of the forest, then there is only one side. If tree_boundary is false, the face is on the interior of a tree. When tree_boundary false, sides[0] contains the lowest z-order quadrant that touches the face. When tree_boundary is true, its value is P8EST_CONNECT_FACE.

source
P4est.LibP4est.p8est_iter_face_sideType
p8est_iter_face_side

Information about one side of a face in the forest. If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If the face is hanging, then the quadrants are listed in z-order. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

FieldNote
treeidthe tree on this side
facewhich quadrant side the face touches
is_hangingboolean: one full quad (0) or four smaller quads (1)
source
P4est.LibP4est.p8est_iter_face_side_tType

Information about one side of a face in the forest. If a quad is local (is_ghost is false), then its quadid indexes the tree's quadrant array; otherwise, it indexes the ghosts array. If the face is hanging, then the quadrants are listed in z-order. If a quadrant should be present, but it is not included in the ghost layer, then quad = NULL, is_ghost is true, and quadid = -1.

source
P4est.LibP4est.p8est_iter_face_tType

The prototype for a function that p8est_iterate() will execute wherever two quadrants share a face: the face can be a 2:1 hanging face, it does not have to be conformal.

Note

the forest must be face balanced for p8est_iterate() to execute a callback function on faces (see p8est_balance()).

Parameters

  • info:[in] information about a quadrant provided to the user
  • user_data:[in,out] the user context passed to p8est_iterate()
source
P4est.LibP4est.p8est_iter_volume_infoType
p8est_iter_volume_info

The information that is available to the user-defined p8est_iter_volume_t callback function.

treeid gives the index in p4est->trees of the tree to which quad belongs. quadid gives the index of quad within tree's quadrants array.

FieldNote
quadthe quadrant of the callback
quadidid in quad's tree array (see p8est_tree_t)
treeidthe tree containing quad
source
P4est.LibP4est.p8est_lid_tType

A datatype to handle the linear id in 3D. We use the implementation of unsigned 128 bit integer in libsc, i.e., a struct with the members high_bits and low_bits (both uint64_t).

source
P4est.LibP4est.p8est_lnodes_bufferType
p8est_lnodes_buffer

p8est_lnodes_buffer_t handles the communication of data associated with nodes.

send_buffers is an array of arrays: one buffer for each process to which the current process sends node-data. It should not be altered between a shared__begin and a shared__end call.

recv_buffers is an array of arrays that is used in lnodes_share_all_. *recv_buffers[j] corresponds with lnodes->sharers[j]: it is the same length as lnodes->sharers[j]->sharednodes. At the completion of lnodes\share_all or lnodes_share_all_end, recv_buffers[j] contains the node-data from the process lnodes->sharers[j]->rank (unless j is the current rank, in which case recv_buffers[j] is empty).

source
P4est.LibP4est.p8est_lnodes_buffer_tType

p8est_lnodes_buffer_t handles the communication of data associated with nodes.

send_buffers is an array of arrays: one buffer for each process to which the current process sends node-data. It should not be altered between a shared__begin and a shared__end call.

recv_buffers is an array of arrays that is used in lnodes_share_all_. *recv_buffers[j] corresponds with lnodes->sharers[j]: it is the same length as lnodes->sharers[j]->sharednodes. At the completion of lnodes\share_all or lnodes_share_all_end, recv_buffers[j] contains the node-data from the process lnodes->sharers[j]->rank (unless j is the current rank, in which case recv_buffers[j] is empty).

source
P4est.LibP4est.p8est_lnodes_rankType
p8est_lnodes_rank

The structure stored in the sharers array.

shared_nodes is a sorted array of p4est_locidx_t that indexes into local nodes. The shared_nodes array has a contiguous (or empty) section of nodes owned by the current rank. shared_mine_offset and shared_mine_count identify this section by indexing the shared_nodes array, not the local nodes array. owned_offset and owned_count define the section of local nodes that is owned by the listed rank (the section may be empty). For the current process these coincide with those in p8est_lnodes_t.

source
P4est.LibP4est.p8est_lnodes_rank_tType

The structure stored in the sharers array.

shared_nodes is a sorted array of p4est_locidx_t that indexes into local nodes. The shared_nodes array has a contiguous (or empty) section of nodes owned by the current rank. shared_mine_offset and shared_mine_count identify this section by indexing the shared_nodes array, not the local nodes array. owned_offset and owned_count define the section of local nodes that is owned by the listed rank (the section may be empty). For the current process these coincide with those in p8est_lnodes_t.

source
P4est.LibP4est.p8est_lnodes_tType

Store a parallel numbering of Lobatto points of a given degree > 0.

Each element has degree+1 nodes per edge and vnodes = (degree+1)^3 nodes per volume. element_nodes is of dimension vnodes * num_local_elements and lists the nodes of each element in lexicographic yx-order (x varies fastest); element_nodes indexes into the set of local nodes, layed out as follows: local nodes = [<––-owned_count––->|<––-nonlocal_nodes––->] = [<––––––––num_local_nodes––––––––->] nonlocal_nodes contains the globally unique numbers for independent nodes that are owned by other processes; for local nodes, the globally unique numbers are given by i + global_offset, where i is the local number. Hanging nodes are always local and don't have a global number. They index the geometrically corresponding independent nodes of a neighbor.

Whether nodes are hanging or not is decided based on the element faces and edges. This information is encoded in face_code with one int16_t per element. If no faces or edges are hanging, the value is zero, otherwise the face_code is interpreted by p8est_lnodes_decode.

Independent nodes can be shared by multiple MPI ranks. The owner rank of a node is the one from the lowest numbered element on the lowest numbered octree touching the node.

What is meant by touching? A quadrant is said to touch all faces/edges/corners that are incident on it, and by extension all nodes that are contained in those faces/edges/corners.

X +–––––-+ x |\ \ x | \ \ . x | \ \ x X | +–––––-+ +––-+ . . | | | |\ \ X o + | | | +––-+ o . \ | p | + | q | o \ | | \| | o \| | +––-+ O +–––––-+

In this example degree = 3. There are 4 nodes that live on the face between q and p, two on each edge and one at each corner of that face. The face is incident on q, so q owns the nodes marked '.' on the face (provided q is from a lower tree or has a lower index than p). The bottom and front edges are incident on q, so q owns its nodes marked 'o' as well. The front lower corner is incident on q, so q owns its node 'O' as well. The other edges and corners are not incident on q, so q cannot own their nodes, marked 'x' and 'X'.

global_owned_count contains the number of independent nodes owned by each process.

The sharers array contains items of type p8est_lnodes_rank_t that hold the ranks that own or share independent local nodes. If there are no shared nodes on this processor, it is empty. Otherwise, it is sorted by rank and the current process is included.

degree < 0 indicates that the lnodes data structure is being used to number the quadrant boundary object (faces, edge and corners) rather than the $C^0$ Lobatto nodes:

if degree == -1, then one node is assigned per face, and no nodes are assigned per volume, per edge, or per corner: this numbering can be used for low-order Raviart-Thomas elements. In this case, vnodes == 6, and the nodes are listed in face-order.

if degree == -2, then one node is assigned per face and per edge and no nodes are assigned per volume or per corner. In this case, vnodes == 18, and the nodes are listed in face-order, followed by edge-order.

if degree == -3, then one node is assigned per face, per edge and per corner and no nodes are assigned per volume. In this case, vnodes == 26, and the nodes are listed in face-order, followed by edge-order, followed by corner-order.

source
P4est.LibP4est.p8est_mesh_tType
p8est_mesh_t

This structure contains complete mesh information on a 2:1 balanced forest. It stores the locally relevant neighborhood, that is, all locally owned quadrants and one layer of adjacent ghost quadrants and their owners.

For each local quadrant, its tree number is stored in quad_to_tree. The quad_to_tree array is NULL by default and can be enabled using p8estmeshnewext. For each ghost quadrant, its owner rank is stored in ghost\to_proc. For each level, an array of local quadrant numbers is stored in quad_level. The quad_level array is NULL by default and can be enabled using p8estmeshnew_ext.

The quad_to_quad list stores one value for each local quadrant's face. This value is in 0..local_num_quadrants-1 for local quadrants, or in local_num_quadrants + (0..ghost_num_quadrants-1) for ghost quadrants.

The quad_to_face list has equally many entries that are either: 1. A value of v = 0..23 indicates one same-size neighbor. This value is decoded as v = r * 6 + nf, where nf = 0..5 is the neighbor's connecting face number and r = 0..3 is the relative orientation of the neighbor's face; see p8est_connectivity.h. 2. A value of v = 24..119 indicates a double-size neighbor. This value is decoded as v = 24 + h * 24 + r * 6 + nf, where r and nf are as above and h = 0..3 is the number of the subface. h designates the subface of the large neighbor that the quadrant touches (this is the same as the large neighbor's face corner). 3. A value of v = -24..-1 indicates four half-size neighbors. In this case the corresponding quad_to_quad index points into the quad_to_half array that stores four quadrant numbers per index, and the orientation of the smaller faces follows from 24 + v. The entries of quad_to_half encode between local and ghost quadrant in the same way as the quad_to_quad values described above. The small neighbors in quad_to_half are stored in the sequence of the face corners of this, i.e., the large quadrant.

A quadrant on the boundary of the forest sees itself and its face number.

The quad_to_edge list stores edge neighbors that are not face neighbors. On the inside of a tree, there are one or two of those depending on size. Between trees, there can be any number of same- or different-sized neighbors. For same-tree same-size neighbors, we record their number in quad_to_edge by the same convention as described for quad_to_quad above. In this case, the neighbor's matching edge number is always diagonally opposite, that is, edge number ^ 3.

For half- and double-size and all inter-tree edge neighbors, the quad_to_edge value is in local_num_quadrants + local_num_ghosts + [0 .. local_num_edges - 1]. After subtracting the number of local and ghost quadrants, it indexes into edge_offset, which encodes a group of edge neighbors. Each member of a group may be one same/double-size quadrant or two half-size quadrants; this is determined by the value of the edge_edge field as follows. 1. A value of e = 0..23 indicates one same-size neighbor. This value is encoded as e = r * 12 + ne, where ne = 0..11 is the neighbor's connecting edge number and r = 0..1 indicates an edge flip. 2. A value of e = 24..71 indicates a double-size neighbor. This value is decoded as e = 24 + h * 24 + r * 12 + ne, where r and ne are as above and h = 0..1 is the number of the subedge. h designates the subedge of the large neighbor that the quadrant touches (this is the same as the large neighbor's edge corner). 3. A value of e = -24..-1 indicates two half-size neighbors. They are represented by two consecutive entries of the edge_quad and edge_edge arrays with identical values for edge_edge. The orientation of the smaller edges follows from 24 + e. The small neighbors in edge_quad are stored in the sequence of the edge corners of this, i.e., the large quadrant.

Edges with no diagonal neighbor at all are assigned the value -3. This only happens on the domain boundary, which is necessarily a tree boundary. Edge neighbors for face-hanging nodes are assigned the value -1.

The quad_to_corner list stores corner neighbors that are not face or edge neighbors. On the inside of a tree, there is precisely one such neighbor per corner. In this case, its index is encoded as described above for quad_to_quad. The neighbor's matching corner number is always diagonally opposite, that is, corner number ^ 7.

On the inside of an inter-tree face, we have precisely one corner neighbor. If a corner is across an inter-tree edge or corner, then the number of corner neighbors may be any non-negative number. In all three cases, the quad_to_corner value is in local_num_quadrants + local_num_ghosts + [0 .. local_num_corners - 1]. After subtracting the number of local and ghost quadrants, it indexes into corner_offset, which encodes a group of corner neighbors. Each group contains the quadrant numbers encoded as usual for quad_to_quad in corner_quad, and the corner number from the neighbor as corner_corner.

Corners with no diagonal neighbor at all are assigned the value -3. This only happens on the domain boundary, which is necessarily a tree boundary. Corner-neighbors for face- and edge-hanging nodes are assigned the value -1.

TODO: In case of an inter-tree neighbor relation in a brick-like situation (one same-size neighbor, diagonally opposite edge/corner), use the same encoding as for edges/corners within a tree.

FieldNote
quad_to_treetree index for each local quad. Is NULL by default, but may be enabled by p8estmeshnew_ext.
ghost_to_procprocessor for each ghost quad
quad_to_quadone index for each of the 6 faces
quad_to_faceencodes orientation/2:1 status
quad_to_halfstores half-size neighbors
quad_levelStores lists of per-level quads. The array has entries indexed by 0..P4EST_QMAXLEVEL inclusive that are arrays of local quadrant ids. Is NULL by default, but may be enabled by p8estmeshnew_ext.
local_num_edgesunsame-size and tree-boundary edges
quad_to_edge12 indices for each local quad
edge_offsetlocal_num_edges + 1 entries
edge_quadedge_offset indexes into this
edge_edgeand this one too (type int8_t)
source
P4est.LibP4est.p8est_quadrantType
p8est_quadrant

The 3D quadrant (i.e., octant) datatype

FieldNote
xcoordinates
y
z
levellevel of refinement
pad8padding
pad16
pa union of additional data attached to a quadrant
source
P4est.LibP4est.p8est_refine_tType

Callback function prototype to decide for refinement.

Parameters

  • p8est:[in] the forest
  • which_tree:[in] the tree containing quadrant
  • quadrant:[in] the quadrant that may be refined

Returns

nonzero if the quadrant shall be refined.

source
P4est.LibP4est.p8est_replace_tType

Callback function prototype to replace one set of quadrants with another.

This is used by extended routines when the quadrants of an existing, valid p8est are changed. The callback allows the user to make changes to newly initialized quadrants before the quadrants that they replace are destroyed.

If the mesh is being refined, num_outgoing will be 1 and num_incoming will be 8, and vice versa if the mesh is being coarsened.

Parameters

  • num_outgoing:[in] The number of outgoing quadrants.
  • outgoing:[in] The outgoing quadrants: after the callback, the user_data, if p8est->data_size is nonzero, will be destroyed.
  • num_incoming:[in] The number of incoming quadrants.
  • incoming:[in,out] The incoming quadrants: prior to the callback, the user_data, if p8est->datasize is nonzero, is allocated, and the [`p8estinit_t`](@ref) callback, if it has been provided, will be called.
source
P4est.LibP4est.p8est_search_all_tType

Callback function for the top-down search through the whole forest.

Parameters

  • p4est:[in] The forest to search. We recurse through the trees one after another.
  • which_tree:[in] The current tree number.
  • quadrant:[in] The current quadrant in the recursion. This quadrant is either a non-leaf tree branch or a leaf. If the quadrant is contained in the local partition, we know which, otherwise we don't. Let us first consider the situation when quadrant is local, which is indicated by both pfirst and plast being equal to p4est->mpirank. Then the parameter local_num is negative for non-leaves and the number of the quadrant as a leaf in local storage otherwise. Only if the quadrant is a local leaf, it points to the actual local storage and can be used to access user data etc., and the recursion terminates. The other possibility is that pfirst < plast, in which case we proceed with the recursion, or both are equal to the same remote rank, in which case the recursion terminates. Either way, the quadrant is not from local forest storage.
  • pfirst:[in] The lowest processor that owns part of quadrant. Guaranteed to be non-empty.
  • plast:[in] The highest processor that owns part of quadrant. Guaranteed to be non-empty.
  • local_num:[in] If quadrant is a local leaf, this number is the index of the leaf in local quadrant storage. Else, this is a negative value.
  • point:[in,out] User-defined representation of a point. This parameter distinguishes two uses of the callback. For each quadrant, the callback is first called with a NULL point, and if this callback returns true, once for each point tracked in this branch. The return value for a point determines whether it shall be tracked further down the branch or not, and has no effect on a local leaf. The call with a NULL point is intended to prepare quadrant-related search meta data that is common to all points, and/or to efficiently terminate the recursion for all points in the branch in one call.

Returns

If false, the recursion at quadrant terminates. If true, it continues if pfirst < plast or if they are both equal to p4est->mpirank and the recursion has not reached a leaf yet.

source
P4est.LibP4est.p8est_search_local_tType

Callback function to query the match of a "point" with a quadrant.

This function can be called in two roles: Per-quadrant, in which case the parameter point is NULL, or per-point, possibly many times per quadrant.

Parameters

  • p4est:[in] The forest to be queried.
  • which_tree:[in] The tree id under consideration.
  • quadrant:[in] The quadrant under consideration. This quadrant may be coarser than the quadrants that are contained in the forest (an ancestor), in which case it is a temporary variable and not part of the forest storage. Otherwise, it is a leaf and points directly into the forest storage.
  • local_num:[in] If the quadrant is not a leaf, this is < 0. Otherwise it is the (non-negative) index of the quadrant relative to the processor-local storage.
  • point:[in] Representation of a "point"; user-defined. If point is NULL, the callback may be used to prepare quadrant-related search meta data.

Returns

If point is NULL, true if the search confined to quadrant should be executed, false to skip it. Else, true if point may be contained in the quadrant and false otherwise; the return value has no effect on a leaf.

source
P4est.LibP4est.p8est_search_partition_tType

Callback function for the partition recursion.

Parameters

  • p4est:[in] The forest to traverse. Its local quadrants are never accessed.
  • which_tree:[in] The tree number under consideration.
  • quadrant:[in] This quadrant is not from local forest storage, and its user data is undefined. It represents the branch of the forest in the top-down recursion.
  • pfirst:[in] The lowest processor that owns part of quadrant. Guaranteed to be non-empty.
  • plast:[in] The highest processor that owns part of quadrant. Guaranteed to be non-empty. If this is equal to pfirst, then the recursion will stop for quadrant's branch after this function returns.
  • point:[in,out] Pointer to a user-defined point object. If called per-quadrant, this is NULL.

Returns

If false, the recursion at quadrant is terminated. If true, it continues if pfirst < plast.

source
P4est.LibP4est.p8est_treeType
p8est_tree

The p8est tree datatype

FieldNote
quadrantslocally stored quadrants
first_descfirst local descendant
last_desclast local descendant
quadrants_offsetcumulative sum over earlier trees on this processor (locals only)
maxlevelhighest local quadrant level
source
P4est.LibP4est.p8est_weight_tType

Callback function prototype to calculate weights for partitioning.

Note

Global sum of weights must fit into a 64bit integer.

Parameters

  • p8est:[in] the forest
  • which_tree:[in] the tree containing quadrant

Returns

a 32bit integer >= 0 as the quadrant weight.

source
P4est.LibP4est.sc_arrayType
sc_array

The sc_array object provides a dynamic array of equal-size elements. Elements are accessed by their 0-based index. Their address may change. The number of elements (== elem_count) of the array can be changed by scarrayresize and scarrayrewind. Elements can be sorted with scarraysort. If the array is sorted, it can be searched with scarraybsearch. A priority queue is implemented with pqueue_add and pqueue_pop (untested).

FieldNote
elem_sizesize of a single element
elem_countnumber of valid elements
byte_allocnumber of allocated bytes or -(number of viewed bytes + 1) if this is a view: the "+ 1" distinguishes an array of size 0 from a view of size 0
arraylinear array to store elements
source
P4est.LibP4est.sc_array_tType

The sc_array object provides a dynamic array of equal-size elements. Elements are accessed by their 0-based index. Their address may change. The number of elements (== elem_count) of the array can be changed by scarrayresize and scarrayrewind. Elements can be sorted with scarraysort. If the array is sorted, it can be searched with scarraybsearch. A priority queue is implemented with pqueue_add and pqueue_pop (untested).

source
P4est.LibP4est.sc_array_type_tType

Function to determine the enumerable type of an object in an array.

Parameters

  • array:[in] Array containing the object.
  • index:[in] The location of the object.
  • data:[in] Arbitrary user data.
source
P4est.LibP4est.sc_hashType
sc_hash

The sc_hash implements a hash table. It uses an array which has linked lists as elements.

FieldNote
elem_counttotal number of objects contained
slotsthe slot count is slots->elem_count
user_datauser data passed to hash function
allocatormust allocate sc_link_t
source
P4est.LibP4est.sc_hash_foreach_tType

Function to call on every data item of a hash table.

Parameters

  • v:[in] The address of the pointer to the current object.
  • u:[in] Arbitrary user data.

Returns

Return true if the traversal should continue, false to stop.

source
P4est.LibP4est.sc_io_error_tType
sc_io_error_t

Error values for io.

EnumeratorNote
SC_IO_ERROR_NONEThe value of zero means no error.
SC_IO_ERROR_FATALThe io object is now disfunctional.
SC_IO_ERROR_AGAINAnother io operation may resolve it. The function just returned was a noop.
source
P4est.LibP4est.sc_io_mode_tType
sc_io_mode_t
EnumeratorNote
SC_IO_MODE_WRITESemantics as "w" in fopen.
SC_IO_MODE_APPENDSemantics as "a" in fopen.
SC_IO_MODE_LASTInvalid entry to close list
source
P4est.LibP4est.sc_mempoolType
sc_mempool

The sc_mempool object provides a large pool of equal-size elements. The pool grows dynamically for element allocation. Elements are referenced by their address which never changes. Elements can be freed (that is, returned to the pool) and are transparently reused. If the zero_and_persist option is selected, new elements are initialized to all zeros on creation, and the contents of an element are not touched between freeing and re-returning it.

FieldNote
elem_sizesize of a single element
elem_countnumber of valid elements
zero_and_persistBoolean; is set in constructor.
mstampfixed-size chunk allocator
freedbuffers the freed elements
source
P4est.LibP4est.sc_mempool_tType

The sc_mempool object provides a large pool of equal-size elements. The pool grows dynamically for element allocation. Elements are referenced by their address which never changes. Elements can be freed (that is, returned to the pool) and are transparently reused. If the zero_and_persist option is selected, new elements are initialized to all zeros on creation, and the contents of an element are not touched between freeing and re-returning it.

source
P4est.LibP4est.sc_mstampType
sc_mstamp

A data container to create memory items of the same size. Allocations are bundled so it's fast for small memory sizes. The items created will remain valid until the container is destroyed. There is no option to return an item to the container. See scmempoolt for that purpose.

FieldNote
elem_sizeInput parameter: size per item
per_stampNumber of items per stamp
stamp_sizeBytes allocated in a stamp
cur_snextNext number within a stamp
currentMemory of current stamp
rememberCollects all stamps
source
P4est.LibP4est.sc_mstamp_tType

A data container to create memory items of the same size. Allocations are bundled so it's fast for small memory sizes. The items created will remain valid until the container is destroyed. There is no option to return an item to the container. See scmempoolt for that purpose.

source
P4est.LibP4est.sc_uint128Type
sc_uint128

An unsigned 128 bit integer represented as two uint64_t.

FieldNote
high_bitsThe more significant 64 bits.
low_bitsThe less significant 64 bits.
source
P4est.LibP4est.p4est_balanceMethod
p4est_balance(p4est_, btype, init_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p4est:[in,out] The p4est to be worked on.
  • btype:[in] Balance type (face or corner/full). Corner balance is almost never required when discretizing a PDE; just causes smoother mesh grading.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p4est_balance (p4est_t * p4est, p4est_connect_type_t btype, p4est_init_t init_fn);
source
P4est.LibP4est.p4est_balance_extMethod
p4est_balance_ext(p4est_, btype, init_fn, replace_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p4est:[in,out] The p4est to be worked on.
  • btype:[in] Balance type (face or corner/full). Corner balance is almost never required when discretizing a PDE; just causes smoother mesh grading.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p4est_balance_ext (p4est_t * p4est, p4est_connect_type_t btype, p4est_init_t init_fn, p4est_replace_t replace_fn);
source
P4est.LibP4est.p4est_balance_subtree_extMethod
p4est_balance_subtree_ext(p4est_, btype, which_tree, init_fn, replace_fn)

Prototype

void p4est_balance_subtree_ext (p4est_t * p4est, p4est_connect_type_t btype, p4est_topidx_t which_tree, p4est_init_t init_fn, p4est_replace_t replace_fn);
source
P4est.LibP4est.p4est_checksumMethod
p4est_checksum(p4est_)

Compute the checksum for a forest. Based on quadrant arrays only. It is independent of partition and mpisize.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p4est_checksum (p4est_t * p4est);
source
P4est.LibP4est.p4est_checksum_partitionMethod
p4est_checksum_partition(p4est_)

Compute a partition-dependent checksum for a forest.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p4est_checksum_partition (p4est_t * p4est);
source
P4est.LibP4est.p4est_coarsenMethod
p4est_coarsen(p4est_, coarsen_recursive, coarsen_fn, init_fn)

Coarsen a forest.

Parameters

  • p4est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p4est_coarsen (p4est_t * p4est, int coarsen_recursive, p4est_coarsen_t coarsen_fn, p4est_init_t init_fn);
source
P4est.LibP4est.p4est_coarsen_extMethod
p4est_coarsen_ext(p4est_, coarsen_recursive, callback_orphans, coarsen_fn, init_fn, replace_fn)

Coarsen a forest.

Parameters

  • p4est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • callback_orphans:[in] Boolean to enable calling coarsen_fn even on non-families. In this case, the second quadrant pointer in the argument list of the callback is NULL, subsequent pointers are undefined, and the return value is ignored. If coarsen_recursive is true, it is possible that a quadrant is called once or more as an orphan and eventually becomes part of a family. With coarsen_recursive false and callback_orphans true, it is guaranteed that every quadrant is passed exactly once into the coarsen_fn callback.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p4est_coarsen_ext (p4est_t * p4est, int coarsen_recursive, int callback_orphans, p4est_coarsen_t coarsen_fn, p4est_init_t init_fn, p4est_replace_t replace_fn);
source
P4est.LibP4est.p4est_connectivity_completeMethod
p4est_connectivity_complete(conn)

Internally connect a connectivity based on tree_to_vertex information. Periodicity that is not inherent in the list of vertices will be lost.

Parameters

  • conn:[in,out] The connectivity needs to have proper vertices and tree_to_vertex fields. The tree_to_tree and tree_to_face fields must be allocated and satisfy p4est_connectivity_is_valid (conn) but will be overwritten. The corner fields will be freed and allocated anew.

Prototype

void p4est_connectivity_complete (p4est_connectivity_t * conn);
source
P4est.LibP4est.p4est_connectivity_deflateMethod
p4est_connectivity_deflate(conn, code)

Allocate memory and store the connectivity information there.

Parameters

  • conn:[in] The connectivity structure to be exported to memory.
  • code:[in] Encoding and compression method for serialization.

Returns

Newly created array that contains the information.

Prototype

sc_array_t *p4est_connectivity_deflate (p4est_connectivity_t * conn, p4est_connectivity_encode_t code);
source
P4est.LibP4est.p4est_connectivity_destroyMethod
p4est_connectivity_destroy(connectivity)

Destroy a connectivity structure. Also destroy all attributes.

Prototype

void p4est_connectivity_destroy (p4est_connectivity_t * connectivity);
source
P4est.LibP4est.p4est_connectivity_face_neighbor_cornerMethod
p4est_connectivity_face_neighbor_corner(c, f, nf, o)

Transform a corner across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • c:[in] A corner number in 0..3.
  • f:[in] A face number that touches the corner c.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The number of the corner seen from the neighbor tree.

Prototype

int p4est_connectivity_face_neighbor_corner (int c, int f, int nf, int o);
source
P4est.LibP4est.p4est_connectivity_face_neighbor_face_cornerMethod
p4est_connectivity_face_neighbor_face_corner(fc, f, nf, o)

Transform a face corner across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • fc:[in] A face corner number in 0..1.
  • f:[in] A face that the face corner number fc is relative to.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The face corner number relative to the neighbor's face.

Prototype

int p4est_connectivity_face_neighbor_face_corner (int fc, int f, int nf, int o);
source
P4est.LibP4est.p4est_connectivity_inflateMethod
p4est_connectivity_inflate(buffer)

Create new connectivity from a memory buffer.

Parameters

  • buffer:[in] The connectivity is created from this memory buffer.

Returns

The newly created connectivity, or NULL on error.

Prototype

p4est_connectivity_t *p4est_connectivity_inflate (sc_array_t * buffer);
source
P4est.LibP4est.p4est_connectivity_is_equalMethod
p4est_connectivity_is_equal(conn1, conn2)

Check two connectivity structures for equality.

Returns

Returns true if structures are equal, false otherwise.

Prototype

int p4est_connectivity_is_equal (p4est_connectivity_t * conn1, p4est_connectivity_t * conn2);
source
P4est.LibP4est.p4est_connectivity_is_equivalentMethod
p4est_connectivity_is_equivalent(conn1, conn2)

p4est_connectivity_is_equivalent This function compares two connectivities for equivalence: it returns true if they are the same connectivity, or if they have the same topology. The definition of topological sameness is strict: there is no attempt made to determine whether permutation and/or rotation of the trees makes the connectivities equivalent.

Parameters

  • conn1:[in] a valid connectivity
  • conn2:[out] a valid connectivity

Prototype

int p4est_connectivity_is_equivalent (p4est_connectivity_t * conn1, p4est_connectivity_t * conn2);
source
P4est.LibP4est.p4est_connectivity_is_validMethod
p4est_connectivity_is_valid(connectivity)

Examine a connectivity structure.

Returns

Returns true if structure is valid, false otherwise.

Prototype

int p4est_connectivity_is_valid (p4est_connectivity_t * connectivity);
source
P4est.LibP4est.p4est_connectivity_join_facesMethod
p4est_connectivity_join_faces(conn, tree_left, tree_right, face_left, face_right, orientation)

p4est_connectivity_join_faces This function takes an existing valid connectivity conn and modifies it by joining two tree faces that are currently boundary faces.

Parameters

  • conn:[in,out] connectivity that will be altered.
  • tree_left:[in] tree that will be on the left side of the joined faces.
  • tree_right:[in] tree that will be on the right side of the joined faces.
  • face_left:[in] face of tree_left that will be joined.
  • face_right:[in] face of tree_right that will be joined.
  • orientation:[in] the orientation of face_left and face_right once joined (see the description of p4est_connectivity_t to understand orientation).

Prototype

void p4est_connectivity_join_faces (p4est_connectivity_t * conn, p4est_topidx_t tree_left, p4est_topidx_t tree_right, int face_left, int face_right, int orientation);
source
P4est.LibP4est.p4est_connectivity_loadMethod
p4est_connectivity_load(filename, bytes)

Load a connectivity structure from disk.

Parameters

  • filename:[in] Name of the file to read.
  • bytes:[in,out] Size in bytes of connectivity on disk or NULL.

Returns

Returns valid connectivity, or NULL on file error.

Prototype

p4est_connectivity_t *p4est_connectivity_load (const char *filename, size_t *bytes);
source
P4est.LibP4est.p4est_connectivity_memory_usedMethod
p4est_connectivity_memory_used(conn)

Calculate memory usage of a connectivity structure.

Parameters

  • conn:[in] Connectivity structure.

Returns

Memory used in bytes.

Prototype

size_t p4est_connectivity_memory_used (p4est_connectivity_t * conn);
source
P4est.LibP4est.p4est_connectivity_newMethod
p4est_connectivity_new(num_vertices, num_trees, num_corners, num_ctt)

Allocate a connectivity structure. The attribute fields are initialized to NULL.

Parameters

  • num_vertices:[in] Number of total vertices (i.e. geometric points).
  • num_trees:[in] Number of trees in the forest.
  • num_corners:[in] Number of tree-connecting corners.
  • num_ctt:[in] Number of total trees in corner_to_tree array.

Returns

A connectivity structure with allocated arrays.

Prototype

p4est_connectivity_t *p4est_connectivity_new (p4est_topidx_t num_vertices, p4est_topidx_t num_trees, p4est_topidx_t num_corners, p4est_topidx_t num_ctt);
source
P4est.LibP4est.p4est_connectivity_new_brickMethod
p4est_connectivity_new_brick(mi, ni, periodic_a, periodic_b)

A rectangular m by n array of trees with configurable periodicity. The brick is periodic in x and y if periodic_a and periodic_b are true, respectively.

Prototype

p4est_connectivity_t *p4est_connectivity_new_brick (int mi, int ni, int periodic_a, int periodic_b);
source
P4est.LibP4est.p4est_connectivity_new_bynameMethod
p4est_connectivity_new_byname(name)

Create connectivity structure from predefined catalogue.

Parameters

  • name:[in] Invokes connectivity_new_* function. brick23 brick (2, 3, 0, 0) corner corner cubed cubed disk disk moebius moebius periodic periodic pillow pillow rotwrap rotwrap star star unit unitsquare

Returns

An initialized connectivity if name is defined, NULL else.

Prototype

p4est_connectivity_t *p4est_connectivity_new_byname (const char *name);
source
P4est.LibP4est.p4est_connectivity_new_copyMethod
p4est_connectivity_new_copy(num_vertices, num_trees, num_corners, vertices, ttv, ttt, ttf, ttc, coff, ctt, ctc)

Allocate a connectivity structure and populate from constants. The attribute fields are initialized to NULL.

Parameters

  • num_vertices:[in] Number of total vertices (i.e. geometric points).
  • num_trees:[in] Number of trees in the forest.
  • num_corners:[in] Number of tree-connecting corners.
  • coff:[in] Corner-to-tree offsets (num_corners + 1 values). This must always be non-NULL; in trivial cases it is just a pointer to a p4est_topix value of 0.

Returns

The connectivity is checked for validity.

Prototype

p4est_connectivity_t *p4est_connectivity_new_copy (p4est_topidx_t num_vertices, p4est_topidx_t num_trees, p4est_topidx_t num_corners, const double *vertices, const p4est_topidx_t * ttv, const p4est_topidx_t * ttt, const int8_t * ttf, const p4est_topidx_t * ttc, const p4est_topidx_t * coff, const p4est_topidx_t * ctt, const int8_t * ctc);
source
P4est.LibP4est.p4est_connectivity_new_cubedMethod
p4est_connectivity_new_cubed()

Create a connectivity structure for the six sides of a unit cube. The ordering of the trees is as follows: 0 1 2 3 <– 3: axis-aligned top side 4 5. This choice has been made for maximum symmetry (see tree_to_* in .c file).

Prototype

p4est_connectivity_t *p4est_connectivity_new_cubed (void);
source
P4est.LibP4est.p4est_connectivity_new_diskMethod
p4est_connectivity_new_disk(periodic_a, periodic_b)

Create a connectivity structure for a five-tree flat spherical disk. This disk can just as well be used as a square to test non-Cartesian maps. Without any mapping this connectivity covers the square [-3, 3]**2.

Note

The API of this function has changed to accept two arguments. You can query the #define P4EST_CONN_DISK_PERIODIC to check whether the new version with the argument is in effect.

The ordering of the trees is as follows: 4 1 2 3 0.

The outside x faces may be identified topologically. The outside y faces may be identified topologically. Both identifications may be specified simultaneously. The general shape and periodicity are the same as those obtained with p4estconnectivitynewbrick (1, 1, periodic\a, periodic_b).

When setting periodic_a and periodic_b to false, the result is the same as that of p4estconnectivitynewdisknonperiodic.

Parameters

  • periodic_a:[in] Bool to make disk periodic in x direction.
  • periodic_b:[in] Bool to make disk periodic in y direction.

Returns

Initialized and usable connectivity.

Prototype

p4est_connectivity_t *p4est_connectivity_new_disk (int periodic_a, int periodic_b);
source
P4est.LibP4est.p4est_connectivity_new_disk2dMethod
p4est_connectivity_new_disk2d()

Create a connectivity structure that maps a 2d disk.

This is a 5 trees connectivity meant to be used together with p4estgeometrynew_disk2d to map the disk.

Prototype

p4est_connectivity_t *p4est_connectivity_new_disk2d (void);
source
P4est.LibP4est.p4est_connectivity_new_disk_nonperiodicMethod
p4est_connectivity_new_disk_nonperiodic()

Create a connectivity structure for a five-tree flat spherical disk. This disk can just as well be used as a square to test non-Cartesian maps. Without any mapping this connectivity covers the square [-3, 3]**2.

Returns

Initialized and usable connectivity.

Prototype

p4est_connectivity_t *p4est_connectivity_new_disk_nonperiodic (void);
source
P4est.LibP4est.p4est_connectivity_new_icosahedronMethod
p4est_connectivity_new_icosahedron()

Create a connectivity for mapping the sphere using an icosahedron.

The regular icosadron is a polyhedron with 20 faces, each of which is an equilateral triangle. To build the p4est connectivity, we group faces 2 by 2 to from 10 quadrangles, and thus 10 trees.

This connectivity is meant to be used together with p4estgeometrynew_icosahedron to map the sphere.

The flat connectivity looks like that: Vextex numbering:

A00 A01 A02 A03 A04 / \ / \ / \ / \ / \ A05–-A06–-A07–-A08–-A09–-A10 \ / \ / \ / \ / \ / \ A11–-A12–-A13–-A14–-A15–-A16 \ / \ / \ / \ / \ / A17 A18 A19 A20 A21

Origin in A05.

Tree numbering:

0 2 4 6 8 1 3 5 7 9

Prototype

p4est_connectivity_t *p4est_connectivity_new_icosahedron ();
source
P4est.LibP4est.p4est_connectivity_new_rotwrapMethod
p4est_connectivity_new_rotwrap()

Create a connectivity structure for a periodic unit square. The left and right faces are identified, and bottom and top opposite.

Prototype

p4est_connectivity_t *p4est_connectivity_new_rotwrap (void);
source
P4est.LibP4est.p4est_connectivity_new_shell2dMethod
p4est_connectivity_new_shell2d()

Create a connectivity structure that builds a 2d spherical shell. p8estconnectivitynew_shell

Prototype

p4est_connectivity_t *p4est_connectivity_new_shell2d (void);
source
P4est.LibP4est.p4est_connectivity_new_twotreesMethod
p4est_connectivity_new_twotrees(l_face, r_face, orientation)

Create a connectivity structure for two trees being rotated w.r.t. each other in a user-defined way

Parameters

  • l_face:[in] index of left face
  • r_face:[in] index of right face
  • orientation:[in] orientation of trees w.r.t. each other

Prototype

p4est_connectivity_t *p4est_connectivity_new_twotrees (int l_face, int r_face, int orientation);
source
P4est.LibP4est.p4est_connectivity_permuteMethod
p4est_connectivity_permute(conn, perm, is_current_to_new)

p4est_connectivity_permute Given a permutation perm of the trees in a connectivity conn, permute the trees of conn in place and update conn to match.

Parameters

  • conn:[in,out] The connectivity whose trees are permuted.
  • perm:[in] A permutation array, whose elements are size_t's.
  • is_current_to_new:[in] if true, the jth entry of perm is the new index for the entry whose current index is j, otherwise the jth entry of perm is the current index of the tree whose index will be j after the permutation.

Prototype

void p4est_connectivity_permute (p4est_connectivity_t * conn, sc_array_t * perm, int is_current_to_new);
source
P4est.LibP4est.p4est_connectivity_read_inpMethod
p4est_connectivity_read_inp(filename)

Create a p4est connectivity from an ABAQUS input file.

This utility function reads a basic ABAQUS file supporting element type with the prefix C2D4, CPS4, and S4 in 2D and of type C3D8 reading them as bilinear quadrilateral and trilinear hexahedral trees respectively.

A basic 2D mesh is given below. The *Node section gives the vertex number and x, y, and z components for each vertex. The *Element section gives the 4 vertices in 2D (8 vertices in 3D) of each element in counter clockwise order. So in 2D the nodes are given as:

4 3 +–––––––––-+ | | | | | | | | | | | | +–––––––––-+ 1 2

and in 3D they are given as:

8 7 +––––––––––-+ |\ |\ | \ | \ | \ | \ | \ | \ | 5+––––––––––-+6 | | | | +––|––––––––+ | 4\ | 3 \ | \ | \ | \ | \ | \| \| +––––––––––-+ 1 2

 *Heading
   box.inp
  *Node
  1,  -5, -5, 0
@@ -38,7 +38,7 @@
  3,  9, 10, 1,  5
  4,  7,  4, 8, 11
  5, 11, 10, 3,  7
- 6,  2,  6, 9,  5

This function reads a mesh from filename and returns an associated p4est connectivity.

Parameters

  • filename:[in] file to read the connectivity from

Returns

an allocated connectivity associated with the mesh in filename or NULL if an error occurred.

Prototype

p4est_connectivity_t *p4est_connectivity_read_inp (const char *filename);
source
P4est.LibP4est.p4est_connectivity_read_inp_streamMethod
p4est_connectivity_read_inp_stream(stream, num_vertices, num_trees, vertices, tree_to_vertex)

Read an ABAQUS input file from a file stream.

This utility function reads a basic ABAQUS file supporting element type with the prefix C2D4, CPS4, and S4 in 2D and of type C3D8 reading them as bilinear quadrilateral and trilinear hexahedral trees respectively.

A basic 2D mesh is given below. The *Node section gives the vertex number and x, y, and z components for each vertex. The *Element section gives the 4 vertices in 2D (8 vertices in 3D) of each element in counter clockwise order. So in 2D the nodes are given as:

4 3 +–––––––––-+ | | | | | | | | | | | | +–––––––––-+ 1 2

and in 3D they are given as:

8 7 +––––––––––-+ |\ |\ | \ | \ | \ | \ | \ | \ | 5+––––––––––-+6 | | | | +––|––––––––+ | 4\ | 3 \ | \ | \ | \ | \ | \| \| +––––––––––-+ 1 2

 *Heading
+ 6,  2,  6, 9,  5

This function reads a mesh from filename and returns an associated p4est connectivity.

Parameters

  • filename:[in] file to read the connectivity from

Returns

an allocated connectivity associated with the mesh in filename or NULL if an error occurred.

Prototype

p4est_connectivity_t *p4est_connectivity_read_inp (const char *filename);
source
P4est.LibP4est.p4est_connectivity_read_inp_streamMethod
p4est_connectivity_read_inp_stream(stream, num_vertices, num_trees, vertices, tree_to_vertex)

Read an ABAQUS input file from a file stream.

This utility function reads a basic ABAQUS file supporting element type with the prefix C2D4, CPS4, and S4 in 2D and of type C3D8 reading them as bilinear quadrilateral and trilinear hexahedral trees respectively.

A basic 2D mesh is given below. The *Node section gives the vertex number and x, y, and z components for each vertex. The *Element section gives the 4 vertices in 2D (8 vertices in 3D) of each element in counter clockwise order. So in 2D the nodes are given as:

4 3 +–––––––––-+ | | | | | | | | | | | | +–––––––––-+ 1 2

and in 3D they are given as:

8 7 +––––––––––-+ |\ |\ | \ | \ | \ | \ | \ | \ | 5+––––––––––-+6 | | | | +––|––––––––+ | 4\ | 3 \ | \ | \ | \ | \ | \| \| +––––––––––-+ 1 2

 *Heading
   box.inp
  *Node
  1,  -5, -5, 0
@@ -58,7 +58,7 @@
  3,  9, 10, 1,  5
  4,  7,  4, 8, 11
  5, 11, 10, 3,  7
- 6,  2,  6, 9,  5

This code can be called two ways. The first, when vertex==NULL and tree_to_vertex==NULL, is used to count the number of trees and vertices in the connectivity to be generated by the .inp mesh in the stream. The second, when vertices!=NULL and tree_to_vertex!=NULL, fill vertices and tree_to_vertex. In this case num_vertices and num_trees need to be set to the maximum number of entries allocated in vertices and tree_to_vertex.

Parameters

  • stream:[in,out] file stream to read the connectivity from
  • num_vertices:[in,out] the number of vertices in the connectivity
  • num_trees:[in,out] the number of trees in the connectivity
  • vertices:[out] the list of vertices of the connectivity
  • tree_to_vertex:[out] the tree_to_vertex map of the connectivity

Returns

0 if successful and nonzero if not

Prototype

int p4est_connectivity_read_inp_stream (FILE * stream, p4est_topidx_t * num_vertices, p4est_topidx_t * num_trees, double *vertices, p4est_topidx_t * tree_to_vertex);
source
P4est.LibP4est.p4est_connectivity_refineMethod
p4est_connectivity_refine(conn, num_per_edge)

Uniformly refine a connectivity. This is useful if you would like to uniformly refine by something other than a power of 2.

Parameters

  • conn:[in] A valid connectivity
  • num_per_edge:[in] The number of new trees in each direction. Must use no more than P4ESTOLDQMAXLEVEL bits.

Returns

a refined connectivity.

Prototype

p4est_connectivity_t *p4est_connectivity_refine (p4est_connectivity_t * conn, int num_per_edge);
source
P4est.LibP4est.p4est_connectivity_saveMethod
p4est_connectivity_save(filename, connectivity)

Save a connectivity structure to disk.

Parameters

  • filename:[in] Name of the file to write.
  • connectivity:[in] Valid connectivity structure.

Returns

Returns 0 on success, nonzero on file error.

Prototype

int p4est_connectivity_save (const char *filename, p4est_connectivity_t * connectivity);
source
P4est.LibP4est.p4est_connectivity_set_attrMethod
p4est_connectivity_set_attr(conn, bytes_per_tree)

Allocate or free the attribute fields in a connectivity.

Parameters

  • conn:[in,out] The conn->*_to_attr fields must either be NULL or previously be allocated by this function.
  • bytes_per_tree:[in] If 0, tree_to_attr is freed (being NULL is ok). If positive, requested space is allocated.

Prototype

void p4est_connectivity_set_attr (p4est_connectivity_t * conn, size_t bytes_per_tree);
source
P4est.LibP4est.p4est_connectivity_sinkMethod
p4est_connectivity_sink(conn, sink)

Write connectivity to a sink object.

Parameters

  • conn:[in] The connectivity to be written.
  • sink:[in,out] The connectivity is written into this sink.

Returns

0 on success, nonzero on error.

Prototype

int p4est_connectivity_sink (p4est_connectivity_t * conn, sc_io_sink_t * sink);
source
P4est.LibP4est.p4est_connectivity_sourceMethod
p4est_connectivity_source(source)

Read connectivity from a source object.

Parameters

  • source:[in,out] The connectivity is read from this source.

Returns

The newly created connectivity, or NULL on error.

Prototype

p4est_connectivity_t *p4est_connectivity_source (sc_io_source_t * source);
source
P4est.LibP4est.p4est_copyMethod
p4est_copy(input, copy_data)

Make a deep copy of a p4est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL. The revision counter of the copy is set to zero.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.

Returns

Returns a valid p4est that does not depend on the input, except for borrowing the same connectivity. Its revision counter is 0.

Prototype

p4est_t *p4est_copy (p4est_t * input, int copy_data);
source
P4est.LibP4est.p4est_copy_extMethod
p4est_copy_ext(input, copy_data, duplicate_mpicomm)

Make a deep copy of a p4est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL. The revision counter of the copy is set to zero.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.
  • duplicate_mpicomm:[in] If true, MPI communicator is copied.

Returns

Returns a valid p4est that does not depend on the input, except for borrowing the same connectivity. Its revision counter is 0.

Prototype

p4est_t *p4est_copy_ext (p4est_t * input, int copy_data, int duplicate_mpicomm);
source
P4est.LibP4est.p4est_destroyMethod
p4est_destroy(p4est_)

Destroy a p4est.

Note

The connectivity structure is not destroyed with the p4est.

Prototype

void p4est_destroy (p4est_t * p4est);
source
P4est.LibP4est.p4est_expand_face_transformMethod
p4est_expand_face_transform(iface, nface, ftransform)

Fill an array with the axis combination of a face neighbor transform.

Parameters

  • iface:[in] The number of the originating face.
  • nface:[in] Encoded as nface = r * 4 + nf, where nf = 0..3 is the neigbbor's connecting face number and r = 0..1 is the relative orientation to the neighbor's face. This encoding matches p4est_connectivity_t.
  • ftransform:[out] This array holds 9 integers. [0,2] The coordinate axis sequence of the origin face, the first referring to the tangential and the second to the normal. A permutation of (0, 1). [3,5] The coordinate axis sequence of the target face. [6,8] Edge reversal flag for tangential axis (boolean); face code in [0, 3] for the normal coordinate q: 0: q' = -q 1: q' = q + 1 2: q' = q - 1 3: q' = 2 - q [1,4,7] 0 (unused for compatibility with 3D).

Prototype

void p4est_expand_face_transform (int iface, int nface, int ftransform[]);
source
P4est.LibP4est.p4est_face_quadrant_existsMethod
p4est_face_quadrant_exists(p4est_, ghost, treeid, q, face, hang, owner_rank)

Checks if quadrant exists in the local forest or the ghost layer.

For quadrants across tree boundaries it checks if the quadrant exists across any face, but not across corners.

Parameters

  • p4est:[in] The forest in which to search for q.
  • ghost:[in] The ghost layer in which to search for q.
  • treeid:[in] The tree to which q belongs.
  • q:[in] The quadrant that is being searched for.
  • face:[in,out] On input, face id across which q was created. On output, the neighbor's face number augmented by orientation, so face is in 0..7.
  • hang:[in,out] If not NULL, signals that q is bigger than the quadrant it came from. The child id of that originating quadrant is passed into hang. On output, hang holds the hanging face number of q that is in contact with its originator.
  • owner_rank:[out] Filled with the rank of the owner if it is found and undefined otherwise.

Returns

Returns the local number of q if the quadrant exists in the local forest or in the ghost_layer. Otherwise, returns -2 for a domain boundary and -1 if not found.

Prototype

p4est_locidx_t p4est_face_quadrant_exists (p4est_t * p4est, p4est_ghost_t * ghost, p4est_topidx_t treeid, const p4est_quadrant_t * q, int *face, int *hang, int *owner_rank);
source
P4est.LibP4est.p4est_find_corner_transformMethod
p4est_find_corner_transform(connectivity, itree, icorner, ci)

Fills an array with information about corner neighbors.

Parameters

  • itree:[in] The number of the originating tree.
  • icorner:[in] The number of the originating corner.
  • ci:[in,out] A p4est_corner_info_t structure with initialized array.

Prototype

void p4est_find_corner_transform (p4est_connectivity_t * connectivity, p4est_topidx_t itree, int icorner, p4est_corner_info_t * ci);
source
P4est.LibP4est.p4est_find_face_transformMethod
p4est_find_face_transform(connectivity, itree, iface, ftransform)

Fill an array with the axis combinations of a tree neighbor transform.

Parameters

  • itree:[in] The number of the originating tree.
  • iface:[in] The number of the originating tree's face.
  • ftransform:[out] This array holds 9 integers. [0,2] The coordinate axis sequence of the origin face. [3,5] The coordinate axis sequence of the target face. [6,8] Edge reverse flag for axis t; face code for axis n. [1,4,7] 0 (unused for compatibility with 3D).

Returns

The face neighbor tree if it exists, -1 otherwise.

Prototype

p4est_topidx_t p4est_find_face_transform (p4est_connectivity_t * connectivity, p4est_topidx_t itree, int iface, int ftransform[]);
source
P4est.LibP4est.p4est_find_higher_boundMethod
p4est_find_higher_bound(array, q, guess)

Find the highest position tq in a quadrant array such that tq <= q.

Returns

Returns the id of the matching quadrant or -1 if array > q or the array is empty.

Prototype

ssize_t p4est_find_higher_bound (sc_array_t * array, const p4est_quadrant_t * q, size_t guess);
source
P4est.LibP4est.p4est_find_lower_boundMethod
p4est_find_lower_bound(array, q, guess)

Find the lowest position tq in a quadrant array such that tq >= q.

Returns

Returns the id of the matching quadrant or -1 if array < q or the array is empty.

Prototype

ssize_t p4est_find_lower_bound (sc_array_t * array, const p4est_quadrant_t * q, size_t guess);
source
P4est.LibP4est.p4est_find_partitionMethod
p4est_find_partition(num_procs, search_in, my_begin, my_end, _begin, _end)

Binary search in partition array. Given two targets my_begin and my_end, find offsets such that search\_in[begin] >= my\_begin, my\_end <= search\_in[end]. If more than one index satisfies the conditions, then the minimal index is the result. If there is no index that satisfies the conditions, then begin and end are tried to set equal such that search\_in[begin] >= my\_end. If my_begin is less or equal than the smallest value of search_in begin is set to 0 and if my_end is bigger or equal than the largest value of search_in end is set to num_procs - 1. If none of the above conditions is satisfied, the output is not well defined. We require `my_begin <= my_begin'.

Parameters

  • num_procs:[in] Number of processes to get the length of search_in.
  • search_in:[in] The sorted array (ascending) in that the function will search. If k indexes search_in, then 0 <= k < num\_procs.
  • my_begin:[in] The first target that defines the start of the search window.
  • my_end:[in] The second target that defines the end of the search window.
  • begin:[in,out] The first offset such that search\_in[begin] >= my\_begin.
  • end:[in,out] The second offset such that my\_end <= search\_in[end].

Prototype

void p4est_find_partition (const int num_procs, p4est_gloidx_t * search_in, p4est_gloidx_t my_begin, p4est_gloidx_t my_end, p4est_gloidx_t * begin, p4est_gloidx_t * end);
source
P4est.LibP4est.p4est_find_quadrant_cumulativeMethod
p4est_find_quadrant_cumulative(p4est_, cumulative_id, which_tree, quadrant_id)

Search a local quadrant by its cumulative number in the forest.

We perform a binary search over the processor-local trees, which means that it is advisable NOT to use this function if possible, and to try to maintain O(1) tree context information in the calling code.

Parameters

  • p4est:[in] Forest to be worked with.
  • cumulative_id:[in] Cumulative index over all trees of quadrant.
  • which_tree:[in,out] If not NULL, the input value can be -1 or an initial guess for the quadrant's tree. An initial guess must be the index of a nonempty local tree. Output is the tree of returned quadrant.
  • quadrant_id:[out] If not NULL, the number of quadrant in tree.

Returns

The identified quadrant.

Prototype

p4est_quadrant_t *p4est_find_quadrant_cumulative (p4est_t * p4est, p4est_locidx_t cumulative_id, p4est_topidx_t * which_tree, p4est_locidx_t * quadrant_id);
source
P4est.LibP4est.p4est_find_range_boundariesMethod
p4est_find_range_boundaries(lq, uq, level, faces, corners)

Find the boundary points touched by a range of quadrants.

Given two smallest quadrants, lq and uq, that mark the first and the last quadrant in a range of quadrants, determine which portions of the tree boundary the range touches.

Parameters

  • lq:[in] The smallest quadrant at the start of the range: if NULL, the tree's first quadrant is taken to be the start of the range.
  • uq:[in] The smallest quadrant at the end of the range: if NULL, the tree's last quadrant is taken to be the end of the range.
  • level:[in] The level of the containing quadrant whose boundaries are tested: 0 if we want to test the boundaries of the whole tree.
  • faces:[in,out] An array of size 4 that is filled: faces[i] is true if the range touches that face.
  • corners:[in,out] An array of size 4 that is filled: corners[i] is true if the range touches that corner. faces or corners may be NULL.

Returns

Returns an int32_t encoded with the same information in faces and corners: the first (least) four bits represent the four faces, the next four bits represent the four corners.

Prototype

int32_t p4est_find_range_boundaries (p4est_quadrant_t * lq, p4est_quadrant_t * uq, int level, int faces[], int corners[]);
source
P4est.LibP4est.p4est_get_plex_data_extMethod
p4est_get_plex_data_ext(p4est_, ghost, lnodes, ctype, overlap, first_local_quad, out_points_per_dim, out_cone_sizes, out_cones, out_cone_orientations, out_vertex_coords, out_children, out_parents, out_childids, out_leaves, out_remotes, custom_numbering)

Create the data necessary to create a PETsc DMPLEX representation of a forest, as well as the accompanying lnodes and ghost layer. The forest must be at least face balanced (see p4est_balance()). See test/test_plex2.c for example usage.

All arrays should be initialized to hold sizeof (p4est_locidx_t), except for out_remotes, which should be initialized to hold (2 * sizeof (p4est_locidx_t)).

Parameters

  • p4est:[in] the forest
  • ghost:[out] the ghost layer
  • lnodes:[out] the lnodes
  • ctype:[in] the type of adjacency for the overlap
  • overlap:[in] the number of layers of overlap (zero is acceptable)
  • first_local_quad:[out] the local quadrants are assigned contiguous plex indices, starting with this index
  • out_points_per_dim:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cone_sizes:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cones:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cone_orientations:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_vertex_coords:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_children:[in,out] filled with argument for DMPlexSetTree()
  • out_parents:[in,out] filled with argument for DMPlexSetTree()
  • out_childids:[in,out] filled with argument for DMPlexSetTree()
  • out_leaves:[in,out] filled with argument for PetscSFSetGraph()
  • out_remotes:[in,out] filled with argument for PetscSFSetGraph()
  • custom_numbering:[in] Whether or use the default numbering (0) of DMPlex child ids or the custom (1).

Prototype

void p4est_get_plex_data_ext (p4est_t * p4est, p4est_ghost_t ** ghost, p4est_lnodes_t ** lnodes, p4est_connect_type_t ctype, int overlap, p4est_locidx_t * first_local_quad, sc_array_t * out_points_per_dim, sc_array_t * out_cone_sizes, sc_array_t * out_cones, sc_array_t * out_cone_orientations, sc_array_t * out_vertex_coords, sc_array_t * out_children, sc_array_t * out_parents, sc_array_t * out_childids, sc_array_t * out_leaves, sc_array_t * out_remotes, int custom_numbering);
source
P4est.LibP4est.p4est_ghost_bsearchMethod
p4est_ghost_bsearch(ghost, which_proc, which_tree, q)

Conduct binary search for exact match on a range of the ghost layer.

Parameters

  • ghost:[in] The ghost layer.
  • which_proc:[in] The owner of the searched quadrant. Can be -1.
  • which_tree:[in] The tree of the searched quadrant. Can be -1.
  • q:[in] Valid quadrant is searched in the ghost layer.

Returns

Offset in the ghost layer, or -1 if not found.

Prototype

ssize_t p4est_ghost_bsearch (p4est_ghost_t * ghost, int which_proc, p4est_topidx_t which_tree, const p4est_quadrant_t * q);
source
P4est.LibP4est.p4est_ghost_checksumMethod
p4est_ghost_checksum(p4est_, ghost)

Compute the parallel checksum of a ghost layer.

Parameters

  • p4est:[in] The MPI information of this p4est will be used.
  • ghost:[in] A ghost layer obtained from the p4est.

Returns

Parallel checksum on rank 0, 0 otherwise.

Prototype

unsigned p4est_ghost_checksum (p4est_t * p4est, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_containsMethod
p4est_ghost_contains(ghost, which_proc, which_tree, q)

Conduct binary search for ancestor on range of the ghost layer.

Parameters

  • ghost:[in] The ghost layer.
  • which_proc:[in] The owner of the searched quadrant. Can be -1.
  • which_tree:[in] The tree of the searched quadrant. Can be -1.
  • q:[in] Valid quadrant's ancestor is searched.

Returns

Offset in the ghost layer, or -1 if not found.

Prototype

ssize_t p4est_ghost_contains (p4est_ghost_t * ghost, int which_proc, p4est_topidx_t which_tree, const p4est_quadrant_t * q);
source
P4est.LibP4est.p4est_ghost_exchange_customMethod
p4est_ghost_exchange_custom(p4est_, ghost, data_size, mirror_data, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. The data size is the same for all quadrants and can be chosen arbitrarily.

Parameters

  • p4est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • data_size:[in] The data size to transfer per quadrant.
  • mirror_data:[in] One data pointer per mirror quadrant as input.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghosts in sequence, which must hold at least data_size for each ghost.

Prototype

void p4est_ghost_exchange_custom (p4est_t * p4est, p4est_ghost_t * ghost, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_custom_beginMethod
p4est_ghost_exchange_custom_begin(p4est_, ghost, data_size, mirror_data, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p4est_ghost_exchange_custom. The return type is always non-NULL and must be passed to p4est_ghost_exchange_custom_end to complete the exchange. The ghost data must not be accessed before completion. The mirror data can be safely discarded right after this function returns since it is copied into internal send buffers.

Parameters

  • mirror_data:[in] Not required to stay alive any longer.
  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p4est_ghost_exchange_t *p4est_ghost_exchange_custom_begin (p4est_t * p4est, p4est_ghost_t * ghost, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_custom_levelsMethod
p4est_ghost_exchange_custom_levels(p4est_, ghost, minlevel, maxlevel, data_size, mirror_data, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. The data size is the same for all quadrants and can be chosen arbitrarily. This function restricts the transfer to a range of refinement levels. The memory for quadrants outside the level range is not dereferenced.

Parameters

  • p4est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • minlevel:[in] Level of the largest quads to be exchanged. Use <= 0 for no restriction.
  • maxlevel:[in] Level of the smallest quads to be exchanged. Use >= P4EST_QMAXLEVEL for no restriction.
  • data_size:[in] The data size to transfer per quadrant.
  • mirror_data:[in] One data pointer per mirror quadrant as input.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghosts in sequence, which must hold at least data_size for each ghost.

Prototype

void p4est_ghost_exchange_custom_levels (p4est_t * p4est, p4est_ghost_t * ghost, int minlevel, int maxlevel, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_custom_levels_beginMethod
p4est_ghost_exchange_custom_levels_begin(p4est_, ghost, minlevel, maxlevel, data_size, mirror_data, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p4est_ghost_exchange_custom_levels. The return type is always non-NULL and must be passed to p4est_ghost_exchange_custom_levels_end to complete the exchange. The ghost data must not be accessed before completion. The mirror data can be safely discarded right after this function returns since it is copied into internal send buffers.

Parameters

  • mirror_data:[in] Not required to stay alive any longer.
  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p4est_ghost_exchange_t *p4est_ghost_exchange_custom_levels_begin (p4est_t * p4est, p4est_ghost_t * ghost, int minlevel, int maxlevel, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_dataMethod
p4est_ghost_exchange_data(p4est_, ghost, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. Send the data stored in the quadrant's user_data. This is either the pointer variable itself if p4est->datasize is 0, or the content of the referenced memory field if p4est->data\size is positive.

Parameters

  • p4est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghost quadrants in sequence. If p4est->data_size is 0, must at least hold sizeof (void *) bytes for each, otherwise p4est->data_size each.

Prototype

void p4est_ghost_exchange_data (p4est_t * p4est, p4est_ghost_t * ghost, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_data_beginMethod
p4est_ghost_exchange_data_begin(p4est_, ghost, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p4est_ghost_exchange_data. The return type is always non-NULL and must be passed to p4est_ghost_exchange_data_end to complete the exchange. The ghost data must not be accessed before completion.

Parameters

  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p4est_ghost_exchange_t *p4est_ghost_exchange_data_begin (p4est_t * p4est, p4est_ghost_t * ghost, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_expandMethod
p4est_ghost_expand(p4est_, ghost)

Expand the size of the ghost layer and mirrors by one additional layer of adjacency.

Parameters

  • p4est:[in] The forest from which the ghost layer was generated.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p4est_ghost_expand (p4est_t * p4est, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_expand_by_lnodesMethod
p4est_ghost_expand_by_lnodes(p4est_, lnodes, ghost)

Expand the ghost layer as in p4est_ghost_expand(), but use node support to define adjacency instead of geometric adjacency.

Parameters

  • p4est:[in] The forest from which the ghost layer was generated.
  • lnodes:[in] The nodes to support.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p4est_ghost_expand_by_lnodes (p4est_t * p4est, p4est_lnodes_t * lnodes, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_is_validMethod
p4est_ghost_is_valid(p4est_, ghost)

Examine if a ghost structure is valid. Test if within a ghost-structure the array ghosts is in p4est_quadrant_compare_piggy order. Test if local_num in piggy3 data member of the quadrants in ghosts and mirrors are in ascending order (ascending within each rank for ghost).

Test if the p4est_locidx_t arrays are in ascending order (for mirror_proc_mirrors ascending within each rank)

Parameters

  • p4est:[in] the forest.
  • ghost:[in] Ghost layer structure.

Returns

true if ghost is valid

Prototype

int p4est_ghost_is_valid (p4est_t * p4est, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_memory_usedMethod
p4est_ghost_memory_used(ghost)

Calculate the memory usage of the ghost layer.

Parameters

  • ghost:[in] Ghost layer structure.

Returns

Memory used in bytes.

Prototype

size_t p4est_ghost_memory_used (p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_newMethod
p4est_ghost_new(p4est_, btype)

Builds the ghost layer.

This will gather the quadrants from each neighboring proc to build one layer of face and corner based ghost elements around the ones they own.

Parameters

  • p4est:[in] The forest for which the ghost layer will be generated.
  • btype:[in] Which ghosts to include (across face, corner or full).

Returns

A fully initialized ghost layer.

Prototype

p4est_ghost_t *p4est_ghost_new (p4est_t * p4est, p4est_connect_type_t btype);
source
P4est.LibP4est.p4est_ghost_support_lnodesMethod
p4est_ghost_support_lnodes(p4est_, lnodes, ghost)

Expand the ghost layer to include the support of all nodes supported on the local partition.

Parameters

  • p4est:[in] The forest from which the ghost layer was generated.
  • lnodes:[in] The nodes to support.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p4est_ghost_support_lnodes (p4est_t * p4est, p4est_lnodes_t * lnodes, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_initMethod
p4est_init(log_handler, log_threshold)

Registers p4est with the SC Library and sets the logging behavior. This function is optional. This function must only be called before additional threads are created. If this function is not called or called with log_handler == NULL, the default SC log handler will be used. If this function is not called or called with log_threshold == SC_LP_DEFAULT, the default SC log threshold will be used. The default SC log settings can be changed with sc_set_log_defaults ().

Prototype

void p4est_init (sc_log_handler_t log_handler, int log_threshold);
source
P4est.LibP4est.p4est_is_balancedMethod
p4est_is_balanced(p4est_, btype)

Check a forest to see if it is balanced.

This function builds the ghost layer and discards it when done.

Parameters

  • p4est:[in] The p4est to be tested.
  • btype:[in] Balance type (face, corner or default, full).

Returns

Returns true if balanced, false otherwise.

Prototype

int p4est_is_balanced (p4est_t * p4est, p4est_connect_type_t btype);
source
P4est.LibP4est.p4est_iterateMethod
p4est_iterate(p4est_, ghost_layer, user_data, iter_volume, iter_face, iter_corner)

Execute user supplied callbacks at every volume, face, and corner in the local forest.

p4est_iterate executes the user-supplied callback functions at every volume, face, and corner in the local forest. The ghost_layer may be NULL. The user_data pointer is not touched by p4est_iterate, but is passed to each of the callbacks. Any of the callbacks may be NULL. The callback functions are interspersed with each other, i.e. some face callbacks will occur between volume callbacks, and some corner callbacks will occur between face callbacks:

  1. volume callbacks occur in the sorted Morton-index order. 2) a face callback is not executed until after the volume callbacks have been executed for the quadrants that share it. 3) a corner callback is not executed until the face callbacks have been executed for all faces that touch the corner. 4) it is not always the case that every face callback for a given quadrant is executed before any of the corner callbacks. 5) callbacks are not executed at faces or corners that only involve ghost quadrants, i.e. that are not adjacent in the local section of the forest.

Parameters

  • p4est:[in] the forest
  • ghost_layer:[in] optional: when not given, callbacks at the boundaries of the local partition cannot provide quadrant data about ghost quadrants: missing (p4est_quadrant_t *) pointers are set to NULL, missing indices are set to -1.
  • user_data:[in,out] optional context to supply to each callback
  • iter_volume:[in] callback function for every quadrant's interior
  • iter_face:[in] callback function for every face between quadrants
  • iter_corner:[in] callback function for every corner between quadrants

Prototype

void p4est_iterate (p4est_t * p4est, p4est_ghost_t * ghost_layer, void *user_data, p4est_iter_volume_t iter_volume, p4est_iter_face_t iter_face, p4est_iter_corner_t iter_corner);
source
P4est.LibP4est.p4est_iterate_extMethod
p4est_iterate_ext(p4est_, ghost_layer, user_data, iter_volume, iter_face, iter_corner, remote)

p4est_iterate_ext adds the option remote: if this is false, then it is the same as p4est_iterate; if this is true, then corner callbacks are also called on corners for hanging faces touched by local quadrants.

Prototype

void p4est_iterate_ext (p4est_t * p4est, p4est_ghost_t * ghost_layer, void *user_data, p4est_iter_volume_t iter_volume, p4est_iter_face_t iter_face, p4est_iter_corner_t iter_corner, int remote);
source
P4est.LibP4est.p4est_lid_addMethod
p4est_lid_add(a, b, result)

Adds the uint128_t b to the uint128_t a. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void p4est_lid_add (const p4est_lid_t * a, const p4est_lid_t * b, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_bitwise_andMethod
p4est_lid_bitwise_and(a, b, result)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void p4est_lid_bitwise_and (const p4est_lid_t * a, const p4est_lid_t * b, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_bitwise_and_inplaceMethod
p4est_lid_bitwise_and_inplace(a, b)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void p4est_lid_bitwise_and_inplace (p4est_lid_t * a, const p4est_lid_t * b);
source
P4est.LibP4est.p4est_lid_bitwise_negMethod
p4est_lid_bitwise_neg(a, result)

Calculates the bitwise negation of the uint128_t a. a == result is allowed.

Parameters

  • a:[in] A pointer to a p4est_lid_t.
  • result:[out] A pointer to a p4est_lid_t. The bitwise negation of a will be saved in result.

Prototype

void p4est_lid_bitwise_neg (const p4est_lid_t * a, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_bitwise_orMethod
p4est_lid_bitwise_or(a, b, result)

Calculates the bitwise or of the uint128_t a and b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void p4est_lid_bitwise_or (const p4est_lid_t * a, const p4est_lid_t * b, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_bitwise_or_inplaceMethod
p4est_lid_bitwise_or_inplace(a, b)

Calculates the bitwise or of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void p4est_lid_bitwise_or_inplace (p4est_lid_t * a, const p4est_lid_t * b);
source
P4est.LibP4est.p4est_lid_chk_bitMethod
p4est_lid_chk_bit(input, bit_number)

Returns the bit_number-th bit of input. This function checks a bit of an existing, initialized value.

Parameters

  • input:[in] A pointer to a p4est_lid_t.
  • bit_number:[in] The bit (counted from the right hand side) that is checked by logical and. Require 0 <= bit_number < 64.

Returns

True if bit is set, false if not.

Prototype

int p4est_lid_chk_bit (const p4est_lid_t * input, int bit_number);
source
P4est.LibP4est.p4est_lid_copyMethod
p4est_lid_copy(input, output)

Copies an initialized p4est_lid_t to a p4est_lid_t.

Parameters

  • input:[in] A pointer to the p4est_lid_t that is copied.
  • output:[in,out] A pointer to a p4est_lid_t. The low bits of output will be set to the low bits of input and high bits are ignored.

Prototype

void p4est_lid_copy (const p4est_lid_t * input, p4est_lid_t * output);
source
P4est.LibP4est.p4est_lid_initMethod
p4est_lid_init(input, high, low)

Initializes an unsigned 64 bit integer. high is just a a placeholder to use the same interface in 3D.

Parameters

  • input:[in,out] A pointer to a p4est_lid_t that will be intialized.
  • high:[in] The given high bits must be zero.
  • low:[in] The given low bits to initialize input.

Prototype

void p4est_lid_init (p4est_lid_t * input, uint64_t high, uint64_t low);
source
P4est.LibP4est.p4est_lid_set_bitMethod
p4est_lid_set_bit(input, bit_number)

Sets the exponent-th bit of a to one. This function modifies an existing, initialized value.

Parameters

  • input:[in,out] A pointer to a p4est_lid_t.
  • bit_number:[in] The bit (counted from the right hand side) that is set to one by logical or. Require 0 <= bit_number < 64.

Prototype

void p4est_lid_set_bit (p4est_lid_t * input, int bit_number);
source
P4est.LibP4est.p4est_lid_set_uint64Method
p4est_lid_set_uint64(input, u)

Initializes a linear index to an unsigned 64 bit integer.

Parameters

  • input:[out] A pointer to a p4est_lid_t that will be intialized.

Prototype

void p4est_lid_set_uint64 (p4est_lid_t * input, uint64_t u);
source
P4est.LibP4est.p4est_lid_shift_leftMethod
p4est_lid_shift_left(input, shift_count, result)

Calculates the bit left shift of uint128_t input by shift_count bits. We shift in zeros from the right. If shift_count >= 64, result is 0. All bits left from the 63th bit (counted zero based from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a p4est_lid_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a p4est_lid_t. The left shifted number will be saved in result.

Prototype

void p4est_lid_shift_left (const p4est_lid_t * input, unsigned shift_count, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_shift_rightMethod
p4est_lid_shift_right(input, shift_count, result)

Calculates the bit right shift of uint128_t input by shift_count bits. We shift in zeros from the left. If shift_count >= 64, result is 0. All bits right from the zeroth bit (counted from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a p4est_lid_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a p4est_lid_t. The right shifted number will be saved in result.

Prototype

void p4est_lid_shift_right (const p4est_lid_t * input, unsigned shift_count, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_subMethod
p4est_lid_sub(a, b, result)

Substracts the p4est_lid_t b from the p4est_lid_t a. This function assumes that the result is >= 0. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void p4est_lid_sub (const p4est_lid_t * a, const p4est_lid_t * b, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_sub_inplaceMethod
p4est_lid_sub_inplace(a, b)

Substracts the uint128_t b from the uint128_t a. The result is saved in a. a == b is allowed. This function assumes that the result is >= 0.

Parameters

Prototype

void p4est_lid_sub_inplace (p4est_lid_t * a, const p4est_lid_t * b);
source
P4est.LibP4est.p4est_lnodes_newMethod
p4est_lnodes_new(p4est_, ghost_layer, degree)

Prototype

p4est_lnodes_t *p4est_lnodes_new (p4est_t * p4est, p4est_ghost_t * ghost_layer, int degree);
source
P4est.LibP4est.p4est_lnodes_share_allMethod
p4est_lnodes_share_all(node_data, lnodes)

Equivalent to calling p4est_lnodes_share_all_end directly after p4est_lnodes_share_all_begin. Use if there is no local work that can be done to mask the communication cost.

Returns

A fully initialized buffer that contains the received data. After processing this data, the buffer must be freed with p4est_lnodes_buffer_destroy.

Prototype

p4est_lnodes_buffer_t *p4est_lnodes_share_all (sc_array_t * node_data, p4est_lnodes_t * lnodes);
source
P4est.LibP4est.p4est_lnodes_share_all_beginMethod
p4est_lnodes_share_all_begin(node_data, lnodes)

p4est_lnodes_share_all_begin

node_data is a user_defined array of arbitrary type, where each entry is associated with the lnodes local nodes entry of matching index. For every process that shares an entry with the current one, the value in the node_data array of that process is written into a buffer->recvbuffers entry as described above. The user can then perform some arbitrary work that requires the data from all processes that share a node (such as reduce, max, min, etc.). When the work concludes, the buffer should be destroyed with [`p4estlnodesbufferdestroy`](@ref).

Values of node_data are not guaranteed to be sent, and buffer->recvbuffer entries are not guaranteed to be received until the buffer created by [`p4estlnodesshareallbegin](@ref) is passed to [p4estlnodesshareall_end`](@ref).

Prototype

p4est_lnodes_buffer_t *p4est_lnodes_share_all_begin (sc_array_t * node_data, p4est_lnodes_t * lnodes);
source
P4est.LibP4est.p4est_lnodes_share_owned_beginMethod
p4est_lnodes_share_owned_begin(node_data, lnodes)

p4est_lnodes_share_owned_begin

node_data is a user-defined array of arbitrary type, where each entry is associated with the lnodes local nodes entry of matching index. For every local nodes entry that is owned by a process other than the current one, the value in the node_data array of the owning process is written directly into the node_data array of the current process. Values of node_data are not guaranteed to be sent or received until the buffer created by p4est_lnodes_share_owned_begin is passed to p4est_lnodes_share_owned_end.

To be memory neutral, the buffer created by p4est_lnodes_share_owned_begin must be destroying with p4est_lnodes_buffer_destroy (it is not destroyed by p4est_lnodes_share_owned_end).

Prototype

p4est_lnodes_buffer_t *p4est_lnodes_share_owned_begin (sc_array_t * node_data, p4est_lnodes_t * lnodes);
source
P4est.LibP4est.p4est_loadMethod
p4est_load(filename, mpicomm, data_size, load_data, user_pointer, connectivity)

Prototype

p4est_t *p4est_load (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, void *user_pointer, p4est_connectivity_t ** connectivity);
source
P4est.LibP4est.p4est_load_extMethod
p4est_load_ext(filename, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p4est_t *p4est_load_ext (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p4est_connectivity_t ** connectivity);
source
P4est.LibP4est.p4est_memory_usedMethod
p4est_memory_used(p4est_)

Calculate local memory usage of a forest structure. Not collective. The memory used on the current rank is returned. The connectivity structure is not counted since it is not owned; use p4est_connectivity_memory_usage (p4est->connectivity).

Parameters

  • p4est:[in] Valid forest structure.

Returns

Memory used in bytes.

Prototype

size_t p4est_memory_used (p4est_t * p4est);
source
P4est.LibP4est.p4est_mesh_face_neighbor_dataMethod
p4est_mesh_face_neighbor_data(mfn, ghost_data)

Get the user data for the current face neighbor.

Parameters

  • mfn:[in] Internal status of the iterator.
  • ghost_data:[in] Data for the ghost quadrants that has been synchronized with p4est_ghost_exchange_data.

Returns

A pointer to the user data for the current neighbor.

Prototype

void *p4est_mesh_face_neighbor_data (p4est_mesh_face_neighbor_t * mfn, void *ghost_data);
source
P4est.LibP4est.p4est_mesh_face_neighbor_initMethod
p4est_mesh_face_neighbor_init(mfn, p4est_, ghost, mesh, which_tree, quadrant)

Initialize a mesh neighbor iterator by quadrant pointer.

Parameters

  • mfn:[out] A p4est_mesh_face_neighbor_t to be initialized.
  • which_tree:[in] Tree of quadrant whose neighbors are looped over.
  • quadrant:[in] Pointer to quadrant contained in which_tree.

Prototype

void p4est_mesh_face_neighbor_init (p4est_mesh_face_neighbor_t * mfn, p4est_t * p4est, p4est_ghost_t * ghost, p4est_mesh_t * mesh, p4est_topidx_t which_tree, p4est_quadrant_t * quadrant);
source
P4est.LibP4est.p4est_mesh_face_neighbor_init2Method
p4est_mesh_face_neighbor_init2(mfn, p4est_, ghost, mesh, which_tree, quadrant_id)

Initialize a mesh neighbor iterator by quadrant index.

Parameters

  • mfn:[out] A p4est_mesh_face_neighbor_t to be initialized.
  • which_tree:[in] Tree of quadrant whose neighbors are looped over.
  • quadrant_id:[in] Index relative to which_tree of quadrant.

Prototype

void p4est_mesh_face_neighbor_init2 (p4est_mesh_face_neighbor_t * mfn, p4est_t * p4est, p4est_ghost_t * ghost, p4est_mesh_t * mesh, p4est_topidx_t which_tree, p4est_locidx_t quadrant_id);
source
P4est.LibP4est.p4est_mesh_face_neighbor_nextMethod
p4est_mesh_face_neighbor_next(mfn, ntree, nquad, nface, nrank)

Move the iterator forward to loop around neighbors of the quadrant.

Parameters

  • mfn:[in,out] Internal status of the iterator.
  • ntree:[out] If not NULL, the tree number of the neighbor.
  • nquad:[out] If not NULL, the quadrant number within tree. For ghosts instead the number in ghost layer.
  • nface:[out] If not NULL, neighbor's face as in p4est_mesh_t.
  • nrank:[out] If not NULL, the owner process of the neighbor.

Returns

Either a real quadrant or one from the ghost layer. Returns NULL when the iterator is done.

Prototype

p4est_quadrant_t *p4est_mesh_face_neighbor_next (p4est_mesh_face_neighbor_t * mfn, p4est_topidx_t * ntree, p4est_locidx_t * nquad, int *nface, int *nrank);
source
P4est.LibP4est.p4est_mesh_get_neighborsMethod
p4est_mesh_get_neighbors(p4est_, ghost, mesh, curr_quad_id, direction, neighboring_quads, neighboring_encs, neighboring_qids)

Lookup neighboring quads of quadrant in a specific direction.

Parameters

  • p4est:[in] Forest to be worked with.
  • ghost:[in] Ghost layer.
  • mesh:[in] Mesh structure.
  • curr_quad_id:[in] Process-local id of current quad.
  • direction:[in] Direction i in which to look for adjacent quadrants is encoded as follows: 0 .. 3 neighbor(-s) across face i, 4 .. 7 neighbor(-s) across corner i-4. TODO: Allow any combination of empty output arrays.
  • neighboring_quads:[out] Array containing neighboring quad(-s). Needs to be empty on input, size of p4est_quadrant_t *. May be NULL, then neighboring_qids must not be NULL.
  • neighboring_qids:[out] Array containing quadrant ids for neighboring quadrants. May be NULL, then no neighboring qids are collected. If non-NULL the array needs to be empty and will contain int. CAUTION: Note, that the encodings differ from the encodings saved in the mesh. TODO: Encodings are the same as in p4est_mesh for all quadrants. TODO: Ghosts can be encoded by returning the quad_to_quad convention in qid. For ghost quadrants, we add -300 to the values in p4est_mesh. This means that values below -100 belong to ghosts, values above to locals. Positive values are for local quadrants, negative values indicate ghost quadrants. Faces: 1 .. 8 => same size neighbor (r * 4 + nf) + 1; nf = 0 .. 3 face index; r = 0 .. 1 relative orientation 9 .. 24 => double size neighbor 9 + h * 8 + r * 4 + nf; h = 0 .. 1 number of the subface; r, nf as above 25 .. 32 => half-size neighbors 25 + r * 4 + nf; r, nf as above Corners: 1 .. 4 => size not encoded for corners nc + 1; nc = 0 .. 3 corner index
  • neighboring_encs:[out] Array containing encodings for neighboring quads. Needs to be empty, contains int.

Prototype

p4est_locidx_t p4est_mesh_get_neighbors (p4est_t * p4est, p4est_ghost_t * ghost, p4est_mesh_t * mesh, p4est_locidx_t curr_quad_id, p4est_locidx_t direction, sc_array_t * neighboring_quads, sc_array_t * neighboring_encs, sc_array_t * neighboring_qids);
source
P4est.LibP4est.p4est_mesh_get_quadrantMethod
p4est_mesh_get_quadrant(p4est_, mesh, qid)

Access a process-local quadrant inside a forest. Needs a mesh with populated quad_to_tree array. This is a special case of p4estmeshquadrant_cumulative.

Parameters

  • p4est:[in] The forest.
  • mesh:[in] The mesh.
  • qid:[in] Process-local id of the quadrant (cumulative over trees).

Returns

A pointer to the requested quadrant.

Prototype

p4est_quadrant_t *p4est_mesh_get_quadrant (p4est_t * p4est, p4est_mesh_t * mesh, p4est_locidx_t qid);
source
P4est.LibP4est.p4est_mesh_memory_usedMethod
p4est_mesh_memory_used(mesh)

Calculate the memory usage of the mesh structure.

Parameters

  • mesh:[in] Mesh structure.

Returns

Memory used in bytes.

Prototype

size_t p4est_mesh_memory_used (p4est_mesh_t * mesh);
source
P4est.LibP4est.p4est_mesh_newMethod
p4est_mesh_new(p4est_, ghost, btype)

Create a p4est_mesh structure. This function does not populate the quad_to_tree and quad_level fields. To populate them, use p4estmeshnew_ext.

Parameters

  • p4est:[in] A forest that is fully 2:1 balanced.
  • ghost:[in] The ghost layer created from the provided p4est.
  • btype:[in] Determines the highest codimension of neighbors.

Returns

A fully allocated mesh structure.

Prototype

p4est_mesh_t *p4est_mesh_new (p4est_t * p4est, p4est_ghost_t * ghost, p4est_connect_type_t btype);
source
P4est.LibP4est.p4est_mesh_new_extMethod
p4est_mesh_new_ext(p4est_, ghost, compute_tree_index, compute_level_lists, btype)

Create a new mesh.

Parameters

  • p4est:[in] A forest that is fully 2:1 balanced.
  • ghost:[in] The ghost layer created from the provided p4est.
  • compute_tree_index:[in] Boolean to decide whether to allocate and compute the quad_to_tree list.
  • compute_level_lists:[in] Boolean to decide whether to compute the level lists in quad_level.
  • btype:[in] Currently ignored, only face neighbors are stored.

Returns

A fully allocated mesh structure.

Prototype

p4est_mesh_t *p4est_mesh_new_ext (p4est_t * p4est, p4est_ghost_t * ghost, int compute_tree_index, int compute_level_lists, p4est_connect_type_t btype);
source
P4est.LibP4est.p4est_mesh_quadrant_cumulativeMethod
p4est_mesh_quadrant_cumulative(p4est_, mesh, cumulative_id, which_tree, quadrant_id)

Find a quadrant based on its cumulative number in the local forest. If the quad_to_tree field of the mesh structure exists, this is O(1). Otherwise, we perform a binary search over the processor-local trees.

Parameters

  • p4est:[in] Forest to be worked with.
  • mesh:[in] A mesh derived from the forest.
  • cumulative_id:[in] Cumulative index over all trees of quadrant. Must refer to a local (non-ghost) quadrant.
  • which_tree:[in,out] If not NULL, the input value can be -1 or an initial guess for the quadrant's tree and output is the tree of returned quadrant.
  • quadrant_id:[out] If not NULL, the number of quadrant in tree.

Returns

The identified quadrant.

Prototype

p4est_quadrant_t *p4est_mesh_quadrant_cumulative (p4est_t * p4est, p4est_mesh_t * mesh, p4est_locidx_t cumulative_id, p4est_topidx_t * which_tree, p4est_locidx_t * quadrant_id);
source
P4est.LibP4est.p4est_newMethod
p4est_new(mpicomm, connectivity, data_size, init_fn, user_pointer)

Prototype

p4est_t *p4est_new (sc_MPI_Comm mpicomm, p4est_connectivity_t * connectivity, size_t data_size, p4est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p4est_new_extMethod
p4est_new_ext(mpicomm, connectivity, min_quadrants, min_level, fill_uniform, data_size, init_fn, user_pointer)

Prototype

p4est_t *p4est_new_ext (sc_MPI_Comm mpicomm, p4est_connectivity_t * connectivity, p4est_locidx_t min_quadrants, int min_level, int fill_uniform, size_t data_size, p4est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p4est_partitionMethod
p4est_partition(p4est_, allow_for_coarsening, weight_fn)

Equally partition the forest. The partition can be by element count or by a user-defined weight.

The forest will be partitioned between processors such that they have an approximately equal number of quadrants (or sum of weights).

On one process, the function noops and does not call the weight callback. Otherwise, the weight callback is called once per quadrant in order.

Parameters

  • p4est:[in,out] The forest that will be partitioned.
  • allow_for_coarsening:[in] Slightly modify partition such that quadrant families are not split between ranks.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning. When running with mpisize == 1, never called. Otherwise, called in order for all quadrants if not NULL. A weighting function with constant weight 1 on each quadrant is equivalent to weight_fn == NULL but other constant weightings may result in different uniform partitionings.

Prototype

void p4est_partition (p4est_t * p4est, int allow_for_coarsening, p4est_weight_t weight_fn);
source
P4est.LibP4est.p4est_partition_extMethod
p4est_partition_ext(p4est_, partition_for_coarsening, weight_fn)

Repartition the forest.

The forest is partitioned between processors such that each processor has an approximately equal number of quadrants (or weight).

Parameters

  • p4est:[in,out] The forest that will be partitioned.
  • partition_for_coarsening:[in] If true, the partition is modified to allow one level of coarsening.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning. A weighting function with constant weight 1 on each quadrant is equivalent to weight_fn == NULL but other constant weightings may result in different uniform partitionings.

Returns

The global number of shipped quadrants

Prototype

p4est_gloidx_t p4est_partition_ext (p4est_t * p4est, int partition_for_coarsening, p4est_weight_t weight_fn);
source
P4est.LibP4est.p4est_partition_for_coarseningMethod
p4est_partition_for_coarsening(p4est_, num_quadrants_in_proc)

Correct partition to allow one level of coarsening.

Parameters

  • p4est:[in] forest whose partition is corrected
  • num_quadrants_in_proc:[in,out] partition that will be corrected

Returns

absolute number of moved quadrants

Prototype

p4est_gloidx_t p4est_partition_for_coarsening (p4est_t * p4est, p4est_locidx_t * num_quadrants_in_proc);
source
P4est.LibP4est.p4est_partition_lnodesMethod
p4est_partition_lnodes(p4est_, ghost, degree, partition_for_coarsening)

Partition using weights based on the number of nodes assigned to each element in lnodes

Parameters

  • p4est:[in,out] the forest to be repartitioned
  • ghost:[in] the ghost layer
  • degree:[in] the degree that would be passed to p4est_lnodes_new()
  • partition_for_coarsening:[in] whether the partition should allow coarsening (i.e. group siblings who might merge)

Prototype

void p4est_partition_lnodes (p4est_t * p4est, p4est_ghost_t * ghost, int degree, int partition_for_coarsening);
source
P4est.LibP4est.p4est_partition_lnodes_detailedMethod
p4est_partition_lnodes_detailed(p4est_, ghost, nodes_per_volume, nodes_per_face, nodes_per_corner, partition_for_coarsening)

Partition using weights that are broken down by where they reside: in volumes, on faces, or on corners.

Prototype

void p4est_partition_lnodes_detailed (p4est_t * p4est, p4est_ghost_t * ghost, int nodes_per_volume, int nodes_per_face, int nodes_per_corner, int partition_for_coarsening);
source
P4est.LibP4est.p4est_partition_to_p6est_partitionMethod
p4est_partition_to_p6est_partition(p6est_, num_columns_in_proc, num_layers_in_proc)

Prototype

void p4est_partition_to_p6est_partition (p6est_t * p6est, p4est_locidx_t * num_columns_in_proc, p4est_locidx_t * num_layers_in_proc);
source
P4est.LibP4est.p4est_qcoord_to_vertexMethod
p4est_qcoord_to_vertex(connectivity, treeid, x, y, vxyz)

Transform a quadrant coordinate into the space spanned by tree vertices.

Parameters

  • connectivity:[in] Connectivity must provide the vertices.
  • treeid:[in] Identify the tree that contains x, y.
  • x,:[in] y Quadrant coordinates relative to treeid.
  • vxyz:[out] Transformed coordinates in vertex space.

Prototype

void p4est_qcoord_to_vertex (p4est_connectivity_t * connectivity, p4est_topidx_t treeid, p4est_qcoord_t x, p4est_qcoord_t y, double vxyz[3]);
source
P4est.LibP4est.p4est_quadrant_existsMethod
p4est_quadrant_exists(p4est_, ghost, treeid, q, exists_arr, rproc_arr, rquad_arr)

Checks if quadrant exists in the local forest or the ghost layer.

For quadrants across tree corners it checks if the quadrant exists in any of the corner neighbors, thus it can execute multiple queries.

Parameters

  • p4est:[in] The forest in which to search for q
  • ghost:[in] The ghost layer in which to search for q
  • treeid:[in] The tree to which q belongs (can be extended).
  • q:[in] The quadrant that is being searched for.
  • exists_arr:[in,out] Must exist and be of of elem_size = sizeof (int) for inter-tree corner cases. Is resized by this function to one entry for each corner search and set to true/false depending on its existence in the local forest or ghost_layer.
  • rproc_arr:[in,out] If not NULL is filled with one rank per query.
  • rquad_arr:[in,out] If not NULL is filled with one quadrant per query. Its piggy3 member is defined as well.

Returns

true if the quadrant exists in the local forest or in the ghost_layer, and false if doesn't exist in either.

Prototype

int p4est_quadrant_exists (p4est_t * p4est, p4est_ghost_t * ghost, p4est_topidx_t treeid, const p4est_quadrant_t * q, sc_array_t * exists_arr, sc_array_t * rproc_arr, sc_array_t * rquad_arr);
source
P4est.LibP4est.p4est_quadrant_find_ownerMethod
p4est_quadrant_find_owner(p4est_, treeid, face, q)

Gets the processor id of a quadrant's owner. The quadrant can lie outside of a tree across faces (and only faces).

Warning

Does not work for tree edge or corner neighbors.

Parameters

  • p4est:[in] The forest in which to search for a quadrant.
  • treeid:[in] The tree to which the quadrant belongs.
  • face:[in] Supply a face direction if known, or -1 otherwise.
  • q:[in] The quadrant that is being searched for.

Returns

Processor id of the owner or -1 if the quadrant lies outside of the mesh.

Prototype

int p4est_quadrant_find_owner (p4est_t * p4est, p4est_topidx_t treeid, int face, const p4est_quadrant_t * q);
source
P4est.LibP4est.p4est_quadrant_linear_id_ext128Method
p4est_quadrant_linear_id_ext128(quadrant, level, id)

Computes the linear position as p4est_lid_t of a quadrant in a uniform grid. The grid and quadrant levels need not coincide. If they do, this is the inverse of p4estquadrantset_morton.

Note

The user_data of quadrant is never modified.

Parameters

  • quadrant:[in] Quadrant whose linear index will be computed. If the quadrant is smaller than the grid (has a higher quadrant->level), the result is computed from its ancestor at the grid's level. If the quadrant has a smaller level than the grid (it is bigger than a grid cell), the grid cell sharing its lower left corner is used as reference.
  • level:[in] The level of the regular grid compared to which the linear position is to be computed.
  • id:[in,out] A pointer to an allocated or static p4est_lid_t. id will be the linear position of this quadrant on a uniform grid.

Prototype

void p4est_quadrant_linear_id_ext128 (const p4est_quadrant_t * quadrant, int level, p4est_lid_t * id);
source
P4est.LibP4est.p4est_quadrant_set_morton_ext128Method
p4est_quadrant_set_morton_ext128(quadrant, level, id)

Set quadrant Morton indices based on linear position given as p4est_lid_t in uniform grid. This is the inverse operation of p4estquadrantlinear_id.

Note

The user_data of quadrant is never modified.

Parameters

  • quadrant:[in,out] Quadrant whose Morton indices will be set.
  • level:[in] Level of the grid and of the resulting quadrant.
  • id:[in] Linear index of the quadrant on a uniform grid.

Prototype

void p4est_quadrant_set_morton_ext128 (p4est_quadrant_t * quadrant, int level, const p4est_lid_t * id);
source
P4est.LibP4est.p4est_refineMethod
p4est_refine(p4est_, refine_recursive, refine_fn, init_fn)

Refine a forest.

Parameters

  • p4est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn gets called, or use p4est_refine_ext in p4est_extended.h and examine whether replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data of newly created quadrants, which is already allocated. This function pointer may be NULL.

Prototype

void p4est_refine (p4est_t * p4est, int refine_recursive, p4est_refine_t refine_fn, p4est_init_t init_fn);
source
P4est.LibP4est.p4est_refine_extMethod
p4est_refine_ext(p4est_, refine_recursive, maxlevel, refine_fn, init_fn, replace_fn)

Refine a forest with a bounded refinement level and a replace option.

Parameters

  • p4est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • maxlevel:[in] Maximum allowed refinement level (inclusive). If this is negative the level is restricted only by the compile-time constant QMAXLEVEL in p4est.h.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn or replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data for newly created quadrants, which is guaranteed to be allocated. This function pointer may be NULL.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace; may be NULL.

Prototype

void p4est_refine_ext (p4est_t * p4est, int refine_recursive, int maxlevel, p4est_refine_t refine_fn, p4est_init_t init_fn, p4est_replace_t replace_fn);
source
P4est.LibP4est.p4est_reset_dataMethod
p4est_reset_data(p4est_, data_size, init_fn, user_pointer)

Reset user pointer and element data. When the data size is changed the quadrant data is freed and allocated. The initialization callback is invoked on each quadrant. Old user_data content is disregarded.

Parameters

  • data_size:[in] This is the size of data for each quadrant which can be zero. Then user_data_pool is set to NULL.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically. May be NULL.
  • user_pointer:[in] Assign to the user_pointer member of the p4est before init_fn is called the first time.

Prototype

void p4est_reset_data (p4est_t * p4est, size_t data_size, p4est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p4est_revisionMethod
p4est_revision(p4est_)

Return the revision counter of the forest. Not collective, even though the revision value is the same on all ranks. A newly created forest starts with a revision counter of zero. Every refine, coarsen, partition, and balance that actually changes the mesh increases the counter by one. Operations with no effect keep the old value.

Parameters

  • p8est:[in] The forest must be valid.

Returns

Non-negative number.

Prototype

long p4est_revision (p4est_t * p4est);
source
P4est.LibP4est.p4est_saveMethod
p4est_save(filename, p4est_, save_data)

Save the complete connectivity/p4est data to disk.

This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations.

By default, we write the current processor count and partition into the file header. This makes the file depend on mpisize. For changing this see p4est_save_ext() in p4est_extended.h.

The revision counter is not saved to the file, since that would make files different that come from different revisions but store the same mesh.

Note

Aborts on file errors.

Note

If p4est is not configured to use MPI-IO, some processes return from this function before the file is complete, in which case immediate read-access to the file may require a call to sc_MPI_Barrier.

Parameters

  • filename:[in] Name of the file to write.
  • p4est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.

Prototype

void p4est_save (const char *filename, p4est_t * p4est, int save_data);
source
P4est.LibP4est.p4est_save_extMethod
p4est_save_ext(filename, p4est_, save_data, save_partition)

Save the complete connectivity/p4est data to disk. This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations. See p4est_load_ext for information on the autopartition parameter.

Note

Aborts on file errors.

Parameters

  • filename:[in] Name of the file to write.
  • p4est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.
  • save_partition:[in] If false, save file as if 1 core was used. If true, save core count and partition. Advantage: Partition can be recovered on loading with same mpisize and autopartition false. Disadvantage: Makes the file depend on mpisize. Either way the file can be loaded with autopartition true.

Prototype

void p4est_save_ext (const char *filename, p4est_t * p4est, int save_data, int save_partition);
source
P4est.LibP4est.p4est_searchMethod
p4est_search(p4est_, quadrant_fn, point_fn, points)

This function is provided for backwards compatibility. We call p4estsearchlocal with call_post = 0.

Prototype

void p4est_search (p4est_t * p4est, p4est_search_query_t quadrant_fn, p4est_search_query_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p4est_search_allMethod
p4est_search_all(p4est_, call_post, quadrant_fn, point_fn, points)

Perform a top-down search on the whole forest.

This function combines the functionality of p4estsearchlocal and p4estsearchpartition; their documentation applies for the most part.

The recursion proceeds from the root quadrant of each tree until (a) we encounter a remote quadrant that covers only one processor, or (b) we encounter a local leaf quadrant. In other words, we proceed with the recursion into a quadrant's children if (a) the quadrant is split between two or more processors, no matter whether one of them is the calling processor or not, or (b) if the quadrant is on the local processor but we have not reached a leaf yet.

The search can track one or more points, which are abstract placeholders. They are matched against the quadrants traversed using a callback function. The result of the callback function can be used to stop a recursion early. The user determines how a point is interpreted, we only pass it around.

Note that in the remote case (a), we may terminate the recursion even if the quadrant is not a leaf, which we have no means of knowing. Still, this case is sufficient to determine the processor ownership of a point.

Note

This is a very powerful function that can become slow if not used carefully.

Note

As with the two other search functions in this file, calling it once with many points is generally much faster than calling it once for each point. Using multiple points also allows for a per-quadrant termination of the recursion in addition to a more costly per-point termination.

Note

This function works fine when used for the special cases that either the partition or the local quadrants are not of interest. However, in the case of querying only local information we expect that p4estsearchlocal will be faster since it employs specific local optimizations.

Parameters

  • p4est:[in] The forest to be searched.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] Executed once for each quadrant that is entered. If the callback returns false, this quadrant and its descendants are excluded from the search, and the points in this branch are not queried further. Its point argument is always NULL. Callback may be NULL in which case it is ignored.
  • point_fn:[in] Executed once for each point that is relevant for a quadrant of the search. If it returns true, the point is tracked further down that branch, else it is discarded from the queries for the children. If points is not NULL, this callback must be not NULL. If points is NULL, it is not called.
  • points:[in] User-defined array of points. We do not interpret a point, just pass it into the callbacks. If NULL, only the quadrant_fn callback is executed. If that is NULL, the whole function noops. If not NULL, the point_fn is called on its members during the search.

Prototype

void p4est_search_all (p4est_t * p4est, int call_post, p4est_search_all_t quadrant_fn, p4est_search_all_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p4est_search_localMethod
p4est_search_local(p4est_, call_post, quadrant_fn, point_fn, points)

Search through the local part of a forest. The search is especially efficient if multiple targets, called "points" below, are searched for simultaneously.

The search runs over all local quadrants and proceeds recursively top-down. For each tree, it may start at the root of that tree, or further down at the root of the subtree that contains all of the tree's local quadrants. Likewise, some intermediate levels in the recursion may be skipped if the processor-local part is contained in a single deeper subtree. The outer loop is thus a depth-first, processor-local forest traversal. Each quadrant in that loop either is a leaf, or a (direct or indirect) strict ancestor of a leaf. On entering a new quadrant, a user-provided quadrant-callback is executed.

As a convenience, the user may provide anonymous "points" that are tracked down the forest. This way one search call may be used for multiple targets. The set of points that potentially matches a given quadrant diminishes from the root down to the leaves: For each quadrant, an inner loop over the potentially matching points executes a point-callback for each candidate that determines whether the point may be a match. If not, it is discarded in the current branch, otherwise it is passed to the next deeper level. The callback is allowed to return true for the same point and more than one quadrant; in this case more than one matching quadrant may be identified. The callback is also allowed to return false for all children of a quadrant that it returned true for earlier. If the point callback returns false for all points relevant to a quadrant, the recursion stops. The points can really be anything, p4est does not perform any interpretation, just passes the pointer along to the callback function.

If points are present and the first quadrant callback returned true, we execute it a second time after calling the point callback for all current points. This can be used to gather and postprocess information about the points more easily. If it returns false, the recursion stops.

If the points are a NULL array, they are ignored and the recursion proceeds by querying the per-quadrant callback. If the points are not NULL but an empty array, the recursion will stop immediately!

Parameters

  • p4est:[in] The forest to be searched.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] Executed once when a quadrant is entered, and once when it is left (the second time only if points are present and the first call returned true). This quadrant is always local, if not completely then at least one descendant of it. If the callback returns false, this quadrant and its descendants are excluded from the search recursion. Its point argument is always NULL. Callback may be NULL in which case it is ignored.
  • point_fn:[in] If points is not NULL, must be not NULL. Shall return true for any possible matching point. If points is NULL, this callback is ignored.
  • points:[in] User-defined array of "points". If NULL, only the quadrant_fn callback is executed. If that is NULL, this function noops. If not NULL, the point_fn is called on its members during the search.

Prototype

void p4est_search_local (p4est_t * p4est, int call_post, p4est_search_local_t quadrant_fn, p4est_search_local_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p4est_search_partitionMethod
p4est_search_partition(p4est_, call_post, quadrant_fn, point_fn, points)

Traverse the global partition top-down. We proceed top-down through the partition, identically on all processors except for the results of two user-provided callbacks. The recursion will only go down branches that are split between multiple processors. The callback functions can be used to stop a branch recursion even for split branches. This function offers the option to search for arbitrary user-defined points analogously to p4estsearchlocal.

Note

Traversing the whole processor partition will be at least O(P), so sensible use of the callback function is advised to cut it short.

Parameters

  • p4est:[in] The forest to traverse. Its local quadrants are never accessed.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] This function controls the recursion, which only continues deeper if this callback returns true for a branch quadrant. It is allowed to set this to NULL.
  • point_fn:[in] This function decides per-point whether it is followed down the recursion. Must be non-NULL if points are not NULL.
  • points:[in] User-provided array of points that are passed to the callback point_fn. See p4estsearchlocal for details.

Prototype

void p4est_search_partition (p4est_t * p4est, int call_post, p4est_search_partition_t quadrant_fn, p4est_search_partition_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p4est_source_extMethod
p4est_source_ext(src, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p4est_t *p4est_source_ext (sc_io_source_t * src, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p4est_connectivity_t ** connectivity);
source
P4est.LibP4est.p4est_split_arrayMethod
p4est_split_array(array, level, indices)

Split an array of quadrants by the children of an ancestor.

Given a sorted array of quadrants that have a common ancestor at level level, compute the indices of the first quadrant in each of the common ancestor's children at level level + 1.

Parameters

  • array:[in] The sorted array of quadrants of level > level.
  • level:[in] The level at which there is a common ancestor.
  • indices:[in,out] The indices of the first quadrant in each of the ancestors's children, plus an additional index on the end. The quadrants of array that are descendants of child i have indices between indices[i] and indices[i + 1] - 1. If indices[i] = indices[i+1], this indicates that no quadrant in the array is contained in child i.

Prototype

void p4est_split_array (sc_array_t * array, int level, size_t indices[]);
source
P4est.LibP4est.p4est_versionMethod
p4est_version()

Return the full version of p4est.

Returns

Return the version of p4est using the format VERSION\_MAJOR.VERSION\_MINOR.VERSION\_POINT, where VERSION_POINT can contain dots and characters, e.g. to indicate the additional number of commits and a git commit hash.

Prototype

const char *p4est_version (void);
source
P4est.LibP4est.p6est_balanceMethod
p6est_balance(p6est_, btype, init_fn)

Balance a forest.

Parameters

  • p6est:[in] The p6est to be worked on.
  • btype:[in] Balance type (face, corner or default, full).
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p6est_balance (p6est_t * p6est, p8est_connect_type_t btype, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_balance_extMethod
p6est_balance_ext(p6est_, btype, max_diff, min_diff, init_fn, replace_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p6est:[in,out] The p6est to be worked on.
  • btype:[in] Balance type (face or corner/full). Corner balance is almost never required when discretizing a PDE; just causes smoother mesh grading.
  • max_diff:[in] The maximum difference between the horizontal refinement level and the vertical refinement level
  • min_diff:[in] The minimum difference between the horizontal refinement level and the vertical refinement level
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p6est_balance_ext (p6est_t * p6est, p8est_connect_type_t btype, int max_diff, int min_diff, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_checksumMethod
p6est_checksum(p6est_)

Compute the checksum for a forest. Based on quadrant arrays only. It is independent of partition and mpisize.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p6est_checksum (p6est_t * p6est);
source
P4est.LibP4est.p6est_coarsen_columnsMethod
p6est_coarsen_columns(p6est_, coarsen_recursive, coarsen_fn, init_fn)

Coarsen the columns of a sheet.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • coarsen_fn:[in] Callback function that returns true if a family of columns shall be coarsened
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p6est_coarsen_columns (p6est_t * p6est, int coarsen_recursive, p6est_coarsen_column_t coarsen_fn, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_coarsen_columns_extMethod
p6est_coarsen_columns_ext(p6est_, coarsen_recursive, callback_orphans, coarsen_fn, init_fn, replace_fn)

Horizontally coarsen a forest.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • callback_orphans:[in] Boolean to enable calling coarsen_fn even on non-families. In this case, the second quadrant pointer in the argument list of the callback is NULL, subsequent pointers are undefined, and the return value is ignored. If coarsen_recursive is true, it is possible that a quadrant is called once or more as an orphan and eventually becomes part of a family.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p6est_coarsen_columns_ext (p6est_t * p6est, int coarsen_recursive, int callback_orphans, p6est_coarsen_column_t coarsen_fn, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_coarsen_layersMethod
p6est_coarsen_layers(p6est_, coarsen_recursive, coarsen_fn, init_fn)

Coarsen the layers of a sheet.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • coarsen_fn:[in] Callback function that returns true if a family of layers shall be coarsened
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p6est_coarsen_layers (p6est_t * p6est, int coarsen_recursive, p6est_coarsen_layer_t coarsen_fn, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_coarsen_layers_extMethod
p6est_coarsen_layers_ext(p6est_, coarsen_recursive, callback_orphans, coarsen_fn, init_fn, replace_fn)

Vertically coarsen a forest.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • callback_orphans:[in] Boolean to enable calling coarsen_fn even on non-families. In this case, the second quadrant pointer in the argument list of the callback is NULL, subsequent pointers are undefined, and the return value is ignored. If coarsen_recursive is true, it is possible that a quadrant is called once or more as an orphan and eventually becomes part of a family.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p6est_coarsen_layers_ext (p6est_t * p6est, int coarsen_recursive, int callback_orphans, p6est_coarsen_layer_t coarsen_fn, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_connectivity_newMethod
p6est_connectivity_new(conn4, top_vertices, height)

Create a p6est_connectivity_t from a p4est_connectivity_t. All fields are copied, so all inputs can be safey destroyed.

Parameters

  • conn4:[in] the 2D connectivity
  • top_vertices:[in] if NULL, then the sheet has a uniform vertical profile; otherwise, top_vertices gives teh vertices of the top of the sheet; should be the same size as conn4->treetovertex
  • height:[in] if top_vertices == NULL, then this gives the offset fro the bottom of the sheet to the top.

Returns

the 2D+1D connectivity information.

Prototype

p6est_connectivity_t *p6est_connectivity_new (p4est_connectivity_t * conn4, double *top_vertices, double height[3]);
source
P4est.LibP4est.p6est_copyMethod
p6est_copy(input, copy_data)

Make a deep copy of a p6est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.

Returns

Returns a valid p6est that does not depend on the input.

Prototype

p6est_t *p6est_copy (p6est_t * input, int copy_data);
source
P4est.LibP4est.p6est_copy_extMethod
p6est_copy_ext(input, copy_data, duplicate_mpicomm)

Make a deep copy of a p6est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.
  • duplicate_mpicomm:[in] If true, MPI communicator is copied.

Returns

Returns a valid p6est that does not depend on the input.

Prototype

p6est_t *p6est_copy_ext (p6est_t * input, int copy_data, int duplicate_mpicomm);
source
P4est.LibP4est.p6est_destroyMethod
p6est_destroy(p6est_)

Destroy a p6est.

Note

The connectivity structure is not destroyed with the p6est.

Prototype

void p6est_destroy (p6est_t * p6est);
source
P4est.LibP4est.p6est_loadMethod
p6est_load(filename, mpicomm, data_size, load_data, user_pointer, connectivity)

Prototype

p6est_t *p6est_load (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, void *user_pointer, p6est_connectivity_t ** connectivity);
source
P4est.LibP4est.p6est_load_extMethod
p6est_load_ext(filename, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p6est_t *p6est_load_ext (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p6est_connectivity_t ** connectivity);
source
P4est.LibP4est.p6est_newMethod
p6est_new(mpicomm, connectivity, data_size, init_fn, user_pointer)

Prototype

p6est_t *p6est_new (sc_MPI_Comm mpicomm, p6est_connectivity_t * connectivity, size_t data_size, p6est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p6est_new_extMethod
p6est_new_ext(mpicomm, connectivity, min_quadrants, min_level, min_zlevel, num_zroot, fill_uniform, data_size, init_fn, user_pointer)

Prototype

p6est_t *p6est_new_ext (sc_MPI_Comm mpicomm, p6est_connectivity_t * connectivity, p4est_locidx_t min_quadrants, int min_level, int min_zlevel, int num_zroot, int fill_uniform, size_t data_size, p6est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p6est_new_from_p4estMethod
p6est_new_from_p4est(p4est_, top_vertices, height, min_zlevel, data_size, init_fn, user_pointer)

Create a new forest from an already created p4est that represents columns.

Parameters

  • p4est:[in] A valid p4est. A deep copy will be created, so this can be destroyed without affectin the new p6est object.
  • top_vertices:[in] the same as in p6est_conectivity_new()
  • height:[in] the same as in p6est_conectivity_new()
  • min_zlevel:[in] the same as in p6est_new()
  • data_size:[in] the same as in p6est_new()
  • init_fn:[in] the same as in p6est_new()
  • user_pointer:[in] the same as in p6est_new()

Returns

This returns a valid forest. The user must destroy the connectivity for the new p6est independently.

Prototype

p6est_t *p6est_new_from_p4est (p4est_t * p4est, double *top_vertices, double height[3], int min_zlevel, size_t data_size, p6est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p6est_partitionMethod
p6est_partition(p6est_, weight_fn)

Equally partition the forest.

The forest will be partitioned between processors where they each have an approximately equal number of quadrants.

Note that p6est->layers and p6est->globalfirstlayers may change during this call. Address pointers referencing these objects from before p6est_partition is called become invalid.

Parameters

  • p6est:[in,out] The forest that will be partitioned.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning.

Prototype

p4est_gloidx_t p6est_partition (p6est_t * p6est, p6est_weight_t weight_fn);
source
P4est.LibP4est.p6est_partition_extMethod
p6est_partition_ext(p6est_, partition_for_coarsening, weight_fn)

Repartition the forest.

The forest is partitioned between processors such that each processor has an approximately equal number of quadrants (or weight).

Parameters

  • p6est:[in,out] The forest that will be partitioned.
  • partition_for_coarsening:[in] If true, the partition is modified to allow one level of coarsening.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning.

Returns

The global number of shipped quadrants

Prototype

p4est_gloidx_t p6est_partition_ext (p6est_t * p6est, int partition_for_coarsening, p6est_weight_t weight_fn);
source
P4est.LibP4est.p6est_partition_to_p4est_partitionMethod
p6est_partition_to_p4est_partition(p6est_, num_layers_in_proc, num_columns_in_proc)

Prototype

void p6est_partition_to_p4est_partition (p6est_t * p6est, p4est_locidx_t * num_layers_in_proc, p4est_locidx_t * num_columns_in_proc);
source
P4est.LibP4est.p6est_qcoord_to_vertexMethod
p6est_qcoord_to_vertex(connectivity, treeid, x, y, z, vxyz)

Transform a quadrant coordinate into the space spanned by tree vertices.

Parameters

  • connectivity:[in] Connectivity must provide the vertices.
  • treeid:[in] Identify the tree that contains x, y.
  • x,:[in] y Quadrant coordinates relative to treeid.
  • vxy:[out] Transformed coordinates in vertex space.

Prototype

void p6est_qcoord_to_vertex (p6est_connectivity_t * connectivity, p4est_topidx_t treeid, p4est_qcoord_t x, p4est_qcoord_t y, p4est_qcoord_t z, double vxyz[3]);
source
P4est.LibP4est.p6est_refine_columnsMethod
p6est_refine_columns(p6est_, refine_recursive, refine_fn, init_fn)

Refine the columns of a sheet.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • refine_fn:[in] Callback function that must return true if a column shall be refined into smaller columns. If refine_recursive is true, refine_fn is called for every existing and newly created column. Otherwise, it is called for every existing column. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn gets called, or use p6est_refine_columns_ext in p6est_extended.h and examine whether replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data of newly created layers within columns, which are already allocated. This function pointer may be NULL.

Prototype

void p6est_refine_columns (p6est_t * p6est, int refine_recursive, p6est_refine_column_t refine_fn, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_refine_columns_extMethod
p6est_refine_columns_ext(p6est_, refine_recursive, maxlevel, refine_fn, init_fn, replace_fn)

Horizontally refine a forest with a bounded refinement level and a replace option.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • maxlevel:[in] Maximum allowed refinement level (inclusive). If this is negative the level is restricted only by the compile-time constant QMAXLEVEL in p4est.h.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn or replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data for newly created quadrants, which is guaranteed to be allocated. This function pointer may be NULL.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace; may be NULL.

Prototype

void p6est_refine_columns_ext (p6est_t * p6est, int refine_recursive, int maxlevel, p6est_refine_column_t refine_fn, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_refine_layersMethod
p6est_refine_layers(p6est_, refine_recursive, refine_fn, init_fn)

Refine the layers within the columns of a sheet.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • refine_fn:[in] Callback function that must return true if a layer shall be refined into smaller layers. If refine_recursive is true, refine_fn is called for every existing and newly created layer. Otherwise, it is called for every existing layer. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn gets called, or use p6est_refine_layers_ext in p6est_extended.h and examine whether replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data of newly created layers, which are already allocated. This function pointer may be NULL.

Prototype

void p6est_refine_layers (p6est_t * p6est, int refine_recursive, p6est_refine_layer_t refine_fn, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_refine_layers_extMethod
p6est_refine_layers_ext(p6est_, refine_recursive, maxlevel, refine_fn, init_fn, replace_fn)

Vertically refine a forest with a bounded refinement level and a replace option.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • maxlevel:[in] Maximum allowed refinement level (inclusive). If this is negative the level is restricted only by the compile-time constant QMAXLEVEL in p4est.h.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn or replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data for newly created quadrants, which is guaranteed to be allocated. This function pointer may be NULL.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace; may be NULL.

Prototype

void p6est_refine_layers_ext (p6est_t * p6est, int refine_recursive, int maxlevel, p6est_refine_layer_t refine_fn, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_reset_dataMethod
p6est_reset_data(p6est_, data_size, init_fn, user_pointer)

Reset user pointer and element data. When the data size is changed the quadrant data is freed and allocated. The initialization callback is invoked on each quadrant. Old user_data content is disregarded.

Parameters

  • data_size:[in] This is the size of data for each quadrant which can be zero. Then user_data_pool is set to NULL.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • user_pointer:[in] Assign to the user_pointer member of the p6est before init_fn is called the first time.

Prototype

void p6est_reset_data (p6est_t * p6est, size_t data_size, p6est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p6est_saveMethod
p6est_save(filename, p6est_, save_data)

Save the complete connectivity/p6est data to disk. This is a collective

operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations.

Note

Aborts on file errors.

Parameters

  • filename:[in] Name of the file to write.
  • p6est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.

Prototype

void p6est_save (const char *filename, p6est_t * p6est, int save_data);
source
P4est.LibP4est.p6est_save_extMethod
p6est_save_ext(filename, p6est_, save_data, save_partition)

Save the complete connectivity/p6est data to disk.

This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations. See p6est_load_ext() for information on the autopartition parameter.

Note

Aborts on file errors.

Parameters

  • filename:[in] Name of the file to write.
  • p6est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.
  • save_partition:[in] If false, save file as if 1 core was used. If true, save core count and partition. Advantage: Partition can be recovered on loading with same mpisize and autopartition false. Disadvantage: Makes the file depend on mpisize. Either way the file can be loaded with autopartition true.

Prototype

void p6est_save_ext (const char *filename, p6est_t * p6est, int save_data, int save_partition);
source
P4est.LibP4est.p6est_tree_get_verticesMethod
p6est_tree_get_vertices(conn, which_tree, vertices)

Get the vertices of the corners of a tree.

Parameters

  • conn:[in] the 2D+1D connectivity structure
  • which_tree:[in] a tree in the forest
  • vertices:[out] the coordinates of the corners of the tree

Prototype

void p6est_tree_get_vertices (p6est_connectivity_t * conn, p4est_topidx_t which_tree, double vertices[24]);
source
P4est.LibP4est.p8est_balanceMethod
p8est_balance(p8est_, btype, init_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p8est:[in,out] The p8est to be worked on.
  • btype:[in] Balance type (face, edge, or corner/full). Examples: Finite volume or discontinuous Galerkin methods only require face balance. Continuous finite element methods usually require edge balance. Corner balance is almost never required mathematically; it just produces a smoother mesh grading.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p8est_balance (p8est_t * p8est, p8est_connect_type_t btype, p8est_init_t init_fn);
source
P4est.LibP4est.p8est_balance_extMethod
p8est_balance_ext(p8est_, btype, init_fn, replace_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p8est:[in,out] The p8est to be worked on.
  • btype:[in] Balance type (face, edge, or corner/full). Corner balance is almost never required when discretizing a PDE; just causes smoother mesh grading.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p8est_balance_ext (p8est_t * p8est, p8est_connect_type_t btype, p8est_init_t init_fn, p8est_replace_t replace_fn);
source
P4est.LibP4est.p8est_balance_subtree_extMethod
p8est_balance_subtree_ext(p8est_, btype, which_tree, init_fn, replace_fn)

Prototype

void p8est_balance_subtree_ext (p8est_t * p8est, p8est_connect_type_t btype, p4est_topidx_t which_tree, p8est_init_t init_fn, p8est_replace_t replace_fn);
source
P4est.LibP4est.p8est_checksumMethod
p8est_checksum(p8est_)

Compute the checksum for a forest. Based on quadrant arrays only. It is independent of partition and mpisize.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p8est_checksum (p8est_t * p8est);
source
P4est.LibP4est.p8est_checksum_partitionMethod
p8est_checksum_partition(p8est_)

Compute a partition-dependent checksum for a forest.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p8est_checksum_partition (p8est_t * p8est);
source
P4est.LibP4est.p8est_coarsenMethod
p8est_coarsen(p8est_, coarsen_recursive, coarsen_fn, init_fn)

Coarsen a forest.

Parameters

  • p8est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p8est_coarsen (p8est_t * p8est, int coarsen_recursive, p8est_coarsen_t coarsen_fn, p8est_init_t init_fn);
source
P4est.LibP4est.p8est_coarsen_extMethod
p8est_coarsen_ext(p8est_, coarsen_recursive, callback_orphans, coarsen_fn, init_fn, replace_fn)

Coarsen a forest.

Parameters

  • p8est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • callback_orphans:[in] Boolean to enable calling coarsen_fn even on non-families. In this case, the second quadrant pointer in the argument list of the callback is NULL, subsequent pointers are undefined, and the return value is ignored. If coarsen_recursive is true, it is possible that a quadrant is called once or more as an orphan and eventually becomes part of a family. With coarsen_recursive false and callback_orphans true, it is guaranteed that every quadrant is passed exactly once into the coarsen_fn callback.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p8est_coarsen_ext (p8est_t * p8est, int coarsen_recursive, int callback_orphans, p8est_coarsen_t coarsen_fn, p8est_init_t init_fn, p8est_replace_t replace_fn);
source
P4est.LibP4est.p8est_connectivity_completeMethod
p8est_connectivity_complete(conn)

Internally connect a connectivity based on tree_to_vertex information. Periodicity that is not inherent in the list of vertices will be lost.

Parameters

  • conn:[in,out] The connectivity needs to have proper vertices and tree_to_vertex fields. The tree_to_tree and tree_to_face fields must be allocated and satisfy p8est_connectivity_is_valid (conn) but will be overwritten. The edge and corner fields will be freed and allocated anew.

Prototype

void p8est_connectivity_complete (p8est_connectivity_t * conn);
source
P4est.LibP4est.p8est_connectivity_deflateMethod
p8est_connectivity_deflate(conn, code)

Allocate memory and store the connectivity information there.

Parameters

  • conn:[in] The connectivity structure to be exported to memory.
  • code:[in] Encoding and compression method for serialization.

Returns

Newly created array that contains the information.

Prototype

sc_array_t *p8est_connectivity_deflate (p8est_connectivity_t * conn, p8est_connectivity_encode_t code);
source
P4est.LibP4est.p8est_connectivity_destroyMethod
p8est_connectivity_destroy(connectivity)

Destroy a connectivity structure. Also destroy all attributes.

Prototype

void p8est_connectivity_destroy (p8est_connectivity_t * connectivity);
source
P4est.LibP4est.p8est_connectivity_edge_neighbor_cornerMethod
p8est_connectivity_edge_neighbor_corner(c, e, ne, o)

Transform a corner across one of the adjacent edges into a neighbor tree. This version expects the neighbor edge and orientation separately.

Parameters

  • c:[in] A corner number in 0..7.
  • e:[in] An edge 0..11 that touches the corner c.
  • ne:[in] A neighbor edge that is on the other side of .
  • o:[in] The orientation between tree boundary edges e and .

Returns

Corner number seen from the neighbor.

Prototype

int p8est_connectivity_edge_neighbor_corner (int c, int e, int ne, int o);
source
P4est.LibP4est.p8est_connectivity_edge_neighbor_edge_cornerMethod
p8est_connectivity_edge_neighbor_edge_corner(ec, o)

Transform an edge corner across one of the adjacent edges into a neighbor tree.

Parameters

  • ec:[in] An edge corner number in 0..1.
  • o:[in] The orientation of a tree boundary edge connection.

Returns

The edge corner number seen from the other tree.

Prototype

int p8est_connectivity_edge_neighbor_edge_corner (int ec, int o);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_cornerMethod
p8est_connectivity_face_neighbor_corner(c, f, nf, o)

Transform a corner across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • c:[in] A corner number in 0..7.
  • f:[in] A face number that touches the corner c.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The number of the corner seen from the neighbor tree.

Prototype

int p8est_connectivity_face_neighbor_corner (int c, int f, int nf, int o);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_corner_setMethod
p8est_connectivity_face_neighbor_corner_set(c, f, nf, set)

Transform a corner across one of the adjacent faces into a neighbor tree. It expects a face permutation index that has been precomputed.

Parameters

  • c:[in] A corner number in 0..7.
  • f:[in] A face number that touches the corner c.
  • nf:[in] A neighbor face that is on the other side of .
  • set:[in] A value from p8estfacepermutation_sets that is obtained using f, nf, and a valid orientation: ref = p8est_face_permutation_refs[f][nf]; set = p8est_face_permutation_sets[ref][orientation];

Returns

The corner number in 0..7 seen from the other face.

Prototype

int p8est_connectivity_face_neighbor_corner_set (int c, int f, int nf, int set);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_edgeMethod
p8est_connectivity_face_neighbor_edge(e, f, nf, o)

Transform an edge across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • e:[in] A edge number in 0..11.
  • f:[in] A face 0..5 that touches the edge e.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The edge's number seen from the neighbor.

Prototype

int p8est_connectivity_face_neighbor_edge (int e, int f, int nf, int o);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_face_cornerMethod
p8est_connectivity_face_neighbor_face_corner(fc, f, nf, o)

Transform a face corner across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • fc:[in] A face corner number in 0..3.
  • f:[in] A face that the face corner fc is relative to.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The face corner number relative to the neighbor's face.

Prototype

int p8est_connectivity_face_neighbor_face_corner (int fc, int f, int nf, int o);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_face_edgeMethod
p8est_connectivity_face_neighbor_face_edge(fe, f, nf, o)

Transform a face-edge across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • fe:[in] A face edge number in 0..3.
  • f:[in] A face number that touches the edge e.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The face edge number seen from the neighbor tree.

Prototype

int p8est_connectivity_face_neighbor_face_edge (int fe, int f, int nf, int o);
source
P4est.LibP4est.p8est_connectivity_inflateMethod
p8est_connectivity_inflate(buffer)

Create new connectivity from a memory buffer.

Parameters

  • buffer:[in] The connectivity is created from this memory buffer.

Returns

The newly created connectivity, or NULL on error.

Prototype

p8est_connectivity_t *p8est_connectivity_inflate (sc_array_t * buffer);
source
P4est.LibP4est.p8est_connectivity_is_equalMethod
p8est_connectivity_is_equal(conn1, conn2)

Check two connectivity structures for equality.

Returns

Returns true if structures are equal, false otherwise.

Prototype

int p8est_connectivity_is_equal (p8est_connectivity_t * conn1, p8est_connectivity_t * conn2);
source
P4est.LibP4est.p8est_connectivity_is_equivalentMethod
p8est_connectivity_is_equivalent(conn1, conn2)

p8est_connectivity_is_equivalent This function compares two connectivities for equivalence: it returns true if they are the same connectivity, or if they have the same topology. The definition of topological sameness is strict: there is no attempt made to determine whether permutation and/or rotation of the trees makes the connectivities equivalent.

Parameters

  • conn1:[in] a valid connectivity
  • conn2:[out] a valid connectivity

Prototype

int p8est_connectivity_is_equivalent (p8est_connectivity_t * conn1, p8est_connectivity_t * conn2);
source
P4est.LibP4est.p8est_connectivity_is_validMethod
p8est_connectivity_is_valid(connectivity)

Examine a connectivity structure.

Returns

Returns true if structure is valid, false otherwise.

Prototype

int p8est_connectivity_is_valid (p8est_connectivity_t * connectivity);
source
P4est.LibP4est.p8est_connectivity_join_facesMethod
p8est_connectivity_join_faces(conn, tree_left, tree_right, face_left, face_right, orientation)

p8est_connectivity_join_faces This function takes an existing valid connectivity conn and modifies it by joining two tree faces that are currently boundary faces.

Parameters

  • conn:[in,out] connectivity that will be altered.
  • tree_left:[in] tree that will be on the left side of the joined faces.
  • tree_right:[in] tree that will be on the right side of the joined faces.
  • face_left:[in] face of tree_left that will be joined.
  • face_right:[in] face of tree_right that will be joined.
  • orientation:[in] the orientation of face_left and face_right once joined (see the description of p8est_connectivity_t to understand orientation).

Prototype

void p8est_connectivity_join_faces (p8est_connectivity_t * conn, p4est_topidx_t tree_left, p4est_topidx_t tree_right, int face_left, int face_right, int orientation);
source
P4est.LibP4est.p8est_connectivity_loadMethod
p8est_connectivity_load(filename, bytes)

Load a connectivity structure from disk.

Parameters

  • filename:[in] Name of the file to read.
  • bytes:[out] Size in bytes of connectivity on disk or NULL.

Returns

Returns valid connectivity, or NULL on file error.

Prototype

p8est_connectivity_t *p8est_connectivity_load (const char *filename, size_t *bytes);
source
P4est.LibP4est.p8est_connectivity_memory_usedMethod
p8est_connectivity_memory_used(conn)

Calculate memory usage of a connectivity structure.

Parameters

  • conn:[in] Connectivity structure.

Returns

Memory used in bytes.

Prototype

size_t p8est_connectivity_memory_used (p8est_connectivity_t * conn);
source
P4est.LibP4est.p8est_connectivity_newMethod
p8est_connectivity_new(num_vertices, num_trees, num_edges, num_ett, num_corners, num_ctt)

Allocate a connectivity structure. The attribute fields are initialized to NULL.

Parameters

  • num_vertices:[in] Number of total vertices (i.e. geometric points).
  • num_trees:[in] Number of trees in the forest.
  • num_edges:[in] Number of tree-connecting edges.
  • num_ett:[in] Number of total trees in edge_to_tree array.
  • num_corners:[in] Number of tree-connecting corners.
  • num_ctt:[in] Number of total trees in corner_to_tree array.

Returns

A connectivity structure with allocated arrays.

Prototype

p8est_connectivity_t *p8est_connectivity_new (p4est_topidx_t num_vertices, p4est_topidx_t num_trees, p4est_topidx_t num_edges, p4est_topidx_t num_ett, p4est_topidx_t num_corners, p4est_topidx_t num_ctt);
source
P4est.LibP4est.p8est_connectivity_new_brickMethod
p8est_connectivity_new_brick(m, n, p, periodic_a, periodic_b, periodic_c)

An m by n by p array with periodicity in x, y, and z if periodic_a, periodic_b, and periodic_c are true, respectively.

Prototype

p8est_connectivity_t *p8est_connectivity_new_brick (int m, int n, int p, int periodic_a, int periodic_b, int periodic_c);
source
P4est.LibP4est.p8est_connectivity_new_bynameMethod
p8est_connectivity_new_byname(name)

Create connectivity structure from predefined catalogue.

Parameters

  • name:[in] Invokes connectivity_new_* function. brick235 brick (2, 3, 5, 0, 0, 0) periodic periodic rotcubes rotcubes rotwrap rotwrap shell shell sphere sphere twocubes twocubes twowrap twowrap unit unitcube

Returns

An initialized connectivity if name is defined, NULL else.

Prototype

p8est_connectivity_t *p8est_connectivity_new_byname (const char *name);
source
P4est.LibP4est.p8est_connectivity_new_copyMethod
p8est_connectivity_new_copy(num_vertices, num_trees, num_edges, num_corners, vertices, ttv, ttt, ttf, tte, eoff, ett, ete, ttc, coff, ctt, ctc)

Allocate a connectivity structure and populate from constants. The attribute fields are initialized to NULL.

Parameters

  • num_vertices:[in] Number of total vertices (i.e. geometric points).
  • num_trees:[in] Number of trees in the forest.
  • num_edges:[in] Number of tree-connecting edges.
  • num_corners:[in] Number of tree-connecting corners.
  • eoff:[in] Edge-to-tree offsets (num_edges + 1 values). This must always be non-NULL; in trivial cases it is just a pointer to a p4est_topix value of 0.
  • coff:[in] Corner-to-tree offsets (num_corners + 1 values). This must always be non-NULL; in trivial cases it is just a pointer to a p4est_topix value of 0.

Returns

The connectivity is checked for validity.

Prototype

p8est_connectivity_t *p8est_connectivity_new_copy (p4est_topidx_t num_vertices, p4est_topidx_t num_trees, p4est_topidx_t num_edges, p4est_topidx_t num_corners, const double *vertices, const p4est_topidx_t * ttv, const p4est_topidx_t * ttt, const int8_t * ttf, const p4est_topidx_t * tte, const p4est_topidx_t * eoff, const p4est_topidx_t * ett, const int8_t * ete, const p4est_topidx_t * ttc, const p4est_topidx_t * coff, const p4est_topidx_t * ctt, const int8_t * ctc);
source
P4est.LibP4est.p8est_connectivity_new_rotcubesMethod
p8est_connectivity_new_rotcubes()

Create a connectivity structure that contains a few cubes. These are rotated against each other to stress the topology routines.

Prototype

p8est_connectivity_t *p8est_connectivity_new_rotcubes (void);
source
P4est.LibP4est.p8est_connectivity_new_rotwrapMethod
p8est_connectivity_new_rotwrap()

Create a connectivity structure for a mostly periodic unit cube. The left and right faces are identified, and bottom and top rotated. Front and back are not identified.

Prototype

p8est_connectivity_t *p8est_connectivity_new_rotwrap (void);
source
P4est.LibP4est.p8est_connectivity_new_shellMethod
p8est_connectivity_new_shell()

Create a connectivity structure that builds a spherical shell. It is made up of six connected parts [-1,1]x[-1,1]x[1,2]. This connectivity reuses vertices and relies on a geometry transformation. It is thus not suitable for p8est_connectivity_complete.

Prototype

p8est_connectivity_t *p8est_connectivity_new_shell (void);
source
P4est.LibP4est.p8est_connectivity_new_sphereMethod
p8est_connectivity_new_sphere()

Create a connectivity structure that builds a solid sphere. It is made up of two layers and a cube in the center. This connectivity reuses vertices and relies on a geometry transformation. It is thus not suitable for p8est_connectivity_complete.

Prototype

p8est_connectivity_t *p8est_connectivity_new_sphere (void);
source
P4est.LibP4est.p8est_connectivity_new_torusMethod
p8est_connectivity_new_torus(nSegments)

Create a connectivity structure that builds a revolution torus.

This connectivity reuses vertices and relies on a geometry transformation. It is thus not suitable for p8est_connectivity_complete.

This connectivity reuses ideas from disk2d connectivity. More precisely the torus is divided into segments arround the revolution axis, each segments is made of 5 trees (à la disk2d). The total number of trees if 5 times the number of segments.

This connectivity is meant to be used with p8estgeometrynew_torus

Parameters

  • nSegments:[in] number of trees along the great circle

Prototype

p8est_connectivity_t *p8est_connectivity_new_torus (int nSegments);
source
P4est.LibP4est.p8est_connectivity_new_twotreesMethod
p8est_connectivity_new_twotrees(l_face, r_face, orientation)

Create a connectivity structure for two trees being rotated w.r.t. each other in a user-defined way.

Parameters

  • l_face:[in] index of left face
  • r_face:[in] index of right face
  • orientation:[in] orientation of trees w.r.t. each other

Prototype

p8est_connectivity_t *p8est_connectivity_new_twotrees (int l_face, int r_face, int orientation);
source
P4est.LibP4est.p8est_connectivity_new_twowrapMethod
p8est_connectivity_new_twowrap()

Create a connectivity structure that contains two cubes where the two far ends are identified periodically.

Prototype

p8est_connectivity_t *p8est_connectivity_new_twowrap (void);
source
P4est.LibP4est.p8est_connectivity_permuteMethod
p8est_connectivity_permute(conn, perm, is_current_to_new)

p8est_connectivity_permute Given a permutation perm of the trees in a connectivity conn, permute the trees of conn in place and update conn to match.

Parameters

  • conn:[in,out] The connectivity whose trees are permuted.
  • perm:[in] A permutation array, whose elements are size_t's.
  • is_current_to_new:[in] if true, the jth entry of perm is the new index for the entry whose current index is j, otherwise the jth entry of perm is the current index of the tree whose index will be j after the permutation.

Prototype

void p8est_connectivity_permute (p8est_connectivity_t * conn, sc_array_t * perm, int is_current_to_new);
source
P4est.LibP4est.p8est_connectivity_read_inpMethod
p8est_connectivity_read_inp(filename)

Create a p4est connectivity from an ABAQUS input file.

This utility function reads a basic ABAQUS file supporting element type with the prefix C2D4, CPS4, and S4 in 2D and of type C3D8 reading them as bilinear quadrilateral and trilinear hexahedral trees respectively.

A basic 2D mesh is given below. The *Node section gives the vertex number and x, y, and z components for each vertex. The *Element section gives the 4 vertices in 2D (8 vertices in 3D) of each element in counter clockwise order. So in 2D the nodes are given as:

4 3 +–––––––––-+ | | | | | | | | | | | | +–––––––––-+ 1 2

and in 3D they are given as:

8 7 +––––––––––-+ |\ |\ | \ | \ | \ | \ | \ | \ | 5+––––––––––-+6 | | | | +––|––––––––+ | 4\ | 3 \ | \ | \ | \ | \ | \| \| +––––––––––-+ 1 2

 *Heading
+ 6,  2,  6, 9,  5

This code can be called two ways. The first, when vertex==NULL and tree_to_vertex==NULL, is used to count the number of trees and vertices in the connectivity to be generated by the .inp mesh in the stream. The second, when vertices!=NULL and tree_to_vertex!=NULL, fill vertices and tree_to_vertex. In this case num_vertices and num_trees need to be set to the maximum number of entries allocated in vertices and tree_to_vertex.

Parameters

  • stream:[in,out] file stream to read the connectivity from
  • num_vertices:[in,out] the number of vertices in the connectivity
  • num_trees:[in,out] the number of trees in the connectivity
  • vertices:[out] the list of vertices of the connectivity
  • tree_to_vertex:[out] the tree_to_vertex map of the connectivity

Returns

0 if successful and nonzero if not

Prototype

int p4est_connectivity_read_inp_stream (FILE * stream, p4est_topidx_t * num_vertices, p4est_topidx_t * num_trees, double *vertices, p4est_topidx_t * tree_to_vertex);
source
P4est.LibP4est.p4est_connectivity_refineMethod
p4est_connectivity_refine(conn, num_per_edge)

Uniformly refine a connectivity. This is useful if you would like to uniformly refine by something other than a power of 2.

Parameters

  • conn:[in] A valid connectivity
  • num_per_edge:[in] The number of new trees in each direction. Must use no more than P4ESTOLDQMAXLEVEL bits.

Returns

a refined connectivity.

Prototype

p4est_connectivity_t *p4est_connectivity_refine (p4est_connectivity_t * conn, int num_per_edge);
source
P4est.LibP4est.p4est_connectivity_saveMethod
p4est_connectivity_save(filename, connectivity)

Save a connectivity structure to disk.

Parameters

  • filename:[in] Name of the file to write.
  • connectivity:[in] Valid connectivity structure.

Returns

Returns 0 on success, nonzero on file error.

Prototype

int p4est_connectivity_save (const char *filename, p4est_connectivity_t * connectivity);
source
P4est.LibP4est.p4est_connectivity_set_attrMethod
p4est_connectivity_set_attr(conn, bytes_per_tree)

Allocate or free the attribute fields in a connectivity.

Parameters

  • conn:[in,out] The conn->*_to_attr fields must either be NULL or previously be allocated by this function.
  • bytes_per_tree:[in] If 0, tree_to_attr is freed (being NULL is ok). If positive, requested space is allocated.

Prototype

void p4est_connectivity_set_attr (p4est_connectivity_t * conn, size_t bytes_per_tree);
source
P4est.LibP4est.p4est_connectivity_sinkMethod
p4est_connectivity_sink(conn, sink)

Write connectivity to a sink object.

Parameters

  • conn:[in] The connectivity to be written.
  • sink:[in,out] The connectivity is written into this sink.

Returns

0 on success, nonzero on error.

Prototype

int p4est_connectivity_sink (p4est_connectivity_t * conn, sc_io_sink_t * sink);
source
P4est.LibP4est.p4est_connectivity_sourceMethod
p4est_connectivity_source(source)

Read connectivity from a source object.

Parameters

  • source:[in,out] The connectivity is read from this source.

Returns

The newly created connectivity, or NULL on error.

Prototype

p4est_connectivity_t *p4est_connectivity_source (sc_io_source_t * source);
source
P4est.LibP4est.p4est_copyMethod
p4est_copy(input, copy_data)

Make a deep copy of a p4est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL. The revision counter of the copy is set to zero.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.

Returns

Returns a valid p4est that does not depend on the input, except for borrowing the same connectivity. Its revision counter is 0.

Prototype

p4est_t *p4est_copy (p4est_t * input, int copy_data);
source
P4est.LibP4est.p4est_copy_extMethod
p4est_copy_ext(input, copy_data, duplicate_mpicomm)

Make a deep copy of a p4est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL. The revision counter of the copy is set to zero.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.
  • duplicate_mpicomm:[in] If true, MPI communicator is copied.

Returns

Returns a valid p4est that does not depend on the input, except for borrowing the same connectivity. Its revision counter is 0.

Prototype

p4est_t *p4est_copy_ext (p4est_t * input, int copy_data, int duplicate_mpicomm);
source
P4est.LibP4est.p4est_destroyMethod
p4est_destroy(p4est_)

Destroy a p4est.

Note

The connectivity structure is not destroyed with the p4est.

Prototype

void p4est_destroy (p4est_t * p4est);
source
P4est.LibP4est.p4est_expand_face_transformMethod
p4est_expand_face_transform(iface, nface, ftransform)

Fill an array with the axis combination of a face neighbor transform.

Parameters

  • iface:[in] The number of the originating face.
  • nface:[in] Encoded as nface = r * 4 + nf, where nf = 0..3 is the neigbbor's connecting face number and r = 0..1 is the relative orientation to the neighbor's face. This encoding matches p4est_connectivity_t.
  • ftransform:[out] This array holds 9 integers. [0,2] The coordinate axis sequence of the origin face, the first referring to the tangential and the second to the normal. A permutation of (0, 1). [3,5] The coordinate axis sequence of the target face. [6,8] Edge reversal flag for tangential axis (boolean); face code in [0, 3] for the normal coordinate q: 0: q' = -q 1: q' = q + 1 2: q' = q - 1 3: q' = 2 - q [1,4,7] 0 (unused for compatibility with 3D).

Prototype

void p4est_expand_face_transform (int iface, int nface, int ftransform[]);
source
P4est.LibP4est.p4est_face_quadrant_existsMethod
p4est_face_quadrant_exists(p4est_, ghost, treeid, q, face, hang, owner_rank)

Checks if quadrant exists in the local forest or the ghost layer.

For quadrants across tree boundaries it checks if the quadrant exists across any face, but not across corners.

Parameters

  • p4est:[in] The forest in which to search for q.
  • ghost:[in] The ghost layer in which to search for q.
  • treeid:[in] The tree to which q belongs.
  • q:[in] The quadrant that is being searched for.
  • face:[in,out] On input, face id across which q was created. On output, the neighbor's face number augmented by orientation, so face is in 0..7.
  • hang:[in,out] If not NULL, signals that q is bigger than the quadrant it came from. The child id of that originating quadrant is passed into hang. On output, hang holds the hanging face number of q that is in contact with its originator.
  • owner_rank:[out] Filled with the rank of the owner if it is found and undefined otherwise.

Returns

Returns the local number of q if the quadrant exists in the local forest or in the ghost_layer. Otherwise, returns -2 for a domain boundary and -1 if not found.

Prototype

p4est_locidx_t p4est_face_quadrant_exists (p4est_t * p4est, p4est_ghost_t * ghost, p4est_topidx_t treeid, const p4est_quadrant_t * q, int *face, int *hang, int *owner_rank);
source
P4est.LibP4est.p4est_find_corner_transformMethod
p4est_find_corner_transform(connectivity, itree, icorner, ci)

Fills an array with information about corner neighbors.

Parameters

  • itree:[in] The number of the originating tree.
  • icorner:[in] The number of the originating corner.
  • ci:[in,out] A p4est_corner_info_t structure with initialized array.

Prototype

void p4est_find_corner_transform (p4est_connectivity_t * connectivity, p4est_topidx_t itree, int icorner, p4est_corner_info_t * ci);
source
P4est.LibP4est.p4est_find_face_transformMethod
p4est_find_face_transform(connectivity, itree, iface, ftransform)

Fill an array with the axis combinations of a tree neighbor transform.

Parameters

  • itree:[in] The number of the originating tree.
  • iface:[in] The number of the originating tree's face.
  • ftransform:[out] This array holds 9 integers. [0,2] The coordinate axis sequence of the origin face. [3,5] The coordinate axis sequence of the target face. [6,8] Edge reverse flag for axis t; face code for axis n. [1,4,7] 0 (unused for compatibility with 3D).

Returns

The face neighbor tree if it exists, -1 otherwise.

Prototype

p4est_topidx_t p4est_find_face_transform (p4est_connectivity_t * connectivity, p4est_topidx_t itree, int iface, int ftransform[]);
source
P4est.LibP4est.p4est_find_higher_boundMethod
p4est_find_higher_bound(array, q, guess)

Find the highest position tq in a quadrant array such that tq <= q.

Returns

Returns the id of the matching quadrant or -1 if array > q or the array is empty.

Prototype

ssize_t p4est_find_higher_bound (sc_array_t * array, const p4est_quadrant_t * q, size_t guess);
source
P4est.LibP4est.p4est_find_lower_boundMethod
p4est_find_lower_bound(array, q, guess)

Find the lowest position tq in a quadrant array such that tq >= q.

Returns

Returns the id of the matching quadrant or -1 if array < q or the array is empty.

Prototype

ssize_t p4est_find_lower_bound (sc_array_t * array, const p4est_quadrant_t * q, size_t guess);
source
P4est.LibP4est.p4est_find_partitionMethod
p4est_find_partition(num_procs, search_in, my_begin, my_end, _begin, _end)

Binary search in partition array. Given two targets my_begin and my_end, find offsets such that search\_in[begin] >= my\_begin, my\_end <= search\_in[end]. If more than one index satisfies the conditions, then the minimal index is the result. If there is no index that satisfies the conditions, then begin and end are tried to set equal such that search\_in[begin] >= my\_end. If my_begin is less or equal than the smallest value of search_in begin is set to 0 and if my_end is bigger or equal than the largest value of search_in end is set to num_procs - 1. If none of the above conditions is satisfied, the output is not well defined. We require `my_begin <= my_begin'.

Parameters

  • num_procs:[in] Number of processes to get the length of search_in.
  • search_in:[in] The sorted array (ascending) in that the function will search. If k indexes search_in, then 0 <= k < num\_procs.
  • my_begin:[in] The first target that defines the start of the search window.
  • my_end:[in] The second target that defines the end of the search window.
  • begin:[in,out] The first offset such that search\_in[begin] >= my\_begin.
  • end:[in,out] The second offset such that my\_end <= search\_in[end].

Prototype

void p4est_find_partition (const int num_procs, p4est_gloidx_t * search_in, p4est_gloidx_t my_begin, p4est_gloidx_t my_end, p4est_gloidx_t * begin, p4est_gloidx_t * end);
source
P4est.LibP4est.p4est_find_quadrant_cumulativeMethod
p4est_find_quadrant_cumulative(p4est_, cumulative_id, which_tree, quadrant_id)

Search a local quadrant by its cumulative number in the forest.

We perform a binary search over the processor-local trees, which means that it is advisable NOT to use this function if possible, and to try to maintain O(1) tree context information in the calling code.

Parameters

  • p4est:[in] Forest to be worked with.
  • cumulative_id:[in] Cumulative index over all trees of quadrant.
  • which_tree:[in,out] If not NULL, the input value can be -1 or an initial guess for the quadrant's tree. An initial guess must be the index of a nonempty local tree. Output is the tree of returned quadrant.
  • quadrant_id:[out] If not NULL, the number of quadrant in tree.

Returns

The identified quadrant.

Prototype

p4est_quadrant_t *p4est_find_quadrant_cumulative (p4est_t * p4est, p4est_locidx_t cumulative_id, p4est_topidx_t * which_tree, p4est_locidx_t * quadrant_id);
source
P4est.LibP4est.p4est_find_range_boundariesMethod
p4est_find_range_boundaries(lq, uq, level, faces, corners)

Find the boundary points touched by a range of quadrants.

Given two smallest quadrants, lq and uq, that mark the first and the last quadrant in a range of quadrants, determine which portions of the tree boundary the range touches.

Parameters

  • lq:[in] The smallest quadrant at the start of the range: if NULL, the tree's first quadrant is taken to be the start of the range.
  • uq:[in] The smallest quadrant at the end of the range: if NULL, the tree's last quadrant is taken to be the end of the range.
  • level:[in] The level of the containing quadrant whose boundaries are tested: 0 if we want to test the boundaries of the whole tree.
  • faces:[in,out] An array of size 4 that is filled: faces[i] is true if the range touches that face.
  • corners:[in,out] An array of size 4 that is filled: corners[i] is true if the range touches that corner. faces or corners may be NULL.

Returns

Returns an int32_t encoded with the same information in faces and corners: the first (least) four bits represent the four faces, the next four bits represent the four corners.

Prototype

int32_t p4est_find_range_boundaries (p4est_quadrant_t * lq, p4est_quadrant_t * uq, int level, int faces[], int corners[]);
source
P4est.LibP4est.p4est_get_plex_data_extMethod
p4est_get_plex_data_ext(p4est_, ghost, lnodes, ctype, overlap, first_local_quad, out_points_per_dim, out_cone_sizes, out_cones, out_cone_orientations, out_vertex_coords, out_children, out_parents, out_childids, out_leaves, out_remotes, custom_numbering)

Create the data necessary to create a PETsc DMPLEX representation of a forest, as well as the accompanying lnodes and ghost layer. The forest must be at least face balanced (see p4est_balance()). See test/test_plex2.c for example usage.

All arrays should be initialized to hold sizeof (p4est_locidx_t), except for out_remotes, which should be initialized to hold (2 * sizeof (p4est_locidx_t)).

Parameters

  • p4est:[in] the forest
  • ghost:[out] the ghost layer
  • lnodes:[out] the lnodes
  • ctype:[in] the type of adjacency for the overlap
  • overlap:[in] the number of layers of overlap (zero is acceptable)
  • first_local_quad:[out] the local quadrants are assigned contiguous plex indices, starting with this index
  • out_points_per_dim:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cone_sizes:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cones:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cone_orientations:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_vertex_coords:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_children:[in,out] filled with argument for DMPlexSetTree()
  • out_parents:[in,out] filled with argument for DMPlexSetTree()
  • out_childids:[in,out] filled with argument for DMPlexSetTree()
  • out_leaves:[in,out] filled with argument for PetscSFSetGraph()
  • out_remotes:[in,out] filled with argument for PetscSFSetGraph()
  • custom_numbering:[in] Whether or use the default numbering (0) of DMPlex child ids or the custom (1).

Prototype

void p4est_get_plex_data_ext (p4est_t * p4est, p4est_ghost_t ** ghost, p4est_lnodes_t ** lnodes, p4est_connect_type_t ctype, int overlap, p4est_locidx_t * first_local_quad, sc_array_t * out_points_per_dim, sc_array_t * out_cone_sizes, sc_array_t * out_cones, sc_array_t * out_cone_orientations, sc_array_t * out_vertex_coords, sc_array_t * out_children, sc_array_t * out_parents, sc_array_t * out_childids, sc_array_t * out_leaves, sc_array_t * out_remotes, int custom_numbering);
source
P4est.LibP4est.p4est_ghost_bsearchMethod
p4est_ghost_bsearch(ghost, which_proc, which_tree, q)

Conduct binary search for exact match on a range of the ghost layer.

Parameters

  • ghost:[in] The ghost layer.
  • which_proc:[in] The owner of the searched quadrant. Can be -1.
  • which_tree:[in] The tree of the searched quadrant. Can be -1.
  • q:[in] Valid quadrant is searched in the ghost layer.

Returns

Offset in the ghost layer, or -1 if not found.

Prototype

ssize_t p4est_ghost_bsearch (p4est_ghost_t * ghost, int which_proc, p4est_topidx_t which_tree, const p4est_quadrant_t * q);
source
P4est.LibP4est.p4est_ghost_checksumMethod
p4est_ghost_checksum(p4est_, ghost)

Compute the parallel checksum of a ghost layer.

Parameters

  • p4est:[in] The MPI information of this p4est will be used.
  • ghost:[in] A ghost layer obtained from the p4est.

Returns

Parallel checksum on rank 0, 0 otherwise.

Prototype

unsigned p4est_ghost_checksum (p4est_t * p4est, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_containsMethod
p4est_ghost_contains(ghost, which_proc, which_tree, q)

Conduct binary search for ancestor on range of the ghost layer.

Parameters

  • ghost:[in] The ghost layer.
  • which_proc:[in] The owner of the searched quadrant. Can be -1.
  • which_tree:[in] The tree of the searched quadrant. Can be -1.
  • q:[in] Valid quadrant's ancestor is searched.

Returns

Offset in the ghost layer, or -1 if not found.

Prototype

ssize_t p4est_ghost_contains (p4est_ghost_t * ghost, int which_proc, p4est_topidx_t which_tree, const p4est_quadrant_t * q);
source
P4est.LibP4est.p4est_ghost_exchange_customMethod
p4est_ghost_exchange_custom(p4est_, ghost, data_size, mirror_data, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. The data size is the same for all quadrants and can be chosen arbitrarily.

Parameters

  • p4est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • data_size:[in] The data size to transfer per quadrant.
  • mirror_data:[in] One data pointer per mirror quadrant as input.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghosts in sequence, which must hold at least data_size for each ghost.

Prototype

void p4est_ghost_exchange_custom (p4est_t * p4est, p4est_ghost_t * ghost, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_custom_beginMethod
p4est_ghost_exchange_custom_begin(p4est_, ghost, data_size, mirror_data, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p4est_ghost_exchange_custom. The return type is always non-NULL and must be passed to p4est_ghost_exchange_custom_end to complete the exchange. The ghost data must not be accessed before completion. The mirror data can be safely discarded right after this function returns since it is copied into internal send buffers.

Parameters

  • mirror_data:[in] Not required to stay alive any longer.
  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p4est_ghost_exchange_t *p4est_ghost_exchange_custom_begin (p4est_t * p4est, p4est_ghost_t * ghost, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_custom_levelsMethod
p4est_ghost_exchange_custom_levels(p4est_, ghost, minlevel, maxlevel, data_size, mirror_data, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. The data size is the same for all quadrants and can be chosen arbitrarily. This function restricts the transfer to a range of refinement levels. The memory for quadrants outside the level range is not dereferenced.

Parameters

  • p4est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • minlevel:[in] Level of the largest quads to be exchanged. Use <= 0 for no restriction.
  • maxlevel:[in] Level of the smallest quads to be exchanged. Use >= P4EST_QMAXLEVEL for no restriction.
  • data_size:[in] The data size to transfer per quadrant.
  • mirror_data:[in] One data pointer per mirror quadrant as input.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghosts in sequence, which must hold at least data_size for each ghost.

Prototype

void p4est_ghost_exchange_custom_levels (p4est_t * p4est, p4est_ghost_t * ghost, int minlevel, int maxlevel, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_custom_levels_beginMethod
p4est_ghost_exchange_custom_levels_begin(p4est_, ghost, minlevel, maxlevel, data_size, mirror_data, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p4est_ghost_exchange_custom_levels. The return type is always non-NULL and must be passed to p4est_ghost_exchange_custom_levels_end to complete the exchange. The ghost data must not be accessed before completion. The mirror data can be safely discarded right after this function returns since it is copied into internal send buffers.

Parameters

  • mirror_data:[in] Not required to stay alive any longer.
  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p4est_ghost_exchange_t *p4est_ghost_exchange_custom_levels_begin (p4est_t * p4est, p4est_ghost_t * ghost, int minlevel, int maxlevel, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_dataMethod
p4est_ghost_exchange_data(p4est_, ghost, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. Send the data stored in the quadrant's user_data. This is either the pointer variable itself if p4est->datasize is 0, or the content of the referenced memory field if p4est->data\size is positive.

Parameters

  • p4est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghost quadrants in sequence. If p4est->data_size is 0, must at least hold sizeof (void *) bytes for each, otherwise p4est->data_size each.

Prototype

void p4est_ghost_exchange_data (p4est_t * p4est, p4est_ghost_t * ghost, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_exchange_data_beginMethod
p4est_ghost_exchange_data_begin(p4est_, ghost, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p4est_ghost_exchange_data. The return type is always non-NULL and must be passed to p4est_ghost_exchange_data_end to complete the exchange. The ghost data must not be accessed before completion.

Parameters

  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p4est_ghost_exchange_t *p4est_ghost_exchange_data_begin (p4est_t * p4est, p4est_ghost_t * ghost, void *ghost_data);
source
P4est.LibP4est.p4est_ghost_expandMethod
p4est_ghost_expand(p4est_, ghost)

Expand the size of the ghost layer and mirrors by one additional layer of adjacency.

Parameters

  • p4est:[in] The forest from which the ghost layer was generated.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p4est_ghost_expand (p4est_t * p4est, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_expand_by_lnodesMethod
p4est_ghost_expand_by_lnodes(p4est_, lnodes, ghost)

Expand the ghost layer as in p4est_ghost_expand(), but use node support to define adjacency instead of geometric adjacency.

Parameters

  • p4est:[in] The forest from which the ghost layer was generated.
  • lnodes:[in] The nodes to support.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p4est_ghost_expand_by_lnodes (p4est_t * p4est, p4est_lnodes_t * lnodes, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_is_validMethod
p4est_ghost_is_valid(p4est_, ghost)

Examine if a ghost structure is valid. Test if within a ghost-structure the array ghosts is in p4est_quadrant_compare_piggy order. Test if local_num in piggy3 data member of the quadrants in ghosts and mirrors are in ascending order (ascending within each rank for ghost).

Test if the p4est_locidx_t arrays are in ascending order (for mirror_proc_mirrors ascending within each rank)

Parameters

  • p4est:[in] the forest.
  • ghost:[in] Ghost layer structure.

Returns

true if ghost is valid

Prototype

int p4est_ghost_is_valid (p4est_t * p4est, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_memory_usedMethod
p4est_ghost_memory_used(ghost)

Calculate the memory usage of the ghost layer.

Parameters

  • ghost:[in] Ghost layer structure.

Returns

Memory used in bytes.

Prototype

size_t p4est_ghost_memory_used (p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_ghost_newMethod
p4est_ghost_new(p4est_, btype)

Builds the ghost layer.

This will gather the quadrants from each neighboring proc to build one layer of face and corner based ghost elements around the ones they own.

Parameters

  • p4est:[in] The forest for which the ghost layer will be generated.
  • btype:[in] Which ghosts to include (across face, corner or full).

Returns

A fully initialized ghost layer.

Prototype

p4est_ghost_t *p4est_ghost_new (p4est_t * p4est, p4est_connect_type_t btype);
source
P4est.LibP4est.p4est_ghost_support_lnodesMethod
p4est_ghost_support_lnodes(p4est_, lnodes, ghost)

Expand the ghost layer to include the support of all nodes supported on the local partition.

Parameters

  • p4est:[in] The forest from which the ghost layer was generated.
  • lnodes:[in] The nodes to support.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p4est_ghost_support_lnodes (p4est_t * p4est, p4est_lnodes_t * lnodes, p4est_ghost_t * ghost);
source
P4est.LibP4est.p4est_initMethod
p4est_init(log_handler, log_threshold)

Registers p4est with the SC Library and sets the logging behavior. This function is optional. This function must only be called before additional threads are created. If this function is not called or called with log_handler == NULL, the default SC log handler will be used. If this function is not called or called with log_threshold == SC_LP_DEFAULT, the default SC log threshold will be used. The default SC log settings can be changed with sc_set_log_defaults ().

Prototype

void p4est_init (sc_log_handler_t log_handler, int log_threshold);
source
P4est.LibP4est.p4est_is_balancedMethod
p4est_is_balanced(p4est_, btype)

Check a forest to see if it is balanced.

This function builds the ghost layer and discards it when done.

Parameters

  • p4est:[in] The p4est to be tested.
  • btype:[in] Balance type (face, corner or default, full).

Returns

Returns true if balanced, false otherwise.

Prototype

int p4est_is_balanced (p4est_t * p4est, p4est_connect_type_t btype);
source
P4est.LibP4est.p4est_iterateMethod
p4est_iterate(p4est_, ghost_layer, user_data, iter_volume, iter_face, iter_corner)

Execute user supplied callbacks at every volume, face, and corner in the local forest.

p4est_iterate executes the user-supplied callback functions at every volume, face, and corner in the local forest. The ghost_layer may be NULL. The user_data pointer is not touched by p4est_iterate, but is passed to each of the callbacks. Any of the callbacks may be NULL. The callback functions are interspersed with each other, i.e. some face callbacks will occur between volume callbacks, and some corner callbacks will occur between face callbacks:

  1. volume callbacks occur in the sorted Morton-index order. 2) a face callback is not executed until after the volume callbacks have been executed for the quadrants that share it. 3) a corner callback is not executed until the face callbacks have been executed for all faces that touch the corner. 4) it is not always the case that every face callback for a given quadrant is executed before any of the corner callbacks. 5) callbacks are not executed at faces or corners that only involve ghost quadrants, i.e. that are not adjacent in the local section of the forest.

Parameters

  • p4est:[in] the forest
  • ghost_layer:[in] optional: when not given, callbacks at the boundaries of the local partition cannot provide quadrant data about ghost quadrants: missing (p4est_quadrant_t *) pointers are set to NULL, missing indices are set to -1.
  • user_data:[in,out] optional context to supply to each callback
  • iter_volume:[in] callback function for every quadrant's interior
  • iter_face:[in] callback function for every face between quadrants
  • iter_corner:[in] callback function for every corner between quadrants

Prototype

void p4est_iterate (p4est_t * p4est, p4est_ghost_t * ghost_layer, void *user_data, p4est_iter_volume_t iter_volume, p4est_iter_face_t iter_face, p4est_iter_corner_t iter_corner);
source
P4est.LibP4est.p4est_iterate_extMethod
p4est_iterate_ext(p4est_, ghost_layer, user_data, iter_volume, iter_face, iter_corner, remote)

p4est_iterate_ext adds the option remote: if this is false, then it is the same as p4est_iterate; if this is true, then corner callbacks are also called on corners for hanging faces touched by local quadrants.

Prototype

void p4est_iterate_ext (p4est_t * p4est, p4est_ghost_t * ghost_layer, void *user_data, p4est_iter_volume_t iter_volume, p4est_iter_face_t iter_face, p4est_iter_corner_t iter_corner, int remote);
source
P4est.LibP4est.p4est_lid_addMethod
p4est_lid_add(a, b, result)

Adds the uint128_t b to the uint128_t a. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void p4est_lid_add (const p4est_lid_t * a, const p4est_lid_t * b, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_bitwise_andMethod
p4est_lid_bitwise_and(a, b, result)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void p4est_lid_bitwise_and (const p4est_lid_t * a, const p4est_lid_t * b, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_bitwise_and_inplaceMethod
p4est_lid_bitwise_and_inplace(a, b)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void p4est_lid_bitwise_and_inplace (p4est_lid_t * a, const p4est_lid_t * b);
source
P4est.LibP4est.p4est_lid_bitwise_negMethod
p4est_lid_bitwise_neg(a, result)

Calculates the bitwise negation of the uint128_t a. a == result is allowed.

Parameters

  • a:[in] A pointer to a p4est_lid_t.
  • result:[out] A pointer to a p4est_lid_t. The bitwise negation of a will be saved in result.

Prototype

void p4est_lid_bitwise_neg (const p4est_lid_t * a, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_bitwise_orMethod
p4est_lid_bitwise_or(a, b, result)

Calculates the bitwise or of the uint128_t a and b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void p4est_lid_bitwise_or (const p4est_lid_t * a, const p4est_lid_t * b, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_bitwise_or_inplaceMethod
p4est_lid_bitwise_or_inplace(a, b)

Calculates the bitwise or of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void p4est_lid_bitwise_or_inplace (p4est_lid_t * a, const p4est_lid_t * b);
source
P4est.LibP4est.p4est_lid_chk_bitMethod
p4est_lid_chk_bit(input, bit_number)

Returns the bit_number-th bit of input. This function checks a bit of an existing, initialized value.

Parameters

  • input:[in] A pointer to a p4est_lid_t.
  • bit_number:[in] The bit (counted from the right hand side) that is checked by logical and. Require 0 <= bit_number < 64.

Returns

True if bit is set, false if not.

Prototype

int p4est_lid_chk_bit (const p4est_lid_t * input, int bit_number);
source
P4est.LibP4est.p4est_lid_copyMethod
p4est_lid_copy(input, output)

Copies an initialized p4est_lid_t to a p4est_lid_t.

Parameters

  • input:[in] A pointer to the p4est_lid_t that is copied.
  • output:[in,out] A pointer to a p4est_lid_t. The low bits of output will be set to the low bits of input and high bits are ignored.

Prototype

void p4est_lid_copy (const p4est_lid_t * input, p4est_lid_t * output);
source
P4est.LibP4est.p4est_lid_initMethod
p4est_lid_init(input, high, low)

Initializes an unsigned 64 bit integer. high is just a a placeholder to use the same interface in 3D.

Parameters

  • input:[in,out] A pointer to a p4est_lid_t that will be intialized.
  • high:[in] The given high bits must be zero.
  • low:[in] The given low bits to initialize input.

Prototype

void p4est_lid_init (p4est_lid_t * input, uint64_t high, uint64_t low);
source
P4est.LibP4est.p4est_lid_set_bitMethod
p4est_lid_set_bit(input, bit_number)

Sets the exponent-th bit of a to one. This function modifies an existing, initialized value.

Parameters

  • input:[in,out] A pointer to a p4est_lid_t.
  • bit_number:[in] The bit (counted from the right hand side) that is set to one by logical or. Require 0 <= bit_number < 64.

Prototype

void p4est_lid_set_bit (p4est_lid_t * input, int bit_number);
source
P4est.LibP4est.p4est_lid_set_uint64Method
p4est_lid_set_uint64(input, u)

Initializes a linear index to an unsigned 64 bit integer.

Parameters

  • input:[out] A pointer to a p4est_lid_t that will be intialized.

Prototype

void p4est_lid_set_uint64 (p4est_lid_t * input, uint64_t u);
source
P4est.LibP4est.p4est_lid_shift_leftMethod
p4est_lid_shift_left(input, shift_count, result)

Calculates the bit left shift of uint128_t input by shift_count bits. We shift in zeros from the right. If shift_count >= 64, result is 0. All bits left from the 63th bit (counted zero based from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a p4est_lid_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a p4est_lid_t. The left shifted number will be saved in result.

Prototype

void p4est_lid_shift_left (const p4est_lid_t * input, unsigned shift_count, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_shift_rightMethod
p4est_lid_shift_right(input, shift_count, result)

Calculates the bit right shift of uint128_t input by shift_count bits. We shift in zeros from the left. If shift_count >= 64, result is 0. All bits right from the zeroth bit (counted from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a p4est_lid_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a p4est_lid_t. The right shifted number will be saved in result.

Prototype

void p4est_lid_shift_right (const p4est_lid_t * input, unsigned shift_count, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_subMethod
p4est_lid_sub(a, b, result)

Substracts the p4est_lid_t b from the p4est_lid_t a. This function assumes that the result is >= 0. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void p4est_lid_sub (const p4est_lid_t * a, const p4est_lid_t * b, p4est_lid_t * result);
source
P4est.LibP4est.p4est_lid_sub_inplaceMethod
p4est_lid_sub_inplace(a, b)

Substracts the uint128_t b from the uint128_t a. The result is saved in a. a == b is allowed. This function assumes that the result is >= 0.

Parameters

Prototype

void p4est_lid_sub_inplace (p4est_lid_t * a, const p4est_lid_t * b);
source
P4est.LibP4est.p4est_lnodes_newMethod
p4est_lnodes_new(p4est_, ghost_layer, degree)

Prototype

p4est_lnodes_t *p4est_lnodes_new (p4est_t * p4est, p4est_ghost_t * ghost_layer, int degree);
source
P4est.LibP4est.p4est_lnodes_share_allMethod
p4est_lnodes_share_all(node_data, lnodes)

Equivalent to calling p4est_lnodes_share_all_end directly after p4est_lnodes_share_all_begin. Use if there is no local work that can be done to mask the communication cost.

Returns

A fully initialized buffer that contains the received data. After processing this data, the buffer must be freed with p4est_lnodes_buffer_destroy.

Prototype

p4est_lnodes_buffer_t *p4est_lnodes_share_all (sc_array_t * node_data, p4est_lnodes_t * lnodes);
source
P4est.LibP4est.p4est_lnodes_share_all_beginMethod
p4est_lnodes_share_all_begin(node_data, lnodes)

p4est_lnodes_share_all_begin

node_data is a user_defined array of arbitrary type, where each entry is associated with the lnodes local nodes entry of matching index. For every process that shares an entry with the current one, the value in the node_data array of that process is written into a buffer->recvbuffers entry as described above. The user can then perform some arbitrary work that requires the data from all processes that share a node (such as reduce, max, min, etc.). When the work concludes, the buffer should be destroyed with [`p4estlnodesbufferdestroy`](@ref).

Values of node_data are not guaranteed to be sent, and buffer->recvbuffer entries are not guaranteed to be received until the buffer created by [`p4estlnodesshareallbegin](@ref) is passed to [p4estlnodesshareall_end`](@ref).

Prototype

p4est_lnodes_buffer_t *p4est_lnodes_share_all_begin (sc_array_t * node_data, p4est_lnodes_t * lnodes);
source
P4est.LibP4est.p4est_lnodes_share_owned_beginMethod
p4est_lnodes_share_owned_begin(node_data, lnodes)

p4est_lnodes_share_owned_begin

node_data is a user-defined array of arbitrary type, where each entry is associated with the lnodes local nodes entry of matching index. For every local nodes entry that is owned by a process other than the current one, the value in the node_data array of the owning process is written directly into the node_data array of the current process. Values of node_data are not guaranteed to be sent or received until the buffer created by p4est_lnodes_share_owned_begin is passed to p4est_lnodes_share_owned_end.

To be memory neutral, the buffer created by p4est_lnodes_share_owned_begin must be destroying with p4est_lnodes_buffer_destroy (it is not destroyed by p4est_lnodes_share_owned_end).

Prototype

p4est_lnodes_buffer_t *p4est_lnodes_share_owned_begin (sc_array_t * node_data, p4est_lnodes_t * lnodes);
source
P4est.LibP4est.p4est_loadMethod
p4est_load(filename, mpicomm, data_size, load_data, user_pointer, connectivity)

Prototype

p4est_t *p4est_load (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, void *user_pointer, p4est_connectivity_t ** connectivity);
source
P4est.LibP4est.p4est_load_extMethod
p4est_load_ext(filename, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p4est_t *p4est_load_ext (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p4est_connectivity_t ** connectivity);
source
P4est.LibP4est.p4est_memory_usedMethod
p4est_memory_used(p4est_)

Calculate local memory usage of a forest structure. Not collective. The memory used on the current rank is returned. The connectivity structure is not counted since it is not owned; use p4est_connectivity_memory_usage (p4est->connectivity).

Parameters

  • p4est:[in] Valid forest structure.

Returns

Memory used in bytes.

Prototype

size_t p4est_memory_used (p4est_t * p4est);
source
P4est.LibP4est.p4est_mesh_face_neighbor_dataMethod
p4est_mesh_face_neighbor_data(mfn, ghost_data)

Get the user data for the current face neighbor.

Parameters

  • mfn:[in] Internal status of the iterator.
  • ghost_data:[in] Data for the ghost quadrants that has been synchronized with p4est_ghost_exchange_data.

Returns

A pointer to the user data for the current neighbor.

Prototype

void *p4est_mesh_face_neighbor_data (p4est_mesh_face_neighbor_t * mfn, void *ghost_data);
source
P4est.LibP4est.p4est_mesh_face_neighbor_initMethod
p4est_mesh_face_neighbor_init(mfn, p4est_, ghost, mesh, which_tree, quadrant)

Initialize a mesh neighbor iterator by quadrant pointer.

Parameters

  • mfn:[out] A p4est_mesh_face_neighbor_t to be initialized.
  • which_tree:[in] Tree of quadrant whose neighbors are looped over.
  • quadrant:[in] Pointer to quadrant contained in which_tree.

Prototype

void p4est_mesh_face_neighbor_init (p4est_mesh_face_neighbor_t * mfn, p4est_t * p4est, p4est_ghost_t * ghost, p4est_mesh_t * mesh, p4est_topidx_t which_tree, p4est_quadrant_t * quadrant);
source
P4est.LibP4est.p4est_mesh_face_neighbor_init2Method
p4est_mesh_face_neighbor_init2(mfn, p4est_, ghost, mesh, which_tree, quadrant_id)

Initialize a mesh neighbor iterator by quadrant index.

Parameters

  • mfn:[out] A p4est_mesh_face_neighbor_t to be initialized.
  • which_tree:[in] Tree of quadrant whose neighbors are looped over.
  • quadrant_id:[in] Index relative to which_tree of quadrant.

Prototype

void p4est_mesh_face_neighbor_init2 (p4est_mesh_face_neighbor_t * mfn, p4est_t * p4est, p4est_ghost_t * ghost, p4est_mesh_t * mesh, p4est_topidx_t which_tree, p4est_locidx_t quadrant_id);
source
P4est.LibP4est.p4est_mesh_face_neighbor_nextMethod
p4est_mesh_face_neighbor_next(mfn, ntree, nquad, nface, nrank)

Move the iterator forward to loop around neighbors of the quadrant.

Parameters

  • mfn:[in,out] Internal status of the iterator.
  • ntree:[out] If not NULL, the tree number of the neighbor.
  • nquad:[out] If not NULL, the quadrant number within tree. For ghosts instead the number in ghost layer.
  • nface:[out] If not NULL, neighbor's face as in p4est_mesh_t.
  • nrank:[out] If not NULL, the owner process of the neighbor.

Returns

Either a real quadrant or one from the ghost layer. Returns NULL when the iterator is done.

Prototype

p4est_quadrant_t *p4est_mesh_face_neighbor_next (p4est_mesh_face_neighbor_t * mfn, p4est_topidx_t * ntree, p4est_locidx_t * nquad, int *nface, int *nrank);
source
P4est.LibP4est.p4est_mesh_get_neighborsMethod
p4est_mesh_get_neighbors(p4est_, ghost, mesh, curr_quad_id, direction, neighboring_quads, neighboring_encs, neighboring_qids)

Lookup neighboring quads of quadrant in a specific direction.

Parameters

  • p4est:[in] Forest to be worked with.
  • ghost:[in] Ghost layer.
  • mesh:[in] Mesh structure.
  • curr_quad_id:[in] Process-local id of current quad.
  • direction:[in] Direction i in which to look for adjacent quadrants is encoded as follows: 0 .. 3 neighbor(-s) across face i, 4 .. 7 neighbor(-s) across corner i-4. TODO: Allow any combination of empty output arrays.
  • neighboring_quads:[out] Array containing neighboring quad(-s). Needs to be empty on input, size of p4est_quadrant_t *. May be NULL, then neighboring_qids must not be NULL.
  • neighboring_qids:[out] Array containing quadrant ids for neighboring quadrants. May be NULL, then no neighboring qids are collected. If non-NULL the array needs to be empty and will contain int. CAUTION: Note, that the encodings differ from the encodings saved in the mesh. TODO: Encodings are the same as in p4est_mesh for all quadrants. TODO: Ghosts can be encoded by returning the quad_to_quad convention in qid. For ghost quadrants, we add -300 to the values in p4est_mesh. This means that values below -100 belong to ghosts, values above to locals. Positive values are for local quadrants, negative values indicate ghost quadrants. Faces: 1 .. 8 => same size neighbor (r * 4 + nf) + 1; nf = 0 .. 3 face index; r = 0 .. 1 relative orientation 9 .. 24 => double size neighbor 9 + h * 8 + r * 4 + nf; h = 0 .. 1 number of the subface; r, nf as above 25 .. 32 => half-size neighbors 25 + r * 4 + nf; r, nf as above Corners: 1 .. 4 => size not encoded for corners nc + 1; nc = 0 .. 3 corner index
  • neighboring_encs:[out] Array containing encodings for neighboring quads. Needs to be empty, contains int.

Prototype

p4est_locidx_t p4est_mesh_get_neighbors (p4est_t * p4est, p4est_ghost_t * ghost, p4est_mesh_t * mesh, p4est_locidx_t curr_quad_id, p4est_locidx_t direction, sc_array_t * neighboring_quads, sc_array_t * neighboring_encs, sc_array_t * neighboring_qids);
source
P4est.LibP4est.p4est_mesh_get_quadrantMethod
p4est_mesh_get_quadrant(p4est_, mesh, qid)

Access a process-local quadrant inside a forest. Needs a mesh with populated quad_to_tree array. This is a special case of p4estmeshquadrant_cumulative.

Parameters

  • p4est:[in] The forest.
  • mesh:[in] The mesh.
  • qid:[in] Process-local id of the quadrant (cumulative over trees).

Returns

A pointer to the requested quadrant.

Prototype

p4est_quadrant_t *p4est_mesh_get_quadrant (p4est_t * p4est, p4est_mesh_t * mesh, p4est_locidx_t qid);
source
P4est.LibP4est.p4est_mesh_memory_usedMethod
p4est_mesh_memory_used(mesh)

Calculate the memory usage of the mesh structure.

Parameters

  • mesh:[in] Mesh structure.

Returns

Memory used in bytes.

Prototype

size_t p4est_mesh_memory_used (p4est_mesh_t * mesh);
source
P4est.LibP4est.p4est_mesh_newMethod
p4est_mesh_new(p4est_, ghost, btype)

Create a p4est_mesh structure. This function does not populate the quad_to_tree and quad_level fields. To populate them, use p4estmeshnew_ext.

Parameters

  • p4est:[in] A forest that is fully 2:1 balanced.
  • ghost:[in] The ghost layer created from the provided p4est.
  • btype:[in] Determines the highest codimension of neighbors.

Returns

A fully allocated mesh structure.

Prototype

p4est_mesh_t *p4est_mesh_new (p4est_t * p4est, p4est_ghost_t * ghost, p4est_connect_type_t btype);
source
P4est.LibP4est.p4est_mesh_new_extMethod
p4est_mesh_new_ext(p4est_, ghost, compute_tree_index, compute_level_lists, btype)

Create a new mesh.

Parameters

  • p4est:[in] A forest that is fully 2:1 balanced.
  • ghost:[in] The ghost layer created from the provided p4est.
  • compute_tree_index:[in] Boolean to decide whether to allocate and compute the quad_to_tree list.
  • compute_level_lists:[in] Boolean to decide whether to compute the level lists in quad_level.
  • btype:[in] Currently ignored, only face neighbors are stored.

Returns

A fully allocated mesh structure.

Prototype

p4est_mesh_t *p4est_mesh_new_ext (p4est_t * p4est, p4est_ghost_t * ghost, int compute_tree_index, int compute_level_lists, p4est_connect_type_t btype);
source
P4est.LibP4est.p4est_mesh_quadrant_cumulativeMethod
p4est_mesh_quadrant_cumulative(p4est_, mesh, cumulative_id, which_tree, quadrant_id)

Find a quadrant based on its cumulative number in the local forest. If the quad_to_tree field of the mesh structure exists, this is O(1). Otherwise, we perform a binary search over the processor-local trees.

Parameters

  • p4est:[in] Forest to be worked with.
  • mesh:[in] A mesh derived from the forest.
  • cumulative_id:[in] Cumulative index over all trees of quadrant. Must refer to a local (non-ghost) quadrant.
  • which_tree:[in,out] If not NULL, the input value can be -1 or an initial guess for the quadrant's tree and output is the tree of returned quadrant.
  • quadrant_id:[out] If not NULL, the number of quadrant in tree.

Returns

The identified quadrant.

Prototype

p4est_quadrant_t *p4est_mesh_quadrant_cumulative (p4est_t * p4est, p4est_mesh_t * mesh, p4est_locidx_t cumulative_id, p4est_topidx_t * which_tree, p4est_locidx_t * quadrant_id);
source
P4est.LibP4est.p4est_newMethod
p4est_new(mpicomm, connectivity, data_size, init_fn, user_pointer)

Prototype

p4est_t *p4est_new (sc_MPI_Comm mpicomm, p4est_connectivity_t * connectivity, size_t data_size, p4est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p4est_new_extMethod
p4est_new_ext(mpicomm, connectivity, min_quadrants, min_level, fill_uniform, data_size, init_fn, user_pointer)

Prototype

p4est_t *p4est_new_ext (sc_MPI_Comm mpicomm, p4est_connectivity_t * connectivity, p4est_locidx_t min_quadrants, int min_level, int fill_uniform, size_t data_size, p4est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p4est_partitionMethod
p4est_partition(p4est_, allow_for_coarsening, weight_fn)

Equally partition the forest. The partition can be by element count or by a user-defined weight.

The forest will be partitioned between processors such that they have an approximately equal number of quadrants (or sum of weights).

On one process, the function noops and does not call the weight callback. Otherwise, the weight callback is called once per quadrant in order.

Parameters

  • p4est:[in,out] The forest that will be partitioned.
  • allow_for_coarsening:[in] Slightly modify partition such that quadrant families are not split between ranks.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning. When running with mpisize == 1, never called. Otherwise, called in order for all quadrants if not NULL. A weighting function with constant weight 1 on each quadrant is equivalent to weight_fn == NULL but other constant weightings may result in different uniform partitionings.

Prototype

void p4est_partition (p4est_t * p4est, int allow_for_coarsening, p4est_weight_t weight_fn);
source
P4est.LibP4est.p4est_partition_extMethod
p4est_partition_ext(p4est_, partition_for_coarsening, weight_fn)

Repartition the forest.

The forest is partitioned between processors such that each processor has an approximately equal number of quadrants (or weight).

Parameters

  • p4est:[in,out] The forest that will be partitioned.
  • partition_for_coarsening:[in] If true, the partition is modified to allow one level of coarsening.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning. A weighting function with constant weight 1 on each quadrant is equivalent to weight_fn == NULL but other constant weightings may result in different uniform partitionings.

Returns

The global number of shipped quadrants

Prototype

p4est_gloidx_t p4est_partition_ext (p4est_t * p4est, int partition_for_coarsening, p4est_weight_t weight_fn);
source
P4est.LibP4est.p4est_partition_for_coarseningMethod
p4est_partition_for_coarsening(p4est_, num_quadrants_in_proc)

Correct partition to allow one level of coarsening.

Parameters

  • p4est:[in] forest whose partition is corrected
  • num_quadrants_in_proc:[in,out] partition that will be corrected

Returns

absolute number of moved quadrants

Prototype

p4est_gloidx_t p4est_partition_for_coarsening (p4est_t * p4est, p4est_locidx_t * num_quadrants_in_proc);
source
P4est.LibP4est.p4est_partition_lnodesMethod
p4est_partition_lnodes(p4est_, ghost, degree, partition_for_coarsening)

Partition using weights based on the number of nodes assigned to each element in lnodes

Parameters

  • p4est:[in,out] the forest to be repartitioned
  • ghost:[in] the ghost layer
  • degree:[in] the degree that would be passed to p4est_lnodes_new()
  • partition_for_coarsening:[in] whether the partition should allow coarsening (i.e. group siblings who might merge)

Prototype

void p4est_partition_lnodes (p4est_t * p4est, p4est_ghost_t * ghost, int degree, int partition_for_coarsening);
source
P4est.LibP4est.p4est_partition_lnodes_detailedMethod
p4est_partition_lnodes_detailed(p4est_, ghost, nodes_per_volume, nodes_per_face, nodes_per_corner, partition_for_coarsening)

Partition using weights that are broken down by where they reside: in volumes, on faces, or on corners.

Prototype

void p4est_partition_lnodes_detailed (p4est_t * p4est, p4est_ghost_t * ghost, int nodes_per_volume, int nodes_per_face, int nodes_per_corner, int partition_for_coarsening);
source
P4est.LibP4est.p4est_partition_to_p6est_partitionMethod
p4est_partition_to_p6est_partition(p6est_, num_columns_in_proc, num_layers_in_proc)

Prototype

void p4est_partition_to_p6est_partition (p6est_t * p6est, p4est_locidx_t * num_columns_in_proc, p4est_locidx_t * num_layers_in_proc);
source
P4est.LibP4est.p4est_qcoord_to_vertexMethod
p4est_qcoord_to_vertex(connectivity, treeid, x, y, vxyz)

Transform a quadrant coordinate into the space spanned by tree vertices.

Parameters

  • connectivity:[in] Connectivity must provide the vertices.
  • treeid:[in] Identify the tree that contains x, y.
  • x,:[in] y Quadrant coordinates relative to treeid.
  • vxyz:[out] Transformed coordinates in vertex space.

Prototype

void p4est_qcoord_to_vertex (p4est_connectivity_t * connectivity, p4est_topidx_t treeid, p4est_qcoord_t x, p4est_qcoord_t y, double vxyz[3]);
source
P4est.LibP4est.p4est_quadrant_existsMethod
p4est_quadrant_exists(p4est_, ghost, treeid, q, exists_arr, rproc_arr, rquad_arr)

Checks if quadrant exists in the local forest or the ghost layer.

For quadrants across tree corners it checks if the quadrant exists in any of the corner neighbors, thus it can execute multiple queries.

Parameters

  • p4est:[in] The forest in which to search for q
  • ghost:[in] The ghost layer in which to search for q
  • treeid:[in] The tree to which q belongs (can be extended).
  • q:[in] The quadrant that is being searched for.
  • exists_arr:[in,out] Must exist and be of of elem_size = sizeof (int) for inter-tree corner cases. Is resized by this function to one entry for each corner search and set to true/false depending on its existence in the local forest or ghost_layer.
  • rproc_arr:[in,out] If not NULL is filled with one rank per query.
  • rquad_arr:[in,out] If not NULL is filled with one quadrant per query. Its piggy3 member is defined as well.

Returns

true if the quadrant exists in the local forest or in the ghost_layer, and false if doesn't exist in either.

Prototype

int p4est_quadrant_exists (p4est_t * p4est, p4est_ghost_t * ghost, p4est_topidx_t treeid, const p4est_quadrant_t * q, sc_array_t * exists_arr, sc_array_t * rproc_arr, sc_array_t * rquad_arr);
source
P4est.LibP4est.p4est_quadrant_find_ownerMethod
p4est_quadrant_find_owner(p4est_, treeid, face, q)

Gets the processor id of a quadrant's owner. The quadrant can lie outside of a tree across faces (and only faces).

Warning

Does not work for tree edge or corner neighbors.

Parameters

  • p4est:[in] The forest in which to search for a quadrant.
  • treeid:[in] The tree to which the quadrant belongs.
  • face:[in] Supply a face direction if known, or -1 otherwise.
  • q:[in] The quadrant that is being searched for.

Returns

Processor id of the owner or -1 if the quadrant lies outside of the mesh.

Prototype

int p4est_quadrant_find_owner (p4est_t * p4est, p4est_topidx_t treeid, int face, const p4est_quadrant_t * q);
source
P4est.LibP4est.p4est_quadrant_linear_id_ext128Method
p4est_quadrant_linear_id_ext128(quadrant, level, id)

Computes the linear position as p4est_lid_t of a quadrant in a uniform grid. The grid and quadrant levels need not coincide. If they do, this is the inverse of p4estquadrantset_morton.

Note

The user_data of quadrant is never modified.

Parameters

  • quadrant:[in] Quadrant whose linear index will be computed. If the quadrant is smaller than the grid (has a higher quadrant->level), the result is computed from its ancestor at the grid's level. If the quadrant has a smaller level than the grid (it is bigger than a grid cell), the grid cell sharing its lower left corner is used as reference.
  • level:[in] The level of the regular grid compared to which the linear position is to be computed.
  • id:[in,out] A pointer to an allocated or static p4est_lid_t. id will be the linear position of this quadrant on a uniform grid.

Prototype

void p4est_quadrant_linear_id_ext128 (const p4est_quadrant_t * quadrant, int level, p4est_lid_t * id);
source
P4est.LibP4est.p4est_quadrant_set_morton_ext128Method
p4est_quadrant_set_morton_ext128(quadrant, level, id)

Set quadrant Morton indices based on linear position given as p4est_lid_t in uniform grid. This is the inverse operation of p4estquadrantlinear_id.

Note

The user_data of quadrant is never modified.

Parameters

  • quadrant:[in,out] Quadrant whose Morton indices will be set.
  • level:[in] Level of the grid and of the resulting quadrant.
  • id:[in] Linear index of the quadrant on a uniform grid.

Prototype

void p4est_quadrant_set_morton_ext128 (p4est_quadrant_t * quadrant, int level, const p4est_lid_t * id);
source
P4est.LibP4est.p4est_refineMethod
p4est_refine(p4est_, refine_recursive, refine_fn, init_fn)

Refine a forest.

Parameters

  • p4est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn gets called, or use p4est_refine_ext in p4est_extended.h and examine whether replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data of newly created quadrants, which is already allocated. This function pointer may be NULL.

Prototype

void p4est_refine (p4est_t * p4est, int refine_recursive, p4est_refine_t refine_fn, p4est_init_t init_fn);
source
P4est.LibP4est.p4est_refine_extMethod
p4est_refine_ext(p4est_, refine_recursive, maxlevel, refine_fn, init_fn, replace_fn)

Refine a forest with a bounded refinement level and a replace option.

Parameters

  • p4est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • maxlevel:[in] Maximum allowed refinement level (inclusive). If this is negative the level is restricted only by the compile-time constant QMAXLEVEL in p4est.h.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn or replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data for newly created quadrants, which is guaranteed to be allocated. This function pointer may be NULL.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace; may be NULL.

Prototype

void p4est_refine_ext (p4est_t * p4est, int refine_recursive, int maxlevel, p4est_refine_t refine_fn, p4est_init_t init_fn, p4est_replace_t replace_fn);
source
P4est.LibP4est.p4est_reset_dataMethod
p4est_reset_data(p4est_, data_size, init_fn, user_pointer)

Reset user pointer and element data. When the data size is changed the quadrant data is freed and allocated. The initialization callback is invoked on each quadrant. Old user_data content is disregarded.

Parameters

  • data_size:[in] This is the size of data for each quadrant which can be zero. Then user_data_pool is set to NULL.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically. May be NULL.
  • user_pointer:[in] Assign to the user_pointer member of the p4est before init_fn is called the first time.

Prototype

void p4est_reset_data (p4est_t * p4est, size_t data_size, p4est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p4est_revisionMethod
p4est_revision(p4est_)

Return the revision counter of the forest. Not collective, even though the revision value is the same on all ranks. A newly created forest starts with a revision counter of zero. Every refine, coarsen, partition, and balance that actually changes the mesh increases the counter by one. Operations with no effect keep the old value.

Parameters

  • p8est:[in] The forest must be valid.

Returns

Non-negative number.

Prototype

long p4est_revision (p4est_t * p4est);
source
P4est.LibP4est.p4est_saveMethod
p4est_save(filename, p4est_, save_data)

Save the complete connectivity/p4est data to disk.

This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations.

By default, we write the current processor count and partition into the file header. This makes the file depend on mpisize. For changing this see p4est_save_ext() in p4est_extended.h.

The revision counter is not saved to the file, since that would make files different that come from different revisions but store the same mesh.

Note

Aborts on file errors.

Note

If p4est is not configured to use MPI-IO, some processes return from this function before the file is complete, in which case immediate read-access to the file may require a call to sc_MPI_Barrier.

Parameters

  • filename:[in] Name of the file to write.
  • p4est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.

Prototype

void p4est_save (const char *filename, p4est_t * p4est, int save_data);
source
P4est.LibP4est.p4est_save_extMethod
p4est_save_ext(filename, p4est_, save_data, save_partition)

Save the complete connectivity/p4est data to disk. This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations. See p4est_load_ext for information on the autopartition parameter.

Note

Aborts on file errors.

Parameters

  • filename:[in] Name of the file to write.
  • p4est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.
  • save_partition:[in] If false, save file as if 1 core was used. If true, save core count and partition. Advantage: Partition can be recovered on loading with same mpisize and autopartition false. Disadvantage: Makes the file depend on mpisize. Either way the file can be loaded with autopartition true.

Prototype

void p4est_save_ext (const char *filename, p4est_t * p4est, int save_data, int save_partition);
source
P4est.LibP4est.p4est_searchMethod
p4est_search(p4est_, quadrant_fn, point_fn, points)

This function is provided for backwards compatibility. We call p4estsearchlocal with call_post = 0.

Prototype

void p4est_search (p4est_t * p4est, p4est_search_query_t quadrant_fn, p4est_search_query_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p4est_search_allMethod
p4est_search_all(p4est_, call_post, quadrant_fn, point_fn, points)

Perform a top-down search on the whole forest.

This function combines the functionality of p4estsearchlocal and p4estsearchpartition; their documentation applies for the most part.

The recursion proceeds from the root quadrant of each tree until (a) we encounter a remote quadrant that covers only one processor, or (b) we encounter a local leaf quadrant. In other words, we proceed with the recursion into a quadrant's children if (a) the quadrant is split between two or more processors, no matter whether one of them is the calling processor or not, or (b) if the quadrant is on the local processor but we have not reached a leaf yet.

The search can track one or more points, which are abstract placeholders. They are matched against the quadrants traversed using a callback function. The result of the callback function can be used to stop a recursion early. The user determines how a point is interpreted, we only pass it around.

Note that in the remote case (a), we may terminate the recursion even if the quadrant is not a leaf, which we have no means of knowing. Still, this case is sufficient to determine the processor ownership of a point.

Note

This is a very powerful function that can become slow if not used carefully.

Note

As with the two other search functions in this file, calling it once with many points is generally much faster than calling it once for each point. Using multiple points also allows for a per-quadrant termination of the recursion in addition to a more costly per-point termination.

Note

This function works fine when used for the special cases that either the partition or the local quadrants are not of interest. However, in the case of querying only local information we expect that p4estsearchlocal will be faster since it employs specific local optimizations.

Parameters

  • p4est:[in] The forest to be searched.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] Executed once for each quadrant that is entered. If the callback returns false, this quadrant and its descendants are excluded from the search, and the points in this branch are not queried further. Its point argument is always NULL. Callback may be NULL in which case it is ignored.
  • point_fn:[in] Executed once for each point that is relevant for a quadrant of the search. If it returns true, the point is tracked further down that branch, else it is discarded from the queries for the children. If points is not NULL, this callback must be not NULL. If points is NULL, it is not called.
  • points:[in] User-defined array of points. We do not interpret a point, just pass it into the callbacks. If NULL, only the quadrant_fn callback is executed. If that is NULL, the whole function noops. If not NULL, the point_fn is called on its members during the search.

Prototype

void p4est_search_all (p4est_t * p4est, int call_post, p4est_search_all_t quadrant_fn, p4est_search_all_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p4est_search_localMethod
p4est_search_local(p4est_, call_post, quadrant_fn, point_fn, points)

Search through the local part of a forest. The search is especially efficient if multiple targets, called "points" below, are searched for simultaneously.

The search runs over all local quadrants and proceeds recursively top-down. For each tree, it may start at the root of that tree, or further down at the root of the subtree that contains all of the tree's local quadrants. Likewise, some intermediate levels in the recursion may be skipped if the processor-local part is contained in a single deeper subtree. The outer loop is thus a depth-first, processor-local forest traversal. Each quadrant in that loop either is a leaf, or a (direct or indirect) strict ancestor of a leaf. On entering a new quadrant, a user-provided quadrant-callback is executed.

As a convenience, the user may provide anonymous "points" that are tracked down the forest. This way one search call may be used for multiple targets. The set of points that potentially matches a given quadrant diminishes from the root down to the leaves: For each quadrant, an inner loop over the potentially matching points executes a point-callback for each candidate that determines whether the point may be a match. If not, it is discarded in the current branch, otherwise it is passed to the next deeper level. The callback is allowed to return true for the same point and more than one quadrant; in this case more than one matching quadrant may be identified. The callback is also allowed to return false for all children of a quadrant that it returned true for earlier. If the point callback returns false for all points relevant to a quadrant, the recursion stops. The points can really be anything, p4est does not perform any interpretation, just passes the pointer along to the callback function.

If points are present and the first quadrant callback returned true, we execute it a second time after calling the point callback for all current points. This can be used to gather and postprocess information about the points more easily. If it returns false, the recursion stops.

If the points are a NULL array, they are ignored and the recursion proceeds by querying the per-quadrant callback. If the points are not NULL but an empty array, the recursion will stop immediately!

Parameters

  • p4est:[in] The forest to be searched.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] Executed once when a quadrant is entered, and once when it is left (the second time only if points are present and the first call returned true). This quadrant is always local, if not completely then at least one descendant of it. If the callback returns false, this quadrant and its descendants are excluded from the search recursion. Its point argument is always NULL. Callback may be NULL in which case it is ignored.
  • point_fn:[in] If points is not NULL, must be not NULL. Shall return true for any possible matching point. If points is NULL, this callback is ignored.
  • points:[in] User-defined array of "points". If NULL, only the quadrant_fn callback is executed. If that is NULL, this function noops. If not NULL, the point_fn is called on its members during the search.

Prototype

void p4est_search_local (p4est_t * p4est, int call_post, p4est_search_local_t quadrant_fn, p4est_search_local_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p4est_search_partitionMethod
p4est_search_partition(p4est_, call_post, quadrant_fn, point_fn, points)

Traverse the global partition top-down. We proceed top-down through the partition, identically on all processors except for the results of two user-provided callbacks. The recursion will only go down branches that are split between multiple processors. The callback functions can be used to stop a branch recursion even for split branches. This function offers the option to search for arbitrary user-defined points analogously to p4estsearchlocal.

Note

Traversing the whole processor partition will be at least O(P), so sensible use of the callback function is advised to cut it short.

Parameters

  • p4est:[in] The forest to traverse. Its local quadrants are never accessed.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] This function controls the recursion, which only continues deeper if this callback returns true for a branch quadrant. It is allowed to set this to NULL.
  • point_fn:[in] This function decides per-point whether it is followed down the recursion. Must be non-NULL if points are not NULL.
  • points:[in] User-provided array of points that are passed to the callback point_fn. See p4estsearchlocal for details.

Prototype

void p4est_search_partition (p4est_t * p4est, int call_post, p4est_search_partition_t quadrant_fn, p4est_search_partition_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p4est_source_extMethod
p4est_source_ext(src, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p4est_t *p4est_source_ext (sc_io_source_t * src, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p4est_connectivity_t ** connectivity);
source
P4est.LibP4est.p4est_split_arrayMethod
p4est_split_array(array, level, indices)

Split an array of quadrants by the children of an ancestor.

Given a sorted array of quadrants that have a common ancestor at level level, compute the indices of the first quadrant in each of the common ancestor's children at level level + 1.

Parameters

  • array:[in] The sorted array of quadrants of level > level.
  • level:[in] The level at which there is a common ancestor.
  • indices:[in,out] The indices of the first quadrant in each of the ancestors's children, plus an additional index on the end. The quadrants of array that are descendants of child i have indices between indices[i] and indices[i + 1] - 1. If indices[i] = indices[i+1], this indicates that no quadrant in the array is contained in child i.

Prototype

void p4est_split_array (sc_array_t * array, int level, size_t indices[]);
source
P4est.LibP4est.p4est_versionMethod
p4est_version()

Return the full version of p4est.

Returns

Return the version of p4est using the format VERSION\_MAJOR.VERSION\_MINOR.VERSION\_POINT, where VERSION_POINT can contain dots and characters, e.g. to indicate the additional number of commits and a git commit hash.

Prototype

const char *p4est_version (void);
source
P4est.LibP4est.p6est_balanceMethod
p6est_balance(p6est_, btype, init_fn)

Balance a forest.

Parameters

  • p6est:[in] The p6est to be worked on.
  • btype:[in] Balance type (face, corner or default, full).
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p6est_balance (p6est_t * p6est, p8est_connect_type_t btype, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_balance_extMethod
p6est_balance_ext(p6est_, btype, max_diff, min_diff, init_fn, replace_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p6est:[in,out] The p6est to be worked on.
  • btype:[in] Balance type (face or corner/full). Corner balance is almost never required when discretizing a PDE; just causes smoother mesh grading.
  • max_diff:[in] The maximum difference between the horizontal refinement level and the vertical refinement level
  • min_diff:[in] The minimum difference between the horizontal refinement level and the vertical refinement level
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p6est_balance_ext (p6est_t * p6est, p8est_connect_type_t btype, int max_diff, int min_diff, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_checksumMethod
p6est_checksum(p6est_)

Compute the checksum for a forest. Based on quadrant arrays only. It is independent of partition and mpisize.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p6est_checksum (p6est_t * p6est);
source
P4est.LibP4est.p6est_coarsen_columnsMethod
p6est_coarsen_columns(p6est_, coarsen_recursive, coarsen_fn, init_fn)

Coarsen the columns of a sheet.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • coarsen_fn:[in] Callback function that returns true if a family of columns shall be coarsened
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p6est_coarsen_columns (p6est_t * p6est, int coarsen_recursive, p6est_coarsen_column_t coarsen_fn, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_coarsen_columns_extMethod
p6est_coarsen_columns_ext(p6est_, coarsen_recursive, callback_orphans, coarsen_fn, init_fn, replace_fn)

Horizontally coarsen a forest.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • callback_orphans:[in] Boolean to enable calling coarsen_fn even on non-families. In this case, the second quadrant pointer in the argument list of the callback is NULL, subsequent pointers are undefined, and the return value is ignored. If coarsen_recursive is true, it is possible that a quadrant is called once or more as an orphan and eventually becomes part of a family.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p6est_coarsen_columns_ext (p6est_t * p6est, int coarsen_recursive, int callback_orphans, p6est_coarsen_column_t coarsen_fn, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_coarsen_layersMethod
p6est_coarsen_layers(p6est_, coarsen_recursive, coarsen_fn, init_fn)

Coarsen the layers of a sheet.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • coarsen_fn:[in] Callback function that returns true if a family of layers shall be coarsened
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p6est_coarsen_layers (p6est_t * p6est, int coarsen_recursive, p6est_coarsen_layer_t coarsen_fn, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_coarsen_layers_extMethod
p6est_coarsen_layers_ext(p6est_, coarsen_recursive, callback_orphans, coarsen_fn, init_fn, replace_fn)

Vertically coarsen a forest.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • callback_orphans:[in] Boolean to enable calling coarsen_fn even on non-families. In this case, the second quadrant pointer in the argument list of the callback is NULL, subsequent pointers are undefined, and the return value is ignored. If coarsen_recursive is true, it is possible that a quadrant is called once or more as an orphan and eventually becomes part of a family.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p6est_coarsen_layers_ext (p6est_t * p6est, int coarsen_recursive, int callback_orphans, p6est_coarsen_layer_t coarsen_fn, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_connectivity_newMethod
p6est_connectivity_new(conn4, top_vertices, height)

Create a p6est_connectivity_t from a p4est_connectivity_t. All fields are copied, so all inputs can be safey destroyed.

Parameters

  • conn4:[in] the 2D connectivity
  • top_vertices:[in] if NULL, then the sheet has a uniform vertical profile; otherwise, top_vertices gives teh vertices of the top of the sheet; should be the same size as conn4->treetovertex
  • height:[in] if top_vertices == NULL, then this gives the offset fro the bottom of the sheet to the top.

Returns

the 2D+1D connectivity information.

Prototype

p6est_connectivity_t *p6est_connectivity_new (p4est_connectivity_t * conn4, double *top_vertices, double height[3]);
source
P4est.LibP4est.p6est_copyMethod
p6est_copy(input, copy_data)

Make a deep copy of a p6est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.

Returns

Returns a valid p6est that does not depend on the input.

Prototype

p6est_t *p6est_copy (p6est_t * input, int copy_data);
source
P4est.LibP4est.p6est_copy_extMethod
p6est_copy_ext(input, copy_data, duplicate_mpicomm)

Make a deep copy of a p6est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.
  • duplicate_mpicomm:[in] If true, MPI communicator is copied.

Returns

Returns a valid p6est that does not depend on the input.

Prototype

p6est_t *p6est_copy_ext (p6est_t * input, int copy_data, int duplicate_mpicomm);
source
P4est.LibP4est.p6est_destroyMethod
p6est_destroy(p6est_)

Destroy a p6est.

Note

The connectivity structure is not destroyed with the p6est.

Prototype

void p6est_destroy (p6est_t * p6est);
source
P4est.LibP4est.p6est_loadMethod
p6est_load(filename, mpicomm, data_size, load_data, user_pointer, connectivity)

Prototype

p6est_t *p6est_load (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, void *user_pointer, p6est_connectivity_t ** connectivity);
source
P4est.LibP4est.p6est_load_extMethod
p6est_load_ext(filename, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p6est_t *p6est_load_ext (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p6est_connectivity_t ** connectivity);
source
P4est.LibP4est.p6est_newMethod
p6est_new(mpicomm, connectivity, data_size, init_fn, user_pointer)

Prototype

p6est_t *p6est_new (sc_MPI_Comm mpicomm, p6est_connectivity_t * connectivity, size_t data_size, p6est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p6est_new_extMethod
p6est_new_ext(mpicomm, connectivity, min_quadrants, min_level, min_zlevel, num_zroot, fill_uniform, data_size, init_fn, user_pointer)

Prototype

p6est_t *p6est_new_ext (sc_MPI_Comm mpicomm, p6est_connectivity_t * connectivity, p4est_locidx_t min_quadrants, int min_level, int min_zlevel, int num_zroot, int fill_uniform, size_t data_size, p6est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p6est_new_from_p4estMethod
p6est_new_from_p4est(p4est_, top_vertices, height, min_zlevel, data_size, init_fn, user_pointer)

Create a new forest from an already created p4est that represents columns.

Parameters

  • p4est:[in] A valid p4est. A deep copy will be created, so this can be destroyed without affectin the new p6est object.
  • top_vertices:[in] the same as in p6est_conectivity_new()
  • height:[in] the same as in p6est_conectivity_new()
  • min_zlevel:[in] the same as in p6est_new()
  • data_size:[in] the same as in p6est_new()
  • init_fn:[in] the same as in p6est_new()
  • user_pointer:[in] the same as in p6est_new()

Returns

This returns a valid forest. The user must destroy the connectivity for the new p6est independently.

Prototype

p6est_t *p6est_new_from_p4est (p4est_t * p4est, double *top_vertices, double height[3], int min_zlevel, size_t data_size, p6est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p6est_partitionMethod
p6est_partition(p6est_, weight_fn)

Equally partition the forest.

The forest will be partitioned between processors where they each have an approximately equal number of quadrants.

Note that p6est->layers and p6est->globalfirstlayers may change during this call. Address pointers referencing these objects from before p6est_partition is called become invalid.

Parameters

  • p6est:[in,out] The forest that will be partitioned.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning.

Prototype

p4est_gloidx_t p6est_partition (p6est_t * p6est, p6est_weight_t weight_fn);
source
P4est.LibP4est.p6est_partition_extMethod
p6est_partition_ext(p6est_, partition_for_coarsening, weight_fn)

Repartition the forest.

The forest is partitioned between processors such that each processor has an approximately equal number of quadrants (or weight).

Parameters

  • p6est:[in,out] The forest that will be partitioned.
  • partition_for_coarsening:[in] If true, the partition is modified to allow one level of coarsening.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning.

Returns

The global number of shipped quadrants

Prototype

p4est_gloidx_t p6est_partition_ext (p6est_t * p6est, int partition_for_coarsening, p6est_weight_t weight_fn);
source
P4est.LibP4est.p6est_partition_to_p4est_partitionMethod
p6est_partition_to_p4est_partition(p6est_, num_layers_in_proc, num_columns_in_proc)

Prototype

void p6est_partition_to_p4est_partition (p6est_t * p6est, p4est_locidx_t * num_layers_in_proc, p4est_locidx_t * num_columns_in_proc);
source
P4est.LibP4est.p6est_qcoord_to_vertexMethod
p6est_qcoord_to_vertex(connectivity, treeid, x, y, z, vxyz)

Transform a quadrant coordinate into the space spanned by tree vertices.

Parameters

  • connectivity:[in] Connectivity must provide the vertices.
  • treeid:[in] Identify the tree that contains x, y.
  • x,:[in] y Quadrant coordinates relative to treeid.
  • vxy:[out] Transformed coordinates in vertex space.

Prototype

void p6est_qcoord_to_vertex (p6est_connectivity_t * connectivity, p4est_topidx_t treeid, p4est_qcoord_t x, p4est_qcoord_t y, p4est_qcoord_t z, double vxyz[3]);
source
P4est.LibP4est.p6est_refine_columnsMethod
p6est_refine_columns(p6est_, refine_recursive, refine_fn, init_fn)

Refine the columns of a sheet.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • refine_fn:[in] Callback function that must return true if a column shall be refined into smaller columns. If refine_recursive is true, refine_fn is called for every existing and newly created column. Otherwise, it is called for every existing column. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn gets called, or use p6est_refine_columns_ext in p6est_extended.h and examine whether replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data of newly created layers within columns, which are already allocated. This function pointer may be NULL.

Prototype

void p6est_refine_columns (p6est_t * p6est, int refine_recursive, p6est_refine_column_t refine_fn, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_refine_columns_extMethod
p6est_refine_columns_ext(p6est_, refine_recursive, maxlevel, refine_fn, init_fn, replace_fn)

Horizontally refine a forest with a bounded refinement level and a replace option.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • maxlevel:[in] Maximum allowed refinement level (inclusive). If this is negative the level is restricted only by the compile-time constant QMAXLEVEL in p4est.h.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn or replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data for newly created quadrants, which is guaranteed to be allocated. This function pointer may be NULL.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace; may be NULL.

Prototype

void p6est_refine_columns_ext (p6est_t * p6est, int refine_recursive, int maxlevel, p6est_refine_column_t refine_fn, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_refine_layersMethod
p6est_refine_layers(p6est_, refine_recursive, refine_fn, init_fn)

Refine the layers within the columns of a sheet.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • refine_fn:[in] Callback function that must return true if a layer shall be refined into smaller layers. If refine_recursive is true, refine_fn is called for every existing and newly created layer. Otherwise, it is called for every existing layer. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn gets called, or use p6est_refine_layers_ext in p6est_extended.h and examine whether replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data of newly created layers, which are already allocated. This function pointer may be NULL.

Prototype

void p6est_refine_layers (p6est_t * p6est, int refine_recursive, p6est_refine_layer_t refine_fn, p6est_init_t init_fn);
source
P4est.LibP4est.p6est_refine_layers_extMethod
p6est_refine_layers_ext(p6est_, refine_recursive, maxlevel, refine_fn, init_fn, replace_fn)

Vertically refine a forest with a bounded refinement level and a replace option.

Parameters

  • p6est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • maxlevel:[in] Maximum allowed refinement level (inclusive). If this is negative the level is restricted only by the compile-time constant QMAXLEVEL in p4est.h.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn or replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data for newly created quadrants, which is guaranteed to be allocated. This function pointer may be NULL.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace; may be NULL.

Prototype

void p6est_refine_layers_ext (p6est_t * p6est, int refine_recursive, int maxlevel, p6est_refine_layer_t refine_fn, p6est_init_t init_fn, p6est_replace_t replace_fn);
source
P4est.LibP4est.p6est_reset_dataMethod
p6est_reset_data(p6est_, data_size, init_fn, user_pointer)

Reset user pointer and element data. When the data size is changed the quadrant data is freed and allocated. The initialization callback is invoked on each quadrant. Old user_data content is disregarded.

Parameters

  • data_size:[in] This is the size of data for each quadrant which can be zero. Then user_data_pool is set to NULL.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • user_pointer:[in] Assign to the user_pointer member of the p6est before init_fn is called the first time.

Prototype

void p6est_reset_data (p6est_t * p6est, size_t data_size, p6est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p6est_saveMethod
p6est_save(filename, p6est_, save_data)

Save the complete connectivity/p6est data to disk. This is a collective

operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations.

Note

Aborts on file errors.

Parameters

  • filename:[in] Name of the file to write.
  • p6est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.

Prototype

void p6est_save (const char *filename, p6est_t * p6est, int save_data);
source
P4est.LibP4est.p6est_save_extMethod
p6est_save_ext(filename, p6est_, save_data, save_partition)

Save the complete connectivity/p6est data to disk.

This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations. See p6est_load_ext() for information on the autopartition parameter.

Note

Aborts on file errors.

Parameters

  • filename:[in] Name of the file to write.
  • p6est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.
  • save_partition:[in] If false, save file as if 1 core was used. If true, save core count and partition. Advantage: Partition can be recovered on loading with same mpisize and autopartition false. Disadvantage: Makes the file depend on mpisize. Either way the file can be loaded with autopartition true.

Prototype

void p6est_save_ext (const char *filename, p6est_t * p6est, int save_data, int save_partition);
source
P4est.LibP4est.p6est_tree_get_verticesMethod
p6est_tree_get_vertices(conn, which_tree, vertices)

Get the vertices of the corners of a tree.

Parameters

  • conn:[in] the 2D+1D connectivity structure
  • which_tree:[in] a tree in the forest
  • vertices:[out] the coordinates of the corners of the tree

Prototype

void p6est_tree_get_vertices (p6est_connectivity_t * conn, p4est_topidx_t which_tree, double vertices[24]);
source
P4est.LibP4est.p8est_balanceMethod
p8est_balance(p8est_, btype, init_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p8est:[in,out] The p8est to be worked on.
  • btype:[in] Balance type (face, edge, or corner/full). Examples: Finite volume or discontinuous Galerkin methods only require face balance. Continuous finite element methods usually require edge balance. Corner balance is almost never required mathematically; it just produces a smoother mesh grading.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p8est_balance (p8est_t * p8est, p8est_connect_type_t btype, p8est_init_t init_fn);
source
P4est.LibP4est.p8est_balance_extMethod
p8est_balance_ext(p8est_, btype, init_fn, replace_fn)

2:1 balance the size differences of neighboring elements in a forest.

Parameters

  • p8est:[in,out] The p8est to be worked on.
  • btype:[in] Balance type (face, edge, or corner/full). Corner balance is almost never required when discretizing a PDE; just causes smoother mesh grading.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p8est_balance_ext (p8est_t * p8est, p8est_connect_type_t btype, p8est_init_t init_fn, p8est_replace_t replace_fn);
source
P4est.LibP4est.p8est_balance_subtree_extMethod
p8est_balance_subtree_ext(p8est_, btype, which_tree, init_fn, replace_fn)

Prototype

void p8est_balance_subtree_ext (p8est_t * p8est, p8est_connect_type_t btype, p4est_topidx_t which_tree, p8est_init_t init_fn, p8est_replace_t replace_fn);
source
P4est.LibP4est.p8est_checksumMethod
p8est_checksum(p8est_)

Compute the checksum for a forest. Based on quadrant arrays only. It is independent of partition and mpisize.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p8est_checksum (p8est_t * p8est);
source
P4est.LibP4est.p8est_checksum_partitionMethod
p8est_checksum_partition(p8est_)

Compute a partition-dependent checksum for a forest.

Returns

Returns the checksum on processor 0 only. 0 on other processors.

Prototype

unsigned p8est_checksum_partition (p8est_t * p8est);
source
P4est.LibP4est.p8est_coarsenMethod
p8est_coarsen(p8est_, coarsen_recursive, coarsen_fn, init_fn)

Coarsen a forest.

Parameters

  • p8est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.

Prototype

void p8est_coarsen (p8est_t * p8est, int coarsen_recursive, p8est_coarsen_t coarsen_fn, p8est_init_t init_fn);
source
P4est.LibP4est.p8est_coarsen_extMethod
p8est_coarsen_ext(p8est_, coarsen_recursive, callback_orphans, coarsen_fn, init_fn, replace_fn)

Coarsen a forest.

Parameters

  • p8est:[in,out] The forest is changed in place.
  • coarsen_recursive:[in] Boolean to decide on recursive coarsening.
  • callback_orphans:[in] Boolean to enable calling coarsen_fn even on non-families. In this case, the second quadrant pointer in the argument list of the callback is NULL, subsequent pointers are undefined, and the return value is ignored. If coarsen_recursive is true, it is possible that a quadrant is called once or more as an orphan and eventually becomes part of a family. With coarsen_recursive false and callback_orphans true, it is guaranteed that every quadrant is passed exactly once into the coarsen_fn callback.
  • coarsen_fn:[in] Callback function that returns true if a family of quadrants shall be coarsened.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace.

Prototype

void p8est_coarsen_ext (p8est_t * p8est, int coarsen_recursive, int callback_orphans, p8est_coarsen_t coarsen_fn, p8est_init_t init_fn, p8est_replace_t replace_fn);
source
P4est.LibP4est.p8est_connectivity_completeMethod
p8est_connectivity_complete(conn)

Internally connect a connectivity based on tree_to_vertex information. Periodicity that is not inherent in the list of vertices will be lost.

Parameters

  • conn:[in,out] The connectivity needs to have proper vertices and tree_to_vertex fields. The tree_to_tree and tree_to_face fields must be allocated and satisfy p8est_connectivity_is_valid (conn) but will be overwritten. The edge and corner fields will be freed and allocated anew.

Prototype

void p8est_connectivity_complete (p8est_connectivity_t * conn);
source
P4est.LibP4est.p8est_connectivity_deflateMethod
p8est_connectivity_deflate(conn, code)

Allocate memory and store the connectivity information there.

Parameters

  • conn:[in] The connectivity structure to be exported to memory.
  • code:[in] Encoding and compression method for serialization.

Returns

Newly created array that contains the information.

Prototype

sc_array_t *p8est_connectivity_deflate (p8est_connectivity_t * conn, p8est_connectivity_encode_t code);
source
P4est.LibP4est.p8est_connectivity_destroyMethod
p8est_connectivity_destroy(connectivity)

Destroy a connectivity structure. Also destroy all attributes.

Prototype

void p8est_connectivity_destroy (p8est_connectivity_t * connectivity);
source
P4est.LibP4est.p8est_connectivity_edge_neighbor_cornerMethod
p8est_connectivity_edge_neighbor_corner(c, e, ne, o)

Transform a corner across one of the adjacent edges into a neighbor tree. This version expects the neighbor edge and orientation separately.

Parameters

  • c:[in] A corner number in 0..7.
  • e:[in] An edge 0..11 that touches the corner c.
  • ne:[in] A neighbor edge that is on the other side of .
  • o:[in] The orientation between tree boundary edges e and .

Returns

Corner number seen from the neighbor.

Prototype

int p8est_connectivity_edge_neighbor_corner (int c, int e, int ne, int o);
source
P4est.LibP4est.p8est_connectivity_edge_neighbor_edge_cornerMethod
p8est_connectivity_edge_neighbor_edge_corner(ec, o)

Transform an edge corner across one of the adjacent edges into a neighbor tree.

Parameters

  • ec:[in] An edge corner number in 0..1.
  • o:[in] The orientation of a tree boundary edge connection.

Returns

The edge corner number seen from the other tree.

Prototype

int p8est_connectivity_edge_neighbor_edge_corner (int ec, int o);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_cornerMethod
p8est_connectivity_face_neighbor_corner(c, f, nf, o)

Transform a corner across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • c:[in] A corner number in 0..7.
  • f:[in] A face number that touches the corner c.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The number of the corner seen from the neighbor tree.

Prototype

int p8est_connectivity_face_neighbor_corner (int c, int f, int nf, int o);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_corner_setMethod
p8est_connectivity_face_neighbor_corner_set(c, f, nf, set)

Transform a corner across one of the adjacent faces into a neighbor tree. It expects a face permutation index that has been precomputed.

Parameters

  • c:[in] A corner number in 0..7.
  • f:[in] A face number that touches the corner c.
  • nf:[in] A neighbor face that is on the other side of .
  • set:[in] A value from p8estfacepermutation_sets that is obtained using f, nf, and a valid orientation: ref = p8est_face_permutation_refs[f][nf]; set = p8est_face_permutation_sets[ref][orientation];

Returns

The corner number in 0..7 seen from the other face.

Prototype

int p8est_connectivity_face_neighbor_corner_set (int c, int f, int nf, int set);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_edgeMethod
p8est_connectivity_face_neighbor_edge(e, f, nf, o)

Transform an edge across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • e:[in] A edge number in 0..11.
  • f:[in] A face 0..5 that touches the edge e.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The edge's number seen from the neighbor.

Prototype

int p8est_connectivity_face_neighbor_edge (int e, int f, int nf, int o);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_face_cornerMethod
p8est_connectivity_face_neighbor_face_corner(fc, f, nf, o)

Transform a face corner across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • fc:[in] A face corner number in 0..3.
  • f:[in] A face that the face corner fc is relative to.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The face corner number relative to the neighbor's face.

Prototype

int p8est_connectivity_face_neighbor_face_corner (int fc, int f, int nf, int o);
source
P4est.LibP4est.p8est_connectivity_face_neighbor_face_edgeMethod
p8est_connectivity_face_neighbor_face_edge(fe, f, nf, o)

Transform a face-edge across one of the adjacent faces into a neighbor tree. This version expects the neighbor face and orientation separately.

.

Parameters

  • fe:[in] A face edge number in 0..3.
  • f:[in] A face number that touches the edge e.
  • nf:[in] A neighbor face that is on the other side of .
  • o:[in] The orientation between tree boundary faces f and

Returns

The face edge number seen from the neighbor tree.

Prototype

int p8est_connectivity_face_neighbor_face_edge (int fe, int f, int nf, int o);
source
P4est.LibP4est.p8est_connectivity_inflateMethod
p8est_connectivity_inflate(buffer)

Create new connectivity from a memory buffer.

Parameters

  • buffer:[in] The connectivity is created from this memory buffer.

Returns

The newly created connectivity, or NULL on error.

Prototype

p8est_connectivity_t *p8est_connectivity_inflate (sc_array_t * buffer);
source
P4est.LibP4est.p8est_connectivity_is_equalMethod
p8est_connectivity_is_equal(conn1, conn2)

Check two connectivity structures for equality.

Returns

Returns true if structures are equal, false otherwise.

Prototype

int p8est_connectivity_is_equal (p8est_connectivity_t * conn1, p8est_connectivity_t * conn2);
source
P4est.LibP4est.p8est_connectivity_is_equivalentMethod
p8est_connectivity_is_equivalent(conn1, conn2)

p8est_connectivity_is_equivalent This function compares two connectivities for equivalence: it returns true if they are the same connectivity, or if they have the same topology. The definition of topological sameness is strict: there is no attempt made to determine whether permutation and/or rotation of the trees makes the connectivities equivalent.

Parameters

  • conn1:[in] a valid connectivity
  • conn2:[out] a valid connectivity

Prototype

int p8est_connectivity_is_equivalent (p8est_connectivity_t * conn1, p8est_connectivity_t * conn2);
source
P4est.LibP4est.p8est_connectivity_is_validMethod
p8est_connectivity_is_valid(connectivity)

Examine a connectivity structure.

Returns

Returns true if structure is valid, false otherwise.

Prototype

int p8est_connectivity_is_valid (p8est_connectivity_t * connectivity);
source
P4est.LibP4est.p8est_connectivity_join_facesMethod
p8est_connectivity_join_faces(conn, tree_left, tree_right, face_left, face_right, orientation)

p8est_connectivity_join_faces This function takes an existing valid connectivity conn and modifies it by joining two tree faces that are currently boundary faces.

Parameters

  • conn:[in,out] connectivity that will be altered.
  • tree_left:[in] tree that will be on the left side of the joined faces.
  • tree_right:[in] tree that will be on the right side of the joined faces.
  • face_left:[in] face of tree_left that will be joined.
  • face_right:[in] face of tree_right that will be joined.
  • orientation:[in] the orientation of face_left and face_right once joined (see the description of p8est_connectivity_t to understand orientation).

Prototype

void p8est_connectivity_join_faces (p8est_connectivity_t * conn, p4est_topidx_t tree_left, p4est_topidx_t tree_right, int face_left, int face_right, int orientation);
source
P4est.LibP4est.p8est_connectivity_loadMethod
p8est_connectivity_load(filename, bytes)

Load a connectivity structure from disk.

Parameters

  • filename:[in] Name of the file to read.
  • bytes:[out] Size in bytes of connectivity on disk or NULL.

Returns

Returns valid connectivity, or NULL on file error.

Prototype

p8est_connectivity_t *p8est_connectivity_load (const char *filename, size_t *bytes);
source
P4est.LibP4est.p8est_connectivity_memory_usedMethod
p8est_connectivity_memory_used(conn)

Calculate memory usage of a connectivity structure.

Parameters

  • conn:[in] Connectivity structure.

Returns

Memory used in bytes.

Prototype

size_t p8est_connectivity_memory_used (p8est_connectivity_t * conn);
source
P4est.LibP4est.p8est_connectivity_newMethod
p8est_connectivity_new(num_vertices, num_trees, num_edges, num_ett, num_corners, num_ctt)

Allocate a connectivity structure. The attribute fields are initialized to NULL.

Parameters

  • num_vertices:[in] Number of total vertices (i.e. geometric points).
  • num_trees:[in] Number of trees in the forest.
  • num_edges:[in] Number of tree-connecting edges.
  • num_ett:[in] Number of total trees in edge_to_tree array.
  • num_corners:[in] Number of tree-connecting corners.
  • num_ctt:[in] Number of total trees in corner_to_tree array.

Returns

A connectivity structure with allocated arrays.

Prototype

p8est_connectivity_t *p8est_connectivity_new (p4est_topidx_t num_vertices, p4est_topidx_t num_trees, p4est_topidx_t num_edges, p4est_topidx_t num_ett, p4est_topidx_t num_corners, p4est_topidx_t num_ctt);
source
P4est.LibP4est.p8est_connectivity_new_brickMethod
p8est_connectivity_new_brick(m, n, p, periodic_a, periodic_b, periodic_c)

An m by n by p array with periodicity in x, y, and z if periodic_a, periodic_b, and periodic_c are true, respectively.

Prototype

p8est_connectivity_t *p8est_connectivity_new_brick (int m, int n, int p, int periodic_a, int periodic_b, int periodic_c);
source
P4est.LibP4est.p8est_connectivity_new_bynameMethod
p8est_connectivity_new_byname(name)

Create connectivity structure from predefined catalogue.

Parameters

  • name:[in] Invokes connectivity_new_* function. brick235 brick (2, 3, 5, 0, 0, 0) periodic periodic rotcubes rotcubes rotwrap rotwrap shell shell sphere sphere twocubes twocubes twowrap twowrap unit unitcube

Returns

An initialized connectivity if name is defined, NULL else.

Prototype

p8est_connectivity_t *p8est_connectivity_new_byname (const char *name);
source
P4est.LibP4est.p8est_connectivity_new_copyMethod
p8est_connectivity_new_copy(num_vertices, num_trees, num_edges, num_corners, vertices, ttv, ttt, ttf, tte, eoff, ett, ete, ttc, coff, ctt, ctc)

Allocate a connectivity structure and populate from constants. The attribute fields are initialized to NULL.

Parameters

  • num_vertices:[in] Number of total vertices (i.e. geometric points).
  • num_trees:[in] Number of trees in the forest.
  • num_edges:[in] Number of tree-connecting edges.
  • num_corners:[in] Number of tree-connecting corners.
  • eoff:[in] Edge-to-tree offsets (num_edges + 1 values). This must always be non-NULL; in trivial cases it is just a pointer to a p4est_topix value of 0.
  • coff:[in] Corner-to-tree offsets (num_corners + 1 values). This must always be non-NULL; in trivial cases it is just a pointer to a p4est_topix value of 0.

Returns

The connectivity is checked for validity.

Prototype

p8est_connectivity_t *p8est_connectivity_new_copy (p4est_topidx_t num_vertices, p4est_topidx_t num_trees, p4est_topidx_t num_edges, p4est_topidx_t num_corners, const double *vertices, const p4est_topidx_t * ttv, const p4est_topidx_t * ttt, const int8_t * ttf, const p4est_topidx_t * tte, const p4est_topidx_t * eoff, const p4est_topidx_t * ett, const int8_t * ete, const p4est_topidx_t * ttc, const p4est_topidx_t * coff, const p4est_topidx_t * ctt, const int8_t * ctc);
source
P4est.LibP4est.p8est_connectivity_new_rotcubesMethod
p8est_connectivity_new_rotcubes()

Create a connectivity structure that contains a few cubes. These are rotated against each other to stress the topology routines.

Prototype

p8est_connectivity_t *p8est_connectivity_new_rotcubes (void);
source
P4est.LibP4est.p8est_connectivity_new_rotwrapMethod
p8est_connectivity_new_rotwrap()

Create a connectivity structure for a mostly periodic unit cube. The left and right faces are identified, and bottom and top rotated. Front and back are not identified.

Prototype

p8est_connectivity_t *p8est_connectivity_new_rotwrap (void);
source
P4est.LibP4est.p8est_connectivity_new_shellMethod
p8est_connectivity_new_shell()

Create a connectivity structure that builds a spherical shell. It is made up of six connected parts [-1,1]x[-1,1]x[1,2]. This connectivity reuses vertices and relies on a geometry transformation. It is thus not suitable for p8est_connectivity_complete.

Prototype

p8est_connectivity_t *p8est_connectivity_new_shell (void);
source
P4est.LibP4est.p8est_connectivity_new_sphereMethod
p8est_connectivity_new_sphere()

Create a connectivity structure that builds a solid sphere. It is made up of two layers and a cube in the center. This connectivity reuses vertices and relies on a geometry transformation. It is thus not suitable for p8est_connectivity_complete.

Prototype

p8est_connectivity_t *p8est_connectivity_new_sphere (void);
source
P4est.LibP4est.p8est_connectivity_new_torusMethod
p8est_connectivity_new_torus(nSegments)

Create a connectivity structure that builds a revolution torus.

This connectivity reuses vertices and relies on a geometry transformation. It is thus not suitable for p8est_connectivity_complete.

This connectivity reuses ideas from disk2d connectivity. More precisely the torus is divided into segments arround the revolution axis, each segments is made of 5 trees (à la disk2d). The total number of trees if 5 times the number of segments.

This connectivity is meant to be used with p8estgeometrynew_torus

Parameters

  • nSegments:[in] number of trees along the great circle

Prototype

p8est_connectivity_t *p8est_connectivity_new_torus (int nSegments);
source
P4est.LibP4est.p8est_connectivity_new_twotreesMethod
p8est_connectivity_new_twotrees(l_face, r_face, orientation)

Create a connectivity structure for two trees being rotated w.r.t. each other in a user-defined way.

Parameters

  • l_face:[in] index of left face
  • r_face:[in] index of right face
  • orientation:[in] orientation of trees w.r.t. each other

Prototype

p8est_connectivity_t *p8est_connectivity_new_twotrees (int l_face, int r_face, int orientation);
source
P4est.LibP4est.p8est_connectivity_new_twowrapMethod
p8est_connectivity_new_twowrap()

Create a connectivity structure that contains two cubes where the two far ends are identified periodically.

Prototype

p8est_connectivity_t *p8est_connectivity_new_twowrap (void);
source
P4est.LibP4est.p8est_connectivity_permuteMethod
p8est_connectivity_permute(conn, perm, is_current_to_new)

p8est_connectivity_permute Given a permutation perm of the trees in a connectivity conn, permute the trees of conn in place and update conn to match.

Parameters

  • conn:[in,out] The connectivity whose trees are permuted.
  • perm:[in] A permutation array, whose elements are size_t's.
  • is_current_to_new:[in] if true, the jth entry of perm is the new index for the entry whose current index is j, otherwise the jth entry of perm is the current index of the tree whose index will be j after the permutation.

Prototype

void p8est_connectivity_permute (p8est_connectivity_t * conn, sc_array_t * perm, int is_current_to_new);
source
P4est.LibP4est.p8est_connectivity_read_inpMethod
p8est_connectivity_read_inp(filename)

Create a p4est connectivity from an ABAQUS input file.

This utility function reads a basic ABAQUS file supporting element type with the prefix C2D4, CPS4, and S4 in 2D and of type C3D8 reading them as bilinear quadrilateral and trilinear hexahedral trees respectively.

A basic 2D mesh is given below. The *Node section gives the vertex number and x, y, and z components for each vertex. The *Element section gives the 4 vertices in 2D (8 vertices in 3D) of each element in counter clockwise order. So in 2D the nodes are given as:

4 3 +–––––––––-+ | | | | | | | | | | | | +–––––––––-+ 1 2

and in 3D they are given as:

8 7 +––––––––––-+ |\ |\ | \ | \ | \ | \ | \ | \ | 5+––––––––––-+6 | | | | +––|––––––––+ | 4\ | 3 \ | \ | \ | \ | \ | \| \| +––––––––––-+ 1 2

 *Heading
   box.inp
  *Node
      1,    5,   -5,    5
@@ -96,7 +96,7 @@
      5,       8,      21,      27,       9,       1,      20,      26,       3
      6,      21,      14,      18,      27,      20,      11,      12,      26
      7,       9,      27,      25,       5,       3,      26,      24,       2
-     8,      27,      18,      17,      25,      26,      12,      10,      24

This function reads a mesh from filename and returns an associated p4est connectivity.

Parameters

  • filename:[in] file to read the connectivity from

Returns

an allocated connectivity associated with the mesh in filename

Prototype

p8est_connectivity_t *p8est_connectivity_read_inp (const char *filename);
source
P4est.LibP4est.p8est_connectivity_read_inp_streamMethod
p8est_connectivity_read_inp_stream(stream, num_vertices, num_trees, vertices, tree_to_vertex)

Read an ABAQUS input file from a file stream.

This utility function reads a basic ABAQUS file supporting element type with the prefix C2D4, CPS4, and S4 in 2D and of type C3D8 reading them as bilinear quadrilateral and trilinear hexahedral trees respectively.

A basic 2D mesh is given below. The *Node section gives the vertex number and x, y, and z components for each vertex. The *Element section gives the 4 vertices in 2D (8 vertices in 3D) of each element in counter clockwise order. So in 2D the nodes are given as:

4 3 +–––––––––-+ | | | | | | | | | | | | +–––––––––-+ 1 2

and in 3D they are given as:

8 7 +––––––––––-+ |\ |\ | \ | \ | \ | \ | \ | \ | 5+––––––––––-+6 | | | | +––|––––––––+ | 4\ | 3 \ | \ | \ | \ | \ | \| \| +––––––––––-+ 1 2

 *Heading
+     8,      27,      18,      17,      25,      26,      12,      10,      24

This function reads a mesh from filename and returns an associated p4est connectivity.

Parameters

  • filename:[in] file to read the connectivity from

Returns

an allocated connectivity associated with the mesh in filename

Prototype

p8est_connectivity_t *p8est_connectivity_read_inp (const char *filename);
source
P4est.LibP4est.p8est_connectivity_read_inp_streamMethod
p8est_connectivity_read_inp_stream(stream, num_vertices, num_trees, vertices, tree_to_vertex)

Read an ABAQUS input file from a file stream.

This utility function reads a basic ABAQUS file supporting element type with the prefix C2D4, CPS4, and S4 in 2D and of type C3D8 reading them as bilinear quadrilateral and trilinear hexahedral trees respectively.

A basic 2D mesh is given below. The *Node section gives the vertex number and x, y, and z components for each vertex. The *Element section gives the 4 vertices in 2D (8 vertices in 3D) of each element in counter clockwise order. So in 2D the nodes are given as:

4 3 +–––––––––-+ | | | | | | | | | | | | +–––––––––-+ 1 2

and in 3D they are given as:

8 7 +––––––––––-+ |\ |\ | \ | \ | \ | \ | \ | \ | 5+––––––––––-+6 | | | | +––|––––––––+ | 4\ | 3 \ | \ | \ | \ | \ | \| \| +––––––––––-+ 1 2

 *Heading
   box.inp
  *Node
      1,    5,   -5,    5
@@ -134,4 +134,4 @@
      5,       8,      21,      27,       9,       1,      20,      26,       3
      6,      21,      14,      18,      27,      20,      11,      12,      26
      7,       9,      27,      25,       5,       3,      26,      24,       2
-     8,      27,      18,      17,      25,      26,      12,      10,      24

This code can be called two ways. The first, when vertex==NULL and tree_to_vertex==NULL, is used to count the number of trees and vertices in the connectivity to be generated by the .inp mesh in the stream. The second, when vertices!=NULL and tree_to_vertex!=NULL, fill vertices and tree_to_vertex. In this case num_vertices and num_trees need to be set to the maximum number of entries allocated in vertices and tree_to_vertex.

Parameters

  • stream:[in,out] file stream to read the connectivity from
  • num_vertices:[in,out] the number of vertices in the connectivity
  • num_trees:[in,out] the number of trees in the connectivity
  • vertices:[out] the list of vertices of the connectivity
  • tree_to_vertex:[out] the tree_to_vertex map of the connectivity

Returns

0 if successful and nonzero if not

Prototype

int p8est_connectivity_read_inp_stream (FILE * stream, p4est_topidx_t * num_vertices, p4est_topidx_t * num_trees, double *vertices, p4est_topidx_t * tree_to_vertex);
source
P4est.LibP4est.p8est_connectivity_refineMethod
p8est_connectivity_refine(conn, num_per_edge)

Uniformly refine a connectivity. This is useful if you would like to uniformly refine by something other than a power of 2.

Parameters

  • conn:[in] A valid connectivity
  • num_per_edge:[in] The number of new trees in each direction. Must use no more than P8ESTOLDQMAXLEVEL bits.

Returns

a refined connectivity.

Prototype

p8est_connectivity_t *p8est_connectivity_refine (p8est_connectivity_t * conn, int num_per_edge);
source
P4est.LibP4est.p8est_connectivity_saveMethod
p8est_connectivity_save(filename, connectivity)

Save a connectivity structure to disk.

Parameters

  • filename:[in] Name of the file to write.
  • connectivity:[in] Valid connectivity structure.

Returns

Returns 0 on success, nonzero on file error.

Prototype

int p8est_connectivity_save (const char *filename, p8est_connectivity_t * connectivity);
source
P4est.LibP4est.p8est_connectivity_set_attrMethod
p8est_connectivity_set_attr(conn, bytes_per_tree)

Allocate or free the attribute fields in a connectivity.

Parameters

  • conn:[in,out] The conn->*_to_attr fields must either be NULL or previously be allocated by this function.
  • bytes_per_tree:[in] If 0, tree_to_attr is freed (being NULL is ok). If positive, requested space is allocated.

Prototype

void p8est_connectivity_set_attr (p8est_connectivity_t * conn, size_t bytes_per_tree);
source
P4est.LibP4est.p8est_connectivity_sinkMethod
p8est_connectivity_sink(conn, sink)

Write connectivity to a sink object.

Parameters

  • conn:[in] The connectivity to be written.
  • sink:[in,out] The connectivity is written into this sink.

Returns

0 on success, nonzero on error.

Prototype

int p8est_connectivity_sink (p8est_connectivity_t * conn, sc_io_sink_t * sink);
source
P4est.LibP4est.p8est_connectivity_sourceMethod
p8est_connectivity_source(source)

Read connectivity from a source object.

Parameters

  • source:[in,out] The connectivity is read from this source.

Returns

The newly created connectivity, or NULL on error.

Prototype

p8est_connectivity_t *p8est_connectivity_source (sc_io_source_t * source);
source
P4est.LibP4est.p8est_copyMethod
p8est_copy(input, copy_data)

Make a deep copy of a p8est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL. The revision counter of the copy is set to zero.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.

Returns

Returns a valid p8est that does not depend on the input, except for borrowing the same connectivity. Its revision counter is 0.

Prototype

p8est_t *p8est_copy (p8est_t * input, int copy_data);
source
P4est.LibP4est.p8est_copy_extMethod
p8est_copy_ext(input, copy_data, duplicate_mpicomm)

Make a deep copy of a p8est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL. The revision counter of the copy is set to zero.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.
  • duplicate_mpicomm:[in] If true, MPI communicator is copied.

Returns

Returns a valid p8est that does not depend on the input, except for borrowing the same connectivity. Its revision counter is 0.

Prototype

p8est_t *p8est_copy_ext (p8est_t * input, int copy_data, int duplicate_mpicomm);
source
P4est.LibP4est.p8est_destroyMethod
p8est_destroy(p8est_)

Destroy a p8est.

Note

The connectivity structure is not destroyed with the p8est.

Prototype

void p8est_destroy (p8est_t * p8est);
source
P4est.LibP4est.p8est_expand_face_transformMethod
p8est_expand_face_transform(iface, nface, ftransform)

Fill an array with the axis combination of a face neighbor transform.

Parameters

  • iface:[in] The number of the originating face.
  • nface:[in] Encoded as nface = r * 6 + nf, where nf = 0..5 is the neigbbor's connecting face number and r = 0..3 is the relative orientation to the neighbor's face. This encoding matches p8est_connectivity_t.
  • ftransform:[out] This array holds 9 integers. [0]..[2] The coordinate axis sequence of the origin face, the first two referring to the tangentials and the third to the normal. A permutation of (0, 1, 2). [3]..[5] The coordinate axis sequence of the target face. [6]..[8] Edge reversal flags for tangential axes (boolean); face code in [0, 3] for the normal coordinate q: 0: q' = -q 1: q' = q + 1 2: q' = q - 1 3: q' = 2 - q

Prototype

void p8est_expand_face_transform (int iface, int nface, int ftransform[]);
source
P4est.LibP4est.p8est_face_quadrant_existsMethod
p8est_face_quadrant_exists(p8est_, ghost, treeid, q, face, hang, owner_rank)

Checks if quadrant exists in the local forest or the ghost layer.

For quadrants across tree boundaries it checks if the quadrant exists across any face, but not across edges or corners.

Parameters

  • p8est:[in] The forest in which to search for q.
  • ghost:[in] The ghost layer in which to search for q.
  • treeid:[in] The tree to which q belongs.
  • q:[in] The quadrant that is being searched for.
  • face:[in,out] On input, face id across which q was created. On output, the neighbor's face number augmented by orientation, so face is in 0..23.
  • hang:[in,out] If not NULL, signals that q is bigger than the quadrant it came from. The child id of that originating quadrant is passed into hang. On output, hang holds the hanging face number of q that is in contact with its originator.
  • owner_rank:[out] Filled with the rank of the owner if it is found and undefined otherwise.

Returns

Returns the local number of q if the quadrant exists in the local forest or in the ghost_layer. Otherwise, returns -2 for a domain boundary and -1 if not found.

Prototype

p4est_locidx_t p8est_face_quadrant_exists (p8est_t * p8est, p8est_ghost_t * ghost, p4est_topidx_t treeid, const p8est_quadrant_t * q, int *face, int *hang, int *owner_rank);
source
P4est.LibP4est.p8est_find_corner_transformMethod
p8est_find_corner_transform(connectivity, itree, icorner, ci)

Fills an array with information about corner neighbors.

Parameters

  • itree:[in] The number of the originating tree.
  • icorner:[in] The number of the originating corner.
  • ci:[in,out] A p8est_corner_info_t structure with initialized array.

Prototype

void p8est_find_corner_transform (p8est_connectivity_t * connectivity, p4est_topidx_t itree, int icorner, p8est_corner_info_t * ci);
source
P4est.LibP4est.p8est_find_edge_transformMethod
p8est_find_edge_transform(connectivity, itree, iedge, ei)

Fills an array with information about edge neighbors.

Parameters

  • itree:[in] The number of the originating tree.
  • iedge:[in] The number of the originating edge.
  • ei:[in,out] A p8est_edge_info_t structure with initialized array.

Prototype

void p8est_find_edge_transform (p8est_connectivity_t * connectivity, p4est_topidx_t itree, int iedge, p8est_edge_info_t * ei);
source
P4est.LibP4est.p8est_find_face_transformMethod
p8est_find_face_transform(connectivity, itree, iface, ftransform)

Fill an array with the axis combination of a face neighbor transform.

Parameters

  • itree:[in] The number of the originating tree.
  • iface:[in] The number of the originating tree's face.
  • ftransform:[out] This array holds 9 integers. [0]..[2] The coordinate axis sequence of the origin face. [3]..[5] The coordinate axis sequence of the target face. [6]..[8] Edge reverse flag for axes t1, t2; face code for n.

Returns

The face neighbor tree if it exists, -1 otherwise.

Prototype

p4est_topidx_t p8est_find_face_transform (p8est_connectivity_t * connectivity, p4est_topidx_t itree, int iface, int ftransform[]);
source
P4est.LibP4est.p8est_find_higher_boundMethod
p8est_find_higher_bound(array, q, guess)

Find the highest position tq in a quadrant array such that tq <= q.

Returns

Returns the id of the matching quadrant or -1 if array > q or the array is empty.

Prototype

ssize_t p8est_find_higher_bound (sc_array_t * array, const p8est_quadrant_t * q, size_t guess);
source
P4est.LibP4est.p8est_find_lower_boundMethod
p8est_find_lower_bound(array, q, guess)

Find the lowest position tq in a quadrant array such that tq >= q.

Returns

Returns the id of the matching quadrant or -1 if array < q or the array is empty.

Prototype

ssize_t p8est_find_lower_bound (sc_array_t * array, const p8est_quadrant_t * q, size_t guess);
source
P4est.LibP4est.p8est_find_partitionMethod
p8est_find_partition(num_procs, search_in, my_begin, my_end, _begin, _end)

Binary search in partition array. Given two targets my_begin and my_end, find offsets such that search\_in[begin] >= my\_begin, my\_end <= search\_in[end]. If more than one index satisfies the conditions, then the minimal index is the result. If there is no index that satisfies the conditions, then begin and end are tried to set equal such that search\_in[begin] >= my\_end. If my_begin is less or equal than the smallest value of search_in begin is set to 0 and if my_end is bigger or equal than the largest value of search_in end is set to num_procs - 1. If none of the above conditions is satisfied, the output is not well defined. We require `my_begin <= my_begin'.

Parameters

  • num_procs:[in] Number of processes to get the length of search_in.
  • search_in:[in] The sorted array (ascending) in that the function will search. If k indexes search_in, then 0 <= k < num\_procs.
  • my_begin:[in] The first target that defines the start of the search window.
  • my_end:[in] The second target that defines the end of the search window.
  • begin:[in,out] The first offset such that search\_in[begin] >= my\_begin.
  • end:[in,out] The second offset such that my\_end <= search\_in[end].

Prototype

void p8est_find_partition (const int num_procs, p4est_gloidx_t * search_in, p4est_gloidx_t my_begin, p4est_gloidx_t my_end, p4est_gloidx_t * begin, p4est_gloidx_t * end);
source
P4est.LibP4est.p8est_find_quadrant_cumulativeMethod
p8est_find_quadrant_cumulative(p8est_, cumulative_id, which_tree, quadrant_id)

Search a local quadrant by its cumulative number in the forest.

We perform a binary search over the processor-local trees, which means that it is advisable NOT to use this function if possible, and to try to maintain O(1) tree context information in the calling code.

Parameters

  • p8est:[in] Forest to be worked with.
  • cumulative_id:[in] Cumulative index over all trees of quadrant.
  • which_tree:[in,out] If not NULL, the input value can be -1 or an initial guess for the quadrant's tree. An initial guess must be the index of a nonempty local tree. Output is the tree of returned quadrant.
  • quadrant_id:[out] If not NULL, the number of quadrant in tree.

Returns

The identified quadrant.

Prototype

p8est_quadrant_t *p8est_find_quadrant_cumulative (p8est_t * p8est, p4est_locidx_t cumulative_id, p4est_topidx_t * which_tree, p4est_locidx_t * quadrant_id);
source
P4est.LibP4est.p8est_find_range_boundariesMethod
p8est_find_range_boundaries(lq, uq, level, faces, edges, corners)

Find the boundary points touched by a range of quadrants.

Given two smallest quadrants, lq and uq, that mark the first and the last quadrant in a range of quadrants, determine which portions of the tree boundary the range touches.

Parameters

  • lq:[in] The smallest quadrant at the start of the range: if NULL, the tree's first quadrant is taken to be the start of the range.
  • uq:[in] The smallest quadrant at the end of the range: if NULL, the tree's last quadrant is taken to be the end of the range.
  • level:[in] The level of the containing quadrant whose boundaries are tested: 0 if we want to test the boundaries of the whole tree.
  • faces:[in,out] An array of size 6 that is filled: faces[i] is true if the range touches that face.
  • edges:[in,out] An array of size 12 that is filled: edges[i] is true if the range touches that edge.
  • corners:[in,out] An array of size 8 that is filled: corners[i] is true if the range touches that corner. faces, edges or corners may be NULL.

Returns

Returns an int32_t encoded with the same information in faces, edges and corners: the first (least) six bits represent the six faces, the next twelve bits represent the twelve edges, the next eight bits represent the eight corners.

Prototype

int32_t p8est_find_range_boundaries (p8est_quadrant_t * lq, p8est_quadrant_t * uq, int level, int faces[], int edges[], int corners[]);
source
P4est.LibP4est.p8est_get_plex_data_extMethod
p8est_get_plex_data_ext(p8est_, ghost, lnodes, ctype, overlap, first_local_quad, out_points_per_dim, out_cone_sizes, out_cones, out_cone_orientations, out_vertex_coords, out_children, out_parents, out_childids, out_leaves, out_remotes, custom_numbering)

Create the data necessary to create a PETsc DMPLEX representation of a forest, as well as the accompanying lnodes and ghost layer. The forest must be at least face balanced (see p4est_balance()). See test/test_plex2.c for example usage.

All arrays should be initialized to hold sizeof (p4est_locidx_t), except for out_remotes, which should be initialized to hold (2 * sizeof (p4est_locidx_t)).

Parameters

  • p8est:[in] the forest
  • ghost:[out] the ghost layer
  • lnodes:[out] the lnodes
  • ctype:[in] the type of adjacency for the overlap
  • overlap:[in] the number of layers of overlap (zero is acceptable)
  • first_local_quad:[out] the local quadrants are assigned contiguous plex indices, starting with this index
  • out_points_per_dim:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cone_sizes:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cones:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cone_orientations:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_vertex_coords:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_children:[in,out] filled with argument for DMPlexSetTree()
  • out_parents:[in,out] filled with argument for DMPlexSetTree()
  • out_childids:[in,out] filled with argument for DMPlexSetTree()
  • out_leaves:[in,out] filled with argument for PetscSFSetGraph()
  • out_remotes:[in,out] filled with argument for PetscSFSetGraph()
  • custom_numbering:[in] Whether or use the default numbering (0) of DMPlex child ids or the custom (1).

Prototype

void p8est_get_plex_data_ext (p8est_t * p8est, p8est_ghost_t ** ghost, p8est_lnodes_t ** lnodes, p8est_connect_type_t ctype, int overlap, p4est_locidx_t * first_local_quad, sc_array_t * out_points_per_dim, sc_array_t * out_cone_sizes, sc_array_t * out_cones, sc_array_t * out_cone_orientations, sc_array_t * out_vertex_coords, sc_array_t * out_children, sc_array_t * out_parents, sc_array_t * out_childids, sc_array_t * out_leaves, sc_array_t * out_remotes, int custom_numbering);
source
P4est.LibP4est.p8est_ghost_bsearchMethod
p8est_ghost_bsearch(ghost, which_proc, which_tree, q)

Conduct binary search for exact match on a range of the ghost layer.

Parameters

  • ghost:[in] The ghost layer.
  • which_proc:[in] The owner of the searched quadrant. Can be -1.
  • which_tree:[in] The tree of the searched quadrant. Can be -1.
  • q:[in] Valid quadrant is searched in the ghost layer.

Returns

Offset in the ghost layer, or -1 if not found.

Prototype

ssize_t p8est_ghost_bsearch (p8est_ghost_t * ghost, int which_proc, p4est_topidx_t which_tree, const p8est_quadrant_t * q);
source
P4est.LibP4est.p8est_ghost_checksumMethod
p8est_ghost_checksum(p8est_, ghost)

Compute the parallel checksum of a ghost layer.

Parameters

  • p8est:[in] The MPI information of this p8est will be used.
  • ghost:[in] A ghost layer obtained from the p8est.

Returns

Parallel checksum on rank 0, 0 otherwise.

Prototype

unsigned p8est_ghost_checksum (p8est_t * p8est, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_exchange_customMethod
p8est_ghost_exchange_custom(p8est_, ghost, data_size, mirror_data, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. The data size is the same for all quadrants and can be chosen arbitrarily.

Parameters

  • p8est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • data_size:[in] The data size to transfer per quadrant.
  • mirror_data:[in] One data pointer per mirror quadrant.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghosts in sequence, which must hold at least data_size for each ghost.

Prototype

void p8est_ghost_exchange_custom (p8est_t * p8est, p8est_ghost_t * ghost, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_custom_beginMethod
p8est_ghost_exchange_custom_begin(p8est_, ghost, data_size, mirror_data, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p8est_ghost_exchange_custom. The return type is always non-NULL and must be passed to p8est_ghost_exchange_custom_end to complete the exchange. The ghost data must not be accessed before completion. The mirror data can be safely discarded right after this function returns since it is copied into internal send buffers.

Parameters

  • mirror_data:[in] Not required to stay alive any longer.
  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p8est_ghost_exchange_t *p8est_ghost_exchange_custom_begin (p8est_t * p8est, p8est_ghost_t * ghost, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_custom_levelsMethod
p8est_ghost_exchange_custom_levels(p8est_, ghost, minlevel, maxlevel, data_size, mirror_data, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. The data size is the same for all quadrants and can be chosen arbitrarily. This function restricts the transfer to a range of refinement levels. The memory for quadrants outside the level range is not dereferenced.

Parameters

  • p8est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • minlevel:[in] Level of the largest quads to be exchanged. Use <= 0 for no restriction.
  • maxlevel:[in] Level of the smallest quads to be exchanged. Use >= P8EST_QMAXLEVEL for no restriction.
  • data_size:[in] The data size to transfer per quadrant.
  • mirror_data:[in] One data pointer per mirror quadrant as input.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghosts in sequence, which must hold at least data_size for each ghost.

Prototype

void p8est_ghost_exchange_custom_levels (p8est_t * p8est, p8est_ghost_t * ghost, int minlevel, int maxlevel, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_custom_levels_beginMethod
p8est_ghost_exchange_custom_levels_begin(p8est_, ghost, minlevel, maxlevel, data_size, mirror_data, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p8est_ghost_exchange_custom_levels. The return type is always non-NULL and must be passed to p8est_ghost_exchange_custom_levels_end to complete the exchange. The ghost data must not be accessed before completion. The mirror data can be safely discarded right after this function returns since it is copied into internal send buffers.

Parameters

  • mirror_data:[in] Not required to stay alive any longer.
  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p8est_ghost_exchange_t *p8est_ghost_exchange_custom_levels_begin (p8est_t * p8est, p8est_ghost_t * ghost, int minlevel, int maxlevel, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_dataMethod
p8est_ghost_exchange_data(p8est_, ghost, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. Send the data stored in the quadrant's user_data. This is either the pointer variable itself if p8est->datasize is 0, or the content of the referenced memory field if p8est->data\size is positive.

Parameters

  • p8est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghost quadrants in sequence. If p8est->data_size is 0, must at least hold sizeof (void *) bytes for each, otherwise p8est->data_size each.

Prototype

void p8est_ghost_exchange_data (p8est_t * p8est, p8est_ghost_t * ghost, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_data_beginMethod
p8est_ghost_exchange_data_begin(p8est_, ghost, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p8est_ghost_exchange_data. The return type is always non-NULL and must be passed to p8est_ghost_exchange_data_end to complete the exchange. The ghost data must not be accessed before completion.

Parameters

  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p8est_ghost_exchange_t *p8est_ghost_exchange_data_begin (p8est_t * p8est, p8est_ghost_t * ghost, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_expandMethod
p8est_ghost_expand(p8est_, ghost)

Expand the size of the ghost layer and mirrors by one additional layer of adjacency.

Parameters

  • p8est:[in] The forest from which the ghost layer was generated.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p8est_ghost_expand (p8est_t * p8est, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_expand_by_lnodesMethod
p8est_ghost_expand_by_lnodes(p4est_, lnodes, ghost)

Expand the ghost layer as in p8est_ghost_expand(), but use node support to define adjacency instead of geometric adjacency.

Parameters

  • p8est:[in] The forest from which the ghost layer was generated.
  • lnodes:[in] The nodes to support.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p8est_ghost_expand_by_lnodes (p8est_t * p4est, p8est_lnodes_t * lnodes, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_is_validMethod
p8est_ghost_is_valid(p8est_, ghost)

Examine if a ghost structure is valid as desribed above. Test if within a ghost-structure the arrays ghosts and mirrors are in p8est_quadrant_compare_piggy order. Test if local_num in piggy3 data member of the quadrants in ghosts and mirrors are in ascending order (ascending within each rank for ghost).

Test if the p4est_locidx_t arrays are in ascending order (for mirror_proc_mirrors ascending within each rank)

Parameters

  • p8est:[in] the forest.
  • ghost:[in] Ghost layer structure.

Returns

true if ghost is valid

Prototype

int p8est_ghost_is_valid (p8est_t * p8est, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_memory_usedMethod
p8est_ghost_memory_used(ghost)

Calculate the memory usage of the ghost layer.

Parameters

  • ghost:[in] Ghost layer structure.

Returns

Memory used in bytes.

Prototype

size_t p8est_ghost_memory_used (p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_newMethod
p8est_ghost_new(p8est_, btype)

Builds the ghost layer.

This will gather the quadrants from each neighboring proc to build one layer of face, edge and corner based ghost elements around the ones they own.

Parameters

  • p8est:[in] The forest for which the ghost layer will be generated.
  • btype:[in] Which ghosts to include (across face, edge, or corner/full).

Returns

A fully initialized ghost layer.

Prototype

p8est_ghost_t *p8est_ghost_new (p8est_t * p8est, p8est_connect_type_t btype);
source
P4est.LibP4est.p8est_ghost_support_lnodesMethod
p8est_ghost_support_lnodes(p8est_, lnodes, ghost)

Expand the ghost layer to include the support of all nodes supported on the local partition.

Parameters

  • p8est:[in] The forest from which the ghost layer was generated.
  • lnodes:[in] The nodes to support.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p8est_ghost_support_lnodes (p8est_t * p8est, p8est_lnodes_t * lnodes, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_tree_containsMethod
p8est_ghost_tree_contains(ghost, which_proc, which_tree, q)

Conduct binary search for ancestor on range of the ghost layer.

Parameters

  • ghost:[in] The ghost layer.
  • which_proc:[in] The owner of the searched quadrant. Can be -1.
  • which_tree:[in] The tree of the searched quadrant. Can be -1.
  • q:[in] Valid quadrant's ancestor is searched.

Returns

Offset in the ghost layer, or -1 if not found.

Prototype

ssize_t p8est_ghost_tree_contains (p8est_ghost_t * ghost, int which_proc, p4est_topidx_t which_tree, const p8est_quadrant_t * q);
source
P4est.LibP4est.p8est_is_balancedMethod
p8est_is_balanced(p8est_, btype)

Check a forest to see if it is balanced.

This function builds the ghost layer and discards it when done.

Parameters

  • p8est:[in] The p8est to be tested.
  • btype:[in] Balance type (face, edge, corner or default, full).

Returns

Returns true if balanced, false otherwise.

Prototype

int p8est_is_balanced (p8est_t * p8est, p8est_connect_type_t btype);
source
P4est.LibP4est.p8est_iterateMethod
p8est_iterate(p4est_, ghost_layer, user_data, iter_volume, iter_face, iter_edge, iter_corner)

Execute the user-supplied callback functions at every volume, face, edge and corner in the local forest.

The ghost_layer may be NULL. The user_data pointer is not touched by p8est_iterate, but is passed to each of the callbacks. Any of the callback functions may be NULL. The callback functions are interspersed with each other, i.e. some face callbacks will occur between volume callbacks, and some edge callbacks will occur between face callbacks, etc.:

  1. volume callbacks occur in the sorted Morton-index order. 2) a face callback is not executed until after the volume callbacks have been executed for the quadrants that share it. 3) an edge callback is not executed until the face callbacks have been executed for all faces that touch the edge. 4) a corner callback is not executed until the edge callbacks have been executed for all edges that touch the corner. 5) it is not always the case that every face callback for a given quadrant is executed before any of the edge or corner callbacks, and it is not always the case that every edge callback for a given quadrant is executed before any of the corner callbacks. 6) callbacks are not executed at faces, edges or corners that only involve ghost quadrants, i.e. that are not adjacent in the local section of the forest.

Parameters

  • p4est:[in] the forest
  • ghost_layer:[in] optional: when not given, callbacks at the boundaries of the local partition cannot provide quadrant data about ghost quadrants: missing (p8est_quadrant_t *) pointers are set to NULL, missing indices are set to -1.
  • user_data:[in,out] optional context to supply to each callback
  • iter_volume:[in] callback function for every quadrant's interior
  • iter_face:[in] callback function for every face between quadrants
  • iter_edge:[in] callback function for every edge between quadrants
  • iter_corner:[in] callback function for every corner between quadrants

Prototype

void p8est_iterate (p8est_t * p4est, p8est_ghost_t * ghost_layer, void *user_data, p8est_iter_volume_t iter_volume, p8est_iter_face_t iter_face, p8est_iter_edge_t iter_edge, p8est_iter_corner_t iter_corner);
source
P4est.LibP4est.p8est_iterate_extMethod
p8est_iterate_ext(p8est_, ghost_layer, user_data, iter_volume, iter_face, iter_edge, iter_corner, remote)

p8est_iterate_ext adds the option remote: if this is false, then it is the same as p8est_iterate; if this is true, then corner/edge callbacks are also called on corners/edges for hanging faces/edges touched by local quadrants.

Prototype

void p8est_iterate_ext (p8est_t * p8est, p8est_ghost_t * ghost_layer, void *user_data, p8est_iter_volume_t iter_volume, p8est_iter_face_t iter_face, p8est_iter_edge_t iter_edge, p8est_iter_corner_t iter_corner, int remote);
source
P4est.LibP4est.p8est_lid_addMethod
p8est_lid_add(a, b, result)

Adds the uint128_t b to the uint128_t a. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void p8est_lid_add (const p8est_lid_t * a, const p8est_lid_t * b, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_bitwise_andMethod
p8est_lid_bitwise_and(a, b, result)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void p8est_lid_bitwise_and (const p8est_lid_t * a, const p8est_lid_t * b, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_bitwise_and_inplaceMethod
p8est_lid_bitwise_and_inplace(a, b)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void p8est_lid_bitwise_and_inplace (p8est_lid_t * a, const p8est_lid_t * b);
source
P4est.LibP4est.p8est_lid_bitwise_negMethod
p8est_lid_bitwise_neg(a, result)

Calculates the bitwise negation of the uint128_t a. a == result is allowed.

Parameters

  • a:[in] A pointer to a p8est_lid_t.
  • result:[out] A pointer to a p8est_lid_t. The bitwise negation of a will be saved in result.

Prototype

void p8est_lid_bitwise_neg (const p8est_lid_t * a, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_bitwise_orMethod
p8est_lid_bitwise_or(a, b, result)

Calculates the bitwise or of the uint128_t a and b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void p8est_lid_bitwise_or (const p8est_lid_t * a, const p8est_lid_t * b, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_bitwise_or_inplaceMethod
p8est_lid_bitwise_or_inplace(a, b)

Calculates the bitwise or of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void p8est_lid_bitwise_or_inplace (p8est_lid_t * a, const p8est_lid_t * b);
source
P4est.LibP4est.p8est_lid_chk_bitMethod
p8est_lid_chk_bit(input, bit_number)

Returns the bit_number-th bit of input. This function checks a bit of an existing, initialized value.

Parameters

  • input:[in] A pointer to a p8est_lid_t.
  • bit_number:[in] The bit (counted from the right hand side) that is checked by logical and. Require 0 <= bit_number < 128.

Returns

True if bit is set, false if not.

Prototype

int p8est_lid_chk_bit (const p8est_lid_t * input, int bit_number);
source
P4est.LibP4est.p8est_lid_copyMethod
p8est_lid_copy(input, output)

Copies an initialized p8est_lid_t to a p8est_lid_t.

Parameters

  • input:[in] A pointer to the sc_uint128 that is copied.
  • output:[in,out] A pointer to a p8est_lid_t. The high and low bits of output will be set to the high and low bits of input, respectively.

Prototype

void p8est_lid_copy (const p8est_lid_t * input, p8est_lid_t * output);
source
P4est.LibP4est.p8est_lid_initMethod
p8est_lid_init(input, high, low)

Initializes a linear index to a given value.

Parameters

  • a:[in,out] A pointer to the p8est_lid_t that will be initialized.
  • high:[in] The given high bits to intialize a.
  • low:[in] The given low bits to initialize a.

Prototype

void p8est_lid_init (p8est_lid_t * input, uint64_t high, uint64_t low);
source
P4est.LibP4est.p8est_lid_set_bitMethod
p8est_lid_set_bit(input, bit_number)

Sets the exponent-th bit of input to one. This function modifies an existing, initialized value.

Parameters

  • input:[in,out] A pointer to a p8est_lid_t.
  • bit_number:[in] The bit (counted from the right hand side) that is set to one by logical or. Require 0 <= bit_number < 128.

Prototype

void p8est_lid_set_bit (p8est_lid_t * input, int bit_number);
source
P4est.LibP4est.p8est_lid_set_uint64Method
p8est_lid_set_uint64(input, u)

Initializes a linear index to an unsigned 64 bit integer.

Parameters

  • input:[out] A pointer to a p4est_lid_t that will be intialized.

Prototype

void p8est_lid_set_uint64 (p8est_lid_t * input, uint64_t u);
source
P4est.LibP4est.p8est_lid_shift_leftMethod
p8est_lid_shift_left(input, shift_count, result)

Calculates the bit left shift of uint128_t input by shift_count bits. We shift in zeros from the right. If shift_count >= 128, result is 0. All bits left from the 127th bit (counted zero based from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a p8est_lid_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a p8est_lid_t. The left shifted number will be saved in result.

Prototype

void p8est_lid_shift_left (const p8est_lid_t * input, unsigned shift_count, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_shift_rightMethod
p8est_lid_shift_right(input, shift_count, result)

Calculates the bit right shift of uint128_t input by shift_count bits. We shift in zeros from the left. If shift_count >= 128, result is 0. All bits right from the zeroth bit (counted from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a p8est_lid_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a p8est_lid_t. The right shifted number will be saved in result.

Prototype

void p8est_lid_shift_right (const p8est_lid_t * input, unsigned shift_count, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_subMethod
p8est_lid_sub(a, b, result)

Substracts the p8est_lid_t b from the p8est_lid_t a. This function assumes that the result is >= 0. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void p8est_lid_sub (const p8est_lid_t * a, const p8est_lid_t * b, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_sub_inplaceMethod
p8est_lid_sub_inplace(a, b)

Substracts the uint128_t b from the uint128_t a. The result is saved in a. a == b is allowed. This function assumes that the result is >= 0.

Parameters

Prototype

void p8est_lid_sub_inplace (p8est_lid_t * a, const p8est_lid_t * b);
source
P4est.LibP4est.p8est_lnodes_newMethod
p8est_lnodes_new(p8est_, ghost_layer, degree)

Prototype

p8est_lnodes_t *p8est_lnodes_new (p8est_t * p8est, p8est_ghost_t * ghost_layer, int degree);
source
P4est.LibP4est.p8est_lnodes_share_allMethod
p8est_lnodes_share_all(node_data, lnodes)

Equivalend to calling p8est_lnodes_share_all_end directly after p8est_lnodes_share_all_begin. Use if there is no local work that can be done to mask the communication cost.

Returns

A fully initialized buffer that contains the received data. After processing this data, the buffer must be freed with p8est_lnodes_buffer_destroy.

Prototype

p8est_lnodes_buffer_t *p8est_lnodes_share_all (sc_array_t * node_data, p8est_lnodes_t * lnodes);
source
P4est.LibP4est.p8est_lnodes_share_all_beginMethod
p8est_lnodes_share_all_begin(node_data, lnodes)

p8est_lnodes_share_all_begin

node_data is a user_defined array of arbitrary type, where each entry is associated with the lnodes local nodes entry of matching index. For every process that shares an entry with the current one, the value in the node_data array of that process is written into a buffer->recvbuffers entry as described above. The user can then perform some arbitrary work that requires the data from all processes that share a node (such as reduce, max, min, etc.). When the work concludes, the buffer should be destroyed with [`p8estlnodesbufferdestroy`](@ref).

Values of node_data are not guaranteed to be send, and buffer->recvbuffer entries are not guaranteed to be received until the buffer created by [`p8estlnodesshareallbegin](@ref) is passed to [p8estlnodesshareall_end`](@ref).

Prototype

p8est_lnodes_buffer_t *p8est_lnodes_share_all_begin (sc_array_t * node_data, p8est_lnodes_t * lnodes);
source
P4est.LibP4est.p8est_lnodes_share_owned_beginMethod
p8est_lnodes_share_owned_begin(node_data, lnodes)

p8est_lnodes_share_owned_begin

node_data is a user-defined array of arbitrary type, where each entry is associated with the lnodes local nodes entry of matching index. For every local nodes entry that is owned by a process other than the current one, the value in the node_data array of the owning process is written directly into the node_data array of the current process. Values of node_data are not guaranteed to be sent or received until the buffer created by p8est_lnodes_share_owned_begin is passed to p8est_lnodes_share_owned_end.

To be memory neutral, the buffer created by p8est_lnodes_share_owned_begin must be destroying with p8est_lnodes_buffer_destroy (it is not destroyed by p8est_lnodes_share_owned_end).

Prototype

p8est_lnodes_buffer_t *p8est_lnodes_share_owned_begin (sc_array_t * node_data, p8est_lnodes_t * lnodes);
source
P4est.LibP4est.p8est_loadMethod
p8est_load(filename, mpicomm, data_size, load_data, user_pointer, connectivity)

Prototype

p8est_t *p8est_load (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, void *user_pointer, p8est_connectivity_t ** connectivity);
source
P4est.LibP4est.p8est_load_extMethod
p8est_load_ext(filename, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p8est_t *p8est_load_ext (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p8est_connectivity_t ** connectivity);
source
P4est.LibP4est.p8est_memory_usedMethod
p8est_memory_used(p8est_)

Calculate local memory usage of a forest structure. Not collective. The memory used on the current rank is returned. The connectivity structure is not counted since it is not owned; use p8est_connectivity_memory_usage (p8est->connectivity).

Parameters

  • p8est:[in] Valid forest structure.

Returns

Memory used in bytes.

Prototype

size_t p8est_memory_used (p8est_t * p8est);
source
P4est.LibP4est.p8est_mesh_face_neighbor_dataMethod
p8est_mesh_face_neighbor_data(mfn, ghost_data)

Get the user data for the current face neighbor.

Parameters

  • mfn:[in] Internal status of the iterator.
  • ghost_data:[in] Data for the ghost quadrants that has been synchronized with p4est_ghost_exchange_data.

Returns

A pointer to the user data for the current neighbor.

Prototype

void *p8est_mesh_face_neighbor_data (p8est_mesh_face_neighbor_t * mfn, void *ghost_data);
source
P4est.LibP4est.p8est_mesh_face_neighbor_initMethod
p8est_mesh_face_neighbor_init(mfn, p8est_, ghost, mesh, which_tree, quadrant)

Initialize a mesh neighbor iterator by quadrant pointer.

Parameters

  • mfn:[out] A p8est_mesh_face_neighbor_t to be initialized.
  • which_tree:[in] Tree of quadrant whose neighbors are looped over.
  • quadrant:[in] Pointer to quadrant contained in which_tree.

Prototype

void p8est_mesh_face_neighbor_init (p8est_mesh_face_neighbor_t * mfn, p8est_t * p8est, p8est_ghost_t * ghost, p8est_mesh_t * mesh, p4est_topidx_t which_tree, p8est_quadrant_t * quadrant);
source
P4est.LibP4est.p8est_mesh_face_neighbor_init2Method
p8est_mesh_face_neighbor_init2(mfn, p8est_, ghost, mesh, which_tree, quadrant_id)

Initialize a mesh neighbor iterator by quadrant index.

Parameters

  • mfn:[out] A p8est_mesh_face_neighbor_t to be initialized.
  • which_tree:[in] Tree of quadrant whose neighbors are looped over.
  • quadrant_id:[in] Index relative to which_tree of quadrant.

Prototype

void p8est_mesh_face_neighbor_init2 (p8est_mesh_face_neighbor_t * mfn, p8est_t * p8est, p8est_ghost_t * ghost, p8est_mesh_t * mesh, p4est_topidx_t which_tree, p4est_locidx_t quadrant_id);
source
P4est.LibP4est.p8est_mesh_face_neighbor_nextMethod
p8est_mesh_face_neighbor_next(mfn, ntree, nquad, nface, nrank)

Move the iterator forward to loop around neighbors of the quadrant.

Parameters

  • mfn:[in,out] Internal status of the iterator.
  • ntree:[out] If not NULL, the tree number of the neighbor.
  • nquad:[out] If not NULL, the quadrant number within tree. For ghosts instead the number in ghost layer.
  • nface:[out] If not NULL, neighbor's face as in p8est_mesh_t.
  • nrank:[out] If not NULL, the owner process of the neighbor.

Returns

Either a real quadrant or one from the ghost layer. Returns NULL when the iterator is done.

Prototype

p8est_quadrant_t *p8est_mesh_face_neighbor_next (p8est_mesh_face_neighbor_t * mfn, p4est_topidx_t * ntree, p4est_locidx_t * nquad, int *nface, int *nrank);
source
P4est.LibP4est.p8est_mesh_get_neighborsMethod
p8est_mesh_get_neighbors(p4est_, ghost, mesh, curr_quad_id, direction, neighboring_quads, neighboring_encs, neighboring_qids)

Lookup neighboring quads of quadrant in a specific direction

Parameters

  • p4est:[in] Forest to be worked with.
  • ghost:[in] Ghost quadrants.
  • mesh:[in] Mesh structure.
  • curr_quad_id:[in] Process-local ID of current quad.
  • direction:[in] Direction in which to look for adjacent quadrants is encoded as follows: 0 .. 5 neighbor(-s) across f_i, 6 .. 17 neighbor(-s) across e_{i-6} 18 .. 25 neighbor(-s) across c_{i-18}
  • neighboring_quads:[out] Array containing neighboring quad(-s) Needs to be empty, contains p4est_quadrant_t*. May be NULL, then neighboring_qids must not be NULL.
  • neighboring_encs:[out] Array containing encodings for neighboring quads as described below Needs to be empty, contains int. CAUTION: Note, that the encodings differ from the encodings saved in the mesh. Positive values are for local quadrants, negative values indicate ghost quadrants. Faces: 1 .. 24 => same size neighbor (r * 6 + nf) + 1; nf = 0 .. 5 face index; r = 0 .. 3 relative orientation 25 .. 120 => double size neighbor 25 + h * 24 + r * 6 + nf; h = 0 .. 3 number of the subface; r, nf as above 121 .. 144 => half size neighbors 121 + r * 6 + nf; r, nf as above Edges: 1 .. 24 => same size neighbor r * 12 + ne + 1; ne = 0 .. 11 edge index; r = 0 .. 1 relative orientation 25 .. 72 => double size neighbor 25 + h * 24 + r * 12 + ne; h = 0 .. 1 number of the subedge; r, ne as above 73 .. 96 => half size neighbors 73 + r * 12 + ne; r, ne as above Corners: 1 .. 8 => nc + 1; nc = 0 .. 7 corner index
  • neighboring_qids:[out] Array containing quadrant ids for neighboring quadrants. May be NULL, then no neighboring qids are collected. If non-NULL the array needs to be empty and will contain int.

Prototype

p4est_locidx_t p8est_mesh_get_neighbors (p8est_t * p4est, p8est_ghost_t * ghost, p8est_mesh_t * mesh, p4est_locidx_t curr_quad_id, p4est_locidx_t direction, sc_array_t * neighboring_quads, sc_array_t * neighboring_encs, sc_array_t * neighboring_qids);
source
P4est.LibP4est.p8est_mesh_get_quadrantMethod
p8est_mesh_get_quadrant(p4est_, mesh, qid)

Access a process-local quadrant inside a forest. Needs a mesh with populated quad_to_tree array. This is a special case of p8estmeshquadrant_cumulative.

Parameters

  • p4est:[in] The forest.
  • mesh:[in] The mesh.
  • qid:[in] Process-local id of the quadrant (cumulative over trees).

Returns

A pointer to the requested quadrant.

Prototype

p8est_quadrant_t *p8est_mesh_get_quadrant (p8est_t * p4est, p8est_mesh_t * mesh, p4est_locidx_t qid);
source
P4est.LibP4est.p8est_mesh_memory_usedMethod
p8est_mesh_memory_used(mesh)

Calculate the memory usage of the mesh structure.

Parameters

  • mesh:[in] Mesh structure.

Returns

Memory used in bytes.

Prototype

size_t p8est_mesh_memory_used (p8est_mesh_t * mesh);
source
P4est.LibP4est.p8est_mesh_newMethod
p8est_mesh_new(p8est_, ghost, btype)

Create a p8est_mesh structure. This function does not populate the quad_to_tree and quad_level fields. To populate them, use p8estmeshnew_ext.

Parameters

  • p8est:[in] A forest that is fully 2:1 balanced.
  • ghost:[in] The ghost layer created from the provided p4est.
  • btype:[in] Determines the highest codimension of neighbors.

Returns

A fully allocated mesh structure.

Prototype

p8est_mesh_t *p8est_mesh_new (p8est_t * p8est, p8est_ghost_t * ghost, p8est_connect_type_t btype);
source
P4est.LibP4est.p8est_mesh_new_extMethod
p8est_mesh_new_ext(p4est_, ghost, compute_tree_index, compute_level_lists, btype)

Create a new mesh.

Parameters

  • p8est:[in] A forest that is fully 2:1 balanced.
  • ghost:[in] The ghost layer created from the provided p4est.
  • compute_tree_index:[in] Boolean to decide whether to allocate and compute the quad_to_tree list.
  • compute_level_lists:[in] Boolean to decide whether to compute the level lists in quad_level.
  • btype:[in] Currently ignored, only face neighbors are stored.

Returns

A fully allocated mesh structure.

Prototype

p8est_mesh_t *p8est_mesh_new_ext (p8est_t * p4est, p8est_ghost_t * ghost, int compute_tree_index, int compute_level_lists, p8est_connect_type_t btype);
source
P4est.LibP4est.p8est_mesh_quadrant_cumulativeMethod
p8est_mesh_quadrant_cumulative(p8est_, mesh, cumulative_id, which_tree, quadrant_id)

Find a quadrant based on its cumulative number in the local forest. If the quad_to_tree field of the mesh structure exists, this is O(1). Otherwise, we perform a binary search over the processor-local trees.

Parameters

  • p8est:[in] Forest to be worked with.
  • mesh:[in] A mesh derived from the forest.
  • cumulative_id:[in] Cumulative index over all trees of quadrant. Must refer to a local (non-ghost) quadrant.
  • which_tree:[in,out] If not NULL, the input value can be -1 or an initial guess for the quadrant's tree and output is the tree of returned quadrant.
  • quadrant_id:[out] If not NULL, the number of quadrant in tree.

Returns

The identified quadrant.

Prototype

p8est_quadrant_t *p8est_mesh_quadrant_cumulative (p8est_t * p8est, p8est_mesh_t * mesh, p4est_locidx_t cumulative_id, p4est_topidx_t * which_tree, p4est_locidx_t * quadrant_id);
source
P4est.LibP4est.p8est_newMethod
p8est_new(mpicomm, connectivity, data_size, init_fn, user_pointer)

Prototype

p8est_t *p8est_new (sc_MPI_Comm mpicomm, p8est_connectivity_t * connectivity, size_t data_size, p8est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p8est_new_extMethod
p8est_new_ext(mpicomm, connectivity, min_quadrants, min_level, fill_uniform, data_size, init_fn, user_pointer)

Prototype

p8est_t *p8est_new_ext (sc_MPI_Comm mpicomm, p8est_connectivity_t * connectivity, p4est_locidx_t min_quadrants, int min_level, int fill_uniform, size_t data_size, p8est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p8est_partitionMethod
p8est_partition(p8est_, allow_for_coarsening, weight_fn)

Equally partition the forest. The partition can be by element count or by a user-defined weight.

The forest will be partitioned between processors such that they have an approximately equal number of quadrants (or sum of weights).

On one process, the function noops and does not call the weight callback. Otherwise, the weight callback is called once per quadrant in order.

Parameters

  • p8est:[in,out] The forest that will be partitioned.
  • allow_for_coarsening:[in] Slightly modify partition such that quadrant families are not split between ranks.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning. When running with mpisize == 1, never called. Otherwise, called in order for all quadrants if not NULL. A weighting function with constant weight 1 on each quadrant is equivalent to weight_fn == NULL but other constant weightings may result in different uniform partitionings.

Prototype

void p8est_partition (p8est_t * p8est, int allow_for_coarsening, p8est_weight_t weight_fn);
source
P4est.LibP4est.p8est_partition_extMethod
p8est_partition_ext(p8est_, partition_for_coarsening, weight_fn)

Repartition the forest.

The forest is partitioned between processors such that each processor has an approximately equal number of quadrants (or weight).

Parameters

  • p8est:[in,out] The forest that will be partitioned.
  • partition_for_coarsening:[in] If true, the partition is modified to allow one level of coarsening.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning. A weighting function with constant weight 1 on each quadrant is equivalent to weight_fn == NULL but other constant weightings may result in different uniform partitionings.

Returns

The global number of shipped quadrants

Prototype

p4est_gloidx_t p8est_partition_ext (p8est_t * p8est, int partition_for_coarsening, p8est_weight_t weight_fn);
source
P4est.LibP4est.p8est_partition_for_coarseningMethod
p8est_partition_for_coarsening(p8est_, num_quadrants_in_proc)

Correct partition to allow one level of coarsening.

Parameters

  • p8est:[in] forest whose partition is corrected
  • num_quadrants_in_proc:[in,out] partition that will be corrected

Returns

absolute number of moved quadrants

Prototype

p4est_gloidx_t p8est_partition_for_coarsening (p8est_t * p8est, p4est_locidx_t * num_quadrants_in_proc);
source
P4est.LibP4est.p8est_partition_lnodesMethod
p8est_partition_lnodes(p8est_, ghost, degree, partition_for_coarsening)

Partition using weights based on the number of nodes assigned to each element in lnodes

Parameters

  • p8est:[in,out] the forest to be repartitioned
  • ghost:[in] the ghost layer
  • degree:[in] the degree that would be passed to p8est_lnodes_new()
  • partition_for_coarsening:[in] whether the partition should allow coarsening (i.e. group siblings who might merge)

Prototype

void p8est_partition_lnodes (p8est_t * p8est, p8est_ghost_t * ghost, int degree, int partition_for_coarsening);
source
P4est.LibP4est.p8est_partition_lnodes_detailedMethod
p8est_partition_lnodes_detailed(p4est_, ghost, nodes_per_volume, nodes_per_face, nodes_per_edge, nodes_per_corner, partition_for_coarsening)

Partition using weights that are broken down by where they reside: in volumes, on faces, on edges, or on corners.

Prototype

void p8est_partition_lnodes_detailed (p8est_t * p4est, p8est_ghost_t * ghost, int nodes_per_volume, int nodes_per_face, int nodes_per_edge, int nodes_per_corner, int partition_for_coarsening);
source
P4est.LibP4est.p8est_qcoord_to_vertexMethod
p8est_qcoord_to_vertex(connectivity, treeid, x, y, z, vxyz)

Transform a quadrant coordinate into the space spanned by tree vertices.

Parameters

  • connectivity:[in] Connectivity must provide the vertices.
  • treeid:[in] Identify the tree that contains x, y, z.
  • x,:[in] y, z Quadrant coordinates relative to treeid.
  • vxyz:[out] Transformed coordinates in vertex space.

Prototype

void p8est_qcoord_to_vertex (p8est_connectivity_t * connectivity, p4est_topidx_t treeid, p4est_qcoord_t x, p4est_qcoord_t y, p4est_qcoord_t z, double vxyz[3]);
source
P4est.LibP4est.p8est_quadrant_existsMethod
p8est_quadrant_exists(p8est_, ghost, treeid, q, exists_arr, rproc_arr, rquad_arr)

Checks if quadrant exists in the local forest or the ghost layer.

For quadrants across tree corners it checks if the quadrant exists in any of the corner neighbors, thus it can execute multiple queries.

Parameters

  • p8est:[in] The forest in which to search for q
  • ghost:[in] The ghost layer in which to search for q
  • treeid:[in] The tree to which q belongs (can be extended).
  • q:[in] The quadrant that is being searched for.
  • exists_arr:[in,out] Must exist and be of of elem_size = sizeof (int) for inter-tree corner cases. Is resized by this function to one entry for each corner search and set to true/false depending on its existence in the local forest or ghost_layer.
  • rproc_arr:[in,out] If not NULL is filled with one rank per query.
  • rquad_arr:[in,out] If not NULL is filled with one quadrant per query. Its piggy3 member is defined as well.

Returns

true if the quadrant exists in the local forest or in the ghost_layer, and false if doesn't exist in either.

Prototype

int p8est_quadrant_exists (p8est_t * p8est, p8est_ghost_t * ghost, p4est_topidx_t treeid, const p8est_quadrant_t * q, sc_array_t * exists_arr, sc_array_t * rproc_arr, sc_array_t * rquad_arr);
source
P4est.LibP4est.p8est_quadrant_find_ownerMethod
p8est_quadrant_find_owner(p8est_, treeid, face, q)

Gets the processor id of a quadrant's owner. The quadrant can lie outside of a tree across faces (and only faces).

Warning

Does not work for tree edge or corner neighbors.

Parameters

  • p8est:[in] The forest in which to search for a quadrant.
  • treeid:[in] The tree to which the quadrant belongs.
  • face:[in] Supply a face direction if known, or -1 otherwise.
  • q:[in] The quadrant that is being searched for.

Returns

Processor id of the owner or -1 if the quadrant lies outside of the mesh.

Prototype

int p8est_quadrant_find_owner (p8est_t * p8est, p4est_topidx_t treeid, int face, const p8est_quadrant_t * q);
source
P4est.LibP4est.p8est_quadrant_linear_id_ext128Method
p8est_quadrant_linear_id_ext128(quadrant, level, id)

Computes the linear position as p8est_lid_t of a quadrant in a uniform grid. The grid and quadrant levels need not coincide. If they do, this is the inverse of p4estquadrantset_morton.

Note

The user_data of quadrant is never modified.

Parameters

  • quadrant:[in] Quadrant whose linear index will be computed. If the quadrant is smaller than the grid (has a higher quadrant->level), the result is computed from its ancestor at the grid's level. If the quadrant has a smaller level than the grid (it is bigger than a grid cell), the grid cell sharing its lower left corner is used as reference.
  • level:[in] The level of the regular grid compared to which the linear position is to be computed.
  • id:[in,out] A pointer to an allocated or static p8est_lid_t. id will be the linear position of this quadrant on a uniform grid.

Prototype

void p8est_quadrant_linear_id_ext128 (const p8est_quadrant_t * quadrant, int level, p8est_lid_t * id);
source
P4est.LibP4est.p8est_quadrant_set_morton_ext128Method
p8est_quadrant_set_morton_ext128(quadrant, level, id)

Set quadrant Morton indices based on linear position given as p8est_lid_t in uniform grid. This is the inverse operation of p4estquadrantlinear_id.

Note

The user_data of quadrant is never modified.

Parameters

  • quadrant:[in,out] Quadrant whose Morton indices will be set.
  • level:[in] Level of the grid and of the resulting quadrant.
  • id:[in] Linear index of the quadrant on a uniform grid.

Prototype

void p8est_quadrant_set_morton_ext128 (p8est_quadrant_t * quadrant, int level, const p8est_lid_t * id);
source
P4est.LibP4est.p8est_refineMethod
p8est_refine(p8est_, refine_recursive, refine_fn, init_fn)

Refine a forest.

Parameters

  • p8est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn gets called, or use p8est_refine_ext in p8est_extended.h and examine whether replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data of newly created quadrants, which is already allocated. This function pointer may be NULL.

Prototype

void p8est_refine (p8est_t * p8est, int refine_recursive, p8est_refine_t refine_fn, p8est_init_t init_fn);
source
P4est.LibP4est.p8est_refine_extMethod
p8est_refine_ext(p8est_, refine_recursive, maxlevel, refine_fn, init_fn, replace_fn)

Refine a forest with a bounded refinement level and a replace option.

Parameters

  • p8est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • maxlevel:[in] Maximum allowed refinement level (inclusive). If this is negative the level is restricted only by the compile-time constant QMAXLEVEL in p8est.h.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn or replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data for newly created quadrants, which is guaranteed to be allocated. This function pointer may be NULL.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace; may be NULL.

Prototype

void p8est_refine_ext (p8est_t * p8est, int refine_recursive, int maxlevel, p8est_refine_t refine_fn, p8est_init_t init_fn, p8est_replace_t replace_fn);
source
P4est.LibP4est.p8est_reset_dataMethod
p8est_reset_data(p8est_, data_size, init_fn, user_pointer)

Reset user pointer and element data. When the data size is changed the quadrant data is freed and allocated. The initialization callback is invoked on each quadrant. Old user_data content is disregarded.

Parameters

  • data_size:[in] This is the size of data for each quadrant which can be zero. Then user_data_pool is set to NULL.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically. May be NULL.
  • user_pointer:[in] Assign to the user_pointer member of the p8est before init_fn is called the first time.

Prototype

void p8est_reset_data (p8est_t * p8est, size_t data_size, p8est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p8est_revisionMethod
p8est_revision(p8est_)

Return the revision counter of the forest. Not collective, even though the revision value is the same on all ranks. A newly created forest starts with a revision counter of zero. Every refine, coarsen, partition, and balance that actually changes the mesh increases the counter by one. Operations with no effect keep the old value.

Parameters

  • p8est:[in] The forest must be valid.

Returns

Non-negative number.

Prototype

long p8est_revision (p8est_t * p8est);
source
P4est.LibP4est.p8est_saveMethod
p8est_save(filename, p8est_, save_data)

Save the complete connectivity/p8est data to disk.

This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations.

By default, we write the current processor count and partition into the file header. This makes the file depend on mpisize. For changing this see p8est_save_ext() in p8est_extended.h.

The revision counter is not saved to the file, since that would make files different that come from different revisions but store the same mesh.

Note

Aborts on file errors.

Note

If p4est is not configured to use MPI-IO, some processes return from this function before the file is complete, in which case immediate read-access to the file may require a call to sc_MPI_Barrier.

Parameters

  • filename:[in] Name of the file to write.
  • p8est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.

Prototype

void p8est_save (const char *filename, p8est_t * p8est, int save_data);
source
P4est.LibP4est.p8est_save_extMethod
p8est_save_ext(filename, p8est_, save_data, save_partition)

Save the complete connectivity/p8est data to disk. This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations. See p8est_load_ext for information on the autopartition parameter.

Note

Aborts on file errors.

Parameters

  • filename:[in] Name of the file to write.
  • p8est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.
  • save_partition:[in] If false, save file as if 1 core was used. If true, save core count and partition. Advantage: Partition can be recovered on loading with same mpisize and autopartition false. Disadvantage: Makes the file depend on mpisize. Either way the file can be loaded with autopartition true.

Prototype

void p8est_save_ext (const char *filename, p8est_t * p8est, int save_data, int save_partition);
source
P4est.LibP4est.p8est_searchMethod
p8est_search(p4est_, quadrant_fn, point_fn, points)

This function is provided for backwards compatibility. We call p8estsearchlocal with call_post = 0.

Prototype

void p8est_search (p8est_t * p4est, p8est_search_query_t quadrant_fn, p8est_search_query_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p8est_search_allMethod
p8est_search_all(p4est_, call_post, quadrant_fn, point_fn, points)

Perform a top-down search on the whole forest.

This function combines the functionality of p4estsearchlocal and p4estsearchpartition; their documentation applies for the most part.

The recursion proceeds from the root quadrant of each tree until (a) we encounter a remote quadrant that covers only one processor, or (b) we encounter a local leaf quadrant. In other words, we proceed with the recursion into a quadrant's children if (a) the quadrant is split between two or more processors, no matter whether one of them is the calling processor or not, or (b) if the quadrant is on the local processor but we have not reached a leaf yet.

The search can track one or more points, which are abstract placeholders. They are matched against the quadrants traversed using a callback function. The result of the callback function can be used to stop a recursion early. The user determines how a point is interpreted, we only pass it around.

Note that in the remote case (a), we may terminate the recursion even if the quadrant is not a leaf, which we have no means of knowing. Still, this case is sufficient to determine the processor ownership of a point.

Note

This is a very powerful function that can become slow if not used carefully.

Note

As with the two other search functions in this file, calling it once with many points is generally much faster than calling it once for each point. Using multiple points also allows for a per-quadrant termination of the recursion in addition to a more costly per-point termination.

Note

This function works fine when used for the special cases that either the partition or the local quadrants are not of interest. However, in the case of querying only local information we expect that p4estsearchlocal will be faster since it employs specific local optimizations.

Parameters

  • p4est:[in] The forest to be searched.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] Executed once for each quadrant that is entered. If the callback returns false, this quadrant and its descendants are excluded from the search, and the points in this branch are not queried further. Its point argument is always NULL. Callback may be NULL in which case it is ignored.
  • point_fn:[in] Executed once for each point that is relevant for a quadrant of the search. If it returns true, the point is tracked further down that branch, else it is discarded from the queries for the children. If points is not NULL, this callback must be not NULL. If points is NULL, it is not called.
  • points:[in] User-defined array of points. We do not interpret a point, just pass it into the callbacks. If NULL, only the quadrant_fn callback is executed. If that is NULL, the whole function noops. If not NULL, the point_fn is called on its members during the search.

Prototype

void p8est_search_all (p8est_t * p4est, int call_post, p8est_search_all_t quadrant_fn, p8est_search_all_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p8est_search_localMethod
p8est_search_local(p4est_, call_post, quadrant_fn, point_fn, points)

Search through the local part of a forest. The search is especially efficient if multiple targets, called "points" below, are searched for simultaneously.

The search runs over all local quadrants and proceeds recursively top-down. For each tree, it may start at the root of that tree, or further down at the root of the subtree that contains all of the tree's local quadrants. Likewise, some intermediate levels in the recursion may be skipped if the processor-local part is contained in a single deeper subtree. The outer loop is thus a depth-first, processor-local forest traversal. Each quadrant in that loop either is a leaf, or a (direct or indirect) strict ancestor of a leaf. On entering a new quadrant, a user-provided quadrant-callback is executed.

As a convenience, the user may provide anonymous "points" that are tracked down the forest. This way one search call may be used for multiple targets. The set of points that potentially matches a given quadrant diminishes from the root down to the leaves: For each quadrant, an inner loop over the potentially matching points executes a point-callback for each candidate that determines whether the point may be a match. If not, it is discarded in the current branch, otherwise it is passed to the next deeper level. The callback is allowed to return true for the same point and more than one quadrant; in this case more than one matching quadrant may be identified. The callback is also allowed to return false for all children of a quadrant that it returned true for earlier. If the point callback returns false for all points relevant to a quadrant, the recursion stops. The points can really be anything, p4est does not perform any interpretation, just passes the pointer along to the callback function.

If points are present and the first quadrant callback returned true, we execute it a second time after calling the point callback for all current points. This can be used to gather and postprocess information about the points more easily. If it returns false, the recursion stops.

If the points are a NULL array, they are ignored and the recursion proceeds by querying the per-quadrant callback. If the points are not NULL but an empty array, the recursion will stop immediately!

Parameters

  • p4est:[in] The forest to be searched.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] Executed once when a quadrant is entered, and once when it is left (the second time only if points are present and the first call returned true). This quadrant is always local, if not completely than at least one descendant of it. If the callback returns false, this quadrant and its descendants are excluded from the search recursion. Its point argument is always NULL. Callback may be NULL in which case it is ignored.
  • point_fn:[in] If points is not NULL, must be not NULL. Shall return true for any possible matching point. If points is NULL, this callback is ignored.
  • points:[in] User-defined array of "points". If NULL, only the quadrant_fn callback is executed. If that is NULL, this function noops. If not NULL, the point_fn is called on its members during the search.

Prototype

void p8est_search_local (p8est_t * p4est, int call_post, p8est_search_local_t quadrant_fn, p8est_search_local_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p8est_search_partitionMethod
p8est_search_partition(p4est_, call_post, quadrant_fn, point_fn, points)

Traverse the global partition top-down. We proceed top-down through the partition, identically on all processors except for the results of two user-provided callbacks. The recursion will only go down branches that are split between multiple processors. The callback functions can be used to stop a branch recursion even for split branches. This function offers the option to search for arbitrary user-defined points analogously to p4estsearchlocal.

Note

Traversing the whole processor partition will be at least O(P), so sensible use of the callback function is advised to cut it short.

Parameters

  • p4est:[in] The forest to traverse. Its local quadrants are never accessed.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] This function controls the recursion, which only continues deeper if this callback returns true for a branch quadrant. It is allowed to set this to NULL.
  • point_fn:[in] This function decides per-point whether it is followed down the recursion. Must be non-NULL if points are not NULL.
  • points:[in] User-provided array of points that are passed to the callback point_fn. See p8estsearchlocal for details.

Prototype

void p8est_search_partition (p8est_t * p4est, int call_post, p8est_search_partition_t quadrant_fn, p8est_search_partition_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p8est_source_extMethod
p8est_source_ext(src, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p8est_t *p8est_source_ext (sc_io_source_t * src, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p8est_connectivity_t ** connectivity);
source
P4est.LibP4est.p8est_split_arrayMethod
p8est_split_array(array, level, indices)

Split an array of quadrants by the children of an ancestor.

Given a sorted array of quadrants that have a common ancestor at level level, compute the indices of the first quadrant in each of the common ancestor's children at level level + 1.

Parameters

  • array:[in] The sorted array of quadrants of level > level.
  • level:[in] The level at which there is a common ancestor.
  • indices:[in,out] The indices of the first quadrant in each of the ancestors's children, plus an additional index on the end. The quadrants of array that are descendants of child i have indices between indices[i] and indices[i + 1] - 1. If indices[i] = indices[i+1], this indicates that no quadrant in the array is contained in child i.

Prototype

void p8est_split_array (sc_array_t * array, int level, size_t indices[]);
source
P4est.LibP4est.sc_abortMethod
sc_abort()

Print a stack trace, call the abort handler and then call abort ().

Prototype

void sc_abort (void) __attribute__ ((noreturn));
source
P4est.LibP4est.sc_abort_collectiveMethod
sc_abort_collective(msg)

Collective abort where only root prints a message

Prototype

void sc_abort_collective (const char *msg) __attribute__ ((noreturn));
source
P4est.LibP4est.sc_abort_verboseMethod
sc_abort_verbose(filename, lineno, msg)

Print a message to stderr and then call sc_abort ().

Prototype

void sc_abort_verbose (const char *filename, int lineno, const char *msg) __attribute__ ((noreturn));
source
P4est.LibP4est.sc_array_bsearchMethod
sc_array_bsearch(array, key, compar)

Performs a binary search on an array. The array must be sorted.

Parameters

  • array:[in] A sorted array to search in.
  • key:[in] An element to be searched for.
  • compar:[in] The comparison function to be used.

Returns

Returns the index into array for the item found, or -1.

Prototype

ssize_t sc_array_bsearch (sc_array_t * array, const void *key, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_checksumMethod
sc_array_checksum(array)

Computes the adler32 checksum of array data (see zlib documentation). This is a faster checksum than crc32, and it works with zeros as data.

Prototype

unsigned int sc_array_checksum (sc_array_t * array);
source
P4est.LibP4est.sc_array_copyMethod
sc_array_copy(dest, src)

Copy the contents of one array into another. Both arrays must have equal element sizes. The source array may be a view. We use memcpy (3): If the two arrays overlap, results are undefined.

Parameters

  • dest:[in] Array (not a view) will be resized and get new data.
  • src:[in] Array used as source of new data, will not be changed.

Prototype

void sc_array_copy (sc_array_t * dest, sc_array_t * src);
source
P4est.LibP4est.sc_array_copy_intoMethod
sc_array_copy_into(dest, dest_offset, src)

Copy the contents of one array into some portion of another. Both arrays must have equal element sizes. Either array may be a view. The destination array must be large enough. We use memcpy (3): If the two arrays overlap, results are undefined.

Parameters

  • dest:[in] Array will be written into. Its element count must be at least dest_offset + src->elem_count.
  • dest_offset:[in] First index in dest array to be overwritten. As every index, it refers to elements, not bytes.
  • src:[in] Array used as source of new data, will not be changed.

Prototype

void sc_array_copy_into (sc_array_t * dest, size_t dest_offset, sc_array_t * src);
source
P4est.LibP4est.sc_array_destroyMethod
sc_array_destroy(array)

Destroys an array structure.

Parameters

  • array:[in] The array to be destroyed.

Prototype

void sc_array_destroy (sc_array_t * array);
source
P4est.LibP4est.sc_array_destroy_nullMethod
sc_array_destroy_null(parray)

Destroys an array structure and sets the pointer to NULL.

Parameters

  • parray:[in,out] Pointer to address of array to be destroyed. On output, *parray is NULL.

Prototype

void sc_array_destroy_null (sc_array_t ** parray);
source
P4est.LibP4est.sc_array_initMethod
sc_array_init(array, elem_size)

Initializes an already allocated (or static) array structure.

Parameters

  • array:[in,out] Array structure to be initialized.
  • elem_size:[in] Size of one array element in bytes.

Prototype

void sc_array_init (sc_array_t * array, size_t elem_size);
source
P4est.LibP4est.sc_array_init_countMethod
sc_array_init_count(array, elem_size, elem_count)

Initializes an already allocated (or static) array structure and allocates a given number of elements. This function supersedes scarrayinit_size.

Parameters

  • array:[in,out] Array structure to be initialized.
  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] Number of initial array elements.

Prototype

void sc_array_init_count (sc_array_t * array, size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_init_dataMethod
sc_array_init_data(view, base, elem_size, elem_count)

Initializes an already allocated (or static) view from given plain C data. The array view returned does not require sc_array_reset (doesn't hurt though).

Parameters

  • view:[in,out] Array structure to be initialized.
  • base:[in] The data must not be moved while view is alive.
  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] The length of the view in element units. The view cannot be resized to exceed this length. It is not necessary to call sc_array_reset later.

Prototype

void sc_array_init_data (sc_array_t * view, void *base, size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_init_sizeMethod
sc_array_init_size(array, elem_size, elem_count)

Initializes an already allocated (or static) array structure and allocates a given number of elements. Deprecated: use scarrayinit_count.

Parameters

  • array:[in,out] Array structure to be initialized.
  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] Number of initial array elements.

Prototype

void sc_array_init_size (sc_array_t * array, size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_init_viewMethod
sc_array_init_view(view, array, offset, length)

Initializes an already allocated (or static) view from existing sc_array_t. The array view returned does not require sc_array_reset (doesn't hurt though).

Parameters

  • view:[in,out] Array structure to be initialized.
  • array:[in] The array must not be resized while view is alive.
  • offset:[in] The offset of the viewed section in element units. This offset cannot be changed until the view is reset.
  • length:[in] The length of the view in element units. The view cannot be resized to exceed this length. It is not necessary to call sc_array_reset later.

Prototype

void sc_array_init_view (sc_array_t * view, sc_array_t * array, size_t offset, size_t length);
source
P4est.LibP4est.sc_array_is_equalMethod
sc_array_is_equal(array, other)

Check whether two arrays have equal size, count, and content. Either array may be a view. Both arrays will not be changed.

Parameters

  • array:[in] One array to be compared.
  • other:[in] A second array to be compared.

Returns

True if array and other are equal, false otherwise.

Prototype

int sc_array_is_equal (sc_array_t * array, sc_array_t * other);
source
P4est.LibP4est.sc_array_is_permutationMethod
sc_array_is_permutation(array)

Determine whether array is an array of size_t's whose entries include every integer 0 <= i < array->elem_count.

Parameters

  • array:[in] An array.

Returns

Returns 1 if array contains size_t elements whose entries include every integer 0 <= i < array->elem_count, 0 otherwise.

Prototype

int sc_array_is_permutation (sc_array_t * array);
source
P4est.LibP4est.sc_array_is_sortedMethod
sc_array_is_sorted(array, compar)

Check whether the array is sorted wrt. the comparison function.

Parameters

  • array:[in] The array to check.
  • compar:[in] The comparison function to be used.

Returns

True if array is sorted, false otherwise.

Prototype

int sc_array_is_sorted (sc_array_t * array, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_memory_usedMethod
sc_array_memory_used(array, is_dynamic)

Calculate the memory used by an array.

Parameters

Returns

Memory used in bytes.

Prototype

size_t sc_array_memory_used (sc_array_t * array, int is_dynamic);
source
P4est.LibP4est.sc_array_memsetMethod
sc_array_memset(array, c)

Run memset on the array storage. We pass the character to memset unchanged. Thus, care must be taken when setting values below -1 or above 127, just as with standard memset (3).

Parameters

  • array:[in,out] This array's storage will be overwritten.
  • c:[in] Character to overwrite every byte with.

Prototype

void sc_array_memset (sc_array_t * array, int c);
source
P4est.LibP4est.sc_array_move_partMethod
sc_array_move_part(dest, dest_offset, src, src_offset, count)

Copy part of one array into another using memmove (3). Both arrays must have equal element sizes. Either array may be a view. The destination array must be large enough. We use memmove (3): The two arrays may overlap.

Parameters

  • dest:[in] Array will be written into. Its element count must be at least dest_offset + count.
  • dest_offset:[in] First index in dest array to be overwritten. As every index, it refers to elements, not bytes.
  • src:[in] Array will be read from. Its element count must be at least src_offset + count.
  • src_offset:[in] First index in src array to be used. As every index, it refers to elements, not bytes.
  • count:[in] Number of entries copied.

Prototype

void sc_array_move_part (sc_array_t * dest, size_t dest_offset, sc_array_t * src, size_t src_offset, size_t count);
source
P4est.LibP4est.sc_array_newMethod
sc_array_new(elem_size)

Creates a new array structure with 0 elements.

Parameters

  • elem_size:[in] Size of one array element in bytes.

Returns

Return an allocated array of zero length.

Prototype

sc_array_t *sc_array_new (size_t elem_size);
source
P4est.LibP4est.sc_array_new_countMethod
sc_array_new_count(elem_size, elem_count)

Creates a new array structure with a given length (number of elements).

Parameters

  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] Initial number of array elements.

Returns

Return an allocated array with allocated but uninitialized elements.

Prototype

sc_array_t *sc_array_new_count (size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_new_dataMethod
sc_array_new_data(base, elem_size, elem_count)

Creates a new view of an existing plain C array.

Parameters

  • base:[in] The data must not be moved while view is alive.
  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] The length of the view in element units. The view cannot be resized to exceed this length.

Prototype

sc_array_t *sc_array_new_data (void *base, size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_new_viewMethod
sc_array_new_view(array, offset, length)

Creates a new view of an existing sc_array_t.

Parameters

  • array:[in] The array must not be resized while view is alive.
  • offset:[in] The offset of the viewed section in element units. This offset cannot be changed until the view is reset.
  • length:[in] The length of the viewed section in element units. The view cannot be resized to exceed this length.

Prototype

sc_array_t *sc_array_new_view (sc_array_t * array, size_t offset, size_t length);
source
P4est.LibP4est.sc_array_permuteMethod
sc_array_permute(array, newindices, keepperm)

Given permutation newindices, permute array in place. The data that on input is contained in array[i] will be contained in array[newindices[i]] on output. The entries of newindices will be altered unless keepperm is true.

Parameters

  • array:[in,out] An array.
  • newindices:[in,out] Permutation array (see sc_array_is_permutation).
  • keepperm:[in] If true, newindices will be unchanged by the algorithm; if false, newindices will be the identity permutation on output, but the algorithm will only use O(1) space.

Prototype

void sc_array_permute (sc_array_t * array, sc_array_t * newindices, int keepperm);
source
P4est.LibP4est.sc_array_pqueue_addMethod
sc_array_pqueue_add(array, temp, compar)

Adds an element to a priority queue. PQUEUE FUNCTIONS ARE UNTESTED AND CURRENTLY DISABLED. This function is not allowed for views. The priority queue is implemented as a heap in ascending order. A heap is a binary tree where the children are not less than their parent. Assumes that elements [0]..[elem_count-2] form a valid heap. Then propagates [elem_count-1] upward by swapping if necessary.

Note

If the return value is zero for all elements in an array, the array is sorted linearly and unchanged.

Parameters

  • temp:[in] Pointer to unused allocated memory of elem_size.
  • compar:[in] The comparison function to be used.

Returns

Returns the number of swap operations.

Prototype

size_t sc_array_pqueue_add (sc_array_t * array, void *temp, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_pqueue_popMethod
sc_array_pqueue_pop(array, result, compar)

Pops the smallest element from a priority queue. PQUEUE FUNCTIONS ARE UNTESTED AND CURRENTLY DISABLED. This function is not allowed for views. This function assumes that the array forms a valid heap in ascending order.

Note

This function resizes the array to elem_count-1.

Parameters

  • result:[out] Pointer to unused allocated memory of elem_size.
  • compar:[in] The comparison function to be used.

Returns

Returns the number of swap operations.

Prototype

size_t sc_array_pqueue_pop (sc_array_t * array, void *result, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_resetMethod
sc_array_reset(array)

Sets the array count to zero and frees all elements. This function turns a view into a newly initialized array.

Note

Calling sc_array_init, then any array operations, then sc_array_reset is memory neutral. As an exception, the two functions sc_array_init_view and sc_array_init_data do not require a subsequent call to sc_array_reset. Regardless, it is legal to call sc_array_reset anyway.

Parameters

  • array:[in,out] Array structure to be reset.

Prototype

void sc_array_reset (sc_array_t * array);
source
P4est.LibP4est.sc_array_resizeMethod
sc_array_resize(array, new_count)

Sets the element count to new_count. If the array is not a view, reallocation takes place occasionally. If the array is a view, new_count must not be greater than the element count of the view when it was created. The original offset of the view cannot be changed.

Parameters

  • array:[in,out] The element count and address is modified.
  • new_count:[in] New element count of the array. If it is zero and the array is not a view, the effect equals scarrayreset.

Prototype

void sc_array_resize (sc_array_t * array, size_t new_count);
source
P4est.LibP4est.sc_array_rewindMethod
sc_array_rewind(array, new_count)

Shorten an array without reallocating it.

Parameters

  • array:[in,out] The element count of this array is modified.
  • new_count:[in] Must be less or equal than the array's count. If it is less, the number of elements in the array is reduced without reallocating memory. The exception is a new_count of zero specified for an array that is not a view: In this case scarrayreset is equivalent.

Prototype

void sc_array_rewind (sc_array_t * array, size_t new_count);
source
P4est.LibP4est.sc_array_sortMethod
sc_array_sort(array, compar)

Sorts the array in ascending order wrt. the comparison function.

Parameters

  • array:[in] The array to sort.
  • compar:[in] The comparison function to be used.

Prototype

void sc_array_sort (sc_array_t * array, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_splitMethod
sc_array_split(array, offsets, num_types, type_fn, data)

Compute the offsets of groups of enumerable types in an array.

Parameters

  • array:[in] Array that is sorted in ascending order by type. If k indexes array, then 0 <= type_fn (array, k, data) < num_types.
  • offsets:[in,out] An initialized array of type size_t that is resized to num_types + 1 entries. The indices j of array that contain objects of type k are offsets[k] <= j < offsets[k + 1]. If there are no objects of type k, then offsets[k] = offset[k + 1].
  • num_types:[in] The number of possible types of objects in array.
  • type_fn:[in] Returns the type of an object in the array.
  • data:[in] Arbitrary user data passed to type_fn.

Prototype

void sc_array_split (sc_array_t * array, sc_array_t * offsets, size_t num_types, sc_array_type_t type_fn, void *data);
source
P4est.LibP4est.sc_array_truncateMethod
sc_array_truncate(array)

Sets the array count to zero, but does not free elements. Not allowed for views.

Note

This is intended to allow an sc_array to be used as a reusable buffer, where the "high water mark" of the buffer is preserved, so that O(log (max n)) reallocs occur over the life of the buffer.

Parameters

  • array:[in,out] Array structure to be truncated.

Prototype

void sc_array_truncate (sc_array_t * array);
source
P4est.LibP4est.sc_array_uniqMethod
sc_array_uniq(array, compar)

Removed duplicate entries from a sorted array. This function is not allowed for views.

Parameters

  • array:[in,out] The array size will be reduced as necessary.
  • compar:[in] The comparison function to be used.

Prototype

void sc_array_uniq (sc_array_t * array, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_atoiMethod
sc_atoi(nptr)

Safe version of the standard library atoi (3) function.

Parameters

  • nptr:[in] NUL-terminated string.

Returns

Converted integer value. 0 if no valid number. INT_MAX on overflow, INT_MIN on underflow.

Prototype

int sc_atoi (const char *nptr);
source
P4est.LibP4est.sc_atolMethod
sc_atol(nptr)

Safe version of the standard library atol (3) function.

Parameters

  • nptr:[in] NUL-terminated string.

Returns

Converted long value. 0 if no valid number. LONG_MAX on overflow, LONG_MIN on underflow.

Prototype

long sc_atol (const char *nptr);
source
P4est.LibP4est.sc_fflush_fsync_fcloseMethod
sc_fflush_fsync_fclose(file)

Best effort to flush a file's data to disc and close it.

Parameters

  • file:[in,out] File open for writing.

Prototype

void sc_fflush_fsync_fclose (FILE * file);
source
P4est.LibP4est.sc_finalizeMethod
sc_finalize()

Unregisters all packages, runs the memory check, removes the signal handlers and resets sc_identifier and sc_root_*. This function aborts on any inconsistency found unless the global variable default_abort_mismatch is false. This function is optional. This function does not require sc_init to be called first.

Prototype

void sc_finalize (void);
source
P4est.LibP4est.sc_finalize_noabortMethod
sc_finalize_noabort()

Unregisters all packages, runs the memory check, removes the signal handlers and resets sc_identifier and sc_root_*. This function never aborts but returns the number of errors encountered. This function is optional. This function does not require sc_init to be called first.

Returns

0 when everything is consistent, nonzero otherwise.

Prototype

int sc_finalize_noabort (void);
source
P4est.LibP4est.sc_freadMethod
sc_fread(ptr, size, nmemb, file, errmsg)

Read file content into memory.

Note

This function aborts on file errors.

Parameters

  • ptr:[out] Data array to read from disk.
  • size:[in] Size of one array member.
  • nmemb:[in] Number of array members.
  • file:[in,out] File pointer, must be opened for reading.
  • errmsg:[in] Error message passed to SC_CHECK_ABORT.

Prototype

void sc_fread (void *ptr, size_t size, size_t nmemb, FILE * file, const char *errmsg);
source
P4est.LibP4est.sc_fwriteMethod
sc_fwrite(ptr, size, nmemb, file, errmsg)

Write memory content to a file.

Note

This function aborts on file errors.

Parameters

  • ptr:[in] Data array to write to disk.
  • size:[in] Size of one array member.
  • nmemb:[in] Number of array members.
  • file:[in,out] File pointer, must be opened for writing.
  • errmsg:[in] Error message passed to SC_CHECK_ABORT.

Prototype

void sc_fwrite (const void *ptr, size_t size, size_t nmemb, FILE * file, const char *errmsg);
source
P4est.LibP4est.sc_hash_array_insert_uniqueMethod
sc_hash_array_insert_unique(hash_array, v, position)

Insert an object into a hash array if it is not contained already. The object is not copied into the array. Use the return value for that. New objects are guaranteed to be added at the end of the array.

Parameters

  • v:[in] A pointer to the object. Used for search only.
  • position:[out] If position != NULL, *position is set to the array position of the already contained, or if not present, the new object.

Returns

Returns NULL if the object is already contained. Otherwise returns its new address in the array.

Prototype

void *sc_hash_array_insert_unique (sc_hash_array_t * hash_array, void *v, size_t *position);
source
P4est.LibP4est.sc_hash_array_lookupMethod
sc_hash_array_lookup(hash_array, v, position)

Check if an object is contained in a hash array.

Parameters

  • v:[in] A pointer to the object.
  • position:[out] If position != NULL, *position is set to the array position of the already contained object if found.

Returns

Returns true if object is found, false otherwise.

Prototype

int sc_hash_array_lookup (sc_hash_array_t * hash_array, void *v, size_t *position);
source
P4est.LibP4est.sc_hash_array_memory_usedMethod
sc_hash_array_memory_used(ha)

Calculate the memory used by a hash array.

Parameters

  • ha:[in] The hash array.

Returns

Memory used in bytes.

Prototype

size_t sc_hash_array_memory_used (sc_hash_array_t * ha);
source
P4est.LibP4est.sc_hash_array_newMethod
sc_hash_array_new(elem_size, hash_fn, equal_fn, user_data)

Create a new hash array.

Parameters

  • elem_size:[in] Size of one array element in bytes.
  • hash_fn:[in] Function to compute the hash value.
  • equal_fn:[in] Function to test two objects for equality.

Prototype

sc_hash_array_t *sc_hash_array_new (size_t elem_size, sc_hash_function_t hash_fn, sc_equal_function_t equal_fn, void *user_data);
source
P4est.LibP4est.sc_hash_array_ripMethod
sc_hash_array_rip(hash_array, rip)

Extract the array data from a hash array and destroy everything else.

Parameters

  • hash_array:[in] The hash array is destroyed after extraction.
  • rip:[in] Array structure that will be overwritten. All previous array data (if any) will be leaked. The filled array can be freed with sc_array_reset.

Prototype

void sc_hash_array_rip (sc_hash_array_t * hash_array, sc_array_t * rip);
source
P4est.LibP4est.sc_hash_array_truncateMethod
sc_hash_array_truncate(hash_array)

Remove all elements from the hash array.

Parameters

  • hash_array:[in,out] Hash array to truncate.

Prototype

void sc_hash_array_truncate (sc_hash_array_t * hash_array);
source
P4est.LibP4est.sc_hash_destroyMethod
sc_hash_destroy(hash)

Destroy a hash table.

If the allocator is owned, this runs in O(1), otherwise in O(N).

Note

If allocator was provided in sc_hash_new, it will not be destroyed.

Prototype

void sc_hash_destroy (sc_hash_t * hash);
source
P4est.LibP4est.sc_hash_destroy_nullMethod
sc_hash_destroy_null(phash)

Destroy a hash table and set its pointer to NULL. Destruction is done using schashdestroy.

Parameters

  • phash:[in,out] Address of pointer to hash table. On output, pointer is NULLed.

Prototype

void sc_hash_destroy_null (sc_hash_t ** phash);
source
P4est.LibP4est.sc_hash_foreachMethod
sc_hash_foreach(hash, fn)

Invoke a callback for every member of the hash table. The functions hash_fn and equal_fn are not called by this function.

Prototype

void sc_hash_foreach (sc_hash_t * hash, sc_hash_foreach_t fn);
source
P4est.LibP4est.sc_hash_function_stringMethod
sc_hash_function_string(s, u)

Compute a hash value from a null-terminated string. This hash function is NOT cryptographically safe! Use libcrypt then.

Parameters

  • s:[in] Null-terminated string to be hashed.
  • u:[in] Not used.

Returns

The computed hash value as an unsigned integer.

Prototype

unsigned int sc_hash_function_string (const void *s, const void *u);
source
P4est.LibP4est.sc_hash_insert_uniqueMethod
sc_hash_insert_unique(hash, v, found)

Insert an object into a hash table if it is not contained already.

Parameters

  • v:[in] The object to be inserted.
  • found:[out] If found != NULL, *found is set to the address of the pointer to the already contained, or if not present, the new object. You can assign to **found to override.

Returns

Returns true if object is added, false if it is already contained.

Prototype

int sc_hash_insert_unique (sc_hash_t * hash, void *v, void ***found);
source
P4est.LibP4est.sc_hash_lookupMethod
sc_hash_lookup(hash, v, found)

Check if an object is contained in the hash table.

Parameters

  • v:[in] The object to be looked up.
  • found:[out] If found != NULL, *found is set to the address of the pointer to the already contained object if the object is found. You can assign to **found to override.

Returns

Returns true if object is found, false otherwise.

Prototype

int sc_hash_lookup (sc_hash_t * hash, void *v, void ***found);
source
P4est.LibP4est.sc_hash_memory_usedMethod
sc_hash_memory_used(hash)

Calculate the memory used by a hash table.

Parameters

  • hash:[in] The hash table.

Returns

Memory used in bytes.

Prototype

size_t sc_hash_memory_used (sc_hash_t * hash);
source
P4est.LibP4est.sc_hash_newMethod
sc_hash_new(hash_fn, equal_fn, user_data, allocator)

Create a new hash table. The number of hash slots is chosen dynamically.

Parameters

  • hash_fn:[in] Function to compute the hash value.
  • equal_fn:[in] Function to test two objects for equality.
  • user_data:[in] User data passed through to the hash function.
  • allocator:[in] Memory allocator for sc_link_t, can be NULL.

Prototype

sc_hash_t *sc_hash_new (sc_hash_function_t hash_fn, sc_equal_function_t equal_fn, void *user_data, sc_mempool_t * allocator);
source
P4est.LibP4est.sc_hash_print_statisticsMethod
sc_hash_print_statistics(package_id, log_priority, hash)

Compute and print statistical information about the occupancy.

Prototype

void sc_hash_print_statistics (int package_id, int log_priority, sc_hash_t * hash);
source
P4est.LibP4est.sc_hash_removeMethod
sc_hash_remove(hash, v, found)

Remove an object from a hash table.

Parameters

  • v:[in] The object to be removed.
  • found:[out] If found != NULL, *found is set to the object that is removed if that exists.

Returns

Returns true if object is found, false if is not contained.

Prototype

int sc_hash_remove (sc_hash_t * hash, void *v, void **found);
source
P4est.LibP4est.sc_hash_unlinkMethod
sc_hash_unlink(hash)

Unlink all hash elements without returning them to the mempool.

If the allocator is not owned, this runs faster than sc_hash_truncate, but is dangerous because of potential memory leaks.

Parameters

  • hash:[in,out] Hash structure to be unlinked.

Prototype

void sc_hash_unlink (sc_hash_t * hash);
source
P4est.LibP4est.sc_hash_unlink_destroyMethod
sc_hash_unlink_destroy(hash)

Same effect as unlink and destroy, but in O(1). This is dangerous because of potential memory leaks.

Parameters

  • hash:[in] Hash structure to be unlinked and destroyed.

Prototype

void sc_hash_unlink_destroy (sc_hash_t * hash);
source
P4est.LibP4est.sc_initMethod
sc_init(mpicomm, catch_signals, print_backtrace, log_handler, log_threshold)

Prototype

void sc_init (sc_MPI_Comm mpicomm, int catch_signals, int print_backtrace, sc_log_handler_t log_handler, int log_threshold);
source
P4est.LibP4est.sc_io_sink_alignMethod
sc_io_sink_align(sink, bytes_align)

Align sink to a byte boundary by writing zeros.

Parameters

  • sink:[in,out] The sink object to align.
  • bytes_align:[in] Byte boundary.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_sink_align (sc_io_sink_t * sink, size_t bytes_align);
source
P4est.LibP4est.sc_io_sink_completeMethod
sc_io_sink_complete(sink, bytes_in, bytes_out)

Flush all buffered output data to sink. This function may return SC_IO_ERROR_AGAIN if another write is required. Currently this may happen if BUFFER requires an integer multiple of bytes. If successful, the updated value of bytes read and written is returned in bytes_in/out, and the sink status is reset as if the sink had just been created. In particular, the bytes counters are reset to zero. The internal state of the sink is not changed otherwise. It is legal to continue writing to the sink hereafter. The sink actions taken depend on its type. BUFFER, FILEFILE: none. FILENAME: call fclose on sink->file.

Parameters

  • sink:[in,out] The sink object to write to.
  • bytes_in:[in,out] Bytes received since the last new or complete call. May be NULL.
  • bytes_out:[in,out] Bytes written since the last new or complete call. May be NULL.

Returns

0 if completed, nonzero on error.

Prototype

int sc_io_sink_complete (sc_io_sink_t * sink, size_t * bytes_in, size_t * bytes_out);
source
P4est.LibP4est.sc_io_sink_destroyMethod
sc_io_sink_destroy(sink)

Free data sink. Calls sc_io_sink_complete and discards the final counts. Errors from complete lead to SC_IO_ERROR_FATAL returned from this function. Call sc_io_sink_complete yourself if bytes_out is of interest.

Parameters

  • sink:[in,out] The sink object to complete and free.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_sink_destroy (sc_io_sink_t * sink);
source
P4est.LibP4est.sc_io_sink_writeMethod
sc_io_sink_write(sink, data, bytes_avail)

Write data to a sink. Data may be buffered and sunk in a later call. The internal counters sink->bytes_in and sink->bytes_out are updated.

Parameters

  • sink:[in,out] The sink object to write to.
  • data:[in] Data passed into sink.
  • bytes_avail:[in] Number of data bytes passed in.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_sink_write (sc_io_sink_t * sink, const void *data, size_t bytes_avail);
source
P4est.LibP4est.sc_io_source_activate_mirrorMethod
sc_io_source_activate_mirror(source)

Activate a buffer that mirrors (i.e., stores) the data that was read.

Parameters

  • source:[in,out] The source object to activate mirror in.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_source_activate_mirror (sc_io_source_t * source);
source
P4est.LibP4est.sc_io_source_alignMethod
sc_io_source_align(source, bytes_align)

Align source to a byte boundary by skipping.

Parameters

  • source:[in,out] The source object to align.
  • bytes_align:[in] Byte boundary.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_source_align (sc_io_source_t * source, size_t bytes_align);
source
P4est.LibP4est.sc_io_source_completeMethod
sc_io_source_complete(source, bytes_in, bytes_out)

Determine whether all data buffered from source has been returned by read. If it returns SC_IO_ERROR_AGAIN, another sc_io_source_read is required. If the call returns no error, the internal counters source->bytes_in and source->bytes_out are returned to the caller if requested, and reset to 0. The internal state of the source is not changed otherwise. It is legal to continue reading from the source hereafter.

Parameters

  • source:[in,out] The source object to read from.
  • bytes_in:[in,out] If not NULL and true is returned, the total size of the data sourced.
  • bytes_out:[in,out] If not NULL and true is returned, total bytes passed out by source_read.

Returns

SC_IO_ERROR_AGAIN if buffered data remaining. Otherwise return ERROR_NONE and reset counters.

Prototype

int sc_io_source_complete (sc_io_source_t * source, size_t * bytes_in, size_t * bytes_out);
source
P4est.LibP4est.sc_io_source_destroyMethod
sc_io_source_destroy(source)

Free data source. Calls sc_io_source_complete and requires it to return no error. This is to avoid discarding buffered data that has not been passed to read.

Parameters

  • source:[in,out] The source object to free.

Returns

0 on success. Nonzero if an error is encountered or is_complete returns one.

Prototype

int sc_io_source_destroy (sc_io_source_t * source);
source
P4est.LibP4est.sc_io_source_readMethod
sc_io_source_read(source, data, bytes_avail, bytes_out)

Read data from a source. The internal counters source->bytes_in and source->bytes_out are updated. Data is read until the data buffer has not enough room anymore, or source becomes empty. It is possible that data already read internally remains in the source object for the next call. Call sc_io_source_complete and check its return value to find out. Returns an error if bytes_out is NULL and less than bytes_avail are read.

Parameters

  • source:[in,out] The source object to read from.
  • data:[in] Data buffer for reading from sink. If NULL the output data will be thrown away.
  • bytes_avail:[in] Number of bytes available in data buffer.
  • bytes_out:[in,out] If not NULL, byte count read into data buffer. Otherwise, requires to read exactly bytes_avail.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_source_read (sc_io_source_t * source, void *data, size_t bytes_avail, size_t * bytes_out);
source
P4est.LibP4est.sc_io_source_read_mirrorMethod
sc_io_source_read_mirror(source, data, bytes_avail, bytes_out)

Read data from the source's mirror. Same behaviour as sc_io_source_read.

Parameters

  • source:[in,out] The source object to read mirror data from.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_source_read_mirror (sc_io_source_t * source, void *data, size_t bytes_avail, size_t * bytes_out);
source
P4est.LibP4est.sc_is_rootMethod
sc_is_root()

Identify the root process. Only meaningful between sc_init and sc_finalize and with a communicator that is not sc_MPI_COMM_NULL (otherwise always true).

Returns

Return true for the root process and false otherwise.

Prototype

int sc_is_root (void);
source
P4est.LibP4est.sc_list_appendMethod
sc_list_append(list, data)

Insert a list element at the end of the list.

Parameters

  • list:[in,out] Valid list object.
  • data:[in] A new link is created holding this data.

Returns

The link that has been created for data.

Prototype

sc_link_t *sc_list_append (sc_list_t * list, void *data);
source
P4est.LibP4est.sc_list_destroyMethod
sc_list_destroy(list)

Destroy a linked list structure in O(N).

Note

If allocator was provided in sc_list_new, it will not be destroyed.

Parameters

  • list:[in,out] All memory allocated for this list is freed.

Prototype

void sc_list_destroy (sc_list_t * list);
source
P4est.LibP4est.sc_list_initMethod
sc_list_init(list, allocator)

Initialize a list object with an external link allocator.

Parameters

  • list:[in,out] List structure to be initialized.
  • allocator:[in] External memory allocator for sc_link_t, which must exist already.

Prototype

void sc_list_init (sc_list_t * list, sc_mempool_t * allocator);
source
P4est.LibP4est.sc_list_insertMethod
sc_list_insert(list, pred, data)

Insert an element after a given list position.

Parameters

  • list:[in,out] Valid list object.
  • pred:[in,out] The predecessor of the element to be inserted.
  • data:[in] A new link is created holding this data.

Returns

The link that has been created for data.

Prototype

sc_link_t *sc_list_insert (sc_list_t * list, sc_link_t * pred, void *data);
source
P4est.LibP4est.sc_list_memory_usedMethod
sc_list_memory_used(list, is_dynamic)

Calculate the total memory used by a list.

Parameters

Returns

Memory used in bytes.

Prototype

size_t sc_list_memory_used (sc_list_t * list, int is_dynamic);
source
P4est.LibP4est.sc_list_newMethod
sc_list_new(allocator)

Allocate a new, empty linked list.

Parameters

  • allocator:[in] Memory allocator for sc_link_t, can be NULL in which case an internal allocator is created.

Returns

Pointer to a newly allocated, empty list object.

Prototype

sc_list_t *sc_list_new (sc_mempool_t * allocator);
source
P4est.LibP4est.sc_list_popMethod
sc_list_pop(list)

Remove an element from the front of the list.

Parameters

  • list:[in,out] Valid, non-empty list object.

Returns

Returns the data of the removed first list element.

Prototype

void *sc_list_pop (sc_list_t * list);
source
P4est.LibP4est.sc_list_prependMethod
sc_list_prepend(list, data)

Insert a list element at the beginning of the list.

Parameters

  • list:[in,out] Valid list object.
  • data:[in] A new link is created holding this data.

Returns

The link that has been created for data.

Prototype

sc_link_t *sc_list_prepend (sc_list_t * list, void *data);
source
P4est.LibP4est.sc_list_removeMethod
sc_list_remove(list, pred)

Remove an element after a given list position.

Parameters

  • list:[in,out] Valid, non-empty list object.
  • pred:[in] The predecessor of the element to be removed. If pred == NULL, the first element is removed, which is equivalent to calling sc_list_pop (list).

Returns

The data of the removed and freed link.

Prototype

void *sc_list_remove (sc_list_t * list, sc_link_t * pred);
source
P4est.LibP4est.sc_list_unlinkMethod
sc_list_unlink(list)

Unlink all list elements without returning them to the mempool. This runs in O(1) but is dangerous because the link memory stays alive.

Parameters

  • list:[in,out] List structure to be unlinked.

Prototype

void sc_list_unlink (sc_list_t * list);
source
P4est.LibP4est.sc_logMethod
sc_log(filename, lineno, package, category, priority, msg)

The central log function to be called by all packages. Dispatches the log calls by package and filters by category and priority.

Parameters

  • package:[in] Must be a registered package id or -1.
  • category:[in] Must be SC_LC_NORMAL or SC_LC_GLOBAL.
  • priority:[in] Must be > SC_LP_ALWAYS and < SC_LP_SILENT.

Prototype

void sc_log (const char *filename, int lineno, int package, int category, int priority, const char *msg);
source
P4est.LibP4est.sc_log_indent_pop_countMethod
sc_log_indent_pop_count(package, count)

Remove spaces from the start of a package's default log format.

Prototype

void sc_log_indent_pop_count (int package, int count);
source
P4est.LibP4est.sc_mempool_destroyMethod
sc_mempool_destroy(mempool)

Destroy a mempool structure. All elements that are still in use are invalidated.

Parameters

  • mempool:[in,out] Its memory is freed.

Prototype

void sc_mempool_destroy (sc_mempool_t * mempool);
source
P4est.LibP4est.sc_mempool_destroy_nullMethod
sc_mempool_destroy_null(pmempool)

Destroy a mempool structure. All elements that are still in use are invalidated.

Parameters

  • pmempool:[in,out] Address of pointer to memory pool. Its memory is freed, pointer is NULLed.

Prototype

void sc_mempool_destroy_null (sc_mempool_t ** pmempool);
source
P4est.LibP4est.sc_mempool_memory_usedMethod
sc_mempool_memory_used(mempool)

Calculate the memory used by a memory pool.

Parameters

  • array:[in] The memory pool.

Returns

Memory used in bytes.

Prototype

size_t sc_mempool_memory_used (sc_mempool_t * mempool);
source
P4est.LibP4est.sc_mempool_newMethod
sc_mempool_new(elem_size)

Creates a new mempool structure with the zero_and_persist option off. The contents of any elements returned by sc_mempool_alloc are undefined.

Parameters

  • elem_size:[in] Size of one element in bytes.

Returns

Returns an allocated and initialized memory pool.

Prototype

sc_mempool_t *sc_mempool_new (size_t elem_size);
source
P4est.LibP4est.sc_mempool_new_zero_and_persistMethod
sc_mempool_new_zero_and_persist(elem_size)

Creates a new mempool structure with the zero_and_persist option on. The memory of newly created elements is zero'd out, and the contents of an element are not touched between freeing and re-returning it.

Parameters

  • elem_size:[in] Size of one element in bytes.

Returns

Returns an allocated and initialized memory pool.

Prototype

sc_mempool_t *sc_mempool_new_zero_and_persist (size_t elem_size);
source
P4est.LibP4est.sc_mempool_truncateMethod
sc_mempool_truncate(mempool)

Invalidates all previously returned pointers, resets count to 0.

Prototype

void sc_mempool_truncate (sc_mempool_t * mempool);
source
P4est.LibP4est.sc_mpi_readMethod
sc_mpi_read(mpifile, ptr, zcount, t, errmsg)

Prototype

void sc_mpi_read (MPI_File mpifile, const void *ptr, size_t zcount, sc_MPI_Datatype t, const char *errmsg);
source
P4est.LibP4est.sc_mpi_writeMethod
sc_mpi_write(mpifile, ptr, zcount, t, errmsg)

Prototype

void sc_mpi_write (MPI_File mpifile, const void *ptr, size_t zcount, sc_MPI_Datatype t, const char *errmsg);
source
P4est.LibP4est.sc_mstamp_allocMethod
sc_mstamp_alloc(mst)

Return a new item. The memory returned will stay legal until container is destroyed or truncated.

Parameters

  • Properly:[in,out] initialized stamp container.

Returns

Pointer to an item ready to use. Legal until scstampdestroy or scstamptruncate is called on mst.

Prototype

void *sc_mstamp_alloc (sc_mstamp_t * mst);
source
P4est.LibP4est.sc_mstamp_initMethod
sc_mstamp_init(mst, stamp_unit, elem_size)

Initialize a memory stamp container. We provide allocation of fixed-size memory items without allocating new memory in every request. Instead we block the allocations in what we call a stamp of multiple items. Even if no allocations are done, the container's internal memory must be freed eventually by scmstampreset.

Parameters

  • mst:[in,out] Legal pointer to a stamp structure.
  • stamp_unit:[in] Size of each memory block that we allocate. If it is larger than the element size, we may place more than one element in it. Passing 0 is legal and forces stamps that hold one item each.
  • elem_size:[in] Size of each item. Passing 0 is legal. In that case, scmstampalloc returns NULL.

Prototype

void sc_mstamp_init (sc_mstamp_t * mst, size_t stamp_unit, size_t elem_size);
source
P4est.LibP4est.sc_mstamp_memory_usedMethod
sc_mstamp_memory_used(mst)

Return memory size in bytes of all data allocated in the container.

Parameters

  • Properly:[in] initialized stamp container.

Returns

Total container memory size in bytes.

Prototype

size_t sc_mstamp_memory_used (sc_mstamp_t * mst);
source
P4est.LibP4est.sc_mstamp_resetMethod
sc_mstamp_reset(mst)

Free all memory in a stamp structure and all items previously returned.

Parameters

  • Properly:[in,out] initialized stamp container. On output, the structure is undefined.

Prototype

void sc_mstamp_reset (sc_mstamp_t * mst);
source
P4est.LibP4est.sc_mstamp_truncateMethod
sc_mstamp_truncate(mst)

Free all memory in a stamp structure and initialize it anew. Equivalent to calling scmstampreset followed by scmstampinit with the same stamp_unit and elem_size.

Parameters

  • Properly:[in,out] initialized stamp container. On output, its elements have been freed and it is ready for further use.

Prototype

void sc_mstamp_truncate (sc_mstamp_t * mst);
source
P4est.LibP4est.sc_package_is_registeredMethod
sc_package_is_registered(package_id)

Query whether an identifier matches a registered package.

Parameters

  • package_id:[in] Only a non-negative id can be registered.

Returns

True if and only if the package id is non-negative and package is registered.

Prototype

int sc_package_is_registered (int package_id);
source
P4est.LibP4est.sc_package_lockMethod
sc_package_lock(package_id)

Acquire a pthread mutex lock. If configured without –enable-pthread, this function does nothing. This function must be followed with a matching scpackageunlock.

Parameters

  • package_id:[in] Either -1 for an undefined package or an id returned from scpackageregister. Depending on the value, the appropriate mutex is chosen. Thus, we may overlap locking calls with distinct package_id.

Prototype

void sc_package_lock (int package_id);
source
P4est.LibP4est.sc_package_print_summaryMethod
sc_package_print_summary(log_priority)

Print a summary of all packages registered with SC. Uses the SC_LC_GLOBAL log category which by default only prints on rank 0.

Parameters

  • log_priority:[in] Priority passed to sc log functions.

Prototype

void sc_package_print_summary (int log_priority);
source
P4est.LibP4est.sc_package_registerMethod
sc_package_register(log_handler, log_threshold, name, full)

Register a software package with SC. This function must only be called before additional threads are created. The logging parameters are as in sc_set_log_defaults.

Returns

Returns a unique package id.

Prototype

int sc_package_register (sc_log_handler_t log_handler, int log_threshold, const char *name, const char *full);
source
P4est.LibP4est.sc_package_set_abort_alloc_mismatchMethod
sc_package_set_abort_alloc_mismatch(package_id, set_abort)

Set the unregister behavior of sc_package_unregister().

Parameters

  • package_id:[in] Must be -1 for the default package or the identifier of a registered package.
  • set_abort:[in] True if sc_package_unregister() should abort if the number of allocs does not match the number of frees; false otherwise.

Prototype

void sc_package_set_abort_alloc_mismatch (int package_id, int set_abort);
source
P4est.LibP4est.sc_package_set_verbosityMethod
sc_package_set_verbosity(package_id, log_priority)

Set the logging verbosity of a registered package. This can be called at any point in the program, any number of times. It can only lower the verbosity at and below the value of SC_LP_THRESHOLD.

Parameters

  • package_id:[in] Must be a registered package identifier.

Prototype

void sc_package_set_verbosity (int package_id, int log_priority);
source
P4est.LibP4est.sc_package_unlockMethod
sc_package_unlock(package_id)

Release a pthread mutex lock. If configured without –enable-pthread, this function does nothing. This function must be follow a matching scpackagelock.

Parameters

  • package_id:[in] Either -1 for an undefined package or an id returned from scpackageregister. Depending on the value, the appropriate mutex is chosen. Thus, we may overlap locking calls with distinct package_id.

Prototype

void sc_package_unlock (int package_id);
source
P4est.LibP4est.sc_package_unregisterMethod
sc_package_unregister(package_id)

Unregister a software package with SC. This function must only be called after additional threads are finished.

Prototype

void sc_package_unregister (int package_id);
source
P4est.LibP4est.sc_recycle_array_initMethod
sc_recycle_array_init(rec_array, elem_size)

Initialize a recycle array.

Parameters

  • elem_size:[in] Size of the objects to be stored in the array.

Prototype

void sc_recycle_array_init (sc_recycle_array_t * rec_array, size_t elem_size);
source
P4est.LibP4est.sc_recycle_array_insertMethod
sc_recycle_array_insert(rec_array, position)

Insert an object into the recycle array. The object is not copied into the array. Use the return value for that.

Parameters

  • position:[out] If position != NULL, *position is set to the array position of the inserted object.

Returns

Returns the new address of the object in the array.

Prototype

void *sc_recycle_array_insert (sc_recycle_array_t * rec_array, size_t *position);
source
P4est.LibP4est.sc_recycle_array_removeMethod
sc_recycle_array_remove(rec_array, position)

Remove an object from the recycle array. It must be valid.

Parameters

  • position:[in] Index into the array for the object to remove.

Returns

The pointer to the removed object. Will be valid as long as no other function is called on this recycle array.

Prototype

void *sc_recycle_array_remove (sc_recycle_array_t * rec_array, size_t position);
source
P4est.LibP4est.sc_recycle_array_resetMethod
sc_recycle_array_reset(rec_array)

Reset a recycle array.

As with all _reset functions, calling _init, then any array operations, then _reset is memory neutral.

Prototype

void sc_recycle_array_reset (sc_recycle_array_t * rec_array);
source
P4est.LibP4est.sc_set_abort_handlerMethod
sc_set_abort_handler(abort_handler)

Controls the default SC abort behavior.

Parameters

  • abort_handler:[in] Set default SC above handler (NULL selects builtin). ***This function should not return!***

Prototype

void sc_set_abort_handler (sc_abort_handler_t abort_handler);
source
P4est.LibP4est.sc_set_log_defaultsMethod
sc_set_log_defaults(log_stream, log_handler, log_thresold)

Controls the default SC log behavior.

Parameters

  • log_stream:[in] Set stream to use by sc_logf (or NULL for stdout).
  • log_handler:[in] Set default SC log handler (NULL selects builtin).
  • log_threshold:[in] Set default SC log threshold (or SC_LP_DEFAULT). May be SC_LP_ALWAYS or SC_LP_SILENT.

Prototype

void sc_set_log_defaults (FILE * log_stream, sc_log_handler_t log_handler, int log_thresold);
source
P4est.LibP4est.sc_strcopyMethod
sc_strcopy(dest, size, src)

Provide a string copy function.

Parameters

  • dest:[out] Buffer of length at least size. On output, not touched if NULL or size == 0.
  • size:[in] Allocation length of dest.
  • src:[in] Null-terminated string.

Returns

Equivalent to sc_snprintf (dest, size, "s", src).

Prototype

void sc_strcopy (char *dest, size_t size, const char *src);
source
P4est.LibP4est.sc_uint128_addMethod
sc_uint128_add(a, b, result)

Adds the uint128_t b to the uint128_t a. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void sc_uint128_add (const sc_uint128_t * a, const sc_uint128_t * b, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_add_inplaceMethod
sc_uint128_add_inplace(a, b)

Adds the uint128 b to the uint128_t a. The result is saved in a. a == b is allowed.

Parameters

Prototype

void sc_uint128_add_inplace (sc_uint128_t * a, const sc_uint128_t * b);
source
P4est.LibP4est.sc_uint128_bitwise_andMethod
sc_uint128_bitwise_and(a, b, result)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void sc_uint128_bitwise_and (const sc_uint128_t * a, const sc_uint128_t * b, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_bitwise_and_inplaceMethod
sc_uint128_bitwise_and_inplace(a, b)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void sc_uint128_bitwise_and_inplace (sc_uint128_t * a, const sc_uint128_t * b);
source
P4est.LibP4est.sc_uint128_bitwise_negMethod
sc_uint128_bitwise_neg(a, result)

Calculates the bitwise negation of the uint128_t a. a == result is allowed.

Parameters

  • a:[in] A pointer to a sc_uint128_t.
  • result:[out] A pointer to a sc_uint128_t. The bitwise negation of a will be saved in result.

Prototype

void sc_uint128_bitwise_neg (const sc_uint128_t * a, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_bitwise_orMethod
sc_uint128_bitwise_or(a, b, result)

Calculates the bitwise or of the uint128_t a and b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void sc_uint128_bitwise_or (const sc_uint128_t * a, const sc_uint128_t * b, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_bitwise_or_inplaceMethod
sc_uint128_bitwise_or_inplace(a, b)

Calculates the bitwise or of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void sc_uint128_bitwise_or_inplace (sc_uint128_t * a, const sc_uint128_t * b);
source
P4est.LibP4est.sc_uint128_chk_bitMethod
sc_uint128_chk_bit(input, exponent)

Returns the bit_number-th bit of input. This function checks a bit of an existing, initialized value.

Parameters

  • input:[in] A pointer to a sc_uint128_t.
  • bit_number:[in] The bit (counted from the right hand side) that is checked by logical and. Require 0 <= bit_number < 128.

Returns

True if the checked bit is set, false if not.

Prototype

int sc_uint128_chk_bit (const sc_uint128_t * input, int exponent);
source
P4est.LibP4est.sc_uint128_copyMethod
sc_uint128_copy(input, output)

Copies an initialized sc_uint128_t to a sc_uint128_t.

Parameters

  • input:[in] A pointer to the sc_uint128 that is copied.
  • output:[in,out] A pointer to a sc_uint128_t. The high and low bits of output will be set to the high and low bits of input, respectively.

Prototype

void sc_uint128_copy (const sc_uint128_t * input, sc_uint128_t * output);
source
P4est.LibP4est.sc_uint128_initMethod
sc_uint128_init(a, high, low)

Initializes an unsigned 128 bit integer to a given value.

Parameters

  • a:[in,out] A pointer to the sc_uint128_t that will be initialized.
  • high:[in] The given high bits to initialize a.
  • low:[in] The given low bits to initialize a.

Prototype

void sc_uint128_init (sc_uint128_t * a, uint64_t high, uint64_t low);
source
P4est.LibP4est.sc_uint128_set_bitMethod
sc_uint128_set_bit(a, exponent)

Sets the exponent-th bit of a to one and keep all other bits. This function modifies an existing, initialized value.

Parameters

  • a:[in,out] A pointer to a sc_uint128_t.
  • exponent:[in] The bit (0-based from the rightmost bit) that is set to one by logical or. 0 <= exponent < 128.

Prototype

void sc_uint128_set_bit (sc_uint128_t * a, int exponent);
source
P4est.LibP4est.sc_uint128_shift_leftMethod
sc_uint128_shift_left(input, shift_count, result)

Calculates the bit left shift of uint128_t input by shift_count bits. We shift in zeros from the right. If shift_count >= 128, result is 0. All bits left from the 127th bit (counted zero based from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a sc_uint128_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a sc_uint128_t. The left shifted number will be saved in result.

Prototype

void sc_uint128_shift_left (const sc_uint128_t * input, int shift_count, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_shift_rightMethod
sc_uint128_shift_right(input, shift_count, result)

Calculates the bit right shift of uint128_t input by shift_count bits. We shift in zeros from the left. If shift_count >= 128, result is 0. All bits right from the zeroth bit (counted from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a sc_uint128_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a sc_uint128_t. The right shifted number will be saved in result.

Prototype

void sc_uint128_shift_right (const sc_uint128_t * input, int shift_count, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_subMethod
sc_uint128_sub(a, b, result)

Subtracts the uint128_t b from the uint128_t a. This function assumes that the result is >= 0. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void sc_uint128_sub (const sc_uint128_t * a, const sc_uint128_t * b, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_sub_inplaceMethod
sc_uint128_sub_inplace(a, b)

Subtracts the uint128_t b from the uint128_t a. The result is saved in a. a == b is allowed. This function assumes that the result is >= 0.

Parameters

Prototype

void sc_uint128_sub_inplace (sc_uint128_t * a, const sc_uint128_t * b);
source
P4est.LibP4est.sc_versionMethod
sc_version()

Return the full version of libsc.

Returns

Return the version of libsc using the format VERSION\_MAJOR.VERSION\_MINOR.VERSION\_POINT, where VERSION_POINT can contain dots and characters, e.g. to indicate the additional number of commits and a git commit hash.

Prototype

const char *sc_version (void);
source
P4est.LibP4est.sc_vtk_write_binaryMethod
sc_vtk_write_binary(vtkfile, numeric_data, byte_length)

This function writes numeric binary data in VTK base64 encoding.

Parameters

  • vtkfile: Stream opened for writing.
  • numeric_data: A pointer to a numeric data array.
  • byte_length: The length of the data array in bytes.

Returns

Returns 0 on success, -1 on file error.

Prototype

int sc_vtk_write_binary (FILE * vtkfile, char *numeric_data, size_t byte_length);
source
P4est.LibP4est.sc_vtk_write_compressedMethod
sc_vtk_write_compressed(vtkfile, numeric_data, byte_length)

This function writes numeric binary data in VTK compressed format.

Parameters

  • vtkfile: Stream opened for writing.
  • numeric_data: A pointer to a numeric data array.
  • byte_length: The length of the data array in bytes.

Returns

Returns 0 on success, -1 on file error.

Prototype

int sc_vtk_write_compressed (FILE * vtkfile, char *numeric_data, size_t byte_length);
source
+ 8, 27, 18, 17, 25, 26, 12, 10, 24

This code can be called two ways. The first, when vertex==NULL and tree_to_vertex==NULL, is used to count the number of trees and vertices in the connectivity to be generated by the .inp mesh in the stream. The second, when vertices!=NULL and tree_to_vertex!=NULL, fill vertices and tree_to_vertex. In this case num_vertices and num_trees need to be set to the maximum number of entries allocated in vertices and tree_to_vertex.

Parameters

  • stream:[in,out] file stream to read the connectivity from
  • num_vertices:[in,out] the number of vertices in the connectivity
  • num_trees:[in,out] the number of trees in the connectivity
  • vertices:[out] the list of vertices of the connectivity
  • tree_to_vertex:[out] the tree_to_vertex map of the connectivity

Returns

0 if successful and nonzero if not

Prototype

int p8est_connectivity_read_inp_stream (FILE * stream, p4est_topidx_t * num_vertices, p4est_topidx_t * num_trees, double *vertices, p4est_topidx_t * tree_to_vertex);
source
P4est.LibP4est.p8est_connectivity_refineMethod
p8est_connectivity_refine(conn, num_per_edge)

Uniformly refine a connectivity. This is useful if you would like to uniformly refine by something other than a power of 2.

Parameters

  • conn:[in] A valid connectivity
  • num_per_edge:[in] The number of new trees in each direction. Must use no more than P8ESTOLDQMAXLEVEL bits.

Returns

a refined connectivity.

Prototype

p8est_connectivity_t *p8est_connectivity_refine (p8est_connectivity_t * conn, int num_per_edge);
source
P4est.LibP4est.p8est_connectivity_saveMethod
p8est_connectivity_save(filename, connectivity)

Save a connectivity structure to disk.

Parameters

  • filename:[in] Name of the file to write.
  • connectivity:[in] Valid connectivity structure.

Returns

Returns 0 on success, nonzero on file error.

Prototype

int p8est_connectivity_save (const char *filename, p8est_connectivity_t * connectivity);
source
P4est.LibP4est.p8est_connectivity_set_attrMethod
p8est_connectivity_set_attr(conn, bytes_per_tree)

Allocate or free the attribute fields in a connectivity.

Parameters

  • conn:[in,out] The conn->*_to_attr fields must either be NULL or previously be allocated by this function.
  • bytes_per_tree:[in] If 0, tree_to_attr is freed (being NULL is ok). If positive, requested space is allocated.

Prototype

void p8est_connectivity_set_attr (p8est_connectivity_t * conn, size_t bytes_per_tree);
source
P4est.LibP4est.p8est_connectivity_sinkMethod
p8est_connectivity_sink(conn, sink)

Write connectivity to a sink object.

Parameters

  • conn:[in] The connectivity to be written.
  • sink:[in,out] The connectivity is written into this sink.

Returns

0 on success, nonzero on error.

Prototype

int p8est_connectivity_sink (p8est_connectivity_t * conn, sc_io_sink_t * sink);
source
P4est.LibP4est.p8est_connectivity_sourceMethod
p8est_connectivity_source(source)

Read connectivity from a source object.

Parameters

  • source:[in,out] The connectivity is read from this source.

Returns

The newly created connectivity, or NULL on error.

Prototype

p8est_connectivity_t *p8est_connectivity_source (sc_io_source_t * source);
source
P4est.LibP4est.p8est_copyMethod
p8est_copy(input, copy_data)

Make a deep copy of a p8est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL. The revision counter of the copy is set to zero.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.

Returns

Returns a valid p8est that does not depend on the input, except for borrowing the same connectivity. Its revision counter is 0.

Prototype

p8est_t *p8est_copy (p8est_t * input, int copy_data);
source
P4est.LibP4est.p8est_copy_extMethod
p8est_copy_ext(input, copy_data, duplicate_mpicomm)

Make a deep copy of a p8est. The connectivity is not duplicated. Copying of quadrant user data is optional. If old and new data sizes are 0, the user_data field is copied regardless. The inspect member of the copy is set to NULL. The revision counter of the copy is set to zero.

Parameters

  • copy_data:[in] If true, data are copied. If false, data_size is set to 0.
  • duplicate_mpicomm:[in] If true, MPI communicator is copied.

Returns

Returns a valid p8est that does not depend on the input, except for borrowing the same connectivity. Its revision counter is 0.

Prototype

p8est_t *p8est_copy_ext (p8est_t * input, int copy_data, int duplicate_mpicomm);
source
P4est.LibP4est.p8est_destroyMethod
p8est_destroy(p8est_)

Destroy a p8est.

Note

The connectivity structure is not destroyed with the p8est.

Prototype

void p8est_destroy (p8est_t * p8est);
source
P4est.LibP4est.p8est_expand_face_transformMethod
p8est_expand_face_transform(iface, nface, ftransform)

Fill an array with the axis combination of a face neighbor transform.

Parameters

  • iface:[in] The number of the originating face.
  • nface:[in] Encoded as nface = r * 6 + nf, where nf = 0..5 is the neigbbor's connecting face number and r = 0..3 is the relative orientation to the neighbor's face. This encoding matches p8est_connectivity_t.
  • ftransform:[out] This array holds 9 integers. [0]..[2] The coordinate axis sequence of the origin face, the first two referring to the tangentials and the third to the normal. A permutation of (0, 1, 2). [3]..[5] The coordinate axis sequence of the target face. [6]..[8] Edge reversal flags for tangential axes (boolean); face code in [0, 3] for the normal coordinate q: 0: q' = -q 1: q' = q + 1 2: q' = q - 1 3: q' = 2 - q

Prototype

void p8est_expand_face_transform (int iface, int nface, int ftransform[]);
source
P4est.LibP4est.p8est_face_quadrant_existsMethod
p8est_face_quadrant_exists(p8est_, ghost, treeid, q, face, hang, owner_rank)

Checks if quadrant exists in the local forest or the ghost layer.

For quadrants across tree boundaries it checks if the quadrant exists across any face, but not across edges or corners.

Parameters

  • p8est:[in] The forest in which to search for q.
  • ghost:[in] The ghost layer in which to search for q.
  • treeid:[in] The tree to which q belongs.
  • q:[in] The quadrant that is being searched for.
  • face:[in,out] On input, face id across which q was created. On output, the neighbor's face number augmented by orientation, so face is in 0..23.
  • hang:[in,out] If not NULL, signals that q is bigger than the quadrant it came from. The child id of that originating quadrant is passed into hang. On output, hang holds the hanging face number of q that is in contact with its originator.
  • owner_rank:[out] Filled with the rank of the owner if it is found and undefined otherwise.

Returns

Returns the local number of q if the quadrant exists in the local forest or in the ghost_layer. Otherwise, returns -2 for a domain boundary and -1 if not found.

Prototype

p4est_locidx_t p8est_face_quadrant_exists (p8est_t * p8est, p8est_ghost_t * ghost, p4est_topidx_t treeid, const p8est_quadrant_t * q, int *face, int *hang, int *owner_rank);
source
P4est.LibP4est.p8est_find_corner_transformMethod
p8est_find_corner_transform(connectivity, itree, icorner, ci)

Fills an array with information about corner neighbors.

Parameters

  • itree:[in] The number of the originating tree.
  • icorner:[in] The number of the originating corner.
  • ci:[in,out] A p8est_corner_info_t structure with initialized array.

Prototype

void p8est_find_corner_transform (p8est_connectivity_t * connectivity, p4est_topidx_t itree, int icorner, p8est_corner_info_t * ci);
source
P4est.LibP4est.p8est_find_edge_transformMethod
p8est_find_edge_transform(connectivity, itree, iedge, ei)

Fills an array with information about edge neighbors.

Parameters

  • itree:[in] The number of the originating tree.
  • iedge:[in] The number of the originating edge.
  • ei:[in,out] A p8est_edge_info_t structure with initialized array.

Prototype

void p8est_find_edge_transform (p8est_connectivity_t * connectivity, p4est_topidx_t itree, int iedge, p8est_edge_info_t * ei);
source
P4est.LibP4est.p8est_find_face_transformMethod
p8est_find_face_transform(connectivity, itree, iface, ftransform)

Fill an array with the axis combination of a face neighbor transform.

Parameters

  • itree:[in] The number of the originating tree.
  • iface:[in] The number of the originating tree's face.
  • ftransform:[out] This array holds 9 integers. [0]..[2] The coordinate axis sequence of the origin face. [3]..[5] The coordinate axis sequence of the target face. [6]..[8] Edge reverse flag for axes t1, t2; face code for n.

Returns

The face neighbor tree if it exists, -1 otherwise.

Prototype

p4est_topidx_t p8est_find_face_transform (p8est_connectivity_t * connectivity, p4est_topidx_t itree, int iface, int ftransform[]);
source
P4est.LibP4est.p8est_find_higher_boundMethod
p8est_find_higher_bound(array, q, guess)

Find the highest position tq in a quadrant array such that tq <= q.

Returns

Returns the id of the matching quadrant or -1 if array > q or the array is empty.

Prototype

ssize_t p8est_find_higher_bound (sc_array_t * array, const p8est_quadrant_t * q, size_t guess);
source
P4est.LibP4est.p8est_find_lower_boundMethod
p8est_find_lower_bound(array, q, guess)

Find the lowest position tq in a quadrant array such that tq >= q.

Returns

Returns the id of the matching quadrant or -1 if array < q or the array is empty.

Prototype

ssize_t p8est_find_lower_bound (sc_array_t * array, const p8est_quadrant_t * q, size_t guess);
source
P4est.LibP4est.p8est_find_partitionMethod
p8est_find_partition(num_procs, search_in, my_begin, my_end, _begin, _end)

Binary search in partition array. Given two targets my_begin and my_end, find offsets such that search\_in[begin] >= my\_begin, my\_end <= search\_in[end]. If more than one index satisfies the conditions, then the minimal index is the result. If there is no index that satisfies the conditions, then begin and end are tried to set equal such that search\_in[begin] >= my\_end. If my_begin is less or equal than the smallest value of search_in begin is set to 0 and if my_end is bigger or equal than the largest value of search_in end is set to num_procs - 1. If none of the above conditions is satisfied, the output is not well defined. We require `my_begin <= my_begin'.

Parameters

  • num_procs:[in] Number of processes to get the length of search_in.
  • search_in:[in] The sorted array (ascending) in that the function will search. If k indexes search_in, then 0 <= k < num\_procs.
  • my_begin:[in] The first target that defines the start of the search window.
  • my_end:[in] The second target that defines the end of the search window.
  • begin:[in,out] The first offset such that search\_in[begin] >= my\_begin.
  • end:[in,out] The second offset such that my\_end <= search\_in[end].

Prototype

void p8est_find_partition (const int num_procs, p4est_gloidx_t * search_in, p4est_gloidx_t my_begin, p4est_gloidx_t my_end, p4est_gloidx_t * begin, p4est_gloidx_t * end);
source
P4est.LibP4est.p8est_find_quadrant_cumulativeMethod
p8est_find_quadrant_cumulative(p8est_, cumulative_id, which_tree, quadrant_id)

Search a local quadrant by its cumulative number in the forest.

We perform a binary search over the processor-local trees, which means that it is advisable NOT to use this function if possible, and to try to maintain O(1) tree context information in the calling code.

Parameters

  • p8est:[in] Forest to be worked with.
  • cumulative_id:[in] Cumulative index over all trees of quadrant.
  • which_tree:[in,out] If not NULL, the input value can be -1 or an initial guess for the quadrant's tree. An initial guess must be the index of a nonempty local tree. Output is the tree of returned quadrant.
  • quadrant_id:[out] If not NULL, the number of quadrant in tree.

Returns

The identified quadrant.

Prototype

p8est_quadrant_t *p8est_find_quadrant_cumulative (p8est_t * p8est, p4est_locidx_t cumulative_id, p4est_topidx_t * which_tree, p4est_locidx_t * quadrant_id);
source
P4est.LibP4est.p8est_find_range_boundariesMethod
p8est_find_range_boundaries(lq, uq, level, faces, edges, corners)

Find the boundary points touched by a range of quadrants.

Given two smallest quadrants, lq and uq, that mark the first and the last quadrant in a range of quadrants, determine which portions of the tree boundary the range touches.

Parameters

  • lq:[in] The smallest quadrant at the start of the range: if NULL, the tree's first quadrant is taken to be the start of the range.
  • uq:[in] The smallest quadrant at the end of the range: if NULL, the tree's last quadrant is taken to be the end of the range.
  • level:[in] The level of the containing quadrant whose boundaries are tested: 0 if we want to test the boundaries of the whole tree.
  • faces:[in,out] An array of size 6 that is filled: faces[i] is true if the range touches that face.
  • edges:[in,out] An array of size 12 that is filled: edges[i] is true if the range touches that edge.
  • corners:[in,out] An array of size 8 that is filled: corners[i] is true if the range touches that corner. faces, edges or corners may be NULL.

Returns

Returns an int32_t encoded with the same information in faces, edges and corners: the first (least) six bits represent the six faces, the next twelve bits represent the twelve edges, the next eight bits represent the eight corners.

Prototype

int32_t p8est_find_range_boundaries (p8est_quadrant_t * lq, p8est_quadrant_t * uq, int level, int faces[], int edges[], int corners[]);
source
P4est.LibP4est.p8est_get_plex_data_extMethod
p8est_get_plex_data_ext(p8est_, ghost, lnodes, ctype, overlap, first_local_quad, out_points_per_dim, out_cone_sizes, out_cones, out_cone_orientations, out_vertex_coords, out_children, out_parents, out_childids, out_leaves, out_remotes, custom_numbering)

Create the data necessary to create a PETsc DMPLEX representation of a forest, as well as the accompanying lnodes and ghost layer. The forest must be at least face balanced (see p4est_balance()). See test/test_plex2.c for example usage.

All arrays should be initialized to hold sizeof (p4est_locidx_t), except for out_remotes, which should be initialized to hold (2 * sizeof (p4est_locidx_t)).

Parameters

  • p8est:[in] the forest
  • ghost:[out] the ghost layer
  • lnodes:[out] the lnodes
  • ctype:[in] the type of adjacency for the overlap
  • overlap:[in] the number of layers of overlap (zero is acceptable)
  • first_local_quad:[out] the local quadrants are assigned contiguous plex indices, starting with this index
  • out_points_per_dim:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cone_sizes:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cones:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_cone_orientations:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_vertex_coords:[in,out] filled with argument for DMPlexCreateFromDAG()
  • out_children:[in,out] filled with argument for DMPlexSetTree()
  • out_parents:[in,out] filled with argument for DMPlexSetTree()
  • out_childids:[in,out] filled with argument for DMPlexSetTree()
  • out_leaves:[in,out] filled with argument for PetscSFSetGraph()
  • out_remotes:[in,out] filled with argument for PetscSFSetGraph()
  • custom_numbering:[in] Whether or use the default numbering (0) of DMPlex child ids or the custom (1).

Prototype

void p8est_get_plex_data_ext (p8est_t * p8est, p8est_ghost_t ** ghost, p8est_lnodes_t ** lnodes, p8est_connect_type_t ctype, int overlap, p4est_locidx_t * first_local_quad, sc_array_t * out_points_per_dim, sc_array_t * out_cone_sizes, sc_array_t * out_cones, sc_array_t * out_cone_orientations, sc_array_t * out_vertex_coords, sc_array_t * out_children, sc_array_t * out_parents, sc_array_t * out_childids, sc_array_t * out_leaves, sc_array_t * out_remotes, int custom_numbering);
source
P4est.LibP4est.p8est_ghost_bsearchMethod
p8est_ghost_bsearch(ghost, which_proc, which_tree, q)

Conduct binary search for exact match on a range of the ghost layer.

Parameters

  • ghost:[in] The ghost layer.
  • which_proc:[in] The owner of the searched quadrant. Can be -1.
  • which_tree:[in] The tree of the searched quadrant. Can be -1.
  • q:[in] Valid quadrant is searched in the ghost layer.

Returns

Offset in the ghost layer, or -1 if not found.

Prototype

ssize_t p8est_ghost_bsearch (p8est_ghost_t * ghost, int which_proc, p4est_topidx_t which_tree, const p8est_quadrant_t * q);
source
P4est.LibP4est.p8est_ghost_checksumMethod
p8est_ghost_checksum(p8est_, ghost)

Compute the parallel checksum of a ghost layer.

Parameters

  • p8est:[in] The MPI information of this p8est will be used.
  • ghost:[in] A ghost layer obtained from the p8est.

Returns

Parallel checksum on rank 0, 0 otherwise.

Prototype

unsigned p8est_ghost_checksum (p8est_t * p8est, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_exchange_customMethod
p8est_ghost_exchange_custom(p8est_, ghost, data_size, mirror_data, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. The data size is the same for all quadrants and can be chosen arbitrarily.

Parameters

  • p8est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • data_size:[in] The data size to transfer per quadrant.
  • mirror_data:[in] One data pointer per mirror quadrant.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghosts in sequence, which must hold at least data_size for each ghost.

Prototype

void p8est_ghost_exchange_custom (p8est_t * p8est, p8est_ghost_t * ghost, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_custom_beginMethod
p8est_ghost_exchange_custom_begin(p8est_, ghost, data_size, mirror_data, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p8est_ghost_exchange_custom. The return type is always non-NULL and must be passed to p8est_ghost_exchange_custom_end to complete the exchange. The ghost data must not be accessed before completion. The mirror data can be safely discarded right after this function returns since it is copied into internal send buffers.

Parameters

  • mirror_data:[in] Not required to stay alive any longer.
  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p8est_ghost_exchange_t *p8est_ghost_exchange_custom_begin (p8est_t * p8est, p8est_ghost_t * ghost, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_custom_levelsMethod
p8est_ghost_exchange_custom_levels(p8est_, ghost, minlevel, maxlevel, data_size, mirror_data, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. The data size is the same for all quadrants and can be chosen arbitrarily. This function restricts the transfer to a range of refinement levels. The memory for quadrants outside the level range is not dereferenced.

Parameters

  • p8est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • minlevel:[in] Level of the largest quads to be exchanged. Use <= 0 for no restriction.
  • maxlevel:[in] Level of the smallest quads to be exchanged. Use >= P8EST_QMAXLEVEL for no restriction.
  • data_size:[in] The data size to transfer per quadrant.
  • mirror_data:[in] One data pointer per mirror quadrant as input.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghosts in sequence, which must hold at least data_size for each ghost.

Prototype

void p8est_ghost_exchange_custom_levels (p8est_t * p8est, p8est_ghost_t * ghost, int minlevel, int maxlevel, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_custom_levels_beginMethod
p8est_ghost_exchange_custom_levels_begin(p8est_, ghost, minlevel, maxlevel, data_size, mirror_data, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p8est_ghost_exchange_custom_levels. The return type is always non-NULL and must be passed to p8est_ghost_exchange_custom_levels_end to complete the exchange. The ghost data must not be accessed before completion. The mirror data can be safely discarded right after this function returns since it is copied into internal send buffers.

Parameters

  • mirror_data:[in] Not required to stay alive any longer.
  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p8est_ghost_exchange_t *p8est_ghost_exchange_custom_levels_begin (p8est_t * p8est, p8est_ghost_t * ghost, int minlevel, int maxlevel, size_t data_size, void **mirror_data, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_dataMethod
p8est_ghost_exchange_data(p8est_, ghost, ghost_data)

Transfer data for local quadrants that are ghosts to other processors. Send the data stored in the quadrant's user_data. This is either the pointer variable itself if p8est->datasize is 0, or the content of the referenced memory field if p8est->data\size is positive.

Parameters

  • p8est:[in] The forest used for reference.
  • ghost:[in] The ghost layer used for reference.
  • ghost_data:[in,out] Pre-allocated contiguous data for all ghost quadrants in sequence. If p8est->data_size is 0, must at least hold sizeof (void *) bytes for each, otherwise p8est->data_size each.

Prototype

void p8est_ghost_exchange_data (p8est_t * p8est, p8est_ghost_t * ghost, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_exchange_data_beginMethod
p8est_ghost_exchange_data_begin(p8est_, ghost, ghost_data)

Begin an asynchronous ghost data exchange by posting messages. The arguments are identical to p8est_ghost_exchange_data. The return type is always non-NULL and must be passed to p8est_ghost_exchange_data_end to complete the exchange. The ghost data must not be accessed before completion.

Parameters

  • ghost_data:[in,out] Must stay alive into the completion call.

Returns

Transient storage for messages in progress.

Prototype

p8est_ghost_exchange_t *p8est_ghost_exchange_data_begin (p8est_t * p8est, p8est_ghost_t * ghost, void *ghost_data);
source
P4est.LibP4est.p8est_ghost_expandMethod
p8est_ghost_expand(p8est_, ghost)

Expand the size of the ghost layer and mirrors by one additional layer of adjacency.

Parameters

  • p8est:[in] The forest from which the ghost layer was generated.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p8est_ghost_expand (p8est_t * p8est, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_expand_by_lnodesMethod
p8est_ghost_expand_by_lnodes(p4est_, lnodes, ghost)

Expand the ghost layer as in p8est_ghost_expand(), but use node support to define adjacency instead of geometric adjacency.

Parameters

  • p8est:[in] The forest from which the ghost layer was generated.
  • lnodes:[in] The nodes to support.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p8est_ghost_expand_by_lnodes (p8est_t * p4est, p8est_lnodes_t * lnodes, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_is_validMethod
p8est_ghost_is_valid(p8est_, ghost)

Examine if a ghost structure is valid as desribed above. Test if within a ghost-structure the arrays ghosts and mirrors are in p8est_quadrant_compare_piggy order. Test if local_num in piggy3 data member of the quadrants in ghosts and mirrors are in ascending order (ascending within each rank for ghost).

Test if the p4est_locidx_t arrays are in ascending order (for mirror_proc_mirrors ascending within each rank)

Parameters

  • p8est:[in] the forest.
  • ghost:[in] Ghost layer structure.

Returns

true if ghost is valid

Prototype

int p8est_ghost_is_valid (p8est_t * p8est, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_memory_usedMethod
p8est_ghost_memory_used(ghost)

Calculate the memory usage of the ghost layer.

Parameters

  • ghost:[in] Ghost layer structure.

Returns

Memory used in bytes.

Prototype

size_t p8est_ghost_memory_used (p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_newMethod
p8est_ghost_new(p8est_, btype)

Builds the ghost layer.

This will gather the quadrants from each neighboring proc to build one layer of face, edge and corner based ghost elements around the ones they own.

Parameters

  • p8est:[in] The forest for which the ghost layer will be generated.
  • btype:[in] Which ghosts to include (across face, edge, or corner/full).

Returns

A fully initialized ghost layer.

Prototype

p8est_ghost_t *p8est_ghost_new (p8est_t * p8est, p8est_connect_type_t btype);
source
P4est.LibP4est.p8est_ghost_support_lnodesMethod
p8est_ghost_support_lnodes(p8est_, lnodes, ghost)

Expand the ghost layer to include the support of all nodes supported on the local partition.

Parameters

  • p8est:[in] The forest from which the ghost layer was generated.
  • lnodes:[in] The nodes to support.
  • ghost:[in,out] The ghost layer to be expanded.

Prototype

void p8est_ghost_support_lnodes (p8est_t * p8est, p8est_lnodes_t * lnodes, p8est_ghost_t * ghost);
source
P4est.LibP4est.p8est_ghost_tree_containsMethod
p8est_ghost_tree_contains(ghost, which_proc, which_tree, q)

Conduct binary search for ancestor on range of the ghost layer.

Parameters

  • ghost:[in] The ghost layer.
  • which_proc:[in] The owner of the searched quadrant. Can be -1.
  • which_tree:[in] The tree of the searched quadrant. Can be -1.
  • q:[in] Valid quadrant's ancestor is searched.

Returns

Offset in the ghost layer, or -1 if not found.

Prototype

ssize_t p8est_ghost_tree_contains (p8est_ghost_t * ghost, int which_proc, p4est_topidx_t which_tree, const p8est_quadrant_t * q);
source
P4est.LibP4est.p8est_is_balancedMethod
p8est_is_balanced(p8est_, btype)

Check a forest to see if it is balanced.

This function builds the ghost layer and discards it when done.

Parameters

  • p8est:[in] The p8est to be tested.
  • btype:[in] Balance type (face, edge, corner or default, full).

Returns

Returns true if balanced, false otherwise.

Prototype

int p8est_is_balanced (p8est_t * p8est, p8est_connect_type_t btype);
source
P4est.LibP4est.p8est_iterateMethod
p8est_iterate(p4est_, ghost_layer, user_data, iter_volume, iter_face, iter_edge, iter_corner)

Execute the user-supplied callback functions at every volume, face, edge and corner in the local forest.

The ghost_layer may be NULL. The user_data pointer is not touched by p8est_iterate, but is passed to each of the callbacks. Any of the callback functions may be NULL. The callback functions are interspersed with each other, i.e. some face callbacks will occur between volume callbacks, and some edge callbacks will occur between face callbacks, etc.:

  1. volume callbacks occur in the sorted Morton-index order. 2) a face callback is not executed until after the volume callbacks have been executed for the quadrants that share it. 3) an edge callback is not executed until the face callbacks have been executed for all faces that touch the edge. 4) a corner callback is not executed until the edge callbacks have been executed for all edges that touch the corner. 5) it is not always the case that every face callback for a given quadrant is executed before any of the edge or corner callbacks, and it is not always the case that every edge callback for a given quadrant is executed before any of the corner callbacks. 6) callbacks are not executed at faces, edges or corners that only involve ghost quadrants, i.e. that are not adjacent in the local section of the forest.

Parameters

  • p4est:[in] the forest
  • ghost_layer:[in] optional: when not given, callbacks at the boundaries of the local partition cannot provide quadrant data about ghost quadrants: missing (p8est_quadrant_t *) pointers are set to NULL, missing indices are set to -1.
  • user_data:[in,out] optional context to supply to each callback
  • iter_volume:[in] callback function for every quadrant's interior
  • iter_face:[in] callback function for every face between quadrants
  • iter_edge:[in] callback function for every edge between quadrants
  • iter_corner:[in] callback function for every corner between quadrants

Prototype

void p8est_iterate (p8est_t * p4est, p8est_ghost_t * ghost_layer, void *user_data, p8est_iter_volume_t iter_volume, p8est_iter_face_t iter_face, p8est_iter_edge_t iter_edge, p8est_iter_corner_t iter_corner);
source
P4est.LibP4est.p8est_iterate_extMethod
p8est_iterate_ext(p8est_, ghost_layer, user_data, iter_volume, iter_face, iter_edge, iter_corner, remote)

p8est_iterate_ext adds the option remote: if this is false, then it is the same as p8est_iterate; if this is true, then corner/edge callbacks are also called on corners/edges for hanging faces/edges touched by local quadrants.

Prototype

void p8est_iterate_ext (p8est_t * p8est, p8est_ghost_t * ghost_layer, void *user_data, p8est_iter_volume_t iter_volume, p8est_iter_face_t iter_face, p8est_iter_edge_t iter_edge, p8est_iter_corner_t iter_corner, int remote);
source
P4est.LibP4est.p8est_lid_addMethod
p8est_lid_add(a, b, result)

Adds the uint128_t b to the uint128_t a. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void p8est_lid_add (const p8est_lid_t * a, const p8est_lid_t * b, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_bitwise_andMethod
p8est_lid_bitwise_and(a, b, result)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void p8est_lid_bitwise_and (const p8est_lid_t * a, const p8est_lid_t * b, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_bitwise_and_inplaceMethod
p8est_lid_bitwise_and_inplace(a, b)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void p8est_lid_bitwise_and_inplace (p8est_lid_t * a, const p8est_lid_t * b);
source
P4est.LibP4est.p8est_lid_bitwise_negMethod
p8est_lid_bitwise_neg(a, result)

Calculates the bitwise negation of the uint128_t a. a == result is allowed.

Parameters

  • a:[in] A pointer to a p8est_lid_t.
  • result:[out] A pointer to a p8est_lid_t. The bitwise negation of a will be saved in result.

Prototype

void p8est_lid_bitwise_neg (const p8est_lid_t * a, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_bitwise_orMethod
p8est_lid_bitwise_or(a, b, result)

Calculates the bitwise or of the uint128_t a and b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void p8est_lid_bitwise_or (const p8est_lid_t * a, const p8est_lid_t * b, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_bitwise_or_inplaceMethod
p8est_lid_bitwise_or_inplace(a, b)

Calculates the bitwise or of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void p8est_lid_bitwise_or_inplace (p8est_lid_t * a, const p8est_lid_t * b);
source
P4est.LibP4est.p8est_lid_chk_bitMethod
p8est_lid_chk_bit(input, bit_number)

Returns the bit_number-th bit of input. This function checks a bit of an existing, initialized value.

Parameters

  • input:[in] A pointer to a p8est_lid_t.
  • bit_number:[in] The bit (counted from the right hand side) that is checked by logical and. Require 0 <= bit_number < 128.

Returns

True if bit is set, false if not.

Prototype

int p8est_lid_chk_bit (const p8est_lid_t * input, int bit_number);
source
P4est.LibP4est.p8est_lid_copyMethod
p8est_lid_copy(input, output)

Copies an initialized p8est_lid_t to a p8est_lid_t.

Parameters

  • input:[in] A pointer to the sc_uint128 that is copied.
  • output:[in,out] A pointer to a p8est_lid_t. The high and low bits of output will be set to the high and low bits of input, respectively.

Prototype

void p8est_lid_copy (const p8est_lid_t * input, p8est_lid_t * output);
source
P4est.LibP4est.p8est_lid_initMethod
p8est_lid_init(input, high, low)

Initializes a linear index to a given value.

Parameters

  • a:[in,out] A pointer to the p8est_lid_t that will be initialized.
  • high:[in] The given high bits to intialize a.
  • low:[in] The given low bits to initialize a.

Prototype

void p8est_lid_init (p8est_lid_t * input, uint64_t high, uint64_t low);
source
P4est.LibP4est.p8est_lid_set_bitMethod
p8est_lid_set_bit(input, bit_number)

Sets the exponent-th bit of input to one. This function modifies an existing, initialized value.

Parameters

  • input:[in,out] A pointer to a p8est_lid_t.
  • bit_number:[in] The bit (counted from the right hand side) that is set to one by logical or. Require 0 <= bit_number < 128.

Prototype

void p8est_lid_set_bit (p8est_lid_t * input, int bit_number);
source
P4est.LibP4est.p8est_lid_set_uint64Method
p8est_lid_set_uint64(input, u)

Initializes a linear index to an unsigned 64 bit integer.

Parameters

  • input:[out] A pointer to a p4est_lid_t that will be intialized.

Prototype

void p8est_lid_set_uint64 (p8est_lid_t * input, uint64_t u);
source
P4est.LibP4est.p8est_lid_shift_leftMethod
p8est_lid_shift_left(input, shift_count, result)

Calculates the bit left shift of uint128_t input by shift_count bits. We shift in zeros from the right. If shift_count >= 128, result is 0. All bits left from the 127th bit (counted zero based from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a p8est_lid_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a p8est_lid_t. The left shifted number will be saved in result.

Prototype

void p8est_lid_shift_left (const p8est_lid_t * input, unsigned shift_count, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_shift_rightMethod
p8est_lid_shift_right(input, shift_count, result)

Calculates the bit right shift of uint128_t input by shift_count bits. We shift in zeros from the left. If shift_count >= 128, result is 0. All bits right from the zeroth bit (counted from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a p8est_lid_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a p8est_lid_t. The right shifted number will be saved in result.

Prototype

void p8est_lid_shift_right (const p8est_lid_t * input, unsigned shift_count, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_subMethod
p8est_lid_sub(a, b, result)

Substracts the p8est_lid_t b from the p8est_lid_t a. This function assumes that the result is >= 0. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void p8est_lid_sub (const p8est_lid_t * a, const p8est_lid_t * b, p8est_lid_t * result);
source
P4est.LibP4est.p8est_lid_sub_inplaceMethod
p8est_lid_sub_inplace(a, b)

Substracts the uint128_t b from the uint128_t a. The result is saved in a. a == b is allowed. This function assumes that the result is >= 0.

Parameters

Prototype

void p8est_lid_sub_inplace (p8est_lid_t * a, const p8est_lid_t * b);
source
P4est.LibP4est.p8est_lnodes_newMethod
p8est_lnodes_new(p8est_, ghost_layer, degree)

Prototype

p8est_lnodes_t *p8est_lnodes_new (p8est_t * p8est, p8est_ghost_t * ghost_layer, int degree);
source
P4est.LibP4est.p8est_lnodes_share_allMethod
p8est_lnodes_share_all(node_data, lnodes)

Equivalend to calling p8est_lnodes_share_all_end directly after p8est_lnodes_share_all_begin. Use if there is no local work that can be done to mask the communication cost.

Returns

A fully initialized buffer that contains the received data. After processing this data, the buffer must be freed with p8est_lnodes_buffer_destroy.

Prototype

p8est_lnodes_buffer_t *p8est_lnodes_share_all (sc_array_t * node_data, p8est_lnodes_t * lnodes);
source
P4est.LibP4est.p8est_lnodes_share_all_beginMethod
p8est_lnodes_share_all_begin(node_data, lnodes)

p8est_lnodes_share_all_begin

node_data is a user_defined array of arbitrary type, where each entry is associated with the lnodes local nodes entry of matching index. For every process that shares an entry with the current one, the value in the node_data array of that process is written into a buffer->recvbuffers entry as described above. The user can then perform some arbitrary work that requires the data from all processes that share a node (such as reduce, max, min, etc.). When the work concludes, the buffer should be destroyed with [`p8estlnodesbufferdestroy`](@ref).

Values of node_data are not guaranteed to be send, and buffer->recvbuffer entries are not guaranteed to be received until the buffer created by [`p8estlnodesshareallbegin](@ref) is passed to [p8estlnodesshareall_end`](@ref).

Prototype

p8est_lnodes_buffer_t *p8est_lnodes_share_all_begin (sc_array_t * node_data, p8est_lnodes_t * lnodes);
source
P4est.LibP4est.p8est_lnodes_share_owned_beginMethod
p8est_lnodes_share_owned_begin(node_data, lnodes)

p8est_lnodes_share_owned_begin

node_data is a user-defined array of arbitrary type, where each entry is associated with the lnodes local nodes entry of matching index. For every local nodes entry that is owned by a process other than the current one, the value in the node_data array of the owning process is written directly into the node_data array of the current process. Values of node_data are not guaranteed to be sent or received until the buffer created by p8est_lnodes_share_owned_begin is passed to p8est_lnodes_share_owned_end.

To be memory neutral, the buffer created by p8est_lnodes_share_owned_begin must be destroying with p8est_lnodes_buffer_destroy (it is not destroyed by p8est_lnodes_share_owned_end).

Prototype

p8est_lnodes_buffer_t *p8est_lnodes_share_owned_begin (sc_array_t * node_data, p8est_lnodes_t * lnodes);
source
P4est.LibP4est.p8est_loadMethod
p8est_load(filename, mpicomm, data_size, load_data, user_pointer, connectivity)

Prototype

p8est_t *p8est_load (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, void *user_pointer, p8est_connectivity_t ** connectivity);
source
P4est.LibP4est.p8est_load_extMethod
p8est_load_ext(filename, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p8est_t *p8est_load_ext (const char *filename, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p8est_connectivity_t ** connectivity);
source
P4est.LibP4est.p8est_memory_usedMethod
p8est_memory_used(p8est_)

Calculate local memory usage of a forest structure. Not collective. The memory used on the current rank is returned. The connectivity structure is not counted since it is not owned; use p8est_connectivity_memory_usage (p8est->connectivity).

Parameters

  • p8est:[in] Valid forest structure.

Returns

Memory used in bytes.

Prototype

size_t p8est_memory_used (p8est_t * p8est);
source
P4est.LibP4est.p8est_mesh_face_neighbor_dataMethod
p8est_mesh_face_neighbor_data(mfn, ghost_data)

Get the user data for the current face neighbor.

Parameters

  • mfn:[in] Internal status of the iterator.
  • ghost_data:[in] Data for the ghost quadrants that has been synchronized with p4est_ghost_exchange_data.

Returns

A pointer to the user data for the current neighbor.

Prototype

void *p8est_mesh_face_neighbor_data (p8est_mesh_face_neighbor_t * mfn, void *ghost_data);
source
P4est.LibP4est.p8est_mesh_face_neighbor_initMethod
p8est_mesh_face_neighbor_init(mfn, p8est_, ghost, mesh, which_tree, quadrant)

Initialize a mesh neighbor iterator by quadrant pointer.

Parameters

  • mfn:[out] A p8est_mesh_face_neighbor_t to be initialized.
  • which_tree:[in] Tree of quadrant whose neighbors are looped over.
  • quadrant:[in] Pointer to quadrant contained in which_tree.

Prototype

void p8est_mesh_face_neighbor_init (p8est_mesh_face_neighbor_t * mfn, p8est_t * p8est, p8est_ghost_t * ghost, p8est_mesh_t * mesh, p4est_topidx_t which_tree, p8est_quadrant_t * quadrant);
source
P4est.LibP4est.p8est_mesh_face_neighbor_init2Method
p8est_mesh_face_neighbor_init2(mfn, p8est_, ghost, mesh, which_tree, quadrant_id)

Initialize a mesh neighbor iterator by quadrant index.

Parameters

  • mfn:[out] A p8est_mesh_face_neighbor_t to be initialized.
  • which_tree:[in] Tree of quadrant whose neighbors are looped over.
  • quadrant_id:[in] Index relative to which_tree of quadrant.

Prototype

void p8est_mesh_face_neighbor_init2 (p8est_mesh_face_neighbor_t * mfn, p8est_t * p8est, p8est_ghost_t * ghost, p8est_mesh_t * mesh, p4est_topidx_t which_tree, p4est_locidx_t quadrant_id);
source
P4est.LibP4est.p8est_mesh_face_neighbor_nextMethod
p8est_mesh_face_neighbor_next(mfn, ntree, nquad, nface, nrank)

Move the iterator forward to loop around neighbors of the quadrant.

Parameters

  • mfn:[in,out] Internal status of the iterator.
  • ntree:[out] If not NULL, the tree number of the neighbor.
  • nquad:[out] If not NULL, the quadrant number within tree. For ghosts instead the number in ghost layer.
  • nface:[out] If not NULL, neighbor's face as in p8est_mesh_t.
  • nrank:[out] If not NULL, the owner process of the neighbor.

Returns

Either a real quadrant or one from the ghost layer. Returns NULL when the iterator is done.

Prototype

p8est_quadrant_t *p8est_mesh_face_neighbor_next (p8est_mesh_face_neighbor_t * mfn, p4est_topidx_t * ntree, p4est_locidx_t * nquad, int *nface, int *nrank);
source
P4est.LibP4est.p8est_mesh_get_neighborsMethod
p8est_mesh_get_neighbors(p4est_, ghost, mesh, curr_quad_id, direction, neighboring_quads, neighboring_encs, neighboring_qids)

Lookup neighboring quads of quadrant in a specific direction

Parameters

  • p4est:[in] Forest to be worked with.
  • ghost:[in] Ghost quadrants.
  • mesh:[in] Mesh structure.
  • curr_quad_id:[in] Process-local ID of current quad.
  • direction:[in] Direction in which to look for adjacent quadrants is encoded as follows: 0 .. 5 neighbor(-s) across f_i, 6 .. 17 neighbor(-s) across e_{i-6} 18 .. 25 neighbor(-s) across c_{i-18}
  • neighboring_quads:[out] Array containing neighboring quad(-s) Needs to be empty, contains p4est_quadrant_t*. May be NULL, then neighboring_qids must not be NULL.
  • neighboring_encs:[out] Array containing encodings for neighboring quads as described below Needs to be empty, contains int. CAUTION: Note, that the encodings differ from the encodings saved in the mesh. Positive values are for local quadrants, negative values indicate ghost quadrants. Faces: 1 .. 24 => same size neighbor (r * 6 + nf) + 1; nf = 0 .. 5 face index; r = 0 .. 3 relative orientation 25 .. 120 => double size neighbor 25 + h * 24 + r * 6 + nf; h = 0 .. 3 number of the subface; r, nf as above 121 .. 144 => half size neighbors 121 + r * 6 + nf; r, nf as above Edges: 1 .. 24 => same size neighbor r * 12 + ne + 1; ne = 0 .. 11 edge index; r = 0 .. 1 relative orientation 25 .. 72 => double size neighbor 25 + h * 24 + r * 12 + ne; h = 0 .. 1 number of the subedge; r, ne as above 73 .. 96 => half size neighbors 73 + r * 12 + ne; r, ne as above Corners: 1 .. 8 => nc + 1; nc = 0 .. 7 corner index
  • neighboring_qids:[out] Array containing quadrant ids for neighboring quadrants. May be NULL, then no neighboring qids are collected. If non-NULL the array needs to be empty and will contain int.

Prototype

p4est_locidx_t p8est_mesh_get_neighbors (p8est_t * p4est, p8est_ghost_t * ghost, p8est_mesh_t * mesh, p4est_locidx_t curr_quad_id, p4est_locidx_t direction, sc_array_t * neighboring_quads, sc_array_t * neighboring_encs, sc_array_t * neighboring_qids);
source
P4est.LibP4est.p8est_mesh_get_quadrantMethod
p8est_mesh_get_quadrant(p4est_, mesh, qid)

Access a process-local quadrant inside a forest. Needs a mesh with populated quad_to_tree array. This is a special case of p8estmeshquadrant_cumulative.

Parameters

  • p4est:[in] The forest.
  • mesh:[in] The mesh.
  • qid:[in] Process-local id of the quadrant (cumulative over trees).

Returns

A pointer to the requested quadrant.

Prototype

p8est_quadrant_t *p8est_mesh_get_quadrant (p8est_t * p4est, p8est_mesh_t * mesh, p4est_locidx_t qid);
source
P4est.LibP4est.p8est_mesh_memory_usedMethod
p8est_mesh_memory_used(mesh)

Calculate the memory usage of the mesh structure.

Parameters

  • mesh:[in] Mesh structure.

Returns

Memory used in bytes.

Prototype

size_t p8est_mesh_memory_used (p8est_mesh_t * mesh);
source
P4est.LibP4est.p8est_mesh_newMethod
p8est_mesh_new(p8est_, ghost, btype)

Create a p8est_mesh structure. This function does not populate the quad_to_tree and quad_level fields. To populate them, use p8estmeshnew_ext.

Parameters

  • p8est:[in] A forest that is fully 2:1 balanced.
  • ghost:[in] The ghost layer created from the provided p4est.
  • btype:[in] Determines the highest codimension of neighbors.

Returns

A fully allocated mesh structure.

Prototype

p8est_mesh_t *p8est_mesh_new (p8est_t * p8est, p8est_ghost_t * ghost, p8est_connect_type_t btype);
source
P4est.LibP4est.p8est_mesh_new_extMethod
p8est_mesh_new_ext(p4est_, ghost, compute_tree_index, compute_level_lists, btype)

Create a new mesh.

Parameters

  • p8est:[in] A forest that is fully 2:1 balanced.
  • ghost:[in] The ghost layer created from the provided p4est.
  • compute_tree_index:[in] Boolean to decide whether to allocate and compute the quad_to_tree list.
  • compute_level_lists:[in] Boolean to decide whether to compute the level lists in quad_level.
  • btype:[in] Currently ignored, only face neighbors are stored.

Returns

A fully allocated mesh structure.

Prototype

p8est_mesh_t *p8est_mesh_new_ext (p8est_t * p4est, p8est_ghost_t * ghost, int compute_tree_index, int compute_level_lists, p8est_connect_type_t btype);
source
P4est.LibP4est.p8est_mesh_quadrant_cumulativeMethod
p8est_mesh_quadrant_cumulative(p8est_, mesh, cumulative_id, which_tree, quadrant_id)

Find a quadrant based on its cumulative number in the local forest. If the quad_to_tree field of the mesh structure exists, this is O(1). Otherwise, we perform a binary search over the processor-local trees.

Parameters

  • p8est:[in] Forest to be worked with.
  • mesh:[in] A mesh derived from the forest.
  • cumulative_id:[in] Cumulative index over all trees of quadrant. Must refer to a local (non-ghost) quadrant.
  • which_tree:[in,out] If not NULL, the input value can be -1 or an initial guess for the quadrant's tree and output is the tree of returned quadrant.
  • quadrant_id:[out] If not NULL, the number of quadrant in tree.

Returns

The identified quadrant.

Prototype

p8est_quadrant_t *p8est_mesh_quadrant_cumulative (p8est_t * p8est, p8est_mesh_t * mesh, p4est_locidx_t cumulative_id, p4est_topidx_t * which_tree, p4est_locidx_t * quadrant_id);
source
P4est.LibP4est.p8est_newMethod
p8est_new(mpicomm, connectivity, data_size, init_fn, user_pointer)

Prototype

p8est_t *p8est_new (sc_MPI_Comm mpicomm, p8est_connectivity_t * connectivity, size_t data_size, p8est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p8est_new_extMethod
p8est_new_ext(mpicomm, connectivity, min_quadrants, min_level, fill_uniform, data_size, init_fn, user_pointer)

Prototype

p8est_t *p8est_new_ext (sc_MPI_Comm mpicomm, p8est_connectivity_t * connectivity, p4est_locidx_t min_quadrants, int min_level, int fill_uniform, size_t data_size, p8est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p8est_partitionMethod
p8est_partition(p8est_, allow_for_coarsening, weight_fn)

Equally partition the forest. The partition can be by element count or by a user-defined weight.

The forest will be partitioned between processors such that they have an approximately equal number of quadrants (or sum of weights).

On one process, the function noops and does not call the weight callback. Otherwise, the weight callback is called once per quadrant in order.

Parameters

  • p8est:[in,out] The forest that will be partitioned.
  • allow_for_coarsening:[in] Slightly modify partition such that quadrant families are not split between ranks.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning. When running with mpisize == 1, never called. Otherwise, called in order for all quadrants if not NULL. A weighting function with constant weight 1 on each quadrant is equivalent to weight_fn == NULL but other constant weightings may result in different uniform partitionings.

Prototype

void p8est_partition (p8est_t * p8est, int allow_for_coarsening, p8est_weight_t weight_fn);
source
P4est.LibP4est.p8est_partition_extMethod
p8est_partition_ext(p8est_, partition_for_coarsening, weight_fn)

Repartition the forest.

The forest is partitioned between processors such that each processor has an approximately equal number of quadrants (or weight).

Parameters

  • p8est:[in,out] The forest that will be partitioned.
  • partition_for_coarsening:[in] If true, the partition is modified to allow one level of coarsening.
  • weight_fn:[in] A weighting function or NULL for uniform partitioning. A weighting function with constant weight 1 on each quadrant is equivalent to weight_fn == NULL but other constant weightings may result in different uniform partitionings.

Returns

The global number of shipped quadrants

Prototype

p4est_gloidx_t p8est_partition_ext (p8est_t * p8est, int partition_for_coarsening, p8est_weight_t weight_fn);
source
P4est.LibP4est.p8est_partition_for_coarseningMethod
p8est_partition_for_coarsening(p8est_, num_quadrants_in_proc)

Correct partition to allow one level of coarsening.

Parameters

  • p8est:[in] forest whose partition is corrected
  • num_quadrants_in_proc:[in,out] partition that will be corrected

Returns

absolute number of moved quadrants

Prototype

p4est_gloidx_t p8est_partition_for_coarsening (p8est_t * p8est, p4est_locidx_t * num_quadrants_in_proc);
source
P4est.LibP4est.p8est_partition_lnodesMethod
p8est_partition_lnodes(p8est_, ghost, degree, partition_for_coarsening)

Partition using weights based on the number of nodes assigned to each element in lnodes

Parameters

  • p8est:[in,out] the forest to be repartitioned
  • ghost:[in] the ghost layer
  • degree:[in] the degree that would be passed to p8est_lnodes_new()
  • partition_for_coarsening:[in] whether the partition should allow coarsening (i.e. group siblings who might merge)

Prototype

void p8est_partition_lnodes (p8est_t * p8est, p8est_ghost_t * ghost, int degree, int partition_for_coarsening);
source
P4est.LibP4est.p8est_partition_lnodes_detailedMethod
p8est_partition_lnodes_detailed(p4est_, ghost, nodes_per_volume, nodes_per_face, nodes_per_edge, nodes_per_corner, partition_for_coarsening)

Partition using weights that are broken down by where they reside: in volumes, on faces, on edges, or on corners.

Prototype

void p8est_partition_lnodes_detailed (p8est_t * p4est, p8est_ghost_t * ghost, int nodes_per_volume, int nodes_per_face, int nodes_per_edge, int nodes_per_corner, int partition_for_coarsening);
source
P4est.LibP4est.p8est_qcoord_to_vertexMethod
p8est_qcoord_to_vertex(connectivity, treeid, x, y, z, vxyz)

Transform a quadrant coordinate into the space spanned by tree vertices.

Parameters

  • connectivity:[in] Connectivity must provide the vertices.
  • treeid:[in] Identify the tree that contains x, y, z.
  • x,:[in] y, z Quadrant coordinates relative to treeid.
  • vxyz:[out] Transformed coordinates in vertex space.

Prototype

void p8est_qcoord_to_vertex (p8est_connectivity_t * connectivity, p4est_topidx_t treeid, p4est_qcoord_t x, p4est_qcoord_t y, p4est_qcoord_t z, double vxyz[3]);
source
P4est.LibP4est.p8est_quadrant_existsMethod
p8est_quadrant_exists(p8est_, ghost, treeid, q, exists_arr, rproc_arr, rquad_arr)

Checks if quadrant exists in the local forest or the ghost layer.

For quadrants across tree corners it checks if the quadrant exists in any of the corner neighbors, thus it can execute multiple queries.

Parameters

  • p8est:[in] The forest in which to search for q
  • ghost:[in] The ghost layer in which to search for q
  • treeid:[in] The tree to which q belongs (can be extended).
  • q:[in] The quadrant that is being searched for.
  • exists_arr:[in,out] Must exist and be of of elem_size = sizeof (int) for inter-tree corner cases. Is resized by this function to one entry for each corner search and set to true/false depending on its existence in the local forest or ghost_layer.
  • rproc_arr:[in,out] If not NULL is filled with one rank per query.
  • rquad_arr:[in,out] If not NULL is filled with one quadrant per query. Its piggy3 member is defined as well.

Returns

true if the quadrant exists in the local forest or in the ghost_layer, and false if doesn't exist in either.

Prototype

int p8est_quadrant_exists (p8est_t * p8est, p8est_ghost_t * ghost, p4est_topidx_t treeid, const p8est_quadrant_t * q, sc_array_t * exists_arr, sc_array_t * rproc_arr, sc_array_t * rquad_arr);
source
P4est.LibP4est.p8est_quadrant_find_ownerMethod
p8est_quadrant_find_owner(p8est_, treeid, face, q)

Gets the processor id of a quadrant's owner. The quadrant can lie outside of a tree across faces (and only faces).

Warning

Does not work for tree edge or corner neighbors.

Parameters

  • p8est:[in] The forest in which to search for a quadrant.
  • treeid:[in] The tree to which the quadrant belongs.
  • face:[in] Supply a face direction if known, or -1 otherwise.
  • q:[in] The quadrant that is being searched for.

Returns

Processor id of the owner or -1 if the quadrant lies outside of the mesh.

Prototype

int p8est_quadrant_find_owner (p8est_t * p8est, p4est_topidx_t treeid, int face, const p8est_quadrant_t * q);
source
P4est.LibP4est.p8est_quadrant_linear_id_ext128Method
p8est_quadrant_linear_id_ext128(quadrant, level, id)

Computes the linear position as p8est_lid_t of a quadrant in a uniform grid. The grid and quadrant levels need not coincide. If they do, this is the inverse of p4estquadrantset_morton.

Note

The user_data of quadrant is never modified.

Parameters

  • quadrant:[in] Quadrant whose linear index will be computed. If the quadrant is smaller than the grid (has a higher quadrant->level), the result is computed from its ancestor at the grid's level. If the quadrant has a smaller level than the grid (it is bigger than a grid cell), the grid cell sharing its lower left corner is used as reference.
  • level:[in] The level of the regular grid compared to which the linear position is to be computed.
  • id:[in,out] A pointer to an allocated or static p8est_lid_t. id will be the linear position of this quadrant on a uniform grid.

Prototype

void p8est_quadrant_linear_id_ext128 (const p8est_quadrant_t * quadrant, int level, p8est_lid_t * id);
source
P4est.LibP4est.p8est_quadrant_set_morton_ext128Method
p8est_quadrant_set_morton_ext128(quadrant, level, id)

Set quadrant Morton indices based on linear position given as p8est_lid_t in uniform grid. This is the inverse operation of p4estquadrantlinear_id.

Note

The user_data of quadrant is never modified.

Parameters

  • quadrant:[in,out] Quadrant whose Morton indices will be set.
  • level:[in] Level of the grid and of the resulting quadrant.
  • id:[in] Linear index of the quadrant on a uniform grid.

Prototype

void p8est_quadrant_set_morton_ext128 (p8est_quadrant_t * quadrant, int level, const p8est_lid_t * id);
source
P4est.LibP4est.p8est_refineMethod
p8est_refine(p8est_, refine_recursive, refine_fn, init_fn)

Refine a forest.

Parameters

  • p8est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn gets called, or use p8est_refine_ext in p8est_extended.h and examine whether replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data of newly created quadrants, which is already allocated. This function pointer may be NULL.

Prototype

void p8est_refine (p8est_t * p8est, int refine_recursive, p8est_refine_t refine_fn, p8est_init_t init_fn);
source
P4est.LibP4est.p8est_refine_extMethod
p8est_refine_ext(p8est_, refine_recursive, maxlevel, refine_fn, init_fn, replace_fn)

Refine a forest with a bounded refinement level and a replace option.

Parameters

  • p8est:[in,out] The forest is changed in place.
  • refine_recursive:[in] Boolean to decide on recursive refinement.
  • maxlevel:[in] Maximum allowed refinement level (inclusive). If this is negative the level is restricted only by the compile-time constant QMAXLEVEL in p8est.h.
  • refine_fn:[in] Callback function that must return true if a quadrant shall be refined. If refine_recursive is true, refine_fn is called for every existing and newly created quadrant. Otherwise, it is called for every existing quadrant. It is possible that a refinement request made by the callback is ignored. To catch this case, you can examine whether init_fn or replace_fn gets called.
  • init_fn:[in] Callback function to initialize the user_data for newly created quadrants, which is guaranteed to be allocated. This function pointer may be NULL.
  • replace_fn:[in] Callback function that allows the user to change incoming quadrants based on the quadrants they replace; may be NULL.

Prototype

void p8est_refine_ext (p8est_t * p8est, int refine_recursive, int maxlevel, p8est_refine_t refine_fn, p8est_init_t init_fn, p8est_replace_t replace_fn);
source
P4est.LibP4est.p8est_reset_dataMethod
p8est_reset_data(p8est_, data_size, init_fn, user_pointer)

Reset user pointer and element data. When the data size is changed the quadrant data is freed and allocated. The initialization callback is invoked on each quadrant. Old user_data content is disregarded.

Parameters

  • data_size:[in] This is the size of data for each quadrant which can be zero. Then user_data_pool is set to NULL.
  • init_fn:[in] Callback function to initialize the user_data which is already allocated automatically. May be NULL.
  • user_pointer:[in] Assign to the user_pointer member of the p8est before init_fn is called the first time.

Prototype

void p8est_reset_data (p8est_t * p8est, size_t data_size, p8est_init_t init_fn, void *user_pointer);
source
P4est.LibP4est.p8est_revisionMethod
p8est_revision(p8est_)

Return the revision counter of the forest. Not collective, even though the revision value is the same on all ranks. A newly created forest starts with a revision counter of zero. Every refine, coarsen, partition, and balance that actually changes the mesh increases the counter by one. Operations with no effect keep the old value.

Parameters

  • p8est:[in] The forest must be valid.

Returns

Non-negative number.

Prototype

long p8est_revision (p8est_t * p8est);
source
P4est.LibP4est.p8est_saveMethod
p8est_save(filename, p8est_, save_data)

Save the complete connectivity/p8est data to disk.

This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations.

By default, we write the current processor count and partition into the file header. This makes the file depend on mpisize. For changing this see p8est_save_ext() in p8est_extended.h.

The revision counter is not saved to the file, since that would make files different that come from different revisions but store the same mesh.

Note

Aborts on file errors.

Note

If p4est is not configured to use MPI-IO, some processes return from this function before the file is complete, in which case immediate read-access to the file may require a call to sc_MPI_Barrier.

Parameters

  • filename:[in] Name of the file to write.
  • p8est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.

Prototype

void p8est_save (const char *filename, p8est_t * p8est, int save_data);
source
P4est.LibP4est.p8est_save_extMethod
p8est_save_ext(filename, p8est_, save_data, save_partition)

Save the complete connectivity/p8est data to disk. This is a collective operation that all MPI processes need to call. All processes write into the same file, so the filename given needs to be identical over all parallel invocations. See p8est_load_ext for information on the autopartition parameter.

Note

Aborts on file errors.

Parameters

  • filename:[in] Name of the file to write.
  • p8est:[in] Valid forest structure.
  • save_data:[in] If true, the element data is saved. Otherwise, a data size of 0 is saved.
  • save_partition:[in] If false, save file as if 1 core was used. If true, save core count and partition. Advantage: Partition can be recovered on loading with same mpisize and autopartition false. Disadvantage: Makes the file depend on mpisize. Either way the file can be loaded with autopartition true.

Prototype

void p8est_save_ext (const char *filename, p8est_t * p8est, int save_data, int save_partition);
source
P4est.LibP4est.p8est_searchMethod
p8est_search(p4est_, quadrant_fn, point_fn, points)

This function is provided for backwards compatibility. We call p8estsearchlocal with call_post = 0.

Prototype

void p8est_search (p8est_t * p4est, p8est_search_query_t quadrant_fn, p8est_search_query_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p8est_search_allMethod
p8est_search_all(p4est_, call_post, quadrant_fn, point_fn, points)

Perform a top-down search on the whole forest.

This function combines the functionality of p4estsearchlocal and p4estsearchpartition; their documentation applies for the most part.

The recursion proceeds from the root quadrant of each tree until (a) we encounter a remote quadrant that covers only one processor, or (b) we encounter a local leaf quadrant. In other words, we proceed with the recursion into a quadrant's children if (a) the quadrant is split between two or more processors, no matter whether one of them is the calling processor or not, or (b) if the quadrant is on the local processor but we have not reached a leaf yet.

The search can track one or more points, which are abstract placeholders. They are matched against the quadrants traversed using a callback function. The result of the callback function can be used to stop a recursion early. The user determines how a point is interpreted, we only pass it around.

Note that in the remote case (a), we may terminate the recursion even if the quadrant is not a leaf, which we have no means of knowing. Still, this case is sufficient to determine the processor ownership of a point.

Note

This is a very powerful function that can become slow if not used carefully.

Note

As with the two other search functions in this file, calling it once with many points is generally much faster than calling it once for each point. Using multiple points also allows for a per-quadrant termination of the recursion in addition to a more costly per-point termination.

Note

This function works fine when used for the special cases that either the partition or the local quadrants are not of interest. However, in the case of querying only local information we expect that p4estsearchlocal will be faster since it employs specific local optimizations.

Parameters

  • p4est:[in] The forest to be searched.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] Executed once for each quadrant that is entered. If the callback returns false, this quadrant and its descendants are excluded from the search, and the points in this branch are not queried further. Its point argument is always NULL. Callback may be NULL in which case it is ignored.
  • point_fn:[in] Executed once for each point that is relevant for a quadrant of the search. If it returns true, the point is tracked further down that branch, else it is discarded from the queries for the children. If points is not NULL, this callback must be not NULL. If points is NULL, it is not called.
  • points:[in] User-defined array of points. We do not interpret a point, just pass it into the callbacks. If NULL, only the quadrant_fn callback is executed. If that is NULL, the whole function noops. If not NULL, the point_fn is called on its members during the search.

Prototype

void p8est_search_all (p8est_t * p4est, int call_post, p8est_search_all_t quadrant_fn, p8est_search_all_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p8est_search_localMethod
p8est_search_local(p4est_, call_post, quadrant_fn, point_fn, points)

Search through the local part of a forest. The search is especially efficient if multiple targets, called "points" below, are searched for simultaneously.

The search runs over all local quadrants and proceeds recursively top-down. For each tree, it may start at the root of that tree, or further down at the root of the subtree that contains all of the tree's local quadrants. Likewise, some intermediate levels in the recursion may be skipped if the processor-local part is contained in a single deeper subtree. The outer loop is thus a depth-first, processor-local forest traversal. Each quadrant in that loop either is a leaf, or a (direct or indirect) strict ancestor of a leaf. On entering a new quadrant, a user-provided quadrant-callback is executed.

As a convenience, the user may provide anonymous "points" that are tracked down the forest. This way one search call may be used for multiple targets. The set of points that potentially matches a given quadrant diminishes from the root down to the leaves: For each quadrant, an inner loop over the potentially matching points executes a point-callback for each candidate that determines whether the point may be a match. If not, it is discarded in the current branch, otherwise it is passed to the next deeper level. The callback is allowed to return true for the same point and more than one quadrant; in this case more than one matching quadrant may be identified. The callback is also allowed to return false for all children of a quadrant that it returned true for earlier. If the point callback returns false for all points relevant to a quadrant, the recursion stops. The points can really be anything, p4est does not perform any interpretation, just passes the pointer along to the callback function.

If points are present and the first quadrant callback returned true, we execute it a second time after calling the point callback for all current points. This can be used to gather and postprocess information about the points more easily. If it returns false, the recursion stops.

If the points are a NULL array, they are ignored and the recursion proceeds by querying the per-quadrant callback. If the points are not NULL but an empty array, the recursion will stop immediately!

Parameters

  • p4est:[in] The forest to be searched.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] Executed once when a quadrant is entered, and once when it is left (the second time only if points are present and the first call returned true). This quadrant is always local, if not completely than at least one descendant of it. If the callback returns false, this quadrant and its descendants are excluded from the search recursion. Its point argument is always NULL. Callback may be NULL in which case it is ignored.
  • point_fn:[in] If points is not NULL, must be not NULL. Shall return true for any possible matching point. If points is NULL, this callback is ignored.
  • points:[in] User-defined array of "points". If NULL, only the quadrant_fn callback is executed. If that is NULL, this function noops. If not NULL, the point_fn is called on its members during the search.

Prototype

void p8est_search_local (p8est_t * p4est, int call_post, p8est_search_local_t quadrant_fn, p8est_search_local_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p8est_search_partitionMethod
p8est_search_partition(p4est_, call_post, quadrant_fn, point_fn, points)

Traverse the global partition top-down. We proceed top-down through the partition, identically on all processors except for the results of two user-provided callbacks. The recursion will only go down branches that are split between multiple processors. The callback functions can be used to stop a branch recursion even for split branches. This function offers the option to search for arbitrary user-defined points analogously to p4estsearchlocal.

Note

Traversing the whole processor partition will be at least O(P), so sensible use of the callback function is advised to cut it short.

Parameters

  • p4est:[in] The forest to traverse. Its local quadrants are never accessed.
  • call_post:[in] If true, call quadrant callback both pre and post.
  • quadrant_fn:[in] This function controls the recursion, which only continues deeper if this callback returns true for a branch quadrant. It is allowed to set this to NULL.
  • point_fn:[in] This function decides per-point whether it is followed down the recursion. Must be non-NULL if points are not NULL.
  • points:[in] User-provided array of points that are passed to the callback point_fn. See p8estsearchlocal for details.

Prototype

void p8est_search_partition (p8est_t * p4est, int call_post, p8est_search_partition_t quadrant_fn, p8est_search_partition_t point_fn, sc_array_t * points);
source
P4est.LibP4est.p8est_source_extMethod
p8est_source_ext(src, mpicomm, data_size, load_data, autopartition, broadcasthead, user_pointer, connectivity)

Prototype

p8est_t *p8est_source_ext (sc_io_source_t * src, sc_MPI_Comm mpicomm, size_t data_size, int load_data, int autopartition, int broadcasthead, void *user_pointer, p8est_connectivity_t ** connectivity);
source
P4est.LibP4est.p8est_split_arrayMethod
p8est_split_array(array, level, indices)

Split an array of quadrants by the children of an ancestor.

Given a sorted array of quadrants that have a common ancestor at level level, compute the indices of the first quadrant in each of the common ancestor's children at level level + 1.

Parameters

  • array:[in] The sorted array of quadrants of level > level.
  • level:[in] The level at which there is a common ancestor.
  • indices:[in,out] The indices of the first quadrant in each of the ancestors's children, plus an additional index on the end. The quadrants of array that are descendants of child i have indices between indices[i] and indices[i + 1] - 1. If indices[i] = indices[i+1], this indicates that no quadrant in the array is contained in child i.

Prototype

void p8est_split_array (sc_array_t * array, int level, size_t indices[]);
source
P4est.LibP4est.sc_abortMethod
sc_abort()

Print a stack trace, call the abort handler and then call abort ().

Prototype

void sc_abort (void) __attribute__ ((noreturn));
source
P4est.LibP4est.sc_abort_collectiveMethod
sc_abort_collective(msg)

Collective abort where only root prints a message

Prototype

void sc_abort_collective (const char *msg) __attribute__ ((noreturn));
source
P4est.LibP4est.sc_abort_verboseMethod
sc_abort_verbose(filename, lineno, msg)

Print a message to stderr and then call sc_abort ().

Prototype

void sc_abort_verbose (const char *filename, int lineno, const char *msg) __attribute__ ((noreturn));
source
P4est.LibP4est.sc_array_bsearchMethod
sc_array_bsearch(array, key, compar)

Performs a binary search on an array. The array must be sorted.

Parameters

  • array:[in] A sorted array to search in.
  • key:[in] An element to be searched for.
  • compar:[in] The comparison function to be used.

Returns

Returns the index into array for the item found, or -1.

Prototype

ssize_t sc_array_bsearch (sc_array_t * array, const void *key, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_checksumMethod
sc_array_checksum(array)

Computes the adler32 checksum of array data (see zlib documentation). This is a faster checksum than crc32, and it works with zeros as data.

Prototype

unsigned int sc_array_checksum (sc_array_t * array);
source
P4est.LibP4est.sc_array_copyMethod
sc_array_copy(dest, src)

Copy the contents of one array into another. Both arrays must have equal element sizes. The source array may be a view. We use memcpy (3): If the two arrays overlap, results are undefined.

Parameters

  • dest:[in] Array (not a view) will be resized and get new data.
  • src:[in] Array used as source of new data, will not be changed.

Prototype

void sc_array_copy (sc_array_t * dest, sc_array_t * src);
source
P4est.LibP4est.sc_array_copy_intoMethod
sc_array_copy_into(dest, dest_offset, src)

Copy the contents of one array into some portion of another. Both arrays must have equal element sizes. Either array may be a view. The destination array must be large enough. We use memcpy (3): If the two arrays overlap, results are undefined.

Parameters

  • dest:[in] Array will be written into. Its element count must be at least dest_offset + src->elem_count.
  • dest_offset:[in] First index in dest array to be overwritten. As every index, it refers to elements, not bytes.
  • src:[in] Array used as source of new data, will not be changed.

Prototype

void sc_array_copy_into (sc_array_t * dest, size_t dest_offset, sc_array_t * src);
source
P4est.LibP4est.sc_array_destroyMethod
sc_array_destroy(array)

Destroys an array structure.

Parameters

  • array:[in] The array to be destroyed.

Prototype

void sc_array_destroy (sc_array_t * array);
source
P4est.LibP4est.sc_array_destroy_nullMethod
sc_array_destroy_null(parray)

Destroys an array structure and sets the pointer to NULL.

Parameters

  • parray:[in,out] Pointer to address of array to be destroyed. On output, *parray is NULL.

Prototype

void sc_array_destroy_null (sc_array_t ** parray);
source
P4est.LibP4est.sc_array_initMethod
sc_array_init(array, elem_size)

Initializes an already allocated (or static) array structure.

Parameters

  • array:[in,out] Array structure to be initialized.
  • elem_size:[in] Size of one array element in bytes.

Prototype

void sc_array_init (sc_array_t * array, size_t elem_size);
source
P4est.LibP4est.sc_array_init_countMethod
sc_array_init_count(array, elem_size, elem_count)

Initializes an already allocated (or static) array structure and allocates a given number of elements. This function supersedes scarrayinit_size.

Parameters

  • array:[in,out] Array structure to be initialized.
  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] Number of initial array elements.

Prototype

void sc_array_init_count (sc_array_t * array, size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_init_dataMethod
sc_array_init_data(view, base, elem_size, elem_count)

Initializes an already allocated (or static) view from given plain C data. The array view returned does not require sc_array_reset (doesn't hurt though).

Parameters

  • view:[in,out] Array structure to be initialized.
  • base:[in] The data must not be moved while view is alive.
  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] The length of the view in element units. The view cannot be resized to exceed this length. It is not necessary to call sc_array_reset later.

Prototype

void sc_array_init_data (sc_array_t * view, void *base, size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_init_sizeMethod
sc_array_init_size(array, elem_size, elem_count)

Initializes an already allocated (or static) array structure and allocates a given number of elements. Deprecated: use scarrayinit_count.

Parameters

  • array:[in,out] Array structure to be initialized.
  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] Number of initial array elements.

Prototype

void sc_array_init_size (sc_array_t * array, size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_init_viewMethod
sc_array_init_view(view, array, offset, length)

Initializes an already allocated (or static) view from existing sc_array_t. The array view returned does not require sc_array_reset (doesn't hurt though).

Parameters

  • view:[in,out] Array structure to be initialized.
  • array:[in] The array must not be resized while view is alive.
  • offset:[in] The offset of the viewed section in element units. This offset cannot be changed until the view is reset.
  • length:[in] The length of the view in element units. The view cannot be resized to exceed this length. It is not necessary to call sc_array_reset later.

Prototype

void sc_array_init_view (sc_array_t * view, sc_array_t * array, size_t offset, size_t length);
source
P4est.LibP4est.sc_array_is_equalMethod
sc_array_is_equal(array, other)

Check whether two arrays have equal size, count, and content. Either array may be a view. Both arrays will not be changed.

Parameters

  • array:[in] One array to be compared.
  • other:[in] A second array to be compared.

Returns

True if array and other are equal, false otherwise.

Prototype

int sc_array_is_equal (sc_array_t * array, sc_array_t * other);
source
P4est.LibP4est.sc_array_is_permutationMethod
sc_array_is_permutation(array)

Determine whether array is an array of size_t's whose entries include every integer 0 <= i < array->elem_count.

Parameters

  • array:[in] An array.

Returns

Returns 1 if array contains size_t elements whose entries include every integer 0 <= i < array->elem_count, 0 otherwise.

Prototype

int sc_array_is_permutation (sc_array_t * array);
source
P4est.LibP4est.sc_array_is_sortedMethod
sc_array_is_sorted(array, compar)

Check whether the array is sorted wrt. the comparison function.

Parameters

  • array:[in] The array to check.
  • compar:[in] The comparison function to be used.

Returns

True if array is sorted, false otherwise.

Prototype

int sc_array_is_sorted (sc_array_t * array, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_memory_usedMethod
sc_array_memory_used(array, is_dynamic)

Calculate the memory used by an array.

Parameters

Returns

Memory used in bytes.

Prototype

size_t sc_array_memory_used (sc_array_t * array, int is_dynamic);
source
P4est.LibP4est.sc_array_memsetMethod
sc_array_memset(array, c)

Run memset on the array storage. We pass the character to memset unchanged. Thus, care must be taken when setting values below -1 or above 127, just as with standard memset (3).

Parameters

  • array:[in,out] This array's storage will be overwritten.
  • c:[in] Character to overwrite every byte with.

Prototype

void sc_array_memset (sc_array_t * array, int c);
source
P4est.LibP4est.sc_array_move_partMethod
sc_array_move_part(dest, dest_offset, src, src_offset, count)

Copy part of one array into another using memmove (3). Both arrays must have equal element sizes. Either array may be a view. The destination array must be large enough. We use memmove (3): The two arrays may overlap.

Parameters

  • dest:[in] Array will be written into. Its element count must be at least dest_offset + count.
  • dest_offset:[in] First index in dest array to be overwritten. As every index, it refers to elements, not bytes.
  • src:[in] Array will be read from. Its element count must be at least src_offset + count.
  • src_offset:[in] First index in src array to be used. As every index, it refers to elements, not bytes.
  • count:[in] Number of entries copied.

Prototype

void sc_array_move_part (sc_array_t * dest, size_t dest_offset, sc_array_t * src, size_t src_offset, size_t count);
source
P4est.LibP4est.sc_array_newMethod
sc_array_new(elem_size)

Creates a new array structure with 0 elements.

Parameters

  • elem_size:[in] Size of one array element in bytes.

Returns

Return an allocated array of zero length.

Prototype

sc_array_t *sc_array_new (size_t elem_size);
source
P4est.LibP4est.sc_array_new_countMethod
sc_array_new_count(elem_size, elem_count)

Creates a new array structure with a given length (number of elements).

Parameters

  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] Initial number of array elements.

Returns

Return an allocated array with allocated but uninitialized elements.

Prototype

sc_array_t *sc_array_new_count (size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_new_dataMethod
sc_array_new_data(base, elem_size, elem_count)

Creates a new view of an existing plain C array.

Parameters

  • base:[in] The data must not be moved while view is alive.
  • elem_size:[in] Size of one array element in bytes.
  • elem_count:[in] The length of the view in element units. The view cannot be resized to exceed this length.

Prototype

sc_array_t *sc_array_new_data (void *base, size_t elem_size, size_t elem_count);
source
P4est.LibP4est.sc_array_new_viewMethod
sc_array_new_view(array, offset, length)

Creates a new view of an existing sc_array_t.

Parameters

  • array:[in] The array must not be resized while view is alive.
  • offset:[in] The offset of the viewed section in element units. This offset cannot be changed until the view is reset.
  • length:[in] The length of the viewed section in element units. The view cannot be resized to exceed this length.

Prototype

sc_array_t *sc_array_new_view (sc_array_t * array, size_t offset, size_t length);
source
P4est.LibP4est.sc_array_permuteMethod
sc_array_permute(array, newindices, keepperm)

Given permutation newindices, permute array in place. The data that on input is contained in array[i] will be contained in array[newindices[i]] on output. The entries of newindices will be altered unless keepperm is true.

Parameters

  • array:[in,out] An array.
  • newindices:[in,out] Permutation array (see sc_array_is_permutation).
  • keepperm:[in] If true, newindices will be unchanged by the algorithm; if false, newindices will be the identity permutation on output, but the algorithm will only use O(1) space.

Prototype

void sc_array_permute (sc_array_t * array, sc_array_t * newindices, int keepperm);
source
P4est.LibP4est.sc_array_pqueue_addMethod
sc_array_pqueue_add(array, temp, compar)

Adds an element to a priority queue. PQUEUE FUNCTIONS ARE UNTESTED AND CURRENTLY DISABLED. This function is not allowed for views. The priority queue is implemented as a heap in ascending order. A heap is a binary tree where the children are not less than their parent. Assumes that elements [0]..[elem_count-2] form a valid heap. Then propagates [elem_count-1] upward by swapping if necessary.

Note

If the return value is zero for all elements in an array, the array is sorted linearly and unchanged.

Parameters

  • temp:[in] Pointer to unused allocated memory of elem_size.
  • compar:[in] The comparison function to be used.

Returns

Returns the number of swap operations.

Prototype

size_t sc_array_pqueue_add (sc_array_t * array, void *temp, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_pqueue_popMethod
sc_array_pqueue_pop(array, result, compar)

Pops the smallest element from a priority queue. PQUEUE FUNCTIONS ARE UNTESTED AND CURRENTLY DISABLED. This function is not allowed for views. This function assumes that the array forms a valid heap in ascending order.

Note

This function resizes the array to elem_count-1.

Parameters

  • result:[out] Pointer to unused allocated memory of elem_size.
  • compar:[in] The comparison function to be used.

Returns

Returns the number of swap operations.

Prototype

size_t sc_array_pqueue_pop (sc_array_t * array, void *result, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_resetMethod
sc_array_reset(array)

Sets the array count to zero and frees all elements. This function turns a view into a newly initialized array.

Note

Calling sc_array_init, then any array operations, then sc_array_reset is memory neutral. As an exception, the two functions sc_array_init_view and sc_array_init_data do not require a subsequent call to sc_array_reset. Regardless, it is legal to call sc_array_reset anyway.

Parameters

  • array:[in,out] Array structure to be reset.

Prototype

void sc_array_reset (sc_array_t * array);
source
P4est.LibP4est.sc_array_resizeMethod
sc_array_resize(array, new_count)

Sets the element count to new_count. If the array is not a view, reallocation takes place occasionally. If the array is a view, new_count must not be greater than the element count of the view when it was created. The original offset of the view cannot be changed.

Parameters

  • array:[in,out] The element count and address is modified.
  • new_count:[in] New element count of the array. If it is zero and the array is not a view, the effect equals scarrayreset.

Prototype

void sc_array_resize (sc_array_t * array, size_t new_count);
source
P4est.LibP4est.sc_array_rewindMethod
sc_array_rewind(array, new_count)

Shorten an array without reallocating it.

Parameters

  • array:[in,out] The element count of this array is modified.
  • new_count:[in] Must be less or equal than the array's count. If it is less, the number of elements in the array is reduced without reallocating memory. The exception is a new_count of zero specified for an array that is not a view: In this case scarrayreset is equivalent.

Prototype

void sc_array_rewind (sc_array_t * array, size_t new_count);
source
P4est.LibP4est.sc_array_sortMethod
sc_array_sort(array, compar)

Sorts the array in ascending order wrt. the comparison function.

Parameters

  • array:[in] The array to sort.
  • compar:[in] The comparison function to be used.

Prototype

void sc_array_sort (sc_array_t * array, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_array_splitMethod
sc_array_split(array, offsets, num_types, type_fn, data)

Compute the offsets of groups of enumerable types in an array.

Parameters

  • array:[in] Array that is sorted in ascending order by type. If k indexes array, then 0 <= type_fn (array, k, data) < num_types.
  • offsets:[in,out] An initialized array of type size_t that is resized to num_types + 1 entries. The indices j of array that contain objects of type k are offsets[k] <= j < offsets[k + 1]. If there are no objects of type k, then offsets[k] = offset[k + 1].
  • num_types:[in] The number of possible types of objects in array.
  • type_fn:[in] Returns the type of an object in the array.
  • data:[in] Arbitrary user data passed to type_fn.

Prototype

void sc_array_split (sc_array_t * array, sc_array_t * offsets, size_t num_types, sc_array_type_t type_fn, void *data);
source
P4est.LibP4est.sc_array_truncateMethod
sc_array_truncate(array)

Sets the array count to zero, but does not free elements. Not allowed for views.

Note

This is intended to allow an sc_array to be used as a reusable buffer, where the "high water mark" of the buffer is preserved, so that O(log (max n)) reallocs occur over the life of the buffer.

Parameters

  • array:[in,out] Array structure to be truncated.

Prototype

void sc_array_truncate (sc_array_t * array);
source
P4est.LibP4est.sc_array_uniqMethod
sc_array_uniq(array, compar)

Removed duplicate entries from a sorted array. This function is not allowed for views.

Parameters

  • array:[in,out] The array size will be reduced as necessary.
  • compar:[in] The comparison function to be used.

Prototype

void sc_array_uniq (sc_array_t * array, int (*compar) (const void *, const void *));
source
P4est.LibP4est.sc_atoiMethod
sc_atoi(nptr)

Safe version of the standard library atoi (3) function.

Parameters

  • nptr:[in] NUL-terminated string.

Returns

Converted integer value. 0 if no valid number. INT_MAX on overflow, INT_MIN on underflow.

Prototype

int sc_atoi (const char *nptr);
source
P4est.LibP4est.sc_atolMethod
sc_atol(nptr)

Safe version of the standard library atol (3) function.

Parameters

  • nptr:[in] NUL-terminated string.

Returns

Converted long value. 0 if no valid number. LONG_MAX on overflow, LONG_MIN on underflow.

Prototype

long sc_atol (const char *nptr);
source
P4est.LibP4est.sc_fflush_fsync_fcloseMethod
sc_fflush_fsync_fclose(file)

Best effort to flush a file's data to disc and close it.

Parameters

  • file:[in,out] File open for writing.

Prototype

void sc_fflush_fsync_fclose (FILE * file);
source
P4est.LibP4est.sc_finalizeMethod
sc_finalize()

Unregisters all packages, runs the memory check, removes the signal handlers and resets sc_identifier and sc_root_*. This function aborts on any inconsistency found unless the global variable default_abort_mismatch is false. This function is optional. This function does not require sc_init to be called first.

Prototype

void sc_finalize (void);
source
P4est.LibP4est.sc_finalize_noabortMethod
sc_finalize_noabort()

Unregisters all packages, runs the memory check, removes the signal handlers and resets sc_identifier and sc_root_*. This function never aborts but returns the number of errors encountered. This function is optional. This function does not require sc_init to be called first.

Returns

0 when everything is consistent, nonzero otherwise.

Prototype

int sc_finalize_noabort (void);
source
P4est.LibP4est.sc_freadMethod
sc_fread(ptr, size, nmemb, file, errmsg)

Read file content into memory.

Note

This function aborts on file errors.

Parameters

  • ptr:[out] Data array to read from disk.
  • size:[in] Size of one array member.
  • nmemb:[in] Number of array members.
  • file:[in,out] File pointer, must be opened for reading.
  • errmsg:[in] Error message passed to SC_CHECK_ABORT.

Prototype

void sc_fread (void *ptr, size_t size, size_t nmemb, FILE * file, const char *errmsg);
source
P4est.LibP4est.sc_fwriteMethod
sc_fwrite(ptr, size, nmemb, file, errmsg)

Write memory content to a file.

Note

This function aborts on file errors.

Parameters

  • ptr:[in] Data array to write to disk.
  • size:[in] Size of one array member.
  • nmemb:[in] Number of array members.
  • file:[in,out] File pointer, must be opened for writing.
  • errmsg:[in] Error message passed to SC_CHECK_ABORT.

Prototype

void sc_fwrite (const void *ptr, size_t size, size_t nmemb, FILE * file, const char *errmsg);
source
P4est.LibP4est.sc_hash_array_insert_uniqueMethod
sc_hash_array_insert_unique(hash_array, v, position)

Insert an object into a hash array if it is not contained already. The object is not copied into the array. Use the return value for that. New objects are guaranteed to be added at the end of the array.

Parameters

  • v:[in] A pointer to the object. Used for search only.
  • position:[out] If position != NULL, *position is set to the array position of the already contained, or if not present, the new object.

Returns

Returns NULL if the object is already contained. Otherwise returns its new address in the array.

Prototype

void *sc_hash_array_insert_unique (sc_hash_array_t * hash_array, void *v, size_t *position);
source
P4est.LibP4est.sc_hash_array_lookupMethod
sc_hash_array_lookup(hash_array, v, position)

Check if an object is contained in a hash array.

Parameters

  • v:[in] A pointer to the object.
  • position:[out] If position != NULL, *position is set to the array position of the already contained object if found.

Returns

Returns true if object is found, false otherwise.

Prototype

int sc_hash_array_lookup (sc_hash_array_t * hash_array, void *v, size_t *position);
source
P4est.LibP4est.sc_hash_array_memory_usedMethod
sc_hash_array_memory_used(ha)

Calculate the memory used by a hash array.

Parameters

  • ha:[in] The hash array.

Returns

Memory used in bytes.

Prototype

size_t sc_hash_array_memory_used (sc_hash_array_t * ha);
source
P4est.LibP4est.sc_hash_array_newMethod
sc_hash_array_new(elem_size, hash_fn, equal_fn, user_data)

Create a new hash array.

Parameters

  • elem_size:[in] Size of one array element in bytes.
  • hash_fn:[in] Function to compute the hash value.
  • equal_fn:[in] Function to test two objects for equality.

Prototype

sc_hash_array_t *sc_hash_array_new (size_t elem_size, sc_hash_function_t hash_fn, sc_equal_function_t equal_fn, void *user_data);
source
P4est.LibP4est.sc_hash_array_ripMethod
sc_hash_array_rip(hash_array, rip)

Extract the array data from a hash array and destroy everything else.

Parameters

  • hash_array:[in] The hash array is destroyed after extraction.
  • rip:[in] Array structure that will be overwritten. All previous array data (if any) will be leaked. The filled array can be freed with sc_array_reset.

Prototype

void sc_hash_array_rip (sc_hash_array_t * hash_array, sc_array_t * rip);
source
P4est.LibP4est.sc_hash_array_truncateMethod
sc_hash_array_truncate(hash_array)

Remove all elements from the hash array.

Parameters

  • hash_array:[in,out] Hash array to truncate.

Prototype

void sc_hash_array_truncate (sc_hash_array_t * hash_array);
source
P4est.LibP4est.sc_hash_destroyMethod
sc_hash_destroy(hash)

Destroy a hash table.

If the allocator is owned, this runs in O(1), otherwise in O(N).

Note

If allocator was provided in sc_hash_new, it will not be destroyed.

Prototype

void sc_hash_destroy (sc_hash_t * hash);
source
P4est.LibP4est.sc_hash_destroy_nullMethod
sc_hash_destroy_null(phash)

Destroy a hash table and set its pointer to NULL. Destruction is done using schashdestroy.

Parameters

  • phash:[in,out] Address of pointer to hash table. On output, pointer is NULLed.

Prototype

void sc_hash_destroy_null (sc_hash_t ** phash);
source
P4est.LibP4est.sc_hash_foreachMethod
sc_hash_foreach(hash, fn)

Invoke a callback for every member of the hash table. The functions hash_fn and equal_fn are not called by this function.

Prototype

void sc_hash_foreach (sc_hash_t * hash, sc_hash_foreach_t fn);
source
P4est.LibP4est.sc_hash_function_stringMethod
sc_hash_function_string(s, u)

Compute a hash value from a null-terminated string. This hash function is NOT cryptographically safe! Use libcrypt then.

Parameters

  • s:[in] Null-terminated string to be hashed.
  • u:[in] Not used.

Returns

The computed hash value as an unsigned integer.

Prototype

unsigned int sc_hash_function_string (const void *s, const void *u);
source
P4est.LibP4est.sc_hash_insert_uniqueMethod
sc_hash_insert_unique(hash, v, found)

Insert an object into a hash table if it is not contained already.

Parameters

  • v:[in] The object to be inserted.
  • found:[out] If found != NULL, *found is set to the address of the pointer to the already contained, or if not present, the new object. You can assign to **found to override.

Returns

Returns true if object is added, false if it is already contained.

Prototype

int sc_hash_insert_unique (sc_hash_t * hash, void *v, void ***found);
source
P4est.LibP4est.sc_hash_lookupMethod
sc_hash_lookup(hash, v, found)

Check if an object is contained in the hash table.

Parameters

  • v:[in] The object to be looked up.
  • found:[out] If found != NULL, *found is set to the address of the pointer to the already contained object if the object is found. You can assign to **found to override.

Returns

Returns true if object is found, false otherwise.

Prototype

int sc_hash_lookup (sc_hash_t * hash, void *v, void ***found);
source
P4est.LibP4est.sc_hash_memory_usedMethod
sc_hash_memory_used(hash)

Calculate the memory used by a hash table.

Parameters

  • hash:[in] The hash table.

Returns

Memory used in bytes.

Prototype

size_t sc_hash_memory_used (sc_hash_t * hash);
source
P4est.LibP4est.sc_hash_newMethod
sc_hash_new(hash_fn, equal_fn, user_data, allocator)

Create a new hash table. The number of hash slots is chosen dynamically.

Parameters

  • hash_fn:[in] Function to compute the hash value.
  • equal_fn:[in] Function to test two objects for equality.
  • user_data:[in] User data passed through to the hash function.
  • allocator:[in] Memory allocator for sc_link_t, can be NULL.

Prototype

sc_hash_t *sc_hash_new (sc_hash_function_t hash_fn, sc_equal_function_t equal_fn, void *user_data, sc_mempool_t * allocator);
source
P4est.LibP4est.sc_hash_print_statisticsMethod
sc_hash_print_statistics(package_id, log_priority, hash)

Compute and print statistical information about the occupancy.

Prototype

void sc_hash_print_statistics (int package_id, int log_priority, sc_hash_t * hash);
source
P4est.LibP4est.sc_hash_removeMethod
sc_hash_remove(hash, v, found)

Remove an object from a hash table.

Parameters

  • v:[in] The object to be removed.
  • found:[out] If found != NULL, *found is set to the object that is removed if that exists.

Returns

Returns true if object is found, false if is not contained.

Prototype

int sc_hash_remove (sc_hash_t * hash, void *v, void **found);
source
P4est.LibP4est.sc_hash_unlinkMethod
sc_hash_unlink(hash)

Unlink all hash elements without returning them to the mempool.

If the allocator is not owned, this runs faster than sc_hash_truncate, but is dangerous because of potential memory leaks.

Parameters

  • hash:[in,out] Hash structure to be unlinked.

Prototype

void sc_hash_unlink (sc_hash_t * hash);
source
P4est.LibP4est.sc_hash_unlink_destroyMethod
sc_hash_unlink_destroy(hash)

Same effect as unlink and destroy, but in O(1). This is dangerous because of potential memory leaks.

Parameters

  • hash:[in] Hash structure to be unlinked and destroyed.

Prototype

void sc_hash_unlink_destroy (sc_hash_t * hash);
source
P4est.LibP4est.sc_initMethod
sc_init(mpicomm, catch_signals, print_backtrace, log_handler, log_threshold)

Prototype

void sc_init (sc_MPI_Comm mpicomm, int catch_signals, int print_backtrace, sc_log_handler_t log_handler, int log_threshold);
source
P4est.LibP4est.sc_io_sink_alignMethod
sc_io_sink_align(sink, bytes_align)

Align sink to a byte boundary by writing zeros.

Parameters

  • sink:[in,out] The sink object to align.
  • bytes_align:[in] Byte boundary.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_sink_align (sc_io_sink_t * sink, size_t bytes_align);
source
P4est.LibP4est.sc_io_sink_completeMethod
sc_io_sink_complete(sink, bytes_in, bytes_out)

Flush all buffered output data to sink. This function may return SC_IO_ERROR_AGAIN if another write is required. Currently this may happen if BUFFER requires an integer multiple of bytes. If successful, the updated value of bytes read and written is returned in bytes_in/out, and the sink status is reset as if the sink had just been created. In particular, the bytes counters are reset to zero. The internal state of the sink is not changed otherwise. It is legal to continue writing to the sink hereafter. The sink actions taken depend on its type. BUFFER, FILEFILE: none. FILENAME: call fclose on sink->file.

Parameters

  • sink:[in,out] The sink object to write to.
  • bytes_in:[in,out] Bytes received since the last new or complete call. May be NULL.
  • bytes_out:[in,out] Bytes written since the last new or complete call. May be NULL.

Returns

0 if completed, nonzero on error.

Prototype

int sc_io_sink_complete (sc_io_sink_t * sink, size_t * bytes_in, size_t * bytes_out);
source
P4est.LibP4est.sc_io_sink_destroyMethod
sc_io_sink_destroy(sink)

Free data sink. Calls sc_io_sink_complete and discards the final counts. Errors from complete lead to SC_IO_ERROR_FATAL returned from this function. Call sc_io_sink_complete yourself if bytes_out is of interest.

Parameters

  • sink:[in,out] The sink object to complete and free.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_sink_destroy (sc_io_sink_t * sink);
source
P4est.LibP4est.sc_io_sink_writeMethod
sc_io_sink_write(sink, data, bytes_avail)

Write data to a sink. Data may be buffered and sunk in a later call. The internal counters sink->bytes_in and sink->bytes_out are updated.

Parameters

  • sink:[in,out] The sink object to write to.
  • data:[in] Data passed into sink.
  • bytes_avail:[in] Number of data bytes passed in.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_sink_write (sc_io_sink_t * sink, const void *data, size_t bytes_avail);
source
P4est.LibP4est.sc_io_source_activate_mirrorMethod
sc_io_source_activate_mirror(source)

Activate a buffer that mirrors (i.e., stores) the data that was read.

Parameters

  • source:[in,out] The source object to activate mirror in.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_source_activate_mirror (sc_io_source_t * source);
source
P4est.LibP4est.sc_io_source_alignMethod
sc_io_source_align(source, bytes_align)

Align source to a byte boundary by skipping.

Parameters

  • source:[in,out] The source object to align.
  • bytes_align:[in] Byte boundary.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_source_align (sc_io_source_t * source, size_t bytes_align);
source
P4est.LibP4est.sc_io_source_completeMethod
sc_io_source_complete(source, bytes_in, bytes_out)

Determine whether all data buffered from source has been returned by read. If it returns SC_IO_ERROR_AGAIN, another sc_io_source_read is required. If the call returns no error, the internal counters source->bytes_in and source->bytes_out are returned to the caller if requested, and reset to 0. The internal state of the source is not changed otherwise. It is legal to continue reading from the source hereafter.

Parameters

  • source:[in,out] The source object to read from.
  • bytes_in:[in,out] If not NULL and true is returned, the total size of the data sourced.
  • bytes_out:[in,out] If not NULL and true is returned, total bytes passed out by source_read.

Returns

SC_IO_ERROR_AGAIN if buffered data remaining. Otherwise return ERROR_NONE and reset counters.

Prototype

int sc_io_source_complete (sc_io_source_t * source, size_t * bytes_in, size_t * bytes_out);
source
P4est.LibP4est.sc_io_source_destroyMethod
sc_io_source_destroy(source)

Free data source. Calls sc_io_source_complete and requires it to return no error. This is to avoid discarding buffered data that has not been passed to read.

Parameters

  • source:[in,out] The source object to free.

Returns

0 on success. Nonzero if an error is encountered or is_complete returns one.

Prototype

int sc_io_source_destroy (sc_io_source_t * source);
source
P4est.LibP4est.sc_io_source_readMethod
sc_io_source_read(source, data, bytes_avail, bytes_out)

Read data from a source. The internal counters source->bytes_in and source->bytes_out are updated. Data is read until the data buffer has not enough room anymore, or source becomes empty. It is possible that data already read internally remains in the source object for the next call. Call sc_io_source_complete and check its return value to find out. Returns an error if bytes_out is NULL and less than bytes_avail are read.

Parameters

  • source:[in,out] The source object to read from.
  • data:[in] Data buffer for reading from sink. If NULL the output data will be thrown away.
  • bytes_avail:[in] Number of bytes available in data buffer.
  • bytes_out:[in,out] If not NULL, byte count read into data buffer. Otherwise, requires to read exactly bytes_avail.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_source_read (sc_io_source_t * source, void *data, size_t bytes_avail, size_t * bytes_out);
source
P4est.LibP4est.sc_io_source_read_mirrorMethod
sc_io_source_read_mirror(source, data, bytes_avail, bytes_out)

Read data from the source's mirror. Same behaviour as sc_io_source_read.

Parameters

  • source:[in,out] The source object to read mirror data from.

Returns

0 on success, nonzero on error.

Prototype

int sc_io_source_read_mirror (sc_io_source_t * source, void *data, size_t bytes_avail, size_t * bytes_out);
source
P4est.LibP4est.sc_is_rootMethod
sc_is_root()

Identify the root process. Only meaningful between sc_init and sc_finalize and with a communicator that is not sc_MPI_COMM_NULL (otherwise always true).

Returns

Return true for the root process and false otherwise.

Prototype

int sc_is_root (void);
source
P4est.LibP4est.sc_list_appendMethod
sc_list_append(list, data)

Insert a list element at the end of the list.

Parameters

  • list:[in,out] Valid list object.
  • data:[in] A new link is created holding this data.

Returns

The link that has been created for data.

Prototype

sc_link_t *sc_list_append (sc_list_t * list, void *data);
source
P4est.LibP4est.sc_list_destroyMethod
sc_list_destroy(list)

Destroy a linked list structure in O(N).

Note

If allocator was provided in sc_list_new, it will not be destroyed.

Parameters

  • list:[in,out] All memory allocated for this list is freed.

Prototype

void sc_list_destroy (sc_list_t * list);
source
P4est.LibP4est.sc_list_initMethod
sc_list_init(list, allocator)

Initialize a list object with an external link allocator.

Parameters

  • list:[in,out] List structure to be initialized.
  • allocator:[in] External memory allocator for sc_link_t, which must exist already.

Prototype

void sc_list_init (sc_list_t * list, sc_mempool_t * allocator);
source
P4est.LibP4est.sc_list_insertMethod
sc_list_insert(list, pred, data)

Insert an element after a given list position.

Parameters

  • list:[in,out] Valid list object.
  • pred:[in,out] The predecessor of the element to be inserted.
  • data:[in] A new link is created holding this data.

Returns

The link that has been created for data.

Prototype

sc_link_t *sc_list_insert (sc_list_t * list, sc_link_t * pred, void *data);
source
P4est.LibP4est.sc_list_memory_usedMethod
sc_list_memory_used(list, is_dynamic)

Calculate the total memory used by a list.

Parameters

Returns

Memory used in bytes.

Prototype

size_t sc_list_memory_used (sc_list_t * list, int is_dynamic);
source
P4est.LibP4est.sc_list_newMethod
sc_list_new(allocator)

Allocate a new, empty linked list.

Parameters

  • allocator:[in] Memory allocator for sc_link_t, can be NULL in which case an internal allocator is created.

Returns

Pointer to a newly allocated, empty list object.

Prototype

sc_list_t *sc_list_new (sc_mempool_t * allocator);
source
P4est.LibP4est.sc_list_popMethod
sc_list_pop(list)

Remove an element from the front of the list.

Parameters

  • list:[in,out] Valid, non-empty list object.

Returns

Returns the data of the removed first list element.

Prototype

void *sc_list_pop (sc_list_t * list);
source
P4est.LibP4est.sc_list_prependMethod
sc_list_prepend(list, data)

Insert a list element at the beginning of the list.

Parameters

  • list:[in,out] Valid list object.
  • data:[in] A new link is created holding this data.

Returns

The link that has been created for data.

Prototype

sc_link_t *sc_list_prepend (sc_list_t * list, void *data);
source
P4est.LibP4est.sc_list_removeMethod
sc_list_remove(list, pred)

Remove an element after a given list position.

Parameters

  • list:[in,out] Valid, non-empty list object.
  • pred:[in] The predecessor of the element to be removed. If pred == NULL, the first element is removed, which is equivalent to calling sc_list_pop (list).

Returns

The data of the removed and freed link.

Prototype

void *sc_list_remove (sc_list_t * list, sc_link_t * pred);
source
P4est.LibP4est.sc_list_unlinkMethod
sc_list_unlink(list)

Unlink all list elements without returning them to the mempool. This runs in O(1) but is dangerous because the link memory stays alive.

Parameters

  • list:[in,out] List structure to be unlinked.

Prototype

void sc_list_unlink (sc_list_t * list);
source
P4est.LibP4est.sc_logMethod
sc_log(filename, lineno, package, category, priority, msg)

The central log function to be called by all packages. Dispatches the log calls by package and filters by category and priority.

Parameters

  • package:[in] Must be a registered package id or -1.
  • category:[in] Must be SC_LC_NORMAL or SC_LC_GLOBAL.
  • priority:[in] Must be > SC_LP_ALWAYS and < SC_LP_SILENT.

Prototype

void sc_log (const char *filename, int lineno, int package, int category, int priority, const char *msg);
source
P4est.LibP4est.sc_log_indent_pop_countMethod
sc_log_indent_pop_count(package, count)

Remove spaces from the start of a package's default log format.

Prototype

void sc_log_indent_pop_count (int package, int count);
source
P4est.LibP4est.sc_mempool_destroyMethod
sc_mempool_destroy(mempool)

Destroy a mempool structure. All elements that are still in use are invalidated.

Parameters

  • mempool:[in,out] Its memory is freed.

Prototype

void sc_mempool_destroy (sc_mempool_t * mempool);
source
P4est.LibP4est.sc_mempool_destroy_nullMethod
sc_mempool_destroy_null(pmempool)

Destroy a mempool structure. All elements that are still in use are invalidated.

Parameters

  • pmempool:[in,out] Address of pointer to memory pool. Its memory is freed, pointer is NULLed.

Prototype

void sc_mempool_destroy_null (sc_mempool_t ** pmempool);
source
P4est.LibP4est.sc_mempool_memory_usedMethod
sc_mempool_memory_used(mempool)

Calculate the memory used by a memory pool.

Parameters

  • array:[in] The memory pool.

Returns

Memory used in bytes.

Prototype

size_t sc_mempool_memory_used (sc_mempool_t * mempool);
source
P4est.LibP4est.sc_mempool_newMethod
sc_mempool_new(elem_size)

Creates a new mempool structure with the zero_and_persist option off. The contents of any elements returned by sc_mempool_alloc are undefined.

Parameters

  • elem_size:[in] Size of one element in bytes.

Returns

Returns an allocated and initialized memory pool.

Prototype

sc_mempool_t *sc_mempool_new (size_t elem_size);
source
P4est.LibP4est.sc_mempool_new_zero_and_persistMethod
sc_mempool_new_zero_and_persist(elem_size)

Creates a new mempool structure with the zero_and_persist option on. The memory of newly created elements is zero'd out, and the contents of an element are not touched between freeing and re-returning it.

Parameters

  • elem_size:[in] Size of one element in bytes.

Returns

Returns an allocated and initialized memory pool.

Prototype

sc_mempool_t *sc_mempool_new_zero_and_persist (size_t elem_size);
source
P4est.LibP4est.sc_mempool_truncateMethod
sc_mempool_truncate(mempool)

Invalidates all previously returned pointers, resets count to 0.

Prototype

void sc_mempool_truncate (sc_mempool_t * mempool);
source
P4est.LibP4est.sc_mpi_readMethod
sc_mpi_read(mpifile, ptr, zcount, t, errmsg)

Prototype

void sc_mpi_read (MPI_File mpifile, const void *ptr, size_t zcount, sc_MPI_Datatype t, const char *errmsg);
source
P4est.LibP4est.sc_mpi_writeMethod
sc_mpi_write(mpifile, ptr, zcount, t, errmsg)

Prototype

void sc_mpi_write (MPI_File mpifile, const void *ptr, size_t zcount, sc_MPI_Datatype t, const char *errmsg);
source
P4est.LibP4est.sc_mstamp_allocMethod
sc_mstamp_alloc(mst)

Return a new item. The memory returned will stay legal until container is destroyed or truncated.

Parameters

  • Properly:[in,out] initialized stamp container.

Returns

Pointer to an item ready to use. Legal until scstampdestroy or scstamptruncate is called on mst.

Prototype

void *sc_mstamp_alloc (sc_mstamp_t * mst);
source
P4est.LibP4est.sc_mstamp_initMethod
sc_mstamp_init(mst, stamp_unit, elem_size)

Initialize a memory stamp container. We provide allocation of fixed-size memory items without allocating new memory in every request. Instead we block the allocations in what we call a stamp of multiple items. Even if no allocations are done, the container's internal memory must be freed eventually by scmstampreset.

Parameters

  • mst:[in,out] Legal pointer to a stamp structure.
  • stamp_unit:[in] Size of each memory block that we allocate. If it is larger than the element size, we may place more than one element in it. Passing 0 is legal and forces stamps that hold one item each.
  • elem_size:[in] Size of each item. Passing 0 is legal. In that case, scmstampalloc returns NULL.

Prototype

void sc_mstamp_init (sc_mstamp_t * mst, size_t stamp_unit, size_t elem_size);
source
P4est.LibP4est.sc_mstamp_memory_usedMethod
sc_mstamp_memory_used(mst)

Return memory size in bytes of all data allocated in the container.

Parameters

  • Properly:[in] initialized stamp container.

Returns

Total container memory size in bytes.

Prototype

size_t sc_mstamp_memory_used (sc_mstamp_t * mst);
source
P4est.LibP4est.sc_mstamp_resetMethod
sc_mstamp_reset(mst)

Free all memory in a stamp structure and all items previously returned.

Parameters

  • Properly:[in,out] initialized stamp container. On output, the structure is undefined.

Prototype

void sc_mstamp_reset (sc_mstamp_t * mst);
source
P4est.LibP4est.sc_mstamp_truncateMethod
sc_mstamp_truncate(mst)

Free all memory in a stamp structure and initialize it anew. Equivalent to calling scmstampreset followed by scmstampinit with the same stamp_unit and elem_size.

Parameters

  • Properly:[in,out] initialized stamp container. On output, its elements have been freed and it is ready for further use.

Prototype

void sc_mstamp_truncate (sc_mstamp_t * mst);
source
P4est.LibP4est.sc_package_is_registeredMethod
sc_package_is_registered(package_id)

Query whether an identifier matches a registered package.

Parameters

  • package_id:[in] Only a non-negative id can be registered.

Returns

True if and only if the package id is non-negative and package is registered.

Prototype

int sc_package_is_registered (int package_id);
source
P4est.LibP4est.sc_package_lockMethod
sc_package_lock(package_id)

Acquire a pthread mutex lock. If configured without –enable-pthread, this function does nothing. This function must be followed with a matching scpackageunlock.

Parameters

  • package_id:[in] Either -1 for an undefined package or an id returned from scpackageregister. Depending on the value, the appropriate mutex is chosen. Thus, we may overlap locking calls with distinct package_id.

Prototype

void sc_package_lock (int package_id);
source
P4est.LibP4est.sc_package_print_summaryMethod
sc_package_print_summary(log_priority)

Print a summary of all packages registered with SC. Uses the SC_LC_GLOBAL log category which by default only prints on rank 0.

Parameters

  • log_priority:[in] Priority passed to sc log functions.

Prototype

void sc_package_print_summary (int log_priority);
source
P4est.LibP4est.sc_package_registerMethod
sc_package_register(log_handler, log_threshold, name, full)

Register a software package with SC. This function must only be called before additional threads are created. The logging parameters are as in sc_set_log_defaults.

Returns

Returns a unique package id.

Prototype

int sc_package_register (sc_log_handler_t log_handler, int log_threshold, const char *name, const char *full);
source
P4est.LibP4est.sc_package_set_abort_alloc_mismatchMethod
sc_package_set_abort_alloc_mismatch(package_id, set_abort)

Set the unregister behavior of sc_package_unregister().

Parameters

  • package_id:[in] Must be -1 for the default package or the identifier of a registered package.
  • set_abort:[in] True if sc_package_unregister() should abort if the number of allocs does not match the number of frees; false otherwise.

Prototype

void sc_package_set_abort_alloc_mismatch (int package_id, int set_abort);
source
P4est.LibP4est.sc_package_set_verbosityMethod
sc_package_set_verbosity(package_id, log_priority)

Set the logging verbosity of a registered package. This can be called at any point in the program, any number of times. It can only lower the verbosity at and below the value of SC_LP_THRESHOLD.

Parameters

  • package_id:[in] Must be a registered package identifier.

Prototype

void sc_package_set_verbosity (int package_id, int log_priority);
source
P4est.LibP4est.sc_package_unlockMethod
sc_package_unlock(package_id)

Release a pthread mutex lock. If configured without –enable-pthread, this function does nothing. This function must be follow a matching scpackagelock.

Parameters

  • package_id:[in] Either -1 for an undefined package or an id returned from scpackageregister. Depending on the value, the appropriate mutex is chosen. Thus, we may overlap locking calls with distinct package_id.

Prototype

void sc_package_unlock (int package_id);
source
P4est.LibP4est.sc_package_unregisterMethod
sc_package_unregister(package_id)

Unregister a software package with SC. This function must only be called after additional threads are finished.

Prototype

void sc_package_unregister (int package_id);
source
P4est.LibP4est.sc_recycle_array_initMethod
sc_recycle_array_init(rec_array, elem_size)

Initialize a recycle array.

Parameters

  • elem_size:[in] Size of the objects to be stored in the array.

Prototype

void sc_recycle_array_init (sc_recycle_array_t * rec_array, size_t elem_size);
source
P4est.LibP4est.sc_recycle_array_insertMethod
sc_recycle_array_insert(rec_array, position)

Insert an object into the recycle array. The object is not copied into the array. Use the return value for that.

Parameters

  • position:[out] If position != NULL, *position is set to the array position of the inserted object.

Returns

Returns the new address of the object in the array.

Prototype

void *sc_recycle_array_insert (sc_recycle_array_t * rec_array, size_t *position);
source
P4est.LibP4est.sc_recycle_array_removeMethod
sc_recycle_array_remove(rec_array, position)

Remove an object from the recycle array. It must be valid.

Parameters

  • position:[in] Index into the array for the object to remove.

Returns

The pointer to the removed object. Will be valid as long as no other function is called on this recycle array.

Prototype

void *sc_recycle_array_remove (sc_recycle_array_t * rec_array, size_t position);
source
P4est.LibP4est.sc_recycle_array_resetMethod
sc_recycle_array_reset(rec_array)

Reset a recycle array.

As with all _reset functions, calling _init, then any array operations, then _reset is memory neutral.

Prototype

void sc_recycle_array_reset (sc_recycle_array_t * rec_array);
source
P4est.LibP4est.sc_set_abort_handlerMethod
sc_set_abort_handler(abort_handler)

Controls the default SC abort behavior.

Parameters

  • abort_handler:[in] Set default SC above handler (NULL selects builtin). ***This function should not return!***

Prototype

void sc_set_abort_handler (sc_abort_handler_t abort_handler);
source
P4est.LibP4est.sc_set_log_defaultsMethod
sc_set_log_defaults(log_stream, log_handler, log_thresold)

Controls the default SC log behavior.

Parameters

  • log_stream:[in] Set stream to use by sc_logf (or NULL for stdout).
  • log_handler:[in] Set default SC log handler (NULL selects builtin).
  • log_threshold:[in] Set default SC log threshold (or SC_LP_DEFAULT). May be SC_LP_ALWAYS or SC_LP_SILENT.

Prototype

void sc_set_log_defaults (FILE * log_stream, sc_log_handler_t log_handler, int log_thresold);
source
P4est.LibP4est.sc_strcopyMethod
sc_strcopy(dest, size, src)

Provide a string copy function.

Parameters

  • dest:[out] Buffer of length at least size. On output, not touched if NULL or size == 0.
  • size:[in] Allocation length of dest.
  • src:[in] Null-terminated string.

Returns

Equivalent to sc_snprintf (dest, size, "s", src).

Prototype

void sc_strcopy (char *dest, size_t size, const char *src);
source
P4est.LibP4est.sc_uint128_addMethod
sc_uint128_add(a, b, result)

Adds the uint128_t b to the uint128_t a. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void sc_uint128_add (const sc_uint128_t * a, const sc_uint128_t * b, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_add_inplaceMethod
sc_uint128_add_inplace(a, b)

Adds the uint128 b to the uint128_t a. The result is saved in a. a == b is allowed.

Parameters

Prototype

void sc_uint128_add_inplace (sc_uint128_t * a, const sc_uint128_t * b);
source
P4est.LibP4est.sc_uint128_bitwise_andMethod
sc_uint128_bitwise_and(a, b, result)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void sc_uint128_bitwise_and (const sc_uint128_t * a, const sc_uint128_t * b, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_bitwise_and_inplaceMethod
sc_uint128_bitwise_and_inplace(a, b)

Calculates the bitwise and of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void sc_uint128_bitwise_and_inplace (sc_uint128_t * a, const sc_uint128_t * b);
source
P4est.LibP4est.sc_uint128_bitwise_negMethod
sc_uint128_bitwise_neg(a, result)

Calculates the bitwise negation of the uint128_t a. a == result is allowed.

Parameters

  • a:[in] A pointer to a sc_uint128_t.
  • result:[out] A pointer to a sc_uint128_t. The bitwise negation of a will be saved in result.

Prototype

void sc_uint128_bitwise_neg (const sc_uint128_t * a, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_bitwise_orMethod
sc_uint128_bitwise_or(a, b, result)

Calculates the bitwise or of the uint128_t a and b. a == result is allowed. Furthermore, a == result and/or b == result is allowed.

Parameters

Prototype

void sc_uint128_bitwise_or (const sc_uint128_t * a, const sc_uint128_t * b, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_bitwise_or_inplaceMethod
sc_uint128_bitwise_or_inplace(a, b)

Calculates the bitwise or of the uint128_t a and the uint128_t b. a == b is allowed.

Parameters

Prototype

void sc_uint128_bitwise_or_inplace (sc_uint128_t * a, const sc_uint128_t * b);
source
P4est.LibP4est.sc_uint128_chk_bitMethod
sc_uint128_chk_bit(input, exponent)

Returns the bit_number-th bit of input. This function checks a bit of an existing, initialized value.

Parameters

  • input:[in] A pointer to a sc_uint128_t.
  • bit_number:[in] The bit (counted from the right hand side) that is checked by logical and. Require 0 <= bit_number < 128.

Returns

True if the checked bit is set, false if not.

Prototype

int sc_uint128_chk_bit (const sc_uint128_t * input, int exponent);
source
P4est.LibP4est.sc_uint128_copyMethod
sc_uint128_copy(input, output)

Copies an initialized sc_uint128_t to a sc_uint128_t.

Parameters

  • input:[in] A pointer to the sc_uint128 that is copied.
  • output:[in,out] A pointer to a sc_uint128_t. The high and low bits of output will be set to the high and low bits of input, respectively.

Prototype

void sc_uint128_copy (const sc_uint128_t * input, sc_uint128_t * output);
source
P4est.LibP4est.sc_uint128_initMethod
sc_uint128_init(a, high, low)

Initializes an unsigned 128 bit integer to a given value.

Parameters

  • a:[in,out] A pointer to the sc_uint128_t that will be initialized.
  • high:[in] The given high bits to initialize a.
  • low:[in] The given low bits to initialize a.

Prototype

void sc_uint128_init (sc_uint128_t * a, uint64_t high, uint64_t low);
source
P4est.LibP4est.sc_uint128_set_bitMethod
sc_uint128_set_bit(a, exponent)

Sets the exponent-th bit of a to one and keep all other bits. This function modifies an existing, initialized value.

Parameters

  • a:[in,out] A pointer to a sc_uint128_t.
  • exponent:[in] The bit (0-based from the rightmost bit) that is set to one by logical or. 0 <= exponent < 128.

Prototype

void sc_uint128_set_bit (sc_uint128_t * a, int exponent);
source
P4est.LibP4est.sc_uint128_shift_leftMethod
sc_uint128_shift_left(input, shift_count, result)

Calculates the bit left shift of uint128_t input by shift_count bits. We shift in zeros from the right. If shift_count >= 128, result is 0. All bits left from the 127th bit (counted zero based from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a sc_uint128_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a sc_uint128_t. The left shifted number will be saved in result.

Prototype

void sc_uint128_shift_left (const sc_uint128_t * input, int shift_count, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_shift_rightMethod
sc_uint128_shift_right(input, shift_count, result)

Calculates the bit right shift of uint128_t input by shift_count bits. We shift in zeros from the left. If shift_count >= 128, result is 0. All bits right from the zeroth bit (counted from the right hand side) drop out. input == result is allowed.

Parameters

  • input:[in] A pointer to a sc_uint128_t.
  • shift_count:[in] Bits to shift. shift_count >= 0.
  • result:[in,out] A pointer to a sc_uint128_t. The right shifted number will be saved in result.

Prototype

void sc_uint128_shift_right (const sc_uint128_t * input, int shift_count, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_subMethod
sc_uint128_sub(a, b, result)

Subtracts the uint128_t b from the uint128_t a. This function assumes that the result is >= 0. result == a or result == b is not allowed. a == b is allowed.

Parameters

Prototype

void sc_uint128_sub (const sc_uint128_t * a, const sc_uint128_t * b, sc_uint128_t * result);
source
P4est.LibP4est.sc_uint128_sub_inplaceMethod
sc_uint128_sub_inplace(a, b)

Subtracts the uint128_t b from the uint128_t a. The result is saved in a. a == b is allowed. This function assumes that the result is >= 0.

Parameters

Prototype

void sc_uint128_sub_inplace (sc_uint128_t * a, const sc_uint128_t * b);
source
P4est.LibP4est.sc_versionMethod
sc_version()

Return the full version of libsc.

Returns

Return the version of libsc using the format VERSION\_MAJOR.VERSION\_MINOR.VERSION\_POINT, where VERSION_POINT can contain dots and characters, e.g. to indicate the additional number of commits and a git commit hash.

Prototype

const char *sc_version (void);
source
P4est.LibP4est.sc_vtk_write_binaryMethod
sc_vtk_write_binary(vtkfile, numeric_data, byte_length)

This function writes numeric binary data in VTK base64 encoding.

Parameters

  • vtkfile: Stream opened for writing.
  • numeric_data: A pointer to a numeric data array.
  • byte_length: The length of the data array in bytes.

Returns

Returns 0 on success, -1 on file error.

Prototype

int sc_vtk_write_binary (FILE * vtkfile, char *numeric_data, size_t byte_length);
source
P4est.LibP4est.sc_vtk_write_compressedMethod
sc_vtk_write_compressed(vtkfile, numeric_data, byte_length)

This function writes numeric binary data in VTK compressed format.

Parameters

  • vtkfile: Stream opened for writing.
  • numeric_data: A pointer to a numeric data array.
  • byte_length: The length of the data array in bytes.

Returns

Returns 0 on success, -1 on file error.

Prototype

int sc_vtk_write_compressed (FILE * vtkfile, char *numeric_data, size_t byte_length);
source
diff --git a/dev/troubleshooting/index.html b/dev/troubleshooting/index.html index 88862a8..6a560d8 100644 --- a/dev/troubleshooting/index.html +++ b/dev/troubleshooting/index.html @@ -5,4 +5,4 @@ let catch_signals = 0, print_backtrace = 0, log_handler = C_NULL sc_init(MPI.COMM_WORLD, catch_signals, print_backtrace, log_handler, SC_LP_ERROR) -end +end