From eca021431a0c904eb2aedb6ed8d3d3a54a30a6c3 Mon Sep 17 00:00:00 2001 From: "Documenter.jl" Date: Wed, 1 May 2024 23:17:52 +0000 Subject: [PATCH] build based on 01c67b5 --- dev/.documenter-siteinfo.json | 2 +- dev/index.html | 72 ++++++++++++++++++----------------- dev/search_index.js | 2 +- 3 files changed, 40 insertions(+), 36 deletions(-) diff --git a/dev/.documenter-siteinfo.json b/dev/.documenter-siteinfo.json index 8364dae..cdc0772 100644 --- a/dev/.documenter-siteinfo.json +++ b/dev/.documenter-siteinfo.json @@ -1 +1 @@ -{"documenter":{"julia_version":"1.10.3","generation_timestamp":"2024-05-01T22:58:20","documenter_version":"1.4.0"}} \ No newline at end of file +{"documenter":{"julia_version":"1.10.3","generation_timestamp":"2024-05-01T23:17:49","documenter_version":"1.4.0"}} \ No newline at end of file diff --git a/dev/index.html b/dev/index.html index c6768a7..44f7bcc 100644 --- a/dev/index.html +++ b/dev/index.html @@ -12,34 +12,34 @@ kdtree::KDTree; use_nearest_n::Int=4, weighing::Function=(d) -> 1 / d, -) where {T <: Real}

Lowest level interpolation function. It takes a vector of property values and a KDTree defined over a 2D space with the same number of nodes as the property values. It returns a function that can be used to interpolate the property values at any point in the space.

source
interp(
+) where {T <: Real}

Lowest level interpolation function. It takes a vector of property values and a KDTree defined over a 2D space with the same number of nodes as the property values. It returns a function that can be used to interpolate the property values at any point in the space.

source
interp(
     y::Vector{T},
     TPS_mats::Tuple{Matrix{U}, Matrix{U}, Matrix{U}, Vector{Tuple{U, U}}},
-) where {T <: Real, U <: Real}

Lowest level function for Thin Plate Spline method

source
interp(y::Vector{T}, x::Vector{Tuple{U, U}}) where {T <: Real, U <: Real}

Thin plate smoothing interpolation function for a 2d space scalar function. The algorithm has been adopted from:

http://www.geometrictools.com/Documentation/ThinPlateSplines.pdf

This is an implementation of Euler-Lagrange equation for minimizing bending energy of a surface.

source
interp(
+) where {T <: Real, U <: Real}

Lowest level function for Thin Plate Spline method

source
interp(y::Vector{T}, x::Vector{Tuple{U, U}}) where {T <: Real, U <: Real}

Thin plate smoothing interpolation function for a 2d space scalar function. The algorithm has been adopted from:

http://www.geometrictools.com/Documentation/ThinPlateSplines.pdf

This is an implementation of Euler-Lagrange equation for minimizing bending energy of a surface.

source
interp(
     prop_values::Vector{T},
     space::IMASDD.edge_profiles__grid_ggd___space
-) where {T <: Real}

If the whole space is provided instead of a kdtree, calculate the kdtree for whole space. Again, here it is assumed that the property values are porvided for each node of the space.

source
interp(
+) where {T <: Real}

If the whole space is provided instead of a kdtree, calculate the kdtree for whole space. Again, here it is assumed that the property values are porvided for each node of the space.

source
interp(
     prop_values::Vector{Real},
     space::IMASDD.edge_profiles__grid_ggd___space,
     subset::IMASDD.edge_profiles__grid_ggd___grid_subset
-)

If a subset of the space is provided, calculate the kdtree for the subset. In this case it is assumed that the property values are provided for each element of the subset.

source
interp(
+)

If a subset of the space is provided, calculate the kdtree for the subset. In this case it is assumed that the property values are provided for each element of the subset.

source
interp(
     prop::edge_profiles__prop_on_subset,
     grid_ggd::IMASDD.edge_profiles__grid_ggd,
     value_field::Symbol=:values
 )

Example:

grid_ggd = dd.edge_profiles.grid_ggd[1]
 get_electron_density = interp(dd.edge_profiles.ggd[1].electrons.density[1], grid_ggd)
