Skip to content

jriegel/PyOpenJt

 
 

Repository files navigation

PyOpenJt

TOC

  1. Introduction
  2. Jt
  3. Getting Started
  4. License

Screenshot

Introduction

Purpose

The purpose of this library is to make the huge body of Work in PDM systems of big OEMs accessibly to downstream visualization systems, especially game engines.

First step is to build a Python library which read Jt and output a general mesh format like USD and gives enough control for the translation process to account for saddle differences how Parts are formulated in companies.

This leads to Use Pythons scripts to break down common PDM Assembly formats, like PLMXML and STEP to underlying Jt Parts and perform certain transformations:

  • Merge Solids and Parts to bigger mesh structures
  • Filter large PDM Graphs with configurations information
  • Perform different transformations on different Submodules in a large design
  • Transfer information in properties into more sophisticated shader/material mapping

Prior work

All is based on an GPL open source implementation of JT (Jupiter Tessellation) viewer and reader. Forked from Open CASCADE repository.

Used fixes and improvements from following forks

Huge thanks to OpenCascade Company for publishing TKJT and JTAssistand. And also thanks to cbsghost, mmaenz, wwmayer and pgibertini for caring the code through time.

Development Plan

  • Fork project an modernize cMake and dependency management
  • Packaging for Release builds and make first release
  • Access to late load part properties
  • JtDump tool. Dumps all information as JSON
  • Python module and make LSG accessible
  • Jt Mesh to USD Mesh-Definition converter
  • Building Python Test-Cases with corner case Jts
  • Python PLMXML parser
  • Upgrade TKJT to Jt 10.5 specification
  • PyPI Package
  • Remove OpenCascade dependency

Jt

https://en.wikipedia.org/wiki/JT_(visualization_format)

Since Jt is an ISO Standard the documentation is quite expensive! Thankfully the Prostep IVIP published a paper based on the 10.5 standard:

https://www.ps-ent-2023.de/fileadmin/prod-download/PSI14_1_V3_JTIAP_Format_Description_and_annexs.pdf

Getting Started

Windows

This library uses a modern cMake approach and defines all dependencies via VCPKG.

  1. Install and bootstrap VCPKG from https://github.com/microsoft/vcpkg
  2. Run Setup.bat from the root folder of the library

Linux

TBD

Dev-Container

TBD

License

This project is licensed under the GNU General Public License v2.0 - see the LICENSE.txt file for details.

commercial / in-house use

Since TKJT was released under the GPL 2.0 all linked work is treaded under the same terms. That span from the Python module code to the python scripts you write using that Python module (PyOpenJt).

That means:

  1. if you sell software based on PyOpenJt you have to distribute the python scripts with it. All other code which not linking against TKJT or PyOpenJt, you can keep closed source.
  2. if you use PyOpenJt in-house in your company or on your server, you don't have to open your scripts, since you do not distribute the software.

See: https://community.fsfe.org/t/question-about-usage-of-a-gpl-licensed-library-in-a-proprietary-product/364

Since I'm not a lawyer, this is my opinion and no legal advise.

About

OSS OpenJt reader from OpenCascade plus Python binding

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 93.2%
  • CMake 4.9%
  • GLSL 1.3%
  • Other 0.6%