bedrock-ge

Bedrock's Python library for geotechnical engineering.

https://github.com/bedrock-engineer/bedrock-ge

Science Score: 67.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
    Found CITATION.cff file
  • codemeta.json file
    Found codemeta.json file
  • .zenodo.json file
    Found .zenodo.json file
  • DOI references
    Found 3 DOI reference(s) in README
  • Academic publication links
    Links to: zenodo.org
  • Academic email domains
  • Institutional organization owner
  • JOSS paper metadata
  • Scientific vocabulary similarity
    Low similarity (12.2%) to scientific vocabulary

Keywords

aec aeco ags ags3 ags4 bedrock bim borehole civil-engineering geospatial geospatial-data geotechnical-engineering gi-data gis ground-engineering ground-investigation subsurface underground
Last synced: 6 months ago · JSON representation ·

Repository

Bedrock's Python library for geotechnical engineering.

Basic Info
  • Host: GitHub
  • Owner: bedrock-engineer
  • License: apache-2.0
  • Language: Python
  • Default Branch: main
  • Homepage: https://bedrock.engineer/
  • Size: 87.3 MB
Statistics
  • Stars: 17
  • Watchers: 1
  • Forks: 2
  • Open Issues: 13
  • Releases: 7
Topics
aec aeco ags ags3 ags4 bedrock bim borehole civil-engineering geospatial geospatial-data geotechnical-engineering gi-data gis ground-engineering ground-investigation subsurface underground
Created about 2 years ago · Last pushed 7 months ago
Metadata Files
Readme License Code of conduct Citation

README.md

Bedrock logo

Bedrock, the Open-Source Foundation for Geotechnical Engineering


Tests PyPI Python DOI


🌐 Website: https://bedrock.engineer/

📃 Documentation: https://bedrock.engineer/docs

📃 API Reference: https://bedrock.engineer/reference/

🖥️ Source Code: https://github.com/bedrock-engineer/bedrock-ge

🐍 bedrock-ge on PyPI: https://pypi.org/project/bedrock-ge/

🔗 LinkedIn: https://www.linkedin.com/company/bedrock-engineer


Overview

Definition of Bedrock

In an abstract sense, the bedrock refers to the main principles something is based on. [1]

In the real world, the bedrock is the hard area of rock in the ground that holds up the loose soil above. [1]

In many civil engineering projects, the identification of the bedrock through digging, drilling or geophysical methods is an important task, which greatly influences (geotechnical) design. [2]

Sources: [1] Bedrock | Cambridge Dictionary, [2] Bedrock | Wikipedia

Ground Investigation (GI) data is often trapped in legacy formats that limit analysis and visualization possibilities. bedrock-ge lets you transform this data from specialized geotechnical formats and common tabular formats (Excel, CSV) into modern, standardized geospatial data.

This standardization lets you bridge the gap between raw geotechnical data, the modern Python (geo)scientific ecosystem and modern geospatial tools. This gives geotechnical engineers greater flexibility in visualization, modeling, and integration across different software environments while avoiding vendor lock-in. For example, this enables connecting your GI data with GIS as well as BIM environments through platforms like Speckle.

The purpose of Bedrock is NOT to become THE standard for geotechnical data, because we don't need 15 instead of 14 competing standards.

Highlights

📖 Read / write Ground Investigation (GI) data in different formats

| Data Format | Read | Write | | ----------- | ---- | ----- | | AGS 3 | ✅ | ❌ | | AGS 4 | ✅ | ✅ | | Excel | ✅ | ✅ | | CSV | ✅ | ✅ | | JSON | ✅ | ✅ | | GeoJSON | ✅ | ✅ |

Do you need another format? Like DIGGS, NADAG, GEF, or something else? Let us know by creating an issue or starting a discussion.

Also, if you have a project with publicly available GI data, please share that in a discussion, such that we can create a tutorial from it.

✅ Validate your GI data

bedrock-ge comes with data validation to make sure that you can combine Ground Investigation data from multiple files into a single geospatial database with consistent relationships between GI locations, samples, in-situ measurements and lab tests.

This data validation mechanism (based on pandera) is easily extensible, giving you the power to add your own data validation criteria.

🗺️ Put your GI data from multiple files into a single 3D geospatial database

For example, you can take GI data from 100 AGS files and combine them into a single a GeoPackage (like a Shapefile, but then waaay better). Such a GeoPackage can then be loaded into ArcGIS, where you can visualize your GI data in 3D:

Kai Tak, Hong Kong, 3D GI data visualization in ArcGIS
GI data in Kai Tak, Hong Kong. Click here to explore for yourself.

🟦 Put your GI data into Speckle

From ArcGIS or QGIS you can publish your GI data to Speckle and then visualize it together with your ground models and civil engineering designs:

Kai Tak, Hong Kong, data from many sources in Speckle.
Models from Rhino, Revit, Civil3D + context & GI data from Q/ArcGIS. Click here to explore for yourself.
GI data, the derived Leapfrog ground model and a tunnel in Speckle.
GI data, the derived Leapfrog ground model and a tunnel in Speckle. Click here to explore for yourself.

Moreover, your GI data becomes available in all the software that Speckle has connectors for.

