Skip to content

Latest commit

 

History

History
1401 lines (1169 loc) · 35.5 KB

README.md

File metadata and controls

1401 lines (1169 loc) · 35.5 KB

CDR Schemas

Development

Formatting Code

poetry run format

Verify Changes

# verify types (mypy)
poetry run types

# lint
poetry run lint

Build local package

poetry build -f sdist

Update Schema Diagrams

To generate schemas you will need to run poetry install --with docs to install the proper dependencies

poetry run docs

Schemas

Area Extraction
Cog Metadata
Document
Feature Results
Georeference
Line Feature
Map
Map Results
Metadata
Mineral
Point Feature
Polygon Feature
Prospectivity Input
Prospectivity Models

Area Extraction

area extraction
classDiagram

    class AreaType {
        <<Enumeration>>
        Map_Area: str = 'map_area'
        Legend_Area: str = 'legend_area'
        CrossSection: str = 'cross_section'
        OCR: str = 'ocr'
        Polygon_Legend_Area: str = 'polygon_legend_area'
        Line_Point_Legend_Area: str = 'line_point_legend_area'
        Line_Legend_Area: str = 'line_legend_area'
        Point_Legend_Area: str = 'point_legend_area'
        Correlation_Diagram: str = 'correlation_diagram'
    }

    class Area_Extraction {
        type: GeomType = GeomType.Polygon
        coordinates: list[list[list[float | int]]]
        bbox: list[float | int] = list
        category: AreaType
        text: str = ''
        reference_id: str = ''
        validated: bool = False
        model: str
        model_version: str
        confidence: float | int | None = None
    }

    class GeomType {
        <<Enumeration>>
        Point: str = 'Point'
        LineString: str = 'LineString'
        Polygon: str = 'Polygon'
    }

    Area_Extraction ..> AreaType
    Area_Extraction ..> GeomType


Loading

Georeference

georeference
classDiagram

    class Area_Extraction {
        type: GeomType = GeomType.Polygon
        coordinates: list[list[list[float | int]]]
        bbox: list[float | int] = list
        category: AreaType
        text: str = ''
        reference_id: str = ''
        validated: bool = False
        model: str
        model_version: str
        confidence: float | int | None = None
    }

    class GroundControlPoint {
        gcp_id: str
        map_geom: Geom_Point
        px_geom: Pixel_Point
        confidence: float | int | None = None
        model: str
        model_version: str
        crs: str
    }

    class Geom_Point {
        latitude: float | int | None
        longitude: float | int | None
        type: GeomType = GeomType.Point
    }

    class GeoreferenceResults {
        cog_id: str
        georeference_results: list[GeoreferenceResult] = list
        gcps: list[GroundControlPoint] = list
        system: str
        system_version: str
    }

    class GeomType {
        <<Enumeration>>
        Point: str = 'Point'
        LineString: str = 'LineString'
        Polygon: str = 'Polygon'
    }

    class ProjectionResult {
        crs: str
        gcp_ids: list[str]
        file_name: str
        validated: bool = False
    }

    class Pixel_Point {
        rows_from_top: float | int
        columns_from_left: float | int
        type: GeomType = GeomType.Point
    }

    class GeoreferenceResult {
        likely_CRSs: list[str] = list
        map_area: Area_Extraction | None = None
        projections: list[ProjectionResult] = list
    }

    Area_Extraction ..> AreaType
    Area_Extraction ..> GeomType
    Geom_Point ..> GeomType
    Pixel_Point ..> GeomType
    GroundControlPoint ..> Geom_Point
    GroundControlPoint ..> Pixel_Point
    GeoreferenceResult ..> ProjectionResult
    GeoreferenceResult ..> Area_Extraction
    GeoreferenceResults ..> GeoreferenceResult
    GeoreferenceResults ..> GroundControlPoint


Loading

Metadata

