earthwork-net-model / README.md
mac999's picture
Update README.md
42cfbd2 verified
|
raw
history blame
4.91 kB
metadata
language:
  - en
tags:
  - Earthwork
  - Quantity
  - Estimation
  - CAD
  - deep-learning
  - LLM
  - MLP
  - LSTM
  - Transformers
  - BERT
license: mit
datasets:
  - custom
  - cad-drawings
metrics:
  - accuracy
  - loss
library_name: transformers
model_name: EarthworkNet
widget:
  - example_input: Cross-sectional data for earthwork quantity prediction
  - example_output: 'Predicted earthwork quantity such as cut, refill etc : 1234 m³'

Earthwork Network Architecture (ENA)

Overview

The Earthwork Network Architecture (ENA) is the deep learning model designed to compare the accurate estimation prediction of earthwork quantities in construction. This repository includes four distinct deep learning models—MLP, LSTM, Transformers, and LLM-based architectures (BERT)—tailored for automating and enhancing earthwork quantity estimation from CAD-based cross-sectional drawings.

Key Features:

  1. Multi-Model Approach:

    • MLP-Based Model: Lightweight and efficient for smaller datasets.
    • LSTM-Based Model: Ideal for sequential dependencies in time-series data.
    • Transformer-Based Model: Handles complex relationships and large datasets.
    • LLM-Based Model (BERT): Excels in processing contextual and unstructured data.
  2. Automated Data Processing:

    • Converts CAD cross-sectional drawings into structured datasets.
    • Employs a Half-Edge Topology Structure to tokenize and preprocess geometrical features.
  3. Enhanced Performance:

    • Provides superior accuracy in Quantity Takeoff Classification (QTC) for earthwork with reduced loss metrics.
    • Demonstrates robust generalization for unseen datasets, validated through a real-world road construction project.

Research Basis:

The ENA is detailed in the paper Earthwork Network Architecture (ENA): Research for Earthwork Quantity Estimation Method Improvement with Large Language Model. It showcases a comparative analysis of the ENA models and demonstrates the advantages of LLM-based approaches in construction engineering.

Usage

Prerequisites

  • Programming Language: Python 3.8 or above. PyTorch (torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118)
  • Libraries: Install the required libraries using pip install. Detailed dependencies will be provided in the code files.
    pip install json os re logging torch numpy matplotlib seaborn transformers scikit-learn tqdm
    pip install pandas scipy trimesh laspy open3d pyautocad pywin32
    

Data Preparation

  1. Prepare Drawing File:

    • Prepare CAD cross-sectional drawings as input files and load it on Autocad (./input/cross_section_sample_drawing.dwg). Run the below program to extract the entities per each cross-section in the drawing. In addition, you can define the earthwork item's layer name in config.json.
    python create_earthwork_dataset.py --config config.json --output output/ --view output/chain_chunk_6.json
    
    • In Autocad, you can select the cross-section entities using command powered by create_earthwork_dataset program. In reference, we assume that each earthwork item's layer including entities were segmented(Please refer to the below paper).
  2. Prepare Train Dataset:

    • Use the provided scripts to preprocess and tokenize geometrical features.
    python prepare_dataset.py --input output/ --output dataset/
    

Training and Evaluation

  1. Training Data (TBD):
    • Features are tokenized into sequences for MLP, LSTM, Transformers, and LLM models. We'll upload the train source file after arrangement.
    python train_ena_model.py --model_type [MLP|LSTM|Transformer|LLM]
    
  2. Run and Evaluate ENA model:
    • Run the below program to run and test the each ENA model. It will generate log and graph image files to check the performance.
    python ena_run_model.py
    

Results

  • Best Model: LLM-based ENA achieved a QTC accuracy of 97.17%, outperforming other architectures in accuracy and stability.
  • Performance Trade-Offs: LLMs provide high accuracy but require significant computational resources compared to other models.

Coming Soon

  • Source codes for ENA models.
  • Step-by-step tutorials for dataset preparation and model training.

License

This project is licensed under the MIT License.

Citation

If you use this repository, please cite: Kang, T.; Kang, K. Earthwork Network Architecture (ENA): Research for Earthwork Quantity Estimation Method Improvement with Large Language Models. Appl. Sci. 2024, 14, 10517. https://doi.org/10.3390/app142210517