🔓 Free and Open Source Software

bedrock-ge is Free and Open Source Software (FOSS), meaning it gives you full access to the code, and you can customize bedrock-ge to integrate with other tools and fit your workflows and project needs.

As the name implies, FOSS is free to use, so you're not tied to expensive software licenses or locked into a specific software vendor.

You can give feedback and contribute, such that together we can build the tools we've always wanted and needed.

Installation

We recommend to use uv to manage Python for you. Using uv, you can add bedrock-ge to your Python project and install it in your project's virtual environment by running:

bash uv add bedrock-ge

It's also possible to install bedrock-ge from PyPI (Python Packaging Index) using pip:

bash pip install bedrock-ge

Feedback

Got some feedback, a great idea, running into problems when working with Bedrock or just want to ask some questions?

Please feel free to:

  1. Open an issue for feature requests or bug reports: bedrock-ge issues,
  2. Start a discussion in this GitHub repo: Bedrock discussions,
  3. Or start a discussion on the Speckle community forum if that's more appropriate: Speckle community forum

All feedback and engagement with the Bedrock community is welcome.

Contributing

Contributing isn't scary. Contributing isn't just about writing code:

  • Spread the word about Bedrock
  • Use Bedrock and provide feedback
  • Share how you use Bedrock
  • Help each other out, e.g. by replying to questions in the discussions or bedrock-ge issues
  • Documentation and tutorials
  • Most pages on the bedrock.engineer website can be edited, so if you see a spelling mistake or have a suggestion on how to explain something better, click this button to make a contribition.
Edit this page on GitHub button on bedrock.engineer
  • If you would like to contribute code, awesome! Please create an issue for what you'd like to contribute. If you don't know how to get started, please indicate this in your issue, and we'll help you out.

Maintainers

Joost

I studied geotechnical engineering and applied geophysics and then worked for Arup for 4 years as a geotechnical engineer and computational designer.

During my time at Arup I worked a lot on bringing computational design into the world of geotechnical engineering, and on bridging the gaps between geotechnical engineering and structural engineering.

Bedrock is the Free and Open Source Software (FOSS) that I wish existed when I worked as a geotechnical engineer at Arup.

Jules

I studied Applied Geoscience (Petroleum Engineering Reservoir Geology) but frustration with technical software led me to learn to code and as a result, I mostly worked in software development.

Over the past 5 years, I’ve worked on data-rich applications across various domains, specifically in frontend development. My primary interest is figuring out how to build tools for more thoughtful display and processing of technical information, for geoscience in particular.

Contributors

Please take a look at the contributors page.

Professional Support

While bedrock-ge is an Free Open Source Software (FOSS) project, you might be looking for professional support implementing it, contact info@bedrock.engineer for more information.

Owner

  • Name: Bedrock
  • Login: bedrock-engineer
  • Kind: organization
  • Email: info@bedrock.engineer
  • Location: Netherlands

The Open Source Foundation for Ground Engineering

Citation (CITATION.cff)

cff-version: 1.2.0
title: >-
  Bedrock, the open-source foundation for geotechnical
  engineering.
message: >-
  If you use this software, please cite it using the
  metadata from this file.
type: software
authors:
  - given-names: Joost
    family-names: Gevaert
    email: joost.gevaert@bedrock.engineer
    affiliation: Bedrock
    orcid: 'https://orcid.org/0000-0002-6267-6888'
  - given-names: Jules
    family-names: Blom
    email: jules.blom@bedrock.engineer
    affiliation: Bedrock
identifiers:
  - type: doi
    value: 10.5281/zenodo.16270261
    description: >-
      The concept DOI of bedrock-ge. This DOI represents all
      versions of bedrock-ge, and will always resolve to the
      latest one.
repository-code: 'https://github.com/bedrock-engineer/bedrock-ge'
url: 'https://bedrock.engineer/'
keywords:
  - ground investigation
  - geotechnical engineering
  - ground engineering
  - geospatial
  - gis
  - bim
  - ags
  - gef
license: Apache-2.0

GitHub Events

Total
  • Create event: 17
  • Release event: 2
  • Issues event: 16
  • Watch event: 5
  • Delete event: 9
  • Issue comment event: 31
  • Push event: 127
  • Pull request review event: 25
  • Pull request review comment event: 25
  • Pull request event: 47
Last Year
  • Create event: 17
  • Release event: 2
  • Issues event: 16
  • Watch event: 5
  • Delete event: 9
  • Issue comment event: 31
  • Push event: 127
  • Pull request review event: 25
  • Pull request review comment event: 25
  • Pull request event: 47

Packages

  • Total packages: 1
  • Total downloads:
    • pypi 180 last-month
  • Total dependent packages: 0
  • Total dependent repositories: 0
  • Total versions: 8
  • Total maintainers: 1
pypi.org: bedrock-ge

Bedrock's Python library for geotechnical engineering.

  • Versions: 8
  • Dependent Packages: 0
  • Dependent Repositories: 0
  • Downloads: 180 Last month
Rankings
Dependent packages count: 9.3%
Average: 30.9%
Dependent repos count: 52.4%
Maintainers (1)
Last synced: 6 months ago

Dependencies

pyproject.toml pypi
  • pandas *