metadata
classDiagram

    class MapShapeTypes {
        <<Enumeration>>
        rectangular: str = 'rectangular'
        non_rectangular: str = 'non_rectangular'
    }

    class MapMetaData {
        title: str = ''
        year: int | None = None
        crs: str = ''
        authors: list[str] = list
        organization: str = ''
        scale: int | None = None
        quadrangle_name: str = ''
        map_shape: MapShapeTypes | None = None
        map_color_scheme: MapColorSchemeTypes | None = None
        publisher: str = ''
        state: str = ''
        model: str
        model_version: str
    }

    class CogMetaData {
        cog_id: str
        system: str
        system_version: str
        multiple_maps: bool | None = None
        map_metadata: list[MapMetaData] = list
    }

    class MapColorSchemeTypes {
        <<Enumeration>>
        full_color: str = 'full_color'
        monochrome: str = 'monochrome'
        grayscale: str = 'grayscale'
    }

    MapMetaData ..> MapShapeTypes
    MapMetaData ..> MapColorSchemeTypes
    CogMetaData ..> MapMetaData


Loading

Feature Results

feature results
classDiagram

    class PointLegendAndFeaturesResult {
        id: str
        legend_provenance: ModelProvenance | None = None
        name: str
        abbreviation: str = ''
        description: str = ''
        legend_bbox: list[float | int] = list
        legend_contour: list[list[float | int]] = list
        reference_id: str = ''
        validated: bool | None = None
        crs: str = 'pixel'
        cdr_projection_id: str = ''
        point_features: PointFeatureCollection | None = None
    }

    class Area_Extraction {
        type: GeomType = GeomType.Polygon
        coordinates: list[list[list[float | int]]]
        bbox: list[float | int] = list
        category: AreaType
        text: str = ''
        reference_id: str = ''
        validated: bool = False
        model: str
        model_version: str
        confidence: float | int | None = None
    }

    class LineLegendAndFeaturesResult {
        id: str
        legend_provenance: ModelProvenance | None = None
        name: str = ''
        abbreviation: str = ''
        description: str = ''
        legend_bbox: list[float | int] = list
        legend_contour: list[list[float | int]] = list
        reference_id: str = ''
        validated: bool | None = None
        crs: str = 'pixel'
        cdr_projection_id: str = ''
        line_features: LineFeatureCollection | None = None
    }

    class CogMetaData {
        cog_id: str
        system: str
        system_version: str
        multiple_maps: bool | None = None
        map_metadata: list[MapMetaData] = list
    }

    class FeatureResults {
        system: str
        system_version: str
        cog_id: str
        line_feature_results: list[LineLegendAndFeaturesResult] = list
        point_feature_results: list[PointLegendAndFeaturesResult] = list
        polygon_feature_results: list[PolygonLegendAndFeaturesResult] = list
        cog_area_extractions: list[Area_Extraction] = list
        cog_metadata_extractions: list[CogMetaData] = list
    }

    class PolygonLegendAndFeaturesResult {
        id: str
        legend_provenance: ModelProvenance | None = None
        label: str
        abbreviation: str = ''
        description: str = ''
        legend_bbox: list[float | int] = list
        legend_contour: list[list[float | int]] = list
        color: str = ''
        pattern: str = ''
        category: str = ''
        map_unit: list[MapUnit] = list
        reference_id: str = ''
        validated: bool | None = None
        crs: str = 'pixel'
        cdr_projection_id: str = ''
        polygon_features: PolygonFeatureCollection | None = None
    }

    Area_Extraction ..> AreaType
    Area_Extraction ..> GeomType
    LineLegendAndFeaturesResult ..> LineFeatureCollection
    LineLegendAndFeaturesResult ..> ModelProvenance
    PointLegendAndFeaturesResult ..> PointFeatureCollection
    PointLegendAndFeaturesResult ..> ModelProvenance
    PolygonLegendAndFeaturesResult ..> MapUnit
    PolygonLegendAndFeaturesResult ..> PolygonFeatureCollection
    PolygonLegendAndFeaturesResult ..> ModelProvenance
    CogMetaData ..> MapMetaData
    FeatureResults ..> PointLegendAndFeaturesResult
    FeatureResults ..> Area_Extraction
    FeatureResults ..> LineLegendAndFeaturesResult
    FeatureResults ..> CogMetaData
    FeatureResults ..> PolygonLegendAndFeaturesResult


Loading

Point Feature

