Skip to main content

Python package: genesynth

Project description

[![Python packages](https://github.com/sterling312/genesynth/actions/workflows/github-actions-unittests.yaml/badge.svg)](https://github.com/sterling312/genesynth/actions/workflows/github-actions-unittests.yaml)

# genesynth This library is used to synthetically generate structured data based on configuration to be used for testing as well as structured data training purposes. The approach of the library is to leverage as much as C-level python packages such as numpy and scipy to generate data at field level, one type at a time, and use graph approach to piece together the complex dependency as well as de-normalization/sampling from each fields to construct data in a scalable manner fast.

# install ` pip install genesynth `

# example ` $ python -m genesynth.server --host=0.0.0.0 -p 8080 ` ` $ make run `

` $ python -m genesynth.cli -f tests/test.yaml --stdout ` ` $ make cli FILENAME=$(pwd)/tests/test.yaml `

# project status

## supported feature * load yaml as configuration file * arbitrary row size support * data type mapping with configurable parameters * JSON (semi-structured data) support * improved data type support * foreign relationship support * DOT file graph * table graph * built-in orchestrator using graph * thread and process support * intermediary data temporary cache * graph visualization * GenAI based field-level data generation (ollama & openai)

## key features to add * add yaml validator * fix header support * additional output file formats (JSON, PSQL dump, CSV with quotes, etc) * add support for JSON arrays * improve constraint support * add support for quoted string * add support statistical distribution via kernel convolution * optimize orchestration and disk cache efficiency * optimize thread/process based generation * convert serial to autoincrement constraint for integer type * convert password to constraint of string type

## nice to have features to add * support external scheduler * support NLP based text generation * support sklearn * support integration with pytorch embedding * support for object reference via $ref * fix compatibility with [JSON schema array notation](https://json-schema.org/understanding-json-schema/reference/array.html#items) * fix when json array child object appears as separate items

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

genesynth-0.5.5.tar.gz (22.7 kB view details)

Uploaded Source

Built Distribution

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

genesynth-0.5.5-py3-none-any.whl (29.1 kB view details)

Uploaded Python 3

File details

Details for the file genesynth-0.5.5.tar.gz.

File metadata

  • Download URL: genesynth-0.5.5.tar.gz
  • Upload date:
  • Size: 22.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for genesynth-0.5.5.tar.gz
Algorithm Hash digest
SHA256 1c3d95622edefd85b20b9f0008d732fa20a1bde236db9581bebdad0be403c5c4
MD5 49400a61ac200e364155a0c9d33dba1d
BLAKE2b-256 cfe6916244063e456eb0b95601a519e8fa6c71342f2b165ef2f7ca2033ee495b

See more details on using hashes here.

File details

Details for the file genesynth-0.5.5-py3-none-any.whl.

File metadata

  • Download URL: genesynth-0.5.5-py3-none-any.whl
  • Upload date:
  • Size: 29.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for genesynth-0.5.5-py3-none-any.whl
Algorithm Hash digest
SHA256 d6a46fe5f9583b86e6415327b299598ea241f04941445def88fd8b4859d61d45
MD5 19b00e949942b99c417d55dffa6a13f7
BLAKE2b-256 6eaf81cd1cf13c053e0c71ff6d8e7324af16aebaa897ad61f7393233bdb59653

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