Skip to main content

Python library for working with DNV HydroD workspaces and workflows.

Project description

dnv-hydrod

dnv-hydrod is a Python library that provides seamless integration with DNV HydroD through pythonnet, enabling programmatic access to HydroD workspace files (.hydx) and modeling APIs.

This library automatically locates your HydroD installation, loads required .NET assemblies, and provides a Pythonic interface for workspace operations, analysis execution, and concept manipulation.

Requirements:

  • DNV HydroD 9.0 and higher (must be installed on the system)

  • Python 3.10, 3.11, 3.12, or 3.13 (3.14+ not supported)

  • .NET Desktop Runtime matching the version bundled with your HydroD installation, installed globally (system-wide):

    The self-contained runtime shipped inside the HydroD installation folder cannot be used by this package because of a known incompatibility between pythonnet 3.0.5 and a self-contained CoreCLR host (crash in ModuleObject.tp_setattro the first time HydroD's scripting service calls AddNamespace). If the required runtime is missing, dnv-hydrod raises a clear RuntimeError on import with a download link.

Installation

Installing from PyPI (when published):

pip install dnv-hydrod

Quick Start

from dnv.hydrod import *

# Open existing workspace with license keys
with WorkspaceSession(
    r"C:\Projects\myworkspace.hydx",
    license_keys=['WIND']
) as session:
    # Access workspace concepts
    analyses = FindConcept("/Workspace/Analyses")
    
    # Create and execute custom analysis
    ca = CustomAnalysis(analyses, "MyAnalysis")
    ca.InlineScript = """
import time
print('Starting analysis...')
time.sleep(2)
print('Analysis completed!')
"""
    ca.Execute()

Key Features

  • Automatic HydroD Detection: Uses DNV Application Version Manager to locate HydroD installation
  • Context Manager Support: Safe workspace handling with automatic cleanup
  • Pythonic API: Clean, intuitive interface for HydroD operations
  • Embedded Modules: Access to Python utilities embedded in HydroD .NET assemblies

Documentation

This library provides Python bindings to HydroD's .NET API. For comprehensive information about available classes, methods, workflows, and HydroD concepts, please refer to the HydroD Documentation and API reference included with your HydroD installation.

Usage Examples

Creating a New Workspace

from dnv.hydrod import *

# Create new workspace with license keys
with WorkspaceSession(
    r"C:\Projects",
    "NewWorkspace",
    license_keys=['WIND']
) as session:
    # Workspace is automatically saved as NewWorkspace.hydx
    print("Workspace created successfully!")

Working with Concepts

from dnv.hydrod import *

with WorkspaceSession(
    r"C:\Projects\myworkspace.hydx",
    license_keys=['WIND']
) as session:
    # Find concepts using path
    load_cases_table = FindConcept("/Workspace/Analyses/DesignLoadCasesTable1")

    # Create new DesignLoadCase entry
    udlc1 = DesignLoadCase()
    udlc1.Selected=True
    udlc1.Name="DLC_new"
    udlc1.SimaBladedFolder="Inputs\\Sima_ULS_Hs11_Deg90_Vw23"
    udlc1.SimaBladedFileName="sima"
    udlc1.EnvironmentalLoadFactor=0.8
    udlc1.PermanentLoadFactor=0.8
    udlc1.StartTime=300
    udlc1.StopTime=340

    # Add new DesignLoadCase entry to "UlsDesignLoadCases1" concept
    load_cases_table.DesignLoadCases.Add(udlc1)

Generate Runs and run ULS workflow through Python

from dnv.hydrod import *

with WorkspaceSession(
    r"C:\Projects\myworkspace.hydx",
    license_keys=['WIND']
) as session:
    runFolder = FindConcept("/Workspace/Analyses/Workflow1/Runs")
    # If the run folder already exists, delete it to remove previous results
    if (runFolder):
        Delete(runFolder)

    workflow = FindConcept("/Workspace/Analyses/Workflow1")
    workflow.GenerateRuns()
    workflow.Execute()

Architecture

  • load_assemblies.py: Initializes .NET runtime, locates HydroD, loads assemblies
  • workspace_utils.py: Provides WorkspaceSession and utility functions
  • Embedded modules: Python code extracted from HydroD .NET assemblies at runtime

Limitations

  • HydroD must be installed on the system

License

This project is licensed under the MIT License. See the LICENSE file in the package directory for full license text.

Support

For issues, questions, or feedback, please contact DNV software support at software.support@dnv.com.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dnv_hydrod-1.0.3rc64.tar.gz (61.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dnv_hydrod-1.0.3rc64-py3-none-any.whl (65.6 kB view details)

Uploaded Python 3

File details

Details for the file dnv_hydrod-1.0.3rc64.tar.gz.

File metadata

  • Download URL: dnv_hydrod-1.0.3rc64.tar.gz
  • Upload date:
  • Size: 61.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for dnv_hydrod-1.0.3rc64.tar.gz
Algorithm Hash digest
SHA256 6cfd9bb5d13109a98efc9a5c9a5d9b54e9d8afbd154e131874694058b900a16f
MD5 cfca918ee8ff5b1594f4fa538561fbf6
BLAKE2b-256 097fc37ebfd65d72215ea43cea13fcc262f2907d69b0d7b18fa0fcbe9886c0c1

See more details on using hashes here.

File details

Details for the file dnv_hydrod-1.0.3rc64-py3-none-any.whl.

File metadata

  • Download URL: dnv_hydrod-1.0.3rc64-py3-none-any.whl
  • Upload date:
  • Size: 65.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for dnv_hydrod-1.0.3rc64-py3-none-any.whl
Algorithm Hash digest
SHA256 e2fe9e7338f6fe6225b4ff183a385f642073e18da14c4971bd8d54eae8ee622d
MD5 e66a0ba37659fd29afe894d1c3f1f900
BLAKE2b-256 69b250c7a2a8d201fca3d89d34fbf4528fe643324b16fa92a1d2662bb38b0c2f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page