point feature
classDiagram

    class PointFeature {
        type: GeoJsonType = GeoJsonType.Feature
        id: str
        geometry: Point
        properties: PointProperties
    }

    class PointLegendAndFeaturesResult {
        id: str
        legend_provenance: ModelProvenance | None = None
        name: str
        abbreviation: str = ''
        description: str = ''
        legend_bbox: list[float | int] = list
        legend_contour: list[list[float | int]] = list
        reference_id: str = ''
        validated: bool | None = None
        crs: str = 'pixel'
        cdr_projection_id: str = ''
        point_features: PointFeatureCollection | None = None
    }

    class Point {
        coordinates: list[float | int]
        type: GeomType = GeomType.Point
    }

    class GeomType {
        <<Enumeration>>
        Point: str = 'Point'
        LineString: str = 'LineString'
        Polygon: str = 'Polygon'
    }

    class PointProperties {
        model: str
        model_version: str
        confidence: float | int | None = None
        bbox: list[float | int] = list
        dip: int | None = None
        dip_direction: int | None = None
        reference_id: str = ''
        validated: bool | None = None
    }

    class GeoJsonType {
        <<Enumeration>>
        Feature: str = 'Feature'
        FeatureCollection: str = 'FeatureCollection'
    }

    class PointFeatureCollection {
        type: GeoJsonType = GeoJsonType.FeatureCollection
        features: list[PointFeature] = list
    }

    class ModelProvenance {
        model: str
        model_version: str
        confidence: float | int | None = None
    }

    Point ..> GeomType
    PointFeature ..> GeoJsonType
    PointFeature ..> Point
    PointFeature ..> PointProperties
    PointFeatureCollection ..> PointFeature
    PointFeatureCollection ..> GeoJsonType
    PointLegendAndFeaturesResult ..> PointFeatureCollection
    PointLegendAndFeaturesResult ..> ModelProvenance


Loading

Line Feature

line feature
classDiagram

    class LineLegendAndFeaturesResult {
        id: str
        legend_provenance: ModelProvenance | None = None
        name: str = ''
        abbreviation: str = ''
        description: str = ''
        legend_bbox: list[float | int] = list
        legend_contour: list[list[float | int]] = list
        reference_id: str = ''
        validated: bool | None = None
        crs: str = 'pixel'
        cdr_projection_id: str = ''
        line_features: LineFeatureCollection | None = None
    }

    class GeomType {
        <<Enumeration>>
        Point: str = 'Point'
        LineString: str = 'LineString'
        Polygon: str = 'Polygon'
    }

    class GeoJsonType {
        <<Enumeration>>
        Feature: str = 'Feature'
        FeatureCollection: str = 'FeatureCollection'
    }

    class LineFeatureCollection {
        type: GeoJsonType = GeoJsonType.FeatureCollection
        features: list[LineFeature] = list
    }

    class DashType {
        <<Enumeration>>
        none: str = ''
        solid: str = 'solid'
        dash: str = 'dash'
        dotted: str = 'dotted'
    }

    class Line {
        coordinates: list[list[float | int]]
        type: GeomType = GeomType.LineString
    }

    class LineFeature {
        type: GeoJsonType = GeoJsonType.Feature
        id: str
        geometry: Line
        properties: LineProperties
    }

    class LineProperties {
        model: str
        model_version: str
        confidence: float | int | None = None
        dash_pattern: DashType = DashType.none
        symbol: str = ''
        reference_id: str = ''
        validated: bool | None = None
    }

    class ModelProvenance {
        model: str
        model_version: str
        confidence: float | int | None = None
    }

    Line ..> GeomType
    LineProperties ..> DashType
    LineFeature ..> Line
    LineFeature ..> GeoJsonType
    LineFeature ..> LineProperties
    LineFeatureCollection ..> GeoJsonType
    LineFeatureCollection ..> LineFeature
    LineLegendAndFeaturesResult ..> LineFeatureCollection
    LineLegendAndFeaturesResult ..> ModelProvenance


Loading

Polygon Feature

