@endJunction endJunction released this Jan 11, 2018 · 1532 commits to master since this release

Assets 7

Overview of changes since 6.0.8 release.

The changes since the prerelease 6.1.0-rc1 contain few bug fixes and improvements of the CI.

Features:

New processes:

Other process' changes:

  • New equation assembly approach for the staggered scheme. With that, the coupling assembly computations are changed from performing assembly across the different Process classes for a coupling to a single Process class for coupled processes, which was assumed only for the monolithic before. With the changes, the original Process class that for monolithic scheme originally can now handle both of the monolithic and staggered schemes. So far, HT classes get the staggered scheme based on this new framework of assembly. #1970
  • Heterogeneous liquid flow properties (#1979, #2017)
  • New boundary conditions added: Nonuniform Dirichlet (#1952) and Neumann (#1891), and normal traction (#1896)
  • Framework for time stepping and a first application of adaptive time stepping, EvolutionaryPIDcontroller, and automatic time step control (#1803).
  • Nodal source terms (#1977)
  • Fix deformation processes to work correctly with PETSc parallelization (#1838).
  • Fix the access to local data of PETScVector (#1797).
  • Add damping factor to global Newton. #2004
  • Extend extrapolator to vectorial quantities and replace the component-wise output of Darcy velocity and the stress/strain in mechanical processes with single vectorial output.

Material model changes

Testing and documentation:

Infrastructure:

  • Fully moved to Conan for automatic third-party library handling. Can be enabled with OGS_USE_CONAN=ON, see docs. #1907
  • Conan version 1.0 is now required.
  • Dropped travis CI environment and added few new tests on Jenkins because of simpler maintenance.

CMake options changes:

  • OGS_EIGEN_DYNAMIC_SHAPE_MATRICES defaults to OFF on Release
    config, ON otherwise. Can be overridden by explicitly setting the option. #1673
  • New OGS_EIGEN_INITIALIZE_MATRICES_BY_NAN defaults to ON for easier spotting of non-initialized matrices. When OFF, the Eigen's default initialization to 0 is skipped resulting in slightly faster execution. #1917
  • Set default Eigen's cmake flag disabling vectorization since this lead to several problems in different environments. #1919 and the issue linked there #1881

Other

  • PETSc config is tested on Jenkins (envinf1)
  • OGS binaries are provided as eve / envinf1 modules. See docs for details. #1753
  • Migrated Data Explorer to Qt5. #1622, #1625
  • Windows builds are tested on MSVC 2017 on own hardware and on MSVC 2015 on AppVeyor. #1802
  • Minimum GCC version is 4.9 (tested on Travis and Docker builds), 6.2 is tested on UFZ cluster system (envinf1). #1810
  • Removed Windows 32-bit builds from testing --> no Windows XP binaries are provided anymore. #1988
  • Migrated Jenkins Pipeline scripts to new syntax called Declarative Pipeline. #1976
  • Tests to check the gradient of shape function by comparing the given and the computed element volumes (#1873).
Pre-release
Pre-release

@endJunction endJunction released this Dec 11, 2017 · 1604 commits to master since this release

Assets 2

Features:

New processes:

Other process' changes:

  • New equation assembly approach for the staggered scheme. With that, the coupling assembly computations are changed from performing assembly across the different Process classes for a coupling to a single Process class for coupled processes, which was assumed only for the monolithic before. With the changes, the original Process class that for monolithic scheme originally can now handle both of the monolithic and staggered schemes. So far, HT classes get the staggered scheme based on this new framework of assembly. #1970
  • Heterogeneous liquid flow properties (#1979, #2017)
  • New boundary conditions added: Nonuniform Dirichlet (#1952) and Neumann (#1891), and normal traction (#1896)
  • Framework for time stepping and a first application of adaptive time stepping, EvolutionaryPIDcontroller, and automatic time step control (#1803).
  • Nodal source terms (#1977)
  • Fix deformation processes to work correctly with PETSc parallelization (#1838).
  • Fix the access to local data of PETScVector (#1797).
  • Add damping factor to global Newton. #2004
  • Extend extrapolator to vectorial quantities and replace the component-wise output of Darcy velocity and the stress/strain in mechanical processes with single vectorial output.

Material model changes

Testing and documentation:

Infrastructure:

  • Fully moved to Conan for automatic third-party library handling. Can be enabled with OGS_USE_CONAN=ON, see docs. #1907

CMake options changes:

  • OGS_EIGEN_DYNAMIC_SHAPE_MATRICES defaults to OFF on Release
    config, ON otherwise. Can be overridden by explicitly setting the option. #1673
  • New OGS_EIGEN_INITIALIZE_MATRICES_BY_NAN defaults to ON for easier spotting of non-initialized matrices. When OFF, the Eigen's default initialization to 0 is skipped resulting in slightly faster execution. #1917
  • Set default Eigen's cmake flag disabling vectorization since this lead to several problems in different environments. #1919 and the issue linked there #1881

Other

  • PETSc config is tested on Jenkins (envinf1)
  • OGS binaries are provided as eve / envinf1 modules. See docs for details. #1753
  • Migrated Data Explorer to Qt5. #1622, #1625
  • Windows builds are tested on MSVC 2017 on own hardware and on MSVC 2015 on AppVeyor. #1802
  • Minimum GCC version is 4.9 (tested on Travis and Docker builds), 6.2 is tested on UFZ cluster system (envinf1). #1810
  • Removed Windows 32-bit builds from testing --> no Windows XP binaries are provided anymore. #1988
  • Migrated Jenkins Pipeline scripts to new syntax called Declarative Pipeline. #1976
  • Tests to check the gradient of shape function by comparing the given and the computed element volumes (#1873).

@bilke bilke released this Apr 4, 2017 · 2912 commits to master since this release

Assets 2

See #1744. Just used this release for DOI generation.

Assets 8

The highlight of the release is the implementation of the Lower-Interface
Elements for both the small deformation process (M) and hydro-mechanics process
(HM) allowing fractures to be incorporated in the solution domain.
For the liquid flow and two-phase flow processes several material models for the
fluids pressure, density, permeability, and viscosity were added.

Features:

  • Implementation of hydro-mechanics (HM) with LIE. #1537-#1541
  • Implementation of small deformation (M) with LIE. #1452
  • Fracture constitutive models. #1434
  • Hydro-Mechanics process. #1508
  • First version of monolithic hydro-thermal process implementation with
    Boussinesq approximation using constant viscosity. #1534
  • Two phase flow process with pp model implementation. #1530
  • Richards flow process implementation. #1473
  • Liquid process. #1468
  • Classes for relative permeability models. #1531
  • Classes for capillary models. #1517, #1578
  • Ehlers single-surface yield function constitutive relation model. #1556
  • Support scaling, GMRES, and Pardiso in Eigen linear solvers. #1509 #1510
  • Piecewise linear Monotonic curve and a generic curve parser. #1529
  • Support searching boundary nodes in MeshLib::NodeSearch. #1459
  • Support specifying the shape function order in process variables. #1503
  • Command line option --unbuffered-std-out to deactivate buffer for standard output. #1514
  • CMake option OGS_FATAL_ABORT for debugging. #1432
  • Set the default OGS_LOG_LEVEL to debug in release builds. #1522
  • Add integration order in input files. #1464

Utilities

New utilities:

New features:

  • extend NodeReordering to correct ordering of nonlinear nodes #1519

Infrastructure:

  • Ctest now works on Windows too by removing time-wrappers. #1480
  • Moved to public Jenkins instance at jenkins.opengeosys.org. #1505
  • Doxygen warnings parser in Jenkins will mark a build as unstable
    if there are Doxygen warnings. #1585
  • Benchmarking on Jenkins now saves the standard output into a file for each
    test. #1528

Fixes:

  • Fix LocalToGlobalIndexMap with mutliple variables and with multiple componets. #1433 #1440
  • Fix PropertyVector<T*> for multi-component case. #1441
  • Fix checking IDs of nonlinear nodes. #1495
  • Fix incorrect use of getNumberOfBaseNodes(). #1515
  • Fix computing sparsity pattern for mixed shape function order cases. #1548
  • Fix that iterations and residuals were not printed when Eigen linear solver fails. #1499
  • Fix all of the Doxygen warnings in the code. #1569 #1573
  • Fix all of the input file/keyword documentation and its generation.

@endJunction endJunction released this Oct 5, 2016 · 12573 commits to master since this release

Assets 2

Features

The main features of this release is the implementation of two new processes,
the small deformation, and the heat conduction. Some extensions were done to
the DOF table to be able to manage multi-component/multi-variable processes.
Also, during implementation of the Robin boundary conditions, the base classes
for the boundary conditions were generalized.

  • Add small deformation process with linear elastic material model. The
    implementation is based on the Kelvin mapping. #1340
  • Added B-Matrices and Kelvin mapping tools for deformation processes. #1359
  • Heat conduction process implementation. #1328
  • Finalize support for multicomponent boundary conditions adding configuration
    parser. #1343
  • Added uniform Robin boundary condition. #1336
  • Added a generic natural boundary condition class. #1337
  • Added Robin boundary condition. #1336
  • Reworked the Parameter class. It now serves as a basis for BCs and ICs. #1357, #1356
  • Added time-dependent Dirichlet BCs. #1380
  • Add calculation of surface flux, tests for groundwater flow. #1429
  • Implemented numerical Jacobian assembly for Newton-Raphson solver. #1352
  • Added the new parameter type "Group" which can be used for setting material
    ID dependent values. #1426
  • Added fluid property class and several fluid density and viscosity models
    based on it. #1398, #1435
  • Enabled solving of axially symmetric problems on 2D meshes for all currently
    implemented processes. #1443
  • Added time measurement for assembly and solvers. #1322
  • Added named functions, out of which expressions can be built up at run-time
    from the prj file, which can be used to output additional nodal quantities. #1314, #1315
  • Added component-wise norms, and flexible convergence criteria for nonlinear
    solvers. #1349, #1342
  • Restructured the time loop. #1364

Utilities

New utilities:

  • createNeumannBc: The tool integrates the given element property and writes
    the computed data as a PropertyVector with the name node_aggregated_gwn
    into the mesh. The tool also outputs an OGS-5 direct source term (Neumann
    boundary condition) data file. #1346
  • scaleProperty for simple rescaling of mesh properties. #1347
  • convertGEO for geometric file conversion, e.g. gli to glm. #1360
  • swapNodeCoordinateAxes to swap node coordinate values, e.g. XY to XZ plane. #1361
    New feature:
  • Support tetrahedra types in generateStructuredMesh. #1353

Infrastructure

  • Migrated all important Jenkins jobs to script-based
    Jenkins Pipeline
    functionality. For an introduction see
    docs.opengeosys.org - Continuous Integration. #1392, #1396, #1404, #1411, #1424, #1428, #1436
  • Moved CMake logic for packaging executable dependencies (such as shared libs)
    to the install and package targets instead of running after each executable
    gets build. #1458
  • Increase minimum clang compiler version to 3.5 in course of updating travis
    build enviroment to Ubuntu LTS 14.04. #1448
  • Added a script that generates crosslinked Doxygen pages out of ctest input
    files #1348

Fixes:

  • Fix an issue that a shape vector was defined as a column vector. Corrected to
    a row vector . #1288
  • Fix usage of boost::optional<T const&>, which has changed in version 1.61. #1385
  • Fix Grid (enlarge bounding box to fit all points). #1369
  • Fix mapping of geometries to mesh surfaces. #1327. #1368
  • Fix transmitting raster data to element properties. #1347
  • Fixed missing XSD files in packages. #1410
  • Fix a shape vector to a row vector. #1288
  • Fix FEFLOW import. #1397
  • Fix NodeReordering to check ordering of each element. #1425
  • Fix builds linking shared VTK library. #1431
  • Fix global Newton iteration counter. #1341
  • Correct few loops over mesh nodes, which should run over the mesh subsets. #1437
  • Fix shape function computation for 2D elements lying in the x-y-plane #1318
  • Fix AddTest, s.t. ctest now really checks results. #1325
  • Made Eigen preconditioner configurable. #1367

@endJunction endJunction released this Jul 5, 2016 · 12573 commits to master since this release

Assets 2

Features:

  • Transferred the TES process, a monolithically coupled THC model for simulating
    thermochemical energy storag devices, from OGS5. #1181
  • Add external ode-solver interface with Sundials CVODE
    library
    . #1109
  • Introduced a general scheme for documenting OGS6 input file settings. #978
  • Add piecewise linear curves parser to the project files. The curves are
    specified by two vectors, the coordinates and values. They can be used for
    example to map temporal dependencies (time-dependent boundary conditions) or
    as approximations of coefficient dependencies (e.g. pressure-saturation
    curves). #1149
  • Extend the LocalAssemblerInterface by adding default implementations of
    pre/postTimestep and assembleJacobian functions. The current time and time
    step size are passed in the preTimestep call to the particular processes. #1214
  • Add support multi-variable/multi-component in the DOF table interface and
    extend the initial conditions to multi-components. #1224
  • Major rework of the general process interface. That also affects the
    interface of concrete processes and local assemblers.
    least squares optimization. #1145
  • Added functionality for the output of secondary variables. #1171
  • Added material properties for zeolite adsorption and Calcium oxide/hydroxide
    reactions. #1178
  • Added copy constructor for the class Surface, minor improvements in GeoLib. #1237
  • Added classes GeoLib::LineSegment and GeoLib::Polyline::SegmentIterator. #1139
  • GMSHInterface can handle stations as constraints. #1212
  • Added functionality to duplicate geometric data. #1229
  • Station names can be modified in Data Explorer #1273

Infrastructure

  • Fix circular dependencies on library level. This allows for dynamic linking
    which is faster than static and can be used in debug builds, where the
    compilation time is more important than the runtime.
    • Enable shared linking of ogs libraries. #1133
    • Break FileIO on ApplicationsLib dependency. #1138
    • Remove MeshLib on FileIO dependency. #1143, #1153
    • Cleanup some of AssemblerLib dependencies. #1166
    • Split AssemblerLib and move to MathLib and NumLib #1208
    • Move InsituLib to MeshLib #1208
    • Remove MathLib depends on NumLib #1208
    • Remove dependency of FileIO on Data Explorer #1302
  • Introduced Conan package manager for automatic fetching of build dependencies, #1141
  • Inconsistent formatting of tabs and spaces was finally resolved: now all
    formatting, indentation and alignment, are done with four spaces. #1201
  • Windows 32-bit builds are disallowed because they are not supported.
    Can be forced by setting OGS_32_BIT=ON. #1230
  • Simplified FindEigen.cmake, #1209
  • git diff --check is run in its own Travis job, #1207
  • Moved some IO implementations from FileIO to BaseLib/IO, GeoLib/IO, MeshLib/IO, #1182, #1235
  • Eigen is not optional anymore #1218
  • Removed OGS_USE_EIGENLIS CMake option. Use OGS_USE_LIS instead #1251

Fixes:

  • Fix linking of Metis in MathLib. #1147
  • Fix memory leaks in GMSHInterface. #1212
  • Fix build with Lis #1267
  • Fixing several small issues with NetCDF import #1169
  • Restructure Applications related modules
    • Move DataHolderLib and FileIO under Applications #1279
  • Remove calling std::abort within libraries. Exeptions are thrown instead. #1245
  • Fix finding Boost with BOOST_ROOT CMake argument #1287
  • Fix linking of Sundials CVODE library #1197
  • Fixed issue where geometry names would be missing after merging geometries #1295
May 1, 2016
[TES] chaged reaction taming strategy

@endJunction endJunction released this Apr 13, 2016 · 12573 commits to master since this release

Assets 9

Release notes

Implementation of several time integration methods and non-linear solver schemes is the major advance in this release. We have chosen to implement a first order implicit quasi-linear system solver for the equations in the form of $M\dot{x} + Kx + b = 0$, where M, K, and b depend on t and x.

The explicit and the implicit Euler, the Crank-Nicholson, and the BDF (second to sixth order) time integration methods are provided. For the non-linear systems, the Picard and Newton methods are available. See implementation details in the doxygen documentation.

Overall stability of the code was improved with recent usage of clang's address and undefined behaviour sanitizers.

Features:

  • Added an ODE solver library that can solve transient and nonlinear problems
    (see http://doxygen.opengeosys.org/df/d35/group__ODESolver.html).
  • Move up common Process parts from particular GroundwaterFlow process
    implementation. #951, #982
  • Separate Dirichlet boundary condition class implementation. #963
  • Split process output and post timestep. #998
  • Added pre- and postTimestep and -Iteration hooks to processes. #1094, #1100, #1101
  • Added a new configuration tree parser
    • Checks configuration parameters more strictly, automatically prints error/warning messages.
    • Requires Boost >= 1.56 because of boost::optional with move semantics.
    • Command line argument --config-warnings-nonfatal that keeps OGS from terminating on warnings during
      configuration file parsing (errors still makes it terminate).
  • Improved axis aligned bounding box:
    • Is now a from the right half-open interval.
    • Removed template from class declaration.
  • Improved MeshLib: Class MeshElementGrid implements a grid data structure supporting search operations.
  • Added cmake option OGS_EIGEN_DYNAMIC_SHAPE_MATRICES that makes OGS use dynamically.
    allocated shape matrices.
  • Added several cmake options for selecting which element types, dimensions and
    orders to be built. Selecting only few element types speeds up compilation
    significantly. #1092
  • Added a command line argument of -l for OGS cli and testrunner to specify verbosity of logging. #1056
  • Added possibility to specify after which timesteps there shiuld be output.
  • Added possibility to specify timesteps of different size for use with
    transient processes.

DataExplorer and utilities

  • Added command line tool for creating layered meshes from raster files
  • Made OGSFileConverter as a separate library
  • Add a new functionality to the raster file to structured grid conversion, which can now convert pixel values in user-defined scalar arrays
  • Improved DataExplorer, which now enables the possibility to display all scalar arrays in mesh information window.
  • Added generation of structured meshes to DataExplorer
  • Restructured mesh creation access in DataExplorer
  • Added a new functionality to add mesh layers to existing meshes in DataExplorer
  • Reworked tools:
    • CreateBoundaryConditionsAlongPolyline
    • AddTopLayer
    • ResetPropertyInPolygonalRegion
    • removeMeshElements

Infrastructure

Documentation

Fixes

  • Fix bugs in GeoLib:
    • lineSegmentIntersects.
    • Polygon::splitPolygonAtIntersection.
    • Grid.
  • GeoMapper: Refactoring few methods, c++11. #977
  • Rework FileIO::GMSH interface
    • Process geometries located other than in the x-y-plane.
    • Respect the scaling factor for Stations.
    • Fix memory leaks.
    • Added/modified tests for GML-, GMS- and TetGen-files.

@bilke bilke released this Jan 5, 2016 · 12573 commits to master since this release

Assets 9

Release notes

| Released on 2015/01/05, GitHub Release Link

Features:

  • Parallel computing framework for FEM by using PETSc, which also includes
    • Parallel input of partitioned mesh data.
    • Parallel output of solutions by using pvtu data format.
  • New data structures for mesh properties are used everywhere replacing
    Element's value member.
  • The penalty method to impose first-type boundary conditions was substituted
    with a non-penalty method for LIS and Eigen linear solvers.
  • Support for multiple nodal variables is extended to the boundary conditions,
    the sparsity pattern.
  • Passing of linear solver options from the project files is now possible.
  • The global matrix and global vector type of indices is consistent with the
    linear solver library being used.

Infrastructure

  • Added CMake option OGS_CPU_ARCHITECTURE, #858, downloadable binaries build by Jenkins should now run on more CPUs
  • Added CMake options for Boost, VTK and Eigen (OGS_LIB_BOOST, ...) to specify if libs are searched on the system first, then build them locally (Default), or you can specify to just use system libs (System) or force a local build (Local)
  • Added CMake options for enabling Clang sanitizer:
    • OGS_ADDRESS_SANITIZER
    • OGS_UNDEFINED_BEHAVIOR_SANITIZER
  • The zlib library is removed from ThirdParty directory.
  • A LIS solver interface using Eigen's sparse matrices is now available through
    CMake option OGS_USE_EIGENLIS.
  • CMake configuration uses ccache if available.

Documentation

Fixes

  • Fix all ogs-internal warnings on all OS.
  • Move eigen solver compute call to solve(); different fix for 0237275

@bilke bilke released this Sep 22, 2015 · 12573 commits to master since this release

Assets 9

| Released on 2015/09/21, GitHub Release Link

Release notes

Features:

  • Mesh properties are now used for:
    • heterogeneous "initial conditions" (actually a start solution vector for the elliptic problem).
    • spatially heterogeneous hydraulic conductivity values in the groundwater flow process.
  • First steps towards time dependent problems: Time loop integration for processes is provided.
  • Interpolation of nodal quantities on elements using shape functions.
  • Mesh generator can create surface meshes according to a given function

? - DataExplorer extensions:

  • Utilities:
    • MoveGeometry
  • The DOF table handles now all of the provided element types: Hex 8 and 20, Line 2 and 3, Prism 6 and 15, Pyramid 5 and 13, Quad 4, 8, and 9, Tet 4 and 10, Triangle 3 and 6.
  • Eigen linear solver library can be used for solution of the linear systems of equations.
  • Octree data structures for fast searches
    • Volumetric and surface grid
    • ElementSearcher NodeSearcher improvements
  • Generalized the computation of rotation matrix to xy

Fixes

  • FEFLOW interface supports element sets now.
  • Reduce compilation times by using forward declarations and removing unnecessary includes and using explicit template instantiation for often required classes.
  • GMSH2OGS: fixed bug in cases GMSH mesh does not contain line elements
  • CreateBoundaryConditionsAlongPolylines: fixed bug concerning the GeoLib and point ids.
  • PointVec corrected point id map
  • Shape interface creates polylines in a consistent state

Infrastructure

Test examples

  • Test case: groundwater flow in the Unstrut catchment (model consists approximately of 9e6 hexahedral cells)
    • Simulations using homogeneous and heterogeneous hydraulic conductivity
    • Integrated rivers as Dirichlet type boundary conditions
    • Integrated groundwater recharge (spatialy homogeneous) as Neumann boundary condition

unstrut_heterogeneous_rivers_top_layer_diff_recharge-no_recharge

Next steps

The next big step will be the implementation of a parallelization scheme using PETSc library

In development

  • OGS#PETSc interface for parallel computing
  • Solving of time dependent problems

Planned

  • Implementation of a linear parabolic pde solver
  • Extending the linear elliptic solver to non-linear problems