-get_e_field_par = interp(dd.edge_profiles.ggd[1].e_field[1], grid_ggd, :parallel)
source
interp(
+get_e_field_par = interp(dd.edge_profiles.ggd[1].e_field[1], grid_ggd, :parallel)
source
interp(
     prop_arr::AbstractVector{T},
     space::IMASDD.edge_profiles__grid_ggd___space,
     subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
     value_field::Symbol=:values
 ) where {T <: edge_profiles__prop_on_subset}

Example:

sol = get_grid_subset_with_index(dd.edge_profiles.grid_ggd[1], 23)
-get_electron_density = interp(dd.edge_profiles.ggd[1].electrons.density, space, sol)
source
interp(
+get_electron_density = interp(dd.edge_profiles.ggd[1].electrons.density, space, sol)
source
interp(
     prop_arr::AbstractVector{T},
     grid_ggd::IMASDD.edge_profiles__grid_ggd,
     grid_subset_index::Int,
     value_field::Symbol=:values
-) where {T <: edge_profiles__prop_on_subset}

Example:

get_n_e_sep = interp(dd.edge_profiles.ggd[1].electrons.density, grid_ggd, 16)
source
interp(
+) where {T <: edge_profiles__prop_on_subset}

Example:

get_n_e_sep = interp(dd.edge_profiles.ggd[1].electrons.density, grid_ggd, 16)
source
interp(
     prop_arr::AbstractVector{T},
     TPS_mats::Tuple{Matrix{U}, Matrix{U}, Matrix{U}, Vector{Tuple{U, U}}},
     grid_subset_index::Int,
@@ -49,69 +49,69 @@
 for it ∈ eachindex(dd.edge_profiles.ggd)
     get_n_e = interp(dd.edge_profiles.ggd[it].electrons.density, TPS_mat_sep, 5)
     println("This time step has n_e at (0, 0) = ", get_n_e(0, 0))
-end

This will run faster as heavy matrix calculations will happen only once.

source
interp(eqt::IMASDD.equilibrium__time_slice)

For a given equilibrium time slice, return a function that can be used to interpolate from (r, z) space to rho (normalized toroidal flux coordinate)space.

Example:

rz2rho = interp(dd.equilibrium.time_slice[1])
-rho = rz2rho.([(r, z) for r ∈ 3.0:0.01:9.0, z ∈ -5.0:0.01:5.0])
source
interp(
+end

This will run faster as heavy matrix calculations will happen only once.

source
interp(eqt::IMASDD.equilibrium__time_slice)

For a given equilibrium time slice, return a function that can be used to interpolate from (r, z) space to rho (normalized toroidal flux coordinate)space.

Example:

rz2rho = interp(dd.equilibrium.time_slice[1])
+rho = rz2rho.([(r, z) for r ∈ 3.0:0.01:9.0, z ∈ -5.0:0.01:5.0])
source
interp(
     prop::Vector{T},
     prof::IMASDD.core_profiles__profiles_1d,
 ) where {T <: Real}

Returns an inteprolation function for the core profile property values defined on normalized toroidal flux coordinate rho.

Example:

core_profile_n_e = dd.core_profiles.profiles_1d[1].electrons.density
 get_n_e = interp(core_profile_n_e, dd.core_profiles.profiles_1d[1])
-get_n_e(1) # Returns electron density at rho = 1 (separatix)
source
interp(
+get_n_e(1) # Returns electron density at rho = 1 (separatix)
source
interp(
     prop::Vector{T},
     prof::IMASDD.core_profiles__profiles_1d,
     rz2rho::Function,
 )

Returns an inteprolation function in (R, Z) domain for the core profile property values defined on normalized toroidal flux coordinate rho and with a provided function to convert (R,Z) to rho.

Example:

rz2rho = interp(dd.equilibrium.time_slice[1])
 core_profile_n_e = dd.core_profiles.profiles_1d[1].electrons.density
 get_n_e = interp(core_profile_n_e, dd.core_profiles.profiles_1d[1], rz2rho)
-get_n_e(5.0, 3.5) # Returns electron density at (R, Z) = (5.0, 3.5)
source
interp(
+get_n_e(5.0, 3.5) # Returns electron density at (R, Z) = (5.0, 3.5)
source
interp(
     prop::Vector{T},
     prof::IMASDD.core_profiles__profiles_1d,
     eqt::IMASDD.equilibrium__time_slice,
 ) where {T <: Real}

Returns an inteprolation function in (R, Z) domain for the core profile property values defined on normalized toroidal flux coordinate rho and with a provided equilibrium time slice to get (R, Z) to rho conversion.

Example:

eqt = dd.equilibrium.time_slice[1]
 core_profile_n_e = dd.core_profiles.profiles_1d[1].electrons.density
 get_n_e = interp(core_profile_n_e, dd.core_profiles.profiles_1d[1], eqt)
-get_n_e(5.0, 3.5) # Returns electron density at (R, Z) = (5.0, 3.5)
source
GGDUtils.get_TPS_matsFunction
get_TPS_mats(x::Vector{Tuple{U, U}}) where {U <: Real}

We can separate matrix operations of thin plate spline method to utilize the calculation for itnerpolating over same space. Similar to the idea of reusing KDTree like above.

source
GGDUtils.get_kdtreeFunction
get_kdtree(space::IMASDD.edge_profiles__grid_ggd___space)

Get a KDTree for all the cells in the space for search for nearest neighbours.

source
get_kdtree(
+get_n_e(5.0, 3.5) # Returns electron density at (R, Z) = (5.0, 3.5)
source
GGDUtils.get_TPS_matsFunction
get_TPS_mats(x::Vector{Tuple{U, U}}) where {U <: Real}

We can separate matrix operations of thin plate spline method to utilize the calculation for itnerpolating over same space. Similar to the idea of reusing KDTree like above.

source
GGDUtils.get_kdtreeFunction
get_kdtree(space::IMASDD.edge_profiles__grid_ggd___space)

Get a KDTree for all the cells in the space for search for nearest neighbours.

source
get_kdtree(
     space::IMASDD.edge_profiles__grid_ggd___space,
     subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
-)

Get a KDTree for a subset of the space for search for nearest neighbours.

source

Subset Tools

GGDUtils.add_subset_element!Function
add_subset_element!(
+)

Get a KDTree for a subset of the space for search for nearest neighbours.

source

Subset Tools

GGDUtils.add_subset_element!Function
add_subset_element!(
     subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
     sn::Int,
     dim::Int,
     index::Int,
     in_subset=(x...) -> true;
     kwargs...,
-)

Adds a new element to girdsubset with properties space number (sn), dimension (dim), and index (index). The element is added only if the function insubset returns true.

source
add_subset_element!(
+)

Adds a new element to girdsubset with properties space number (sn), dimension (dim), and index (index). The element is added only if the function insubset returns true.

source
add_subset_element!(
     subset,
     sn,
     dim,
     index::Vector{Int},
     in_subset=(x...) -> true;
     kwargs...,
-)

Overloaded to work differently (faster) with list of indices to be added.

source
GGDUtils.get_subset_spaceFunction
get_subset_space(
+)

Overloaded to work differently (faster) with list of indices to be added.

source
GGDUtils.get_subset_spaceFunction
get_subset_space(
     space::IMASDD.edge_profiles__grid_ggd___space,
     elements::AbstractVector{<:IMASDD.edge_profiles__grid_ggd___grid_subset___element}
-)

Returns an array of space object indices corresponding to the correct objectsperdimension (nodes, edges or cells) for the subset elements.

source
GGDUtils.get_grid_subsetFunction
get_grid_subset(
+)

Returns an array of space object indices corresponding to the correct objectsperdimension (nodes, edges or cells) for the subset elements.

source
GGDUtils.get_grid_subsetFunction
get_grid_subset(
     grid_ggd::IMASDD.edge_profiles__grid_ggd,
     grid_subset_index::Int,
-)

Returns the gridsubset in a gridggd with the matching gridsubsetindex

source
get_grid_subset(
+)

Returns the gridsubset in a gridggd with the matching gridsubsetindex

source
get_grid_subset(
     grid_ggd::IMASDD.edge_profiles__grid_ggd,
     grid_subset_name::String,
-)

Returns the gridsubset in a gridggd with the matching gridsubsetname

source
GGDUtils.get_subset_boundary_indsFunction
get_subset_boundary_inds(
+)

Returns the gridsubset in a gridggd with the matching gridsubsetname

source
GGDUtils.get_subset_boundary_indsFunction
get_subset_boundary_inds(
     space::IMASDD.edge_profiles__grid_ggd___space,
     subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
-)

Returns an array of space object indices corresponding to the boundary of the subset. That means, it returns indices of nodes that are at the end of open edge subset or it returns the indices of edges that are the the boundary of a cell subset. Returns an empty array if the subset is 1D (nodes).

source
GGDUtils.get_subset_boundaryFunction
get_subset_boundary(
+)

Returns an array of space object indices corresponding to the boundary of the subset. That means, it returns indices of nodes that are at the end of open edge subset or it returns the indices of edges that are the the boundary of a cell subset. Returns an empty array if the subset is 1D (nodes).

source
GGDUtils.get_subset_boundaryFunction
get_subset_boundary(
     space::IMASDD.edge_profiles__grid_ggd___space,
     subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
-)

Returns an array of elements of grid_subset generated from the boundary of the subset provided. The dimension of these elments is reduced by 1.

source
GGDUtils.subset_doFunction
subset_do(
+)

Returns an array of elements of grid_subset generated from the boundary of the subset provided. The dimension of these elments is reduced by 1.

source
GGDUtils.subset_doFunction
subset_do(
     set_operator,
     itrs::Vararg{
         AbstractVector{<:IMASDD.edge_profiles__grid_ggd___grid_subset___element},
     };
     space::IMASDD.edge_profiles__grid_ggd___space=IMASDD.edge_profiles__grid_ggd___space(),
     use_nodes=false
-)

Function to perform any set operation (intersect, union, setdiff etc.) on subset.element to generate a list of elements to go to subset object. If usenodes is true, the set operation will be applied on the set of nodes from subset.element, space argument is required for this. Note: that the arguments are subset.element (not the subset itself). Similarly, the return object is a list of IMASDD.edgeprofiles__gridggd___gridsubset___element.

source
GGDUtils.get_subset_centersFunction
get_subset_centers(
+)

Function to perform any set operation (intersect, union, setdiff etc.) on subset.element to generate a list of elements to go to subset object. If usenodes is true, the set operation will be applied on the set of nodes from subset.element, space argument is required for this. Note: that the arguments are subset.element (not the subset itself). Similarly, the return object is a list of IMASDD.edgeprofiles__gridggd___gridsubset___element.

source
GGDUtils.get_subset_centersFunction
get_subset_centers(
     space::IMASDD.edge_profiles__grid_ggd___space,
     subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
-)

Returns an array of tuples corresponding to (r,z) coordinates of the center of cells or the center of edges in the subset space.

source
GGDUtils.project_prop_on_subset!Function
project_prop_on_subset!(
+)

Returns an array of tuples corresponding to (r,z) coordinates of the center of cells or the center of edges in the subset space.

source
GGDUtils.project_prop_on_subset!Function
project_prop_on_subset!(
     prop_arr::AbstractVector{T},
     from_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
     to_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
@@ -121,37 +121,41 @@
         Nothing,
         Tuple{Matrix{U}, Matrix{U}, Matrix{U}, Vector{Tuple{U, U}}},
     }=nothing,
-) where {T <: edge_profiles__prop_on_subset, U <: Real}

This function can be used to add another instance on a property vector representing the value in a new subset that can be taken as a projection from an existing larger subset.

Input Arguments:

  • prop: A property like electrons.density that is a vector of objects with fields coefficients, gridindex, gridsubsetindex, and values. The different instances in the vector correspond to different gridsubset for which the property is provided.
  • fromsubset: gridsubset object which is already represented in the property instance. grid subset with index 5 is populated in electrons.density already if the values for all cells are present.
  • tosubset: gridsubset which is either a smaller part of fromsubset (core, sol, idr, odr) but has same dimensions as fromsubset OR is smaller in dimension that goes through the fromsubset (coreboundary, separatix etc.)
  • space: (optional) space object in gridggd is required only when fromsubset is higher dimensional than to_subset.

Returns: NOTE: This function ends in ! which means it updates prop argument in place. But for the additional utility, this function also returns a tuple (tosubsetcenters, topropvalues) when fromsubset dimension is greater than tosubset dimension OR (tosubseteleobjinds, topropvalues) when fromsubset dimension is same as tosubset dimension)

Descriptions: tosubsetcenters: center of cells or center of edges of the tosubset where property values are defined and stored tosubseteleobjinds: Indices of the elements of tosubset where property values are defined and stored topropvalues: The projected values of the properties added to prop object in a new instance

source
project_prop_on_subset!(
+) where {T <: edge_profiles__prop_on_subset, U <: Real}

This function can be used to add another instance on a property vector representing the value in a new subset that can be taken as a projection from an existing larger subset.

Input Arguments:

  • prop: A property like electrons.density that is a vector of objects with fields coefficients, gridindex, gridsubsetindex, and values. The different instances in the vector correspond to different gridsubset for which the property is provided.
  • fromsubset: gridsubset object which is already represented in the property instance. grid subset with index 5 is populated in electrons.density already if the values for all cells are present.
  • tosubset: gridsubset which is either a smaller part of fromsubset (core, sol, idr, odr) but has same dimensions as fromsubset OR is smaller in dimension that goes through the fromsubset (coreboundary, separatix etc.)
  • space: (optional) space object in gridggd is required only when fromsubset is higher dimensional than to_subset.

Returns: NOTE: This function ends in ! which means it updates prop argument in place. But for the additional utility, this function also returns a tuple (tosubsetcenters, topropvalues) when fromsubset dimension is greater than tosubset dimension OR (tosubseteleobjinds, topropvalues) when fromsubset dimension is same as tosubset dimension)

Descriptions: tosubsetcenters: center of cells or center of edges of the tosubset where property values are defined and stored tosubseteleobjinds: Indices of the elements of tosubset where property values are defined and stored topropvalues: The projected values of the properties added to prop object in a new instance

source
project_prop_on_subset!(
     prop_arr::AbstractVector{T},
     from_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
     to_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
     value_field::Symbol=:values,
-) where {T <: edge_profiles__prop_on_subset}

If the dimensions of fromsubset and tosubset are the same, this function can be used to add another instance on a property vector representing the value in tosubset without any interpolation or use of space object. The function returns a tuple of indices of elements of tosubset and the values of the property in to_subset.

source
GGDUtils.deepcopy_subsetFunction
deepcopy_subset(subset::IMASDD.edge_profiles__grid_ggd___grid_subset)

Faster deepcopy function for gridsubset object. This function is used to create a deep copy of a gridsubset object bypassing several checks performed by IMASDD.

source
Base.:∈Function
Base.:∈(
+) where {T <: edge_profiles__prop_on_subset}

If the dimensions of fromsubset and tosubset are the same, this function can be used to add another instance on a property vector representing the value in tosubset without any interpolation or use of space object. The function returns a tuple of indices of elements of tosubset and the values of the property in to_subset.

source
GGDUtils.deepcopy_subsetFunction
deepcopy_subset(subset::IMASDD.edge_profiles__grid_ggd___grid_subset)

Faster deepcopy function for gridsubset object. This function is used to create a deep copy of a gridsubset object bypassing several checks performed by IMASDD.

source
Base.:∈Function
Base.:∈(
     point::Tuple{Real, Real},
     subset_of_space::Tuple{
         IMASDD.edge_profiles__grid_ggd___grid_subset,
         IMASDD.edge_profiles__grid_ggd___space,
     },
-)

Overloading ∈ operator to check if a point is inside a subset of space.

If the subset is 1-dimensional, all points are searched. If the subset is 2-dimensional, it is checked if the point is within the enclosed area. It is assumed that a 2-dimensional subset used in such a context will form a closed area. If the subset is 3-dimensional, its boundary is calculated on the fly. If used multiple times, it is recommended to calculate the boundary once and store it in a variable.

source
GGDUtils.get_prop_with_grid_subset_indexFunction
get_prop_with_grid_subset_index(
+)

Overloading ∈ operator to check if a point is inside a subset of space.

If the subset is 1-dimensional, all points are searched. If the subset is 2-dimensional, it is checked if the point is within the enclosed area. It is assumed that a 2-dimensional subset used in such a context will form a closed area. If the subset is 3-dimensional, its boundary is calculated on the fly. If used multiple times, it is recommended to calculate the boundary once and store it in a variable.

Example:

if (5.5, 0.0) ∈ (subset_sol, space)
+    println("Point (5.5, 0.0) is inside the SOL subset.")
+else
+    println("Point (5.5, 0.0) is outside the SOL subset.")
+end
source
GGDUtils.get_prop_with_grid_subset_indexFunction
get_prop_with_grid_subset_index(
     prop::AbstractVector{T},
     grid_subset_index::Int,
-) where {T <: edge_profiles__prop_on_subset}

Find the edgeprofiles property instance in an array of properties that corresponds to the gridsubset_index provided.

source

Types

GGDUtils.get_types_withFunction
get_types_with(parent::Type, field::Symbol)

A type creation utility meant for searching types in IMAS database. This function returns a list of types that are fields at any level below the parent data type which have a particular field present in it.

Example:

get_types_with(IMASDD.edge_profiles, :grid_subset_index)

returns all edgeprofiles types that have a subfield named gridsubset_index.

source

Plot recipes

Several plot recipes have been defined for easy visualization.

RecipesBase.apply_recipeMethod
plot(space::IMASDD.edge_profiles__grid_ggd___space)

Plot the grid_ggd space object. Defaults to size of [600, 900] and linecolor of :black, linewidth of 0.2, and no legend.

source
RecipesBase.apply_recipeMethod
plot(
+) where {T <: edge_profiles__prop_on_subset}

Find the edgeprofiles property instance in an array of properties that corresponds to the gridsubset_index provided.

source

Types

GGDUtils.get_types_withFunction
get_types_with(parent::Type, field::Symbol)

A type creation utility meant for searching types in IMAS database. This function returns a list of types that are fields at any level below the parent data type which have a particular field present in it.

Example:

get_types_with(IMASDD.edge_profiles, :grid_subset_index)

returns all edgeprofiles types that have a subfield named gridsubset_index.

source

Plot recipes

Several plot recipes have been defined for easy visualization.

RecipesBase.apply_recipeMethod
plot(space::IMASDD.edge_profiles__grid_ggd___space)

Plot the grid_ggd space object. Defaults to size of [600, 900] and linecolor of :black, linewidth of 0.2, and no legend.

source
RecipesBase.apply_recipeMethod
plot(
     space::IMASDD.edge_profiles__grid_ggd___space,
     subset::IMASDD.edge_profiles__grid_ggd___grid_subset,
-)

Plot the a subset of a space. Defaults to size of [600, 900] and linecolor of :black, linewidth of 0.2, and no legend.

source
RecipesBase.apply_recipeMethod
plot(
+)

Plot the a subset of a space. Defaults to size of [600, 900] and linecolor of :black, linewidth of 0.2, and no legend.

source
RecipesBase.apply_recipeMethod
plot(
     grid_ggd::IMASDD.edge_profiles__grid_ggd,
     prop::IMASDD.IDSvectorElement,
-)

Plot 2D heatmap of edgeprofilesggd property on a gridggd space object. Defaults to size of [635, 900], xaxis of "R / m", yaxis of "Z / m", and no legend. If :seriescolor is not provided, :inferno color scheme is used. If :colorbartitle is not provided, the property name is used. This function creates a plot with layout [a{0.95w} b] where a is the heatmap and b is the colorbar.

source
RecipesBase.apply_recipeMethod
plot(
+)

Plot 2D heatmap of edgeprofilesggd property on a gridggd space object. Defaults to size of [635, 900], xaxis of "R / m", yaxis of "Z / m", and no legend. If :seriescolor is not provided, :inferno color scheme is used. If :colorbartitle is not provided, the property name is used. This function creates a plot with layout [a{0.95w} b] where a is the heatmap and b is the colorbar.

source
RecipesBase.apply_recipeMethod
plot(
     grid_ggd_arr::AbstractVector{<:IMASDD.edge_profiles__grid_ggd},
     prop::IMASDD.IDSvectorElement,
-)

Plot 2D heatmap of edgeprofilesggd property on a gridggd space object. Defaults to size of [635, 900], xaxis of "R / m", yaxis of "Z / m", and no legend. If :seriescolor is not provided, :inferno color scheme is used. If :colorbartitle is not provided, the property name is used. This function creates a plot with layout [a{0.95w} b] where a is the heatmap and b is the colorbar.

source
RecipesBase.apply_recipeMethod
plot(
+)

Plot 2D heatmap of edgeprofilesggd property on a gridggd space object. Defaults to size of [635, 900], xaxis of "R / m", yaxis of "Z / m", and no legend. If :seriescolor is not provided, :inferno color scheme is used. If :colorbartitle is not provided, the property name is used. This function creates a plot with layout [a{0.95w} b] where a is the heatmap and b is the colorbar.

source
RecipesBase.apply_recipeMethod
plot(
     ifo::IMASDD.interferometer,
-)

Plot all the channels of interferometer object. Optional keywords:

  • :plottype: :los(default), :ne, or :neaverage. :los plots the line of sight of the channel in a 2D plot, :ne plots the integrated ne along the line of sight vs time, and :neaverage plots the average n_e vs time.
  • :mirror: true(default) or false.
  • :mirror_length: 0.5(default).
  • :mirror_thickness: 0.1(default).
source
RecipesBase.apply_recipeMethod
plot(
+)

Plot all the channels of interferometer object. Optional keywords:

  • :plottype: :los(default), :ne, or :neaverage. :los plots the line of sight of the channel in a 2D plot, :ne plots the integrated ne along the line of sight vs time, and :neaverage plots the average n_e vs time.
  • :mirror: true(default) or false.
  • :mirror_length: 0.5(default).
  • :mirror_thickness: 0.1(default).
source
RecipesBase.apply_recipeMethod
plot(
     ifo_ch::IMASDD.interferometer__channel,
-)

Plot individual channel of interferometer. Optional keywords:

  • :plottype: :los(default), :ne, or :neaverage. :los plots the line of sight of the channel in a 2D plot, :ne plots the integrated ne along the line of sight vs time, and :neaverage plots the average n_e vs time.
  • :mirror: true(default) or false.
  • :mirror_length: 0.5(default).
  • :mirror_thickness: 0.1(default).
source
RecipesBase.apply_recipeMethod
plot(
+)

Plot individual channel of interferometer. Optional keywords:

  • :plottype: :los(default), :ne, or :neaverage. :los plots the line of sight of the channel in a 2D plot, :ne plots the integrated ne along the line of sight vs time, and :neaverage plots the average n_e vs time.
  • :mirror: true(default) or false.
  • :mirror_length: 0.5(default).
  • :mirror_thickness: 0.1(default).
source
RecipesBase.apply_recipeMethod
plot(
     ifo_ch_los::IMASDD.interferometer__channel___line_of_sight,
-)

Plot line of sight of a channel of interferometer.

Default plot settings:

  • subplot: 1
  • size: [600, 900]
  • xaxis: "R / m"
  • yaxis: "Z / m"

Optional keywords:

  • :mirror: true(default) or false.
  • :mirror_length: 0.5(default).
  • :mirror_thickness: 0.1(default).
source
RecipesBase.apply_recipeMethod
plot(
+)

Plot line of sight of a channel of interferometer.

Default plot settings:

  • subplot: 1
  • size: [600, 900]
  • xaxis: "R / m"
  • yaxis: "Z / m"

Optional keywords:

  • :mirror: true(default) or false.
  • :mirror_length: 0.5(default).
  • :mirror_thickness: 0.1(default).
source
RecipesBase.apply_recipeMethod
plot(
     ifo_ch_n_e_line::IMASDD.interferometer__channel___n_e_line,
-)

Plot line integrated electron density of a channel of interferometer.

Default plot settings:

  • subplot: 1
  • xaxis: "time / s"
  • yaxis: "Integerated n_e / m^-2"

Optional keywords:

  • :average: true or false(default). If true, plot the average n_e vs time.
source
RecipesBase.apply_recipeMethod
plot(
+)

Plot line integrated electron density of a channel of interferometer.

Default plot settings:

  • subplot: 1
  • xaxis: "time / s"
  • yaxis: "Integerated n_e / m^-2"

Optional keywords:

  • :average: true or false(default). If true, plot the average n_e vs time.
source
RecipesBase.apply_recipeMethod
plot(
     ifo_ch_n_e_line_average::IMASDD.interferometer__channel___n_e_line_average,
-)

Plot average electron density of a channel of interferometer.

Default plot settings:

  • subplot: 1
  • xaxis: "time / s"
  • yaxis: "Average n_e / m^-3"
source
+)

Plot average electron density of a channel of interferometer.

Default plot settings:

source diff --git a/dev/search_index.js b/dev/search_index.js index 35be924..5ebb281 100644 --- a/dev/search_index.js +++ b/dev/search_index.js @@ -1,3 +1,3 @@ var documenterSearchIndex = {"docs": -[{"location":"#GGDUtils.jl","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Pages = [\"index.md\"]\nDepth = 5","category":"page"},{"location":"#Installation","page":"GGDUtils.jl","title":"Installation","text":"","category":"section"},{"location":"#Using-make:","page":"GGDUtils.jl","title":"Using make:","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"After cloning this repo, check the make menu:","category":"page"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"GGDUtils.jl % make help\nHelp Menu\n\nmake env_with_cloned_repo (or make r): Creates a Julia environment with the cloned repositories\nmake env_with_git_url (or make u): Creates a Julia environment with the git urls without creating local clones\nmake clean: Deletes Project.toml and Manifest.toml for a fresh start","category":"page"},{"location":"#make-r","page":"GGDUtils.jl","title":"make r","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"This option creates local copies of required private repositories at the same level as current repository and uses them in develop mode to create a Manifest.toml","category":"page"},{"location":"#make-u","page":"GGDUtils.jl","title":"make u","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"This option uses url of required private repositories to create a static Manifest.toml attached to current master branches of these repositories.","category":"page"},{"location":"#make-clean","page":"GGDUtils.jl","title":"make clean","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Deletes Manifest.toml so that environment can be recreated, to update or change the last used method.","category":"page"},{"location":"#Using-Julia-REPL-and-installing-using-Github-url","page":"GGDUtils.jl","title":"Using Julia REPL and installing using Github url","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Or, in julia REPL:","category":"page"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"julia> using Pkg;\njulia> Pkg.add(; url=\"https://github.com/ProjectTorreyPines/IMASDD.jl.git\");\njulia> Pkg.add(; url=\"https://github.com/ProjectTorreyPines/GGDUtils.jl.git\");\njulia> Pkg.instantiate()","category":"page"},{"location":"#Interpolations","page":"GGDUtils.jl","title":"Interpolations","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Several interpolation functions are available to create interpolaiton functions for data present in a GGD represented over a particular grid subset:","category":"page"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"interp\nget_TPS_mats\nget_kdtree","category":"page"},{"location":"#GGDUtils.interp","page":"GGDUtils.jl","title":"GGDUtils.interp","text":"interp(\n prop_values::Vector{T},\n kdtree::KDTree;\n use_nearest_n::Int=4,\n weighing::Function=(d) -> 1 / d,\n) where {T <: Real}\n\nLowest level interpolation function. It takes a vector of property values and a KDTree defined over a 2D space with the same number of nodes as the property values. It returns a function that can be used to interpolate the property values at any point in the space.\n\n\n\n\n\ninterp(\n y::Vector{T},\n TPS_mats::Tuple{Matrix{U}, Matrix{U}, Matrix{U}, Vector{Tuple{U, U}}},\n) where {T <: Real, U <: Real}\n\nLowest level function for Thin Plate Spline method\n\n\n\n\n\ninterp(y::Vector{T}, x::Vector{Tuple{U, U}}) where {T <: Real, U <: Real}\n\nThin plate smoothing interpolation function for a 2d space scalar function. The algorithm has been adopted from:\n\nhttp://www.geometrictools.com/Documentation/ThinPlateSplines.pdf\n\nThis is an implementation of Euler-Lagrange equation for minimizing bending energy of a surface.\n\n\n\n\n\ninterp(\n prop_values::Vector{T},\n space::IMASDD.edge_profiles__grid_ggd___space\n) where {T <: Real}\n\nIf the whole space is provided instead of a kdtree, calculate the kdtree for whole space. Again, here it is assumed that the property values are porvided for each node of the space.\n\n\n\n\n\ninterp(\n prop_values::Vector{Real},\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset\n)\n\nIf a subset of the space is provided, calculate the kdtree for the subset. In this case it is assumed that the property values are provided for each element of the subset.\n\n\n\n\n\ninterp(\n prop::edge_profiles__prop_on_subset,\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n value_field::Symbol=:values\n)\n\nExample:\n\ngrid_ggd = dd.edge_profiles.grid_ggd[1]\nget_electron_density = interp(dd.edge_profiles.ggd[1].electrons.density[1], grid_ggd)\nget_e_field_par = interp(dd.edge_profiles.ggd[1].e_field[1], grid_ggd, :parallel)\n\n\n\n\n\ninterp(\n prop_arr::AbstractVector{T},\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n value_field::Symbol=:values\n) where {T <: edge_profiles__prop_on_subset}\n\nExample:\n\nsol = get_grid_subset_with_index(dd.edge_profiles.grid_ggd[1], 23)\nget_electron_density = interp(dd.edge_profiles.ggd[1].electrons.density, space, sol)\n\n\n\n\n\ninterp(\n prop_arr::AbstractVector{T},\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n grid_subset_index::Int,\n value_field::Symbol=:values\n) where {T <: edge_profiles__prop_on_subset}\n\nExample:\n\nget_n_e_sep = interp(dd.edge_profiles.ggd[1].electrons.density, grid_ggd, 16)\n\n\n\n\n\ninterp(\n prop_arr::AbstractVector{T},\n TPS_mats::Tuple{Matrix{U}, Matrix{U}, Matrix{U}, Vector{Tuple{U, U}}},\n grid_subset_index::Int,\n value_field::Val{V}=Val(:values),\n) where {T <: edge_profiles__prop_on_subset, U <: Real, V}\n\nSame use case as above but allows one to reuse previously calculated TPS matrices.\n\nExample:\n\nTPS_mat = get_TPS_mats(dd.edge_profiles.grid_ggd[1], 5);\n\nfor it ∈ eachindex(dd.edge_profiles.ggd)\n get_n_e = interp(dd.edge_profiles.ggd[it].electrons.density, TPS_mat_sep, 5)\n println(\"This time step has n_e at (0, 0) = \", get_n_e(0, 0))\nend\n\nThis will run faster as heavy matrix calculations will happen only once.\n\n\n\n\n\ninterp(eqt::IMASDD.equilibrium__time_slice)\n\nFor a given equilibrium time slice, return a function that can be used to interpolate from (r, z) space to rho (normalized toroidal flux coordinate)space.\n\nExample:\n\nrz2rho = interp(dd.equilibrium.time_slice[1])\nrho = rz2rho.([(r, z) for r ∈ 3.0:0.01:9.0, z ∈ -5.0:0.01:5.0])\n\n\n\n\n\ninterp(\n prop::Vector{T},\n prof::IMASDD.core_profiles__profiles_1d,\n) where {T <: Real}\n\nReturns an inteprolation function for the core profile property values defined on normalized toroidal flux coordinate rho.\n\nExample:\n\ncore_profile_n_e = dd.core_profiles.profiles_1d[1].electrons.density\nget_n_e = interp(core_profile_n_e, dd.core_profiles.profiles_1d[1])\nget_n_e(1) # Returns electron density at rho = 1 (separatix)\n\n\n\n\n\ninterp(\n prop::Vector{T},\n prof::IMASDD.core_profiles__profiles_1d,\n rz2rho::Function,\n)\n\nReturns an inteprolation function in (R, Z) domain for the core profile property values defined on normalized toroidal flux coordinate rho and with a provided function to convert (R,Z) to rho.\n\nExample:\n\nrz2rho = interp(dd.equilibrium.time_slice[1])\ncore_profile_n_e = dd.core_profiles.profiles_1d[1].electrons.density\nget_n_e = interp(core_profile_n_e, dd.core_profiles.profiles_1d[1], rz2rho)\nget_n_e(5.0, 3.5) # Returns electron density at (R, Z) = (5.0, 3.5)\n\n\n\n\n\ninterp(\n prop::Vector{T},\n prof::IMASDD.core_profiles__profiles_1d,\n eqt::IMASDD.equilibrium__time_slice,\n) where {T <: Real}\n\nReturns an inteprolation function in (R, Z) domain for the core profile property values defined on normalized toroidal flux coordinate rho and with a provided equilibrium time slice to get (R, Z) to rho conversion.\n\nExample:\n\neqt = dd.equilibrium.time_slice[1]\ncore_profile_n_e = dd.core_profiles.profiles_1d[1].electrons.density\nget_n_e = interp(core_profile_n_e, dd.core_profiles.profiles_1d[1], eqt)\nget_n_e(5.0, 3.5) # Returns electron density at (R, Z) = (5.0, 3.5)\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_TPS_mats","page":"GGDUtils.jl","title":"GGDUtils.get_TPS_mats","text":"get_TPS_mats(x::Vector{Tuple{U, U}}) where {U <: Real}\n\nWe can separate matrix operations of thin plate spline method to utilize the calculation for itnerpolating over same space. Similar to the idea of reusing KDTree like above.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_kdtree","page":"GGDUtils.jl","title":"GGDUtils.get_kdtree","text":"get_kdtree(space::IMASDD.edge_profiles__grid_ggd___space)\n\nGet a KDTree for all the cells in the space for search for nearest neighbours.\n\n\n\n\n\nget_kdtree(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nGet a KDTree for a subset of the space for search for nearest neighbours.\n\n\n\n\n\n","category":"function"},{"location":"#Subset-Tools","page":"GGDUtils.jl","title":"Subset Tools","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"add_subset_element!\nget_subset_space\nget_grid_subset\nget_subset_boundary_inds\nget_subset_boundary\nsubset_do\nget_subset_centers\nproject_prop_on_subset!\ndeepcopy_subset\nBase.:∈\nget_prop_with_grid_subset_index","category":"page"},{"location":"#GGDUtils.add_subset_element!","page":"GGDUtils.jl","title":"GGDUtils.add_subset_element!","text":"add_subset_element!(\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n sn::Int,\n dim::Int,\n index::Int,\n in_subset=(x...) -> true;\n kwargs...,\n)\n\nAdds a new element to girdsubset with properties space number (sn), dimension (dim), and index (index). The element is added only if the function insubset returns true.\n\n\n\n\n\nadd_subset_element!(\n subset,\n sn,\n dim,\n index::Vector{Int},\n in_subset=(x...) -> true;\n kwargs...,\n)\n\nOverloaded to work differently (faster) with list of indices to be added.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_subset_space","page":"GGDUtils.jl","title":"GGDUtils.get_subset_space","text":"get_subset_space(\n space::IMASDD.edge_profiles__grid_ggd___space,\n elements::AbstractVector{<:IMASDD.edge_profiles__grid_ggd___grid_subset___element}\n)\n\nReturns an array of space object indices corresponding to the correct objectsperdimension (nodes, edges or cells) for the subset elements.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_grid_subset","page":"GGDUtils.jl","title":"GGDUtils.get_grid_subset","text":"get_grid_subset(\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n grid_subset_index::Int,\n)\n\nReturns the gridsubset in a gridggd with the matching gridsubsetindex\n\n\n\n\n\nget_grid_subset(\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n grid_subset_name::String,\n)\n\nReturns the gridsubset in a gridggd with the matching gridsubsetname\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_subset_boundary_inds","page":"GGDUtils.jl","title":"GGDUtils.get_subset_boundary_inds","text":"get_subset_boundary_inds(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nReturns an array of space object indices corresponding to the boundary of the subset. That means, it returns indices of nodes that are at the end of open edge subset or it returns the indices of edges that are the the boundary of a cell subset. Returns an empty array if the subset is 1D (nodes).\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_subset_boundary","page":"GGDUtils.jl","title":"GGDUtils.get_subset_boundary","text":"get_subset_boundary(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nReturns an array of elements of grid_subset generated from the boundary of the subset provided. The dimension of these elments is reduced by 1.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.subset_do","page":"GGDUtils.jl","title":"GGDUtils.subset_do","text":"subset_do(\n set_operator,\n itrs::Vararg{\n AbstractVector{<:IMASDD.edge_profiles__grid_ggd___grid_subset___element},\n };\n space::IMASDD.edge_profiles__grid_ggd___space=IMASDD.edge_profiles__grid_ggd___space(),\n use_nodes=false\n)\n\nFunction to perform any set operation (intersect, union, setdiff etc.) on subset.element to generate a list of elements to go to subset object. If usenodes is true, the set operation will be applied on the set of nodes from subset.element, space argument is required for this. Note: that the arguments are subset.element (not the subset itself). Similarly, the return object is a list of IMASDD.edgeprofiles__gridggd___gridsubset___element.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_subset_centers","page":"GGDUtils.jl","title":"GGDUtils.get_subset_centers","text":"get_subset_centers(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nReturns an array of tuples corresponding to (r,z) coordinates of the center of cells or the center of edges in the subset space.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.project_prop_on_subset!","page":"GGDUtils.jl","title":"GGDUtils.project_prop_on_subset!","text":"project_prop_on_subset!(\n prop_arr::AbstractVector{T},\n from_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n to_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n space::IMASDD.edge_profiles__grid_ggd___space,\n value_field::Symbol=:values;\n TPS_mats::Union{\n Nothing,\n Tuple{Matrix{U}, Matrix{U}, Matrix{U}, Vector{Tuple{U, U}}},\n }=nothing,\n) where {T <: edge_profiles__prop_on_subset, U <: Real}\n\nThis function can be used to add another instance on a property vector representing the value in a new subset that can be taken as a projection from an existing larger subset.\n\nInput Arguments:\n\nprop: A property like electrons.density that is a vector of objects with fields coefficients, gridindex, gridsubsetindex, and values. The different instances in the vector correspond to different gridsubset for which the property is provided.\nfromsubset: gridsubset object which is already represented in the property instance. grid subset with index 5 is populated in electrons.density already if the values for all cells are present.\ntosubset: gridsubset which is either a smaller part of fromsubset (core, sol, idr, odr) but has same dimensions as fromsubset OR is smaller in dimension that goes through the fromsubset (coreboundary, separatix etc.)\nspace: (optional) space object in gridggd is required only when fromsubset is higher dimensional than to_subset.\n\nReturns: NOTE: This function ends in ! which means it updates prop argument in place. But for the additional utility, this function also returns a tuple (tosubsetcenters, topropvalues) when fromsubset dimension is greater than tosubset dimension OR (tosubseteleobjinds, topropvalues) when fromsubset dimension is same as tosubset dimension)\n\nDescriptions: tosubsetcenters: center of cells or center of edges of the tosubset where property values are defined and stored tosubseteleobjinds: Indices of the elements of tosubset where property values are defined and stored topropvalues: The projected values of the properties added to prop object in a new instance\n\n\n\n\n\nproject_prop_on_subset!(\n prop_arr::AbstractVector{T},\n from_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n to_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n value_field::Symbol=:values,\n) where {T <: edge_profiles__prop_on_subset}\n\nIf the dimensions of fromsubset and tosubset are the same, this function can be used to add another instance on a property vector representing the value in tosubset without any interpolation or use of space object. The function returns a tuple of indices of elements of tosubset and the values of the property in to_subset.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.deepcopy_subset","page":"GGDUtils.jl","title":"GGDUtils.deepcopy_subset","text":"deepcopy_subset(subset::IMASDD.edge_profiles__grid_ggd___grid_subset)\n\nFaster deepcopy function for gridsubset object. This function is used to create a deep copy of a gridsubset object bypassing several checks performed by IMASDD.\n\n\n\n\n\n","category":"function"},{"location":"#Base.:∈","page":"GGDUtils.jl","title":"Base.:∈","text":"Base.:∈(\n point::Tuple{Real, Real},\n subset_of_space::Tuple{\n IMASDD.edge_profiles__grid_ggd___grid_subset,\n IMASDD.edge_profiles__grid_ggd___space,\n },\n)\n\nOverloading ∈ operator to check if a point is inside a subset of space.\n\nIf the subset is 1-dimensional, all points are searched. If the subset is 2-dimensional, it is checked if the point is within the enclosed area. It is assumed that a 2-dimensional subset used in such a context will form a closed area. If the subset is 3-dimensional, its boundary is calculated on the fly. If used multiple times, it is recommended to calculate the boundary once and store it in a variable.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_prop_with_grid_subset_index","page":"GGDUtils.jl","title":"GGDUtils.get_prop_with_grid_subset_index","text":"get_prop_with_grid_subset_index(\n prop::AbstractVector{T},\n grid_subset_index::Int,\n) where {T <: edge_profiles__prop_on_subset}\n\nFind the edgeprofiles property instance in an array of properties that corresponds to the gridsubset_index provided.\n\n\n\n\n\n","category":"function"},{"location":"#Types","page":"GGDUtils.jl","title":"Types","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"get_types_with","category":"page"},{"location":"#GGDUtils.get_types_with","page":"GGDUtils.jl","title":"GGDUtils.get_types_with","text":"get_types_with(parent::Type, field::Symbol)\n\nA type creation utility meant for searching types in IMAS database. This function returns a list of types that are fields at any level below the parent data type which have a particular field present in it.\n\nExample:\n\nget_types_with(IMASDD.edge_profiles, :grid_subset_index)\n\nreturns all edgeprofiles types that have a subfield named gridsubset_index.\n\n\n\n\n\n","category":"function"},{"location":"#Plot-recipes","page":"GGDUtils.jl","title":"Plot recipes","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Several plot recipes have been defined for easy visualization.","category":"page"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"RecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.edge_profiles__grid_ggd___space)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.edge_profiles__grid_ggd___space, ::GGDUtils.IMASDD.edge_profiles__grid_ggd___grid_subset)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.edge_profiles__grid_ggd, ::GGDUtils.IMASDD.IDSvectorElement)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::AbstractVector{<:GGDUtils.IMASDD.edge_profiles__grid_ggd}, ::GGDUtils.IMASDD.IDSvectorElement)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer__channel)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer__channel___line_of_sight)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer__channel___n_e_line)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer__channel___n_e_line_average)","category":"page"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.edge_profiles__grid_ggd___space}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(space::IMASDD.edge_profiles__grid_ggd___space)\n\nPlot the grid_ggd space object. Defaults to size of [600, 900] and linecolor of :black, linewidth of 0.2, and no legend.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.edge_profiles__grid_ggd___space, IMASDD.edge_profiles__grid_ggd___grid_subset}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nPlot the a subset of a space. Defaults to size of [600, 900] and linecolor of :black, linewidth of 0.2, and no legend.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.edge_profiles__grid_ggd, IMASDD.IDSvectorElement}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n prop::IMASDD.IDSvectorElement,\n)\n\nPlot 2D heatmap of edgeprofilesggd property on a gridggd space object. Defaults to size of [635, 900], xaxis of \"R / m\", yaxis of \"Z / m\", and no legend. If :seriescolor is not provided, :inferno color scheme is used. If :colorbartitle is not provided, the property name is used. This function creates a plot with layout [a{0.95w} b] where a is the heatmap and b is the colorbar.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, AbstractVector{<:IMASDD.edge_profiles__grid_ggd}, IMASDD.IDSvectorElement}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n grid_ggd_arr::AbstractVector{<:IMASDD.edge_profiles__grid_ggd},\n prop::IMASDD.IDSvectorElement,\n)\n\nPlot 2D heatmap of edgeprofilesggd property on a gridggd space object. Defaults to size of [635, 900], xaxis of \"R / m\", yaxis of \"Z / m\", and no legend. If :seriescolor is not provided, :inferno color scheme is used. If :colorbartitle is not provided, the property name is used. This function creates a plot with layout [a{0.95w} b] where a is the heatmap and b is the colorbar.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo::IMASDD.interferometer,\n)\n\nPlot all the channels of interferometer object. Optional keywords:\n\n:plottype: :los(default), :ne, or :neaverage. :los plots the line of sight of the channel in a 2D plot, :ne plots the integrated ne along the line of sight vs time, and :neaverage plots the average n_e vs time.\n:mirror: true(default) or false.\n:mirror_length: 0.5(default).\n:mirror_thickness: 0.1(default).\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer__channel}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo_ch::IMASDD.interferometer__channel,\n)\n\nPlot individual channel of interferometer. Optional keywords:\n\n:plottype: :los(default), :ne, or :neaverage. :los plots the line of sight of the channel in a 2D plot, :ne plots the integrated ne along the line of sight vs time, and :neaverage plots the average n_e vs time.\n:mirror: true(default) or false.\n:mirror_length: 0.5(default).\n:mirror_thickness: 0.1(default).\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer__channel___line_of_sight}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo_ch_los::IMASDD.interferometer__channel___line_of_sight,\n)\n\nPlot line of sight of a channel of interferometer.\n\nDefault plot settings:\n\nsubplot: 1\nsize: [600, 900]\nxaxis: \"R / m\"\nyaxis: \"Z / m\"\n\nOptional keywords:\n\n:mirror: true(default) or false.\n:mirror_length: 0.5(default).\n:mirror_thickness: 0.1(default).\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer__channel___n_e_line}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo_ch_n_e_line::IMASDD.interferometer__channel___n_e_line,\n)\n\nPlot line integrated electron density of a channel of interferometer.\n\nDefault plot settings:\n\nsubplot: 1\nxaxis: \"time / s\"\nyaxis: \"Integerated n_e / m^-2\"\n\nOptional keywords:\n\n:average: true or false(default). If true, plot the average n_e vs time.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer__channel___n_e_line_average}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo_ch_n_e_line_average::IMASDD.interferometer__channel___n_e_line_average,\n)\n\nPlot average electron density of a channel of interferometer.\n\nDefault plot settings:\n\nsubplot: 1\nxaxis: \"time / s\"\nyaxis: \"Average n_e / m^-3\"\n\n\n\n\n\n","category":"method"}] +[{"location":"#GGDUtils.jl","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Pages = [\"index.md\"]\nDepth = 5","category":"page"},{"location":"#Installation","page":"GGDUtils.jl","title":"Installation","text":"","category":"section"},{"location":"#Using-make:","page":"GGDUtils.jl","title":"Using make:","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"After cloning this repo, check the make menu:","category":"page"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"GGDUtils.jl % make help\nHelp Menu\n\nmake env_with_cloned_repo (or make r): Creates a Julia environment with the cloned repositories\nmake env_with_git_url (or make u): Creates a Julia environment with the git urls without creating local clones\nmake clean: Deletes Project.toml and Manifest.toml for a fresh start","category":"page"},{"location":"#make-r","page":"GGDUtils.jl","title":"make r","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"This option creates local copies of required private repositories at the same level as current repository and uses them in develop mode to create a Manifest.toml","category":"page"},{"location":"#make-u","page":"GGDUtils.jl","title":"make u","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"This option uses url of required private repositories to create a static Manifest.toml attached to current master branches of these repositories.","category":"page"},{"location":"#make-clean","page":"GGDUtils.jl","title":"make clean","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Deletes Manifest.toml so that environment can be recreated, to update or change the last used method.","category":"page"},{"location":"#Using-Julia-REPL-and-installing-using-Github-url","page":"GGDUtils.jl","title":"Using Julia REPL and installing using Github url","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Or, in julia REPL:","category":"page"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"julia> using Pkg;\njulia> Pkg.add(; url=\"https://github.com/ProjectTorreyPines/IMASDD.jl.git\");\njulia> Pkg.add(; url=\"https://github.com/ProjectTorreyPines/GGDUtils.jl.git\");\njulia> Pkg.instantiate()","category":"page"},{"location":"#Interpolations","page":"GGDUtils.jl","title":"Interpolations","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Several interpolation functions are available to create interpolaiton functions for data present in a GGD represented over a particular grid subset:","category":"page"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"interp\nget_TPS_mats\nget_kdtree","category":"page"},{"location":"#GGDUtils.interp","page":"GGDUtils.jl","title":"GGDUtils.interp","text":"interp(\n prop_values::Vector{T},\n kdtree::KDTree;\n use_nearest_n::Int=4,\n weighing::Function=(d) -> 1 / d,\n) where {T <: Real}\n\nLowest level interpolation function. It takes a vector of property values and a KDTree defined over a 2D space with the same number of nodes as the property values. It returns a function that can be used to interpolate the property values at any point in the space.\n\n\n\n\n\ninterp(\n y::Vector{T},\n TPS_mats::Tuple{Matrix{U}, Matrix{U}, Matrix{U}, Vector{Tuple{U, U}}},\n) where {T <: Real, U <: Real}\n\nLowest level function for Thin Plate Spline method\n\n\n\n\n\ninterp(y::Vector{T}, x::Vector{Tuple{U, U}}) where {T <: Real, U <: Real}\n\nThin plate smoothing interpolation function for a 2d space scalar function. The algorithm has been adopted from:\n\nhttp://www.geometrictools.com/Documentation/ThinPlateSplines.pdf\n\nThis is an implementation of Euler-Lagrange equation for minimizing bending energy of a surface.\n\n\n\n\n\ninterp(\n prop_values::Vector{T},\n space::IMASDD.edge_profiles__grid_ggd___space\n) where {T <: Real}\n\nIf the whole space is provided instead of a kdtree, calculate the kdtree for whole space. Again, here it is assumed that the property values are porvided for each node of the space.\n\n\n\n\n\ninterp(\n prop_values::Vector{Real},\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset\n)\n\nIf a subset of the space is provided, calculate the kdtree for the subset. In this case it is assumed that the property values are provided for each element of the subset.\n\n\n\n\n\ninterp(\n prop::edge_profiles__prop_on_subset,\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n value_field::Symbol=:values\n)\n\nExample:\n\ngrid_ggd = dd.edge_profiles.grid_ggd[1]\nget_electron_density = interp(dd.edge_profiles.ggd[1].electrons.density[1], grid_ggd)\nget_e_field_par = interp(dd.edge_profiles.ggd[1].e_field[1], grid_ggd, :parallel)\n\n\n\n\n\ninterp(\n prop_arr::AbstractVector{T},\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n value_field::Symbol=:values\n) where {T <: edge_profiles__prop_on_subset}\n\nExample:\n\nsol = get_grid_subset_with_index(dd.edge_profiles.grid_ggd[1], 23)\nget_electron_density = interp(dd.edge_profiles.ggd[1].electrons.density, space, sol)\n\n\n\n\n\ninterp(\n prop_arr::AbstractVector{T},\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n grid_subset_index::Int,\n value_field::Symbol=:values\n) where {T <: edge_profiles__prop_on_subset}\n\nExample:\n\nget_n_e_sep = interp(dd.edge_profiles.ggd[1].electrons.density, grid_ggd, 16)\n\n\n\n\n\ninterp(\n prop_arr::AbstractVector{T},\n TPS_mats::Tuple{Matrix{U}, Matrix{U}, Matrix{U}, Vector{Tuple{U, U}}},\n grid_subset_index::Int,\n value_field::Val{V}=Val(:values),\n) where {T <: edge_profiles__prop_on_subset, U <: Real, V}\n\nSame use case as above but allows one to reuse previously calculated TPS matrices.\n\nExample:\n\nTPS_mat = get_TPS_mats(dd.edge_profiles.grid_ggd[1], 5);\n\nfor it ∈ eachindex(dd.edge_profiles.ggd)\n get_n_e = interp(dd.edge_profiles.ggd[it].electrons.density, TPS_mat_sep, 5)\n println(\"This time step has n_e at (0, 0) = \", get_n_e(0, 0))\nend\n\nThis will run faster as heavy matrix calculations will happen only once.\n\n\n\n\n\ninterp(eqt::IMASDD.equilibrium__time_slice)\n\nFor a given equilibrium time slice, return a function that can be used to interpolate from (r, z) space to rho (normalized toroidal flux coordinate)space.\n\nExample:\n\nrz2rho = interp(dd.equilibrium.time_slice[1])\nrho = rz2rho.([(r, z) for r ∈ 3.0:0.01:9.0, z ∈ -5.0:0.01:5.0])\n\n\n\n\n\ninterp(\n prop::Vector{T},\n prof::IMASDD.core_profiles__profiles_1d,\n) where {T <: Real}\n\nReturns an inteprolation function for the core profile property values defined on normalized toroidal flux coordinate rho.\n\nExample:\n\ncore_profile_n_e = dd.core_profiles.profiles_1d[1].electrons.density\nget_n_e = interp(core_profile_n_e, dd.core_profiles.profiles_1d[1])\nget_n_e(1) # Returns electron density at rho = 1 (separatix)\n\n\n\n\n\ninterp(\n prop::Vector{T},\n prof::IMASDD.core_profiles__profiles_1d,\n rz2rho::Function,\n)\n\nReturns an inteprolation function in (R, Z) domain for the core profile property values defined on normalized toroidal flux coordinate rho and with a provided function to convert (R,Z) to rho.\n\nExample:\n\nrz2rho = interp(dd.equilibrium.time_slice[1])\ncore_profile_n_e = dd.core_profiles.profiles_1d[1].electrons.density\nget_n_e = interp(core_profile_n_e, dd.core_profiles.profiles_1d[1], rz2rho)\nget_n_e(5.0, 3.5) # Returns electron density at (R, Z) = (5.0, 3.5)\n\n\n\n\n\ninterp(\n prop::Vector{T},\n prof::IMASDD.core_profiles__profiles_1d,\n eqt::IMASDD.equilibrium__time_slice,\n) where {T <: Real}\n\nReturns an inteprolation function in (R, Z) domain for the core profile property values defined on normalized toroidal flux coordinate rho and with a provided equilibrium time slice to get (R, Z) to rho conversion.\n\nExample:\n\neqt = dd.equilibrium.time_slice[1]\ncore_profile_n_e = dd.core_profiles.profiles_1d[1].electrons.density\nget_n_e = interp(core_profile_n_e, dd.core_profiles.profiles_1d[1], eqt)\nget_n_e(5.0, 3.5) # Returns electron density at (R, Z) = (5.0, 3.5)\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_TPS_mats","page":"GGDUtils.jl","title":"GGDUtils.get_TPS_mats","text":"get_TPS_mats(x::Vector{Tuple{U, U}}) where {U <: Real}\n\nWe can separate matrix operations of thin plate spline method to utilize the calculation for itnerpolating over same space. Similar to the idea of reusing KDTree like above.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_kdtree","page":"GGDUtils.jl","title":"GGDUtils.get_kdtree","text":"get_kdtree(space::IMASDD.edge_profiles__grid_ggd___space)\n\nGet a KDTree for all the cells in the space for search for nearest neighbours.\n\n\n\n\n\nget_kdtree(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nGet a KDTree for a subset of the space for search for nearest neighbours.\n\n\n\n\n\n","category":"function"},{"location":"#Subset-Tools","page":"GGDUtils.jl","title":"Subset Tools","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"add_subset_element!\nget_subset_space\nget_grid_subset\nget_subset_boundary_inds\nget_subset_boundary\nsubset_do\nget_subset_centers\nproject_prop_on_subset!\ndeepcopy_subset\nBase.:∈\nget_prop_with_grid_subset_index","category":"page"},{"location":"#GGDUtils.add_subset_element!","page":"GGDUtils.jl","title":"GGDUtils.add_subset_element!","text":"add_subset_element!(\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n sn::Int,\n dim::Int,\n index::Int,\n in_subset=(x...) -> true;\n kwargs...,\n)\n\nAdds a new element to girdsubset with properties space number (sn), dimension (dim), and index (index). The element is added only if the function insubset returns true.\n\n\n\n\n\nadd_subset_element!(\n subset,\n sn,\n dim,\n index::Vector{Int},\n in_subset=(x...) -> true;\n kwargs...,\n)\n\nOverloaded to work differently (faster) with list of indices to be added.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_subset_space","page":"GGDUtils.jl","title":"GGDUtils.get_subset_space","text":"get_subset_space(\n space::IMASDD.edge_profiles__grid_ggd___space,\n elements::AbstractVector{<:IMASDD.edge_profiles__grid_ggd___grid_subset___element}\n)\n\nReturns an array of space object indices corresponding to the correct objectsperdimension (nodes, edges or cells) for the subset elements.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_grid_subset","page":"GGDUtils.jl","title":"GGDUtils.get_grid_subset","text":"get_grid_subset(\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n grid_subset_index::Int,\n)\n\nReturns the gridsubset in a gridggd with the matching gridsubsetindex\n\n\n\n\n\nget_grid_subset(\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n grid_subset_name::String,\n)\n\nReturns the gridsubset in a gridggd with the matching gridsubsetname\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_subset_boundary_inds","page":"GGDUtils.jl","title":"GGDUtils.get_subset_boundary_inds","text":"get_subset_boundary_inds(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nReturns an array of space object indices corresponding to the boundary of the subset. That means, it returns indices of nodes that are at the end of open edge subset or it returns the indices of edges that are the the boundary of a cell subset. Returns an empty array if the subset is 1D (nodes).\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_subset_boundary","page":"GGDUtils.jl","title":"GGDUtils.get_subset_boundary","text":"get_subset_boundary(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nReturns an array of elements of grid_subset generated from the boundary of the subset provided. The dimension of these elments is reduced by 1.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.subset_do","page":"GGDUtils.jl","title":"GGDUtils.subset_do","text":"subset_do(\n set_operator,\n itrs::Vararg{\n AbstractVector{<:IMASDD.edge_profiles__grid_ggd___grid_subset___element},\n };\n space::IMASDD.edge_profiles__grid_ggd___space=IMASDD.edge_profiles__grid_ggd___space(),\n use_nodes=false\n)\n\nFunction to perform any set operation (intersect, union, setdiff etc.) on subset.element to generate a list of elements to go to subset object. If usenodes is true, the set operation will be applied on the set of nodes from subset.element, space argument is required for this. Note: that the arguments are subset.element (not the subset itself). Similarly, the return object is a list of IMASDD.edgeprofiles__gridggd___gridsubset___element.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_subset_centers","page":"GGDUtils.jl","title":"GGDUtils.get_subset_centers","text":"get_subset_centers(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nReturns an array of tuples corresponding to (r,z) coordinates of the center of cells or the center of edges in the subset space.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.project_prop_on_subset!","page":"GGDUtils.jl","title":"GGDUtils.project_prop_on_subset!","text":"project_prop_on_subset!(\n prop_arr::AbstractVector{T},\n from_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n to_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n space::IMASDD.edge_profiles__grid_ggd___space,\n value_field::Symbol=:values;\n TPS_mats::Union{\n Nothing,\n Tuple{Matrix{U}, Matrix{U}, Matrix{U}, Vector{Tuple{U, U}}},\n }=nothing,\n) where {T <: edge_profiles__prop_on_subset, U <: Real}\n\nThis function can be used to add another instance on a property vector representing the value in a new subset that can be taken as a projection from an existing larger subset.\n\nInput Arguments:\n\nprop: A property like electrons.density that is a vector of objects with fields coefficients, gridindex, gridsubsetindex, and values. The different instances in the vector correspond to different gridsubset for which the property is provided.\nfromsubset: gridsubset object which is already represented in the property instance. grid subset with index 5 is populated in electrons.density already if the values for all cells are present.\ntosubset: gridsubset which is either a smaller part of fromsubset (core, sol, idr, odr) but has same dimensions as fromsubset OR is smaller in dimension that goes through the fromsubset (coreboundary, separatix etc.)\nspace: (optional) space object in gridggd is required only when fromsubset is higher dimensional than to_subset.\n\nReturns: NOTE: This function ends in ! which means it updates prop argument in place. But for the additional utility, this function also returns a tuple (tosubsetcenters, topropvalues) when fromsubset dimension is greater than tosubset dimension OR (tosubseteleobjinds, topropvalues) when fromsubset dimension is same as tosubset dimension)\n\nDescriptions: tosubsetcenters: center of cells or center of edges of the tosubset where property values are defined and stored tosubseteleobjinds: Indices of the elements of tosubset where property values are defined and stored topropvalues: The projected values of the properties added to prop object in a new instance\n\n\n\n\n\nproject_prop_on_subset!(\n prop_arr::AbstractVector{T},\n from_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n to_subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n value_field::Symbol=:values,\n) where {T <: edge_profiles__prop_on_subset}\n\nIf the dimensions of fromsubset and tosubset are the same, this function can be used to add another instance on a property vector representing the value in tosubset without any interpolation or use of space object. The function returns a tuple of indices of elements of tosubset and the values of the property in to_subset.\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.deepcopy_subset","page":"GGDUtils.jl","title":"GGDUtils.deepcopy_subset","text":"deepcopy_subset(subset::IMASDD.edge_profiles__grid_ggd___grid_subset)\n\nFaster deepcopy function for gridsubset object. This function is used to create a deep copy of a gridsubset object bypassing several checks performed by IMASDD.\n\n\n\n\n\n","category":"function"},{"location":"#Base.:∈","page":"GGDUtils.jl","title":"Base.:∈","text":"Base.:∈(\n point::Tuple{Real, Real},\n subset_of_space::Tuple{\n IMASDD.edge_profiles__grid_ggd___grid_subset,\n IMASDD.edge_profiles__grid_ggd___space,\n },\n)\n\nOverloading ∈ operator to check if a point is inside a subset of space.\n\nIf the subset is 1-dimensional, all points are searched. If the subset is 2-dimensional, it is checked if the point is within the enclosed area. It is assumed that a 2-dimensional subset used in such a context will form a closed area. If the subset is 3-dimensional, its boundary is calculated on the fly. If used multiple times, it is recommended to calculate the boundary once and store it in a variable.\n\nExample:\n\nif (5.5, 0.0) ∈ (subset_sol, space)\n println(\"Point (5.5, 0.0) is inside the SOL subset.\")\nelse\n println(\"Point (5.5, 0.0) is outside the SOL subset.\")\nend\n\n\n\n\n\n","category":"function"},{"location":"#GGDUtils.get_prop_with_grid_subset_index","page":"GGDUtils.jl","title":"GGDUtils.get_prop_with_grid_subset_index","text":"get_prop_with_grid_subset_index(\n prop::AbstractVector{T},\n grid_subset_index::Int,\n) where {T <: edge_profiles__prop_on_subset}\n\nFind the edgeprofiles property instance in an array of properties that corresponds to the gridsubset_index provided.\n\n\n\n\n\n","category":"function"},{"location":"#Types","page":"GGDUtils.jl","title":"Types","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"get_types_with","category":"page"},{"location":"#GGDUtils.get_types_with","page":"GGDUtils.jl","title":"GGDUtils.get_types_with","text":"get_types_with(parent::Type, field::Symbol)\n\nA type creation utility meant for searching types in IMAS database. This function returns a list of types that are fields at any level below the parent data type which have a particular field present in it.\n\nExample:\n\nget_types_with(IMASDD.edge_profiles, :grid_subset_index)\n\nreturns all edgeprofiles types that have a subfield named gridsubset_index.\n\n\n\n\n\n","category":"function"},{"location":"#Plot-recipes","page":"GGDUtils.jl","title":"Plot recipes","text":"","category":"section"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"Several plot recipes have been defined for easy visualization.","category":"page"},{"location":"","page":"GGDUtils.jl","title":"GGDUtils.jl","text":"RecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.edge_profiles__grid_ggd___space)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.edge_profiles__grid_ggd___space, ::GGDUtils.IMASDD.edge_profiles__grid_ggd___grid_subset)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.edge_profiles__grid_ggd, ::GGDUtils.IMASDD.IDSvectorElement)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::AbstractVector{<:GGDUtils.IMASDD.edge_profiles__grid_ggd}, ::GGDUtils.IMASDD.IDSvectorElement)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer__channel)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer__channel___line_of_sight)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer__channel___n_e_line)\nRecipesBase.apply_recipe(::Dict{Symbol,Any}, ::GGDUtils.IMASDD.interferometer__channel___n_e_line_average)","category":"page"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.edge_profiles__grid_ggd___space}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(space::IMASDD.edge_profiles__grid_ggd___space)\n\nPlot the grid_ggd space object. Defaults to size of [600, 900] and linecolor of :black, linewidth of 0.2, and no legend.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.edge_profiles__grid_ggd___space, IMASDD.edge_profiles__grid_ggd___grid_subset}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n space::IMASDD.edge_profiles__grid_ggd___space,\n subset::IMASDD.edge_profiles__grid_ggd___grid_subset,\n)\n\nPlot the a subset of a space. Defaults to size of [600, 900] and linecolor of :black, linewidth of 0.2, and no legend.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.edge_profiles__grid_ggd, IMASDD.IDSvectorElement}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n grid_ggd::IMASDD.edge_profiles__grid_ggd,\n prop::IMASDD.IDSvectorElement,\n)\n\nPlot 2D heatmap of edgeprofilesggd property on a gridggd space object. Defaults to size of [635, 900], xaxis of \"R / m\", yaxis of \"Z / m\", and no legend. If :seriescolor is not provided, :inferno color scheme is used. If :colorbartitle is not provided, the property name is used. This function creates a plot with layout [a{0.95w} b] where a is the heatmap and b is the colorbar.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, AbstractVector{<:IMASDD.edge_profiles__grid_ggd}, IMASDD.IDSvectorElement}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n grid_ggd_arr::AbstractVector{<:IMASDD.edge_profiles__grid_ggd},\n prop::IMASDD.IDSvectorElement,\n)\n\nPlot 2D heatmap of edgeprofilesggd property on a gridggd space object. Defaults to size of [635, 900], xaxis of \"R / m\", yaxis of \"Z / m\", and no legend. If :seriescolor is not provided, :inferno color scheme is used. If :colorbartitle is not provided, the property name is used. This function creates a plot with layout [a{0.95w} b] where a is the heatmap and b is the colorbar.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo::IMASDD.interferometer,\n)\n\nPlot all the channels of interferometer object. Optional keywords:\n\n:plottype: :los(default), :ne, or :neaverage. :los plots the line of sight of the channel in a 2D plot, :ne plots the integrated ne along the line of sight vs time, and :neaverage plots the average n_e vs time.\n:mirror: true(default) or false.\n:mirror_length: 0.5(default).\n:mirror_thickness: 0.1(default).\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer__channel}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo_ch::IMASDD.interferometer__channel,\n)\n\nPlot individual channel of interferometer. Optional keywords:\n\n:plottype: :los(default), :ne, or :neaverage. :los plots the line of sight of the channel in a 2D plot, :ne plots the integrated ne along the line of sight vs time, and :neaverage plots the average n_e vs time.\n:mirror: true(default) or false.\n:mirror_length: 0.5(default).\n:mirror_thickness: 0.1(default).\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer__channel___line_of_sight}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo_ch_los::IMASDD.interferometer__channel___line_of_sight,\n)\n\nPlot line of sight of a channel of interferometer.\n\nDefault plot settings:\n\nsubplot: 1\nsize: [600, 900]\nxaxis: \"R / m\"\nyaxis: \"Z / m\"\n\nOptional keywords:\n\n:mirror: true(default) or false.\n:mirror_length: 0.5(default).\n:mirror_thickness: 0.1(default).\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer__channel___n_e_line}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo_ch_n_e_line::IMASDD.interferometer__channel___n_e_line,\n)\n\nPlot line integrated electron density of a channel of interferometer.\n\nDefault plot settings:\n\nsubplot: 1\nxaxis: \"time / s\"\nyaxis: \"Integerated n_e / m^-2\"\n\nOptional keywords:\n\n:average: true or false(default). If true, plot the average n_e vs time.\n\n\n\n\n\n","category":"method"},{"location":"#RecipesBase.apply_recipe-Tuple{Dict{Symbol, Any}, IMASDD.interferometer__channel___n_e_line_average}","page":"GGDUtils.jl","title":"RecipesBase.apply_recipe","text":"plot(\n ifo_ch_n_e_line_average::IMASDD.interferometer__channel___n_e_line_average,\n)\n\nPlot average electron density of a channel of interferometer.\n\nDefault plot settings:\n\nsubplot: 1\nxaxis: \"time / s\"\nyaxis: \"Average n_e / m^-3\"\n\n\n\n\n\n","category":"method"}] }