polygon feature
classDiagram

    class PolygonProperties {
        model: str
        model_version: str
        reference_id: str = ''
        validated: bool | None = None
        confidence: float | int | None = None
    }

    class GeomType {
        <<Enumeration>>
        Point: str = 'Point'
        LineString: str = 'LineString'
        Polygon: str = 'Polygon'
    }

    class PolygonLegendAndFeaturesResult {
        id: str
        legend_provenance: ModelProvenance | None = None
        label: str
        abbreviation: str = ''
        description: str = ''
        legend_bbox: list[float | int] = list
        legend_contour: list[list[float | int]] = list
        color: str = ''
        pattern: str = ''
        category: str = ''
        map_unit: list[MapUnit] = list
        reference_id: str = ''
        validated: bool | None = None
        crs: str = 'pixel'
        cdr_projection_id: str = ''
        polygon_features: PolygonFeatureCollection | None = None
    }

    class GeoJsonType {
        <<Enumeration>>
        Feature: str = 'Feature'
        FeatureCollection: str = 'FeatureCollection'
    }

    class MapUnit {
        age_text: str = ''
        b_age: float | None = None
        b_interval: str = ''
        lithology: str = ''
        name: str = ''
        t_age: float | None = None
        t_interval: str = ''
        comments: str = ''
    }

    class Polygon {
        coordinates: list[list[list[float | int]]]
        type: GeomType = GeomType.Polygon
    }

    class PolygonFeature {
        type: GeoJsonType = GeoJsonType.Feature
        id: str
        geometry: Polygon
        properties: PolygonProperties
    }

    class PolygonFeatureCollection {
        type: GeoJsonType = GeoJsonType.FeatureCollection
        features: list[PolygonFeature] = list
    }

    class ModelProvenance {
        model: str
        model_version: str
        confidence: float | int | None = None
    }

    Polygon ..> GeomType
    PolygonFeature ..> GeoJsonType
    PolygonFeature ..> PolygonProperties
    PolygonFeature ..> Polygon
    PolygonFeatureCollection ..> GeoJsonType
    PolygonFeatureCollection ..> PolygonFeature
    PolygonLegendAndFeaturesResult ..> MapUnit
    PolygonLegendAndFeaturesResult ..> PolygonFeatureCollection
    PolygonLegendAndFeaturesResult ..> ModelProvenance


Loading

Cog Metadata

cog metadata
classDiagram

    class MapShapeTypes {
        <<Enumeration>>
        rectangular: str = 'rectangular'
        non_rectangular: str = 'non_rectangular'
    }

    class MapMetaData {
        title: str = ''
        year: int | None = None
        crs: str = ''
        authors: list[str] = list
        organization: str = ''
        scale: int | None = None
        quadrangle_name: str = ''
        map_shape: MapShapeTypes | None = None
        map_color_scheme: MapColorSchemeTypes | None = None
        publisher: str = ''
        state: str = ''
        model: str
        model_version: str
    }

    class CogMetaData {
        cog_id: str
        system: str
        system_version: str
        multiple_maps: bool | None = None
        map_metadata: list[MapMetaData] = list
    }

    class MapColorSchemeTypes {
        <<Enumeration>>
        full_color: str = 'full_color'
        monochrome: str = 'monochrome'
        grayscale: str = 'grayscale'
    }

    MapMetaData ..> MapShapeTypes
    MapMetaData ..> MapColorSchemeTypes
    CogMetaData ..> MapMetaData


Loading

Document

document
classDiagram

    class DocumentMetaData {
        doi: str = ''
        authors: list[str] = list
        journal: str = ''
        year: int | None = None
        month: int | None = None
        volume: int | None = None
        issue: str = ''
        description: str = ''
        publisher: str = ''
    }

    class Document {
        id: str
        title: str
        is_open: bool
        pages: int
        size: int
        provenance: list[DocumentProvenance] = list
        metadata: DocumentMetaData | None = None
        system: str
        system_version: str
    }

    class DocumentProvenance {
        external_system_name: str
        external_system_id: str = ''
        external_system_url: str = ''
    }

    class DocumentExtraction {
        id: str | None = None
        document_id: str = None
        extraction_type: str
        extraction_label: str
        score: float | None = None
        bbox: tuple[float, float, float, float] | None = None
        page_num: int | None = None
        external_link: str | None = None
        data: dict[] | None = None
        system: str
        system_version: str
    }

    class UploadDocument {
        title: str
        is_open: bool = True
        provenance: list[DocumentProvenance] = list
        metadata: DocumentMetaData | None = None
        system: str
        system_version: str
    }

    UploadDocument ..> DocumentMetaData
    UploadDocument ..> DocumentProvenance
    Document ..> DocumentMetaData
    Document ..> DocumentProvenance


Loading

Mineral

mineral
classDiagram

    class MineralInventory {
        contained_metal: float | None = None
        commodity: str = ''
        commodity_observed_name: str = ''
        ore_unit: str = ''
        ore_value: float | None = None
        grade_unit: str = ''
        grade_value: float | None = None
        cutoff_grade_unit: str = ''
        cutoff_grade_value: float | None = None
        material_form: float | None = None
        material_form_unit: str = ''
        material_form_conversion: float | None = None
        confidence: Confidence | None = None
        categories: list[MineralInventoryCategory] = list
        documents: list[DocumentReference] = list
        records: list[RecordReference] = list
        date: str = ''
        zone: str = ''
    }

    class RecordReference {
        record_id: str = ''
        source: str = ''
        uri: str = ''
    }

    class DocumentReference {
        cdr_id: str
        page: int | None = None
        x_min: float | None = None
        x_max: float | None = None
        y_min: float | None = None
        y_max: float | None = None
    }

    class MappableCriteria {
        criteria: str
        theoretical: str = ''
        potential_dataset: list[EvidenceLayer] = list
        supporting_references: list[DocumentReference]
    }

    class MineralSystem {
        deposit_type: list[str] = list
        source: list[MappableCriteria] = list
        pathway: list[MappableCriteria] = list
        trap: list[MappableCriteria] = list
        preservation: list[MappableCriteria] = list
        energy: list[MappableCriteria] = list
        outflow: list[MappableCriteria] = list
    }

    class EvidenceLayer {
        name: str = ''
        relevance_score: float
    }

    class DedupSiteRecord {
        id: str | None = None
        mineral_site_id: str
        name: str = ''
        country: str = ''
        province: str = ''
        site_rank: str = ''
        site_type: str = ''
    }

    class GeologyInfo {
        age: str = ''
        unit_name: str = ''
        description: str = ''
        lithology: list[str] = list
        process: list[str] = list
        environment: list[str] = list
        comments: str = ''
    }

    class DedupSite {
        id: str | None = None
        sites: list[DedupSiteRecord] = list
        commodity: str
        contained_metal: float | None = None
        contained_metal_units: str = ''
        tonnage: float | None = None
        tonnage_units: str = ''
        grade: float | None = None
        grade_units: str = ''
        crs: str = ''
        centroid: str | None = ''
        geom: str | None = ''
        deposit_type_candidate: list[DepositTypeCandidate] = list
        system: str
        system_version: str
        data_snapshot: str
        data_snapshot_date: str
    }

    class MineralInventoryCategory {
        category: str
        confidence: float | int | None = None
        source: str
    }

    class MineralSite {
        id: str
        source_id: str = ''
        record_id: str = ''
        name: str = ''
        site_rank: str = ''
        site_type: str = ''
        country: list[str] = list
        province: list[str] = list
        location: GeoLocationInfo | None = None
        mineral_inventory: list[MineralInventory] = list
        deposit_type_candidate: list[DepositTypeCandidate] = list
        validated: bool = False
        system: str
        system_version: str
    }

    class DepositType {
        id: str | None = None
        name: str
        environment: str
        group: str
    }

    class GeoLocationInfo {
        crs: str
        geom: str
    }

    class Confidence {
        confidence: float | int | None = None
        source: str
    }

    class DepositTypeCandidate {
        observed_name: str = ''
        deposit_type_id: str | None = None
        confidence: float | int | None = None
        source: str
    }

    MappableCriteria ..> EvidenceLayer
    MappableCriteria ..> DocumentReference
    MineralSystem ..> MappableCriteria
    MineralInventory ..> RecordReference
    MineralInventory ..> Confidence
    MineralInventory ..> DocumentReference
    MineralInventory ..> MineralInventoryCategory
    MineralSite ..> MineralInventory
    MineralSite ..> GeoLocationInfo
    MineralSite ..> DepositTypeCandidate
    DedupSite ..> DepositTypeCandidate
    DedupSite ..> DedupSiteRecord


Loading

Map Results

map results
classDiagram

    class FeatureResults {
        system: str
        system_version: str
        cog_id: str
        line_feature_results: list[LineLegendAndFeaturesResult] = list
        point_feature_results: list[PointLegendAndFeaturesResult] = list
        polygon_feature_results: list[PolygonLegendAndFeaturesResult] = list
        cog_area_extractions: list[Area_Extraction] = list
        cog_metadata_extractions: list[CogMetaData] = list
    }

    class GeoreferenceResults {
        cog_id: str
        georeference_results: list[GeoreferenceResult] = list
        gcps: list[GroundControlPoint] = list
        system: str
        system_version: str
    }

    class MapResults {
        cog_id: str
        georef_results: list[GeoreferenceResults] = list
        extraction_results: list[FeatureResults] = list
    }

    FeatureResults ..> PointLegendAndFeaturesResult
    FeatureResults ..> Area_Extraction
    FeatureResults ..> LineLegendAndFeaturesResult
    FeatureResults ..> CogMetaData
    FeatureResults ..> PolygonLegendAndFeaturesResult
    GeoreferenceResults ..> GeoreferenceResult
    GeoreferenceResults ..> GroundControlPoint
    MapResults ..> FeatureResults
    MapResults ..> GeoreferenceResults


Loading

Map

map
classDiagram

    class Map {
        id: str
        provenance: list[MapProvenance] = list
        is_open: bool
        system: str
        system_version: str
    }

    class MapProvenance {
        system_name: str
        id: str = None
        url: str = None
    }

    Map ..> MapProvenance


Loading

Prospectivity Input

prospectivity input
classDiagram

    class DataTypeId {
        raw_data_type: RawDataType
        id: str
    }

    class Point {
        bbox: tuple[float, float, float, float] | tuple[float, float, float, float, float, float] | None = None
        type: Literal['Point']
        coordinates: Position2D | Position3D
    }

    class Impute {
        impute_method: ImputeMethod
        window_size: list[int] = [3, 3]
    }

    class CreateProspectModelMetaData {
        cma_id: str
        system: str
        system_version: str
        author: str = ''
        date: str = ''
        organization: str = ''
        model_type: str
        train_config: SOMTrainConfig | NeuralNetUserOptions | RFUserOptions | fastBNNUserOptions
        evidence_layers: list[str]
    }

    class DefineVectorProcessDataLayer {
        label_raster: bool = False
        title: str
        evidence_features: list[DataTypeId] = list
        extra_geometries: list[Point | LineString | Polygon] = list
        transform_methods: list[TransformMethod | Impute | ScalingType] = list
    }

    class DataSource {
        DOI: str | None
        authors: list[str] | None
        publication_date: str | None
        category: LayerCategory | str | None
        subcategory: str | None
        description: str | None
        derivative_ops: str | None
        type: LayerDataType
        resolution: tuple | None
        format: DataFormat
        download_url: str | None
    }

    class SaveProcessedDataLayer {
        cma_id: str
        title: str
        label_raster: bool = False
        raw_data_info: list[DataTypeId] = list
        extra_geometries: list[] = list
        system: str
        system_version: str
        transform_methods: list[TransformMethod | Impute | ScalingType] = list
        event_id: str = ''
    }

    class DataFormat {
        <<Enumeration>>
        TIF: str = 'tif'
        SHP: str = 'shp'
    }

    class LayerCategory {
        <<Enumeration>>
        GEOPHYSICS: str = 'geophysics'
        GEOLOGY: str = 'geology'
        GEOCHEMISTRY: str = 'geochemistry'
    }

    class LayerDataType {
        <<Enumeration>>
        CONTINUOUS: str = 'continuous'
        BINARY: str = 'binary'
        CATEGORICAL: str = 'categorical'
    }

    class MultiPolygon {
        bbox: tuple[float, float, float, float] | tuple[float, float, float, float, float, float] | None = None
        type: Literal['MultiPolygon']
        coordinates: list[list[list[Position2D | Position3D]]]
    }

    class NeuralNetUserOptions {
        likely_negative_range: tuple[float, float] | None = (0.1, 1.0)
        fraction_train_split: float | None = 0.8
        upsample_multiplier: float | None = 20.0
        dropout_tuple: tuple[float, float, float] | None = (0.0, 0.25, 0.25)
        learning_rate: float | None = 0.001
        weight_decay: float | None = 0.01
        smoothing: float | None = 0.3
    }

    class ScalingType {
        <<Enumeration>>
        MINMAX: str = 'minmax'
        MAXABS: str = 'maxabs'
        STANDARD: str = 'standard'
    }

    class RFUserOptions {
        n_estimators: int | None = 100
        n_unlabeled: int | None = 40000
    }

    class ProspectivityOutputLayer {
        system: str
        system_version: str
        model: str = ''
        model_version: str = ''
        model_run_id: str
        output_type: str
        cma_id: str
        title: str
    }

    class TransformMethod {
        <<Enumeration>>
        LOG: str = 'log'
        ABS: str = 'abs'
        SQRT: str = 'sqrt'
    }

    class CreateCriticalMineralAssessment {
        crs: str
        extent: MultiPolygon
        resolution: list[float | int]
        mineral: str
        description: str
        creation_date: datetime = now
    }

    class RawDataType {
        <<Enumeration>>
        MINERAL_SITE: str = 'mineral_site'
        POINT: str = 'point'
        LINE: str = 'line'
        POLYGON: str = 'polygon'
        TIF: str = 'tif'
        VECTOR: str = 'vector'
    }

    class LineString {
        bbox: tuple[float, float, float, float] | tuple[float, float, float, float, float, float] | None = None
        type: Literal['LineString']
        coordinates: list[Position2D | Position3D]
    }

    class Polygon {
        bbox: tuple[float, float, float, float] | tuple[float, float, float, float, float, float] | None = None
        type: Literal['Polygon']
        coordinates: list[list[Position2D | Position3D]]
    }

    class CreateDataSource {
        DOI: str = ''
        authors: list[str] = list
        publication_date: str = ''
        category: LayerCategory
        subcategory: str = ''
        description: str = ''
        derivative_ops: str = ''
        type: LayerDataType
        resolution: list[float | int] = list
        format: DataFormat
        reference_url: str = ''
        evidence_layer_raster_prefix: str = ''
    }

    class DefineProcessDataLayer {
        data_source_id: str
        title: str
        transform_methods: list[TransformMethod | Impute | ScalingType] = list
        label_raster: bool = False
    }

    class ImputeMethod {
        <<Enumeration>>
        MEAN: str = 'mean'
        MEDIAN: str = 'median'
    }

    class fastBNNUserOptions {
        train_size: float | None = 1.0
        init_negatives_multiplier: int | None = 20
        upsample_positives_multiplier: float | None = 0.0
        learning_rate: float | None = 0.001
        training_epochs: int | None = 100
        network_arch_depth: int | None = 2
        network_arch_width: int | None = 1
        network_arch_core_units: list[int] | None = None
        network_arch_head_units: list[int] | None = None
    }

    class CreateProcessDataLayers {
        cma_id: str
        system: str
        system_version: str
        evidence_layers: list[DefineProcessDataLayer] = list
        vector_layers: list[DefineVectorProcessDataLayer] = list
    }

    class SOMTrainConfig {
        size: int = 20
        dimensions_x: int | None = 20
        dimensions_y: int | None = 20
        num_initializations: int | None = 5
        num_epochs: int = 10
        grid_type: SOMGrid | None = 'rectangular'
        som_type: SOMType | None = 'toroid'
        som_initialization: SOMInitialization | None = 'random'
        initial_neighborhood_size: float | None = 0.0
        final_neighborhood_size: float | None = 1.0
        neighborhood_function: NeighborhoodFunction | None = 'gaussian'
        gaussian_neighborhood_coefficient: float | None = 0.5
        learning_rate_decay: LearningRateDecay | None = 'linear'
        neighborhood_decay: NeighborhoodDecay | None = 'linear'
        initial_learning_rate: float | None
        final_learning_rate: float | None
        kmeans: bool | None = True
        kmeans_min: int | None = 1
        kmeans_max: int | None = 10
    }

    LineString ..> Position3D
    LineString ..> Position2D
    MultiPolygon ..> Position3D
    MultiPolygon ..> Position2D
    Point ..> Position3D
    Point ..> Position2D
    Polygon ..> Position3D
    Polygon ..> Position2D
    SOMTrainConfig ..> SOMInitialization
    SOMTrainConfig ..> LearningRateDecay
    SOMTrainConfig ..> SOMType
    SOMTrainConfig ..> NeighborhoodDecay
    SOMTrainConfig ..> SOMGrid
    SOMTrainConfig ..> NeighborhoodFunction
    Impute ..> ImputeMethod
    CreateDataSource ..> LayerCategory
    CreateDataSource ..> LayerDataType
    CreateDataSource ..> DataFormat
    CreateCriticalMineralAssessment ..> datetime
    CreateCriticalMineralAssessment ..> MultiPolygon
    DefineProcessDataLayer ..> Impute
    DefineProcessDataLayer ..> TransformMethod
    DefineProcessDataLayer ..> ScalingType
    DataTypeId ..> RawDataType
    SaveProcessedDataLayer ..> Impute
    SaveProcessedDataLayer ..> DataTypeId
    SaveProcessedDataLayer ..> TransformMethod
    SaveProcessedDataLayer ..> ScalingType
    DefineVectorProcessDataLayer ..> LineString
    DefineVectorProcessDataLayer ..> DataTypeId
    DefineVectorProcessDataLayer ..> Polygon
    DefineVectorProcessDataLayer ..> Point
    DefineVectorProcessDataLayer ..> ScalingType
    DefineVectorProcessDataLayer ..> Impute
    DefineVectorProcessDataLayer ..> TransformMethod
    CreateProspectModelMetaData ..> RFUserOptions
    CreateProspectModelMetaData ..> fastBNNUserOptions
    CreateProspectModelMetaData ..> NeuralNetUserOptions
    CreateProspectModelMetaData ..> SOMTrainConfig
    CreateProcessDataLayers ..> DefineVectorProcessDataLayer
    CreateProcessDataLayers ..> DefineProcessDataLayer
    DataSource ..> LayerCategory
    DataSource ..> LayerDataType
    DataSource ..> DataFormat
    DataSource ..> tuple


Loading

Prospectivity Models

prospectivity models
classDiagram

    class NeuralNetUserOptions {
        likely_negative_range: tuple[float, float] | None = (0.1, 1.0)
        fraction_train_split: float | None = 0.8
        upsample_multiplier: float | None = 20.0
        dropout_tuple: tuple[float, float, float] | None = (0.0, 0.25, 0.25)
        learning_rate: float | None = 0.001
        weight_decay: float | None = 0.01
        smoothing: float | None = 0.3
    }

    class LearningRateDecay {
        <<Enumeration>>
        LINEAR: str = 'linear'
        EXPONENTIAL: str = 'exponential'
    }

    class SOMType {
        <<Enumeration>>
        TOROID: str = 'toroid'
        SHEET: str = 'sheet'
    }

    class RFUserOptions {
        n_estimators: int | None = 100
        n_unlabeled: int | None = 40000
    }

    class SOMInitialization {
        <<Enumeration>>
        RANDOM: str = 'random'
        PCA: str = 'pca'
    }

    class SOMGrid {
        <<Enumeration>>
        HEXAGONAL: str = 'hexagonal'
        RECTANGULAR: str = 'rectangular'
    }

    class NeighborhoodDecay {
        <<Enumeration>>
        LINEAR: str = 'linear'
        EXPONENTIAL: str = 'exponential'
    }

    class fastBNNUserOptions {
        train_size: float | None = 1.0
        init_negatives_multiplier: int | None = 20
        upsample_positives_multiplier: float | None = 0.0
        learning_rate: float | None = 0.001
        training_epochs: int | None = 100
        network_arch_depth: int | None = 2
        network_arch_width: int | None = 1
        network_arch_core_units: list[int] | None = None
        network_arch_head_units: list[int] | None = None
    }

    class NeighborhoodFunction {
        <<Enumeration>>
        GAUSSIAN: str = 'gaussian'
        BUBBLE: str = 'bubble'
    }

    class SOMTrainConfig {
        size: int = 20
        dimensions_x: int | None = 20
        dimensions_y: int | None = 20
        num_initializations: int | None = 5
        num_epochs: int = 10
        grid_type: SOMGrid | None = 'rectangular'
        som_type: SOMType | None = 'toroid'
        som_initialization: SOMInitialization | None = 'random'
        initial_neighborhood_size: float | None = 0.0
        final_neighborhood_size: float | None = 1.0
        neighborhood_function: NeighborhoodFunction | None = 'gaussian'
        gaussian_neighborhood_coefficient: float | None = 0.5
        learning_rate_decay: LearningRateDecay | None = 'linear'
        neighborhood_decay: NeighborhoodDecay | None = 'linear'
        initial_learning_rate: float | None
        final_learning_rate: float | None
        kmeans: bool | None = True
        kmeans_min: int | None = 1
        kmeans_max: int | None = 10
    }

    SOMTrainConfig ..> SOMInitialization
    SOMTrainConfig ..> LearningRateDecay
    SOMTrainConfig ..> SOMType
    SOMTrainConfig ..> NeighborhoodDecay
    SOMTrainConfig ..> SOMGrid
    SOMTrainConfig ..> NeighborhoodFunction


Loading