No project description provided
Project description
DATAMIMIC Community Edition ๐
Introduction
Welcome to DATAMIMIC, the Model-Driven and AI-powered platform that revolutionizes test data generation! By leveraging advanced AI and model-driven technologies, DATAMIMIC enables developers and testers to create realistic, scalable, and privacy-compliant test data with ease.
DATAMIMIC Feature Overview ๐ฏ
Core Features ๐ต
๐ง Model-Driven Generation
- Create sophisticated data models for consistent test data generation
- Define complex relationships between entities
- Support for nested and hierarchical data structures
๐ Data Types & Integration
- Basic Data Types Support
- All standard primitive types
- Complex data structures
- Custom data type definitions
- Core Database Integration
- RDBMS support (PostgreSQL, MySQL, Oracle)
- MongoDB integration
- Basic import/export functionality
๐ก๏ธ Data Privacy & Compliance
- GDPR-compliant data anonymization
- Basic pseudonymization capabilities
- Data masking for sensitive information
- Configurable privacy rules
โก Core Capabilities
- High Performance Engine
- Optimized for large datasets
- Parallel processing support
- Memory-efficient operations
- Python Integration
- Native Python API
- Seamless dependency management
- Python script extensions
- Basic Extensibility
- Custom generator support
- Plugin architecture
- Basic scripting capabilities
Enterprise Features ๐ฃ
๐ง AI-Powered Generation
- GAN-based Synthesis
- Realistic data patterns
- Learning from existing datasets
- Pattern replication
- LLM Integration
- Natural language content
- Context-aware generation
- Semantic consistency
- Automatic Modeling
- Schema inference
- Pattern detection
- Model optimization
๐ Advanced Integrations
- Streaming Support
- Kafka integration
- Real-time data generation
- Stream processing
- Enterprise Formats
- EDI processing
- Advanced XSD handling
- Custom format support
- Advanced Connectors
- Enterprise systems
- Cloud platforms
- Legacy systems
๐ก๏ธ Enhanced Privacy Features
- Advanced Anonymization
- Context-aware masking
- Reversible anonymization
- Custom privacy rules
- Compliance Tools
- Audit logging
- Compliance reporting
- Policy enforcement
- Enterprise Security
- Role-based access
- Encryption support
- Security audit trails
๐ Advanced Data Validation
- Validation Framework
- Custom rule engines
- Complex validation logic
- Cross-field validation
Why Use DATAMIMIC?
Traditional test data generation can be time-consuming and may compromise data privacy. DATAMIMIC addresses these challenges by:
- Reducing Time-to-Market: Quickly generate test data without manual intervention.
- Enhancing Test Coverage: Simulate diverse data scenarios for comprehensive testing.
- Ensuring Compliance: Maintain data privacy and comply with legal regulations.
- Improving Data Quality: Generate realistic data that mirrors production environments.
Installation
Prerequisites
- Operating System: Windows, macOS, or Linux
- Python: Version 3.10 or higher
- Optional: uv Package Manager for development setup GitHub
User Installation
The simplest way to get started with DATAMIMIC is through pip:
pip install datamimic-ce
Verify the installation:
datamimic --version
Developer Installation
For contributors and developers who want to work with the source code:
-
Install uv Package Manager:
pip install uv
-
Clone and set up the repository:
git clone https://github.com/rapiddweller/datamimic.git cd datamimic uv sync
Usage Guide
Basic Usage
-
Create a new data generation project:
datamimic init my-project cd my-project
-
Configure your data model in
datamimic.xml:<setup> <generate name="datamimic_user_list" count="100" target="CSV,JSON"> <variable name="person" entity="Person(min_age=18, max_age=90, female_quota=0.5)"/> <key name="id" generator="IncrementGenerator"/> <key name="first_name" script="person.given_name"/> <key name="last_name" script="person.family_name"/> <key name="gender" script="person.gender"/> <key name="birth_date" script="person.birthdate" converter="DateFormat('%d.%m.%Y')"/> <key name="email" script="person.family_name + '@' + person.given_name + '.de'"/> <key name="ce_user" values="True, False"/> <key name="ee_user" values="True, False"/> <key name="datamimic_lover" constant="DEFINITELY"/> </generate> </setup>
-
Generate data:
datamimic run datamimic.xml
-
Access the generated data in the
outputdirectory.json export:
[ {"id": 1, "first_name": "Mary", "last_name": "Mcgowan", "gender": "female", "birth_date": "1946-05-15T00:00:00", "email": "Mcgowan@Mary.de", "ce_user": false, "ee_user": true, "datamimic_lover": "DEFINITELY"}, {"id": 2, "first_name": "Gabrielle", "last_name": "Malone", "gender": "female", "birth_date": "1989-11-27T00:00:00", "email": "Malone@Gabrielle.de", "ce_user": false, "ee_user": true, "datamimic_lover": "DEFINITELY"}, {"id": 4, "first_name": "Margaret", "last_name": "Torres", "gender": "female", "birth_date": "2006-07-13T00:00:00", "email": "Torres@Margaret.de", "ce_user": false, "ee_user": false, "datamimic_lover": "DEFINITELY"}, {"id": 5, "first_name": "Monica", "last_name": "Meyers", "gender": "female", "birth_date": "1983-07-22T00:00:00", "email": "Meyers@Monica.de", "ce_user": true, "ee_user": false, "datamimic_lover": "DEFINITELY"}, {"id": 6, "first_name": "Jason", "last_name": "Davis", "gender": "male", "birth_date": "1941-07-05T00:00:00", "email": "Davis@Jason.de", "ce_user": true, "ee_user": false, "datamimic_lover": "DEFINITELY"}, {"...": "..."}, {"id": 100, "first_name": "Jared", "last_name": "Rivas", "gender": "male", "birth_date": "1975-03-16T00:00:00", "email": "Rivas@Jared.de", "ce_user": true, "ee_user": true, "datamimic_lover": "DEFINITELY"} ]
csv export:
id|first_name|last_name|gender|birth_date|email|ce_user|ee_user|datamimic_lover 1|Mary|Mcgowan|female|1946-05-15 00:00:00|Mcgowan@Mary.de|False|True|DEFINITELY 2|Gabrielle|Malone|female|1989-11-27 00:00:00|Malone@Gabrielle.de|False|True|DEFINITELY 3|Antonio|Davis|male|2005-05-12 00:00:00|Davis@Antonio.de|False|True|DEFINITELY 4|Margaret|Torres|female|2006-07-13 00:00:00|Torres@Margaret.de|False|False|DEFINITELY 5|Monica|Meyers|female|1983-07-22 00:00:00|Meyers@Monica.de|True|False|DEFINITELY ... 100|Jason|Davis|male|1941-07-05 00:00:00|Davis@Jason.de|True|False|DEFINITELY
Advanced Features
DATAMIMIC supports various advanced features:
- Custom Generators: Create your own data generators
- Data Relationships: Define complex relationships between entities
- Import/Export Formats: Support for JSON, XML, CSV, RDBMS and MongoDB
- Import/Export Formats ( only EE ): Kafka, EDI, XSD and more
- Data Anonymization: Anonymize data to comply with privacy regulations
- Data Validation: Define and enforce data validation rules
- Scripting: Extend functionality using Python scripts
- Database Integration: Connect to databases for seamless data generation
- Model-Driven Generation: Utilize models to generate realistic data
- Validation Rules: Define and enforce data validation rules
- Scripting: Extend functionality using Python scripts
Examples and Demos
Explore our demo collection:
# List available demos
datamimic demo list
# Run a specific demo
datamimic demo create demo-model
datamimic run ./demo-model/datamimic.xml
Key demos include:
- Basic entity generation
- Complex relationships
- Database integration
- Custom generator creation
- Privacy compliance examples
Find more examples in the datamimic_ce/demos directory.
Contributing
We โค๏ธ contributions! Here's how you can help:
- Code Contributions: Submit pull requests for new features or bug fixes.
- Documentation: Improve existing docs or help with translations.
- Community Engagement: Join discussions and support other users.
๐ DATAMIMIC Licensing Options
๐ Community Edition
Open Source Freedom for Everyone
โจ Key Benefits
- ๐ MIT License: Maximum freedom for innovation
- ๐ผ Commercial Ready: Use freely in commercial projects
- ๐ Modification Rights: Full source code access and modification rights
- ๐ No Restrictions: Deploy anywhere, anytime
๐ What's Included
-
๐ฆ Core Features
- Model-driven data generation
- Basic data types & integrations
- GDPR compliance tools
-
๐ฅ Community Support
- Active GitHub community
- Public issue tracking
- Community discussions
- Regular updates
๐ซ Perfect For
- Individual developers
- Startups & small teams
- Open source projects
- Learning & evaluation
- POC development
โญ Enterprise Edition
Professional Power for Business Success
๐ Premium Benefits
- ๐ Commercial License: Enterprise-grade flexibility
- ๐ Advanced Features: Full suite of professional tools
- ๐ฏ Priority Support: Direct access to expert team
- ๐ ๏ธ Custom Solutions: Tailored to your needs
๐ Premium Features
-
๐ค AI Capabilities
- GAN-based synthesis
- LLM integration
- Automated modeling
-
๐ Enterprise Integration
- Advanced connectors
- Kafka streaming
- EDI support
-
๐ก๏ธ Enhanced Security
- Advanced privacy features
- Compliance reporting
- Audit trails
๐ฏ Ideal For
- Large enterprises
- Financial institutions
- Healthcare organizations
- Government agencies
- High-compliance industries
๐ Get Started
Ready to unlock the full potential of DATAMIMIC?
Contact Our Team:
- ๐ง Email: sales@rapiddweller.com
- ๐ Visit: datamimic.io/enterprise
๐ค Compare Editions
| Feature | Community | Enterprise |
|---|---|---|
| Base Features | โ | โ |
| Source Code Access | โ | โ |
| Commercial Use | โ | โ |
| AI Features | โ | โ |
| Priority Support | โ | โ |
| Enterprise Integrations | โ | โ |
| SLA Support | โ | โ |
| Custom Development | โ | โ |
"Empower your data generation journey with the right DATAMIMIC edition for your needs"
Support
Need help or have questions? We're here for you!
- ๐ Documentation
- ๐ฌ GitHub Discussions
- ๐ Issue Tracker
- ๐ง Email Support
Connect with Us
Stay updated and connect with our community!
- ๐ Website: www.datamimic.io
- ๐ข Rapiddweller: www.rapiddweller.com
- ๐ผ LinkedIn: rapiddweller
Acknowledgments
A big thank you to all our contributors! Your efforts make DATAMIMIC possible.
Don't forget to โญ star and ๐ watch this repository to stay updated!
Legal Notices
For detailed licensing information, please see the LICENSE file.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file datamimic_ce-1.2.0.tar.gz.
File metadata
- Download URL: datamimic_ce-1.2.0.tar.gz
- Upload date:
- Size: 12.4 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fcb07b5501298f41d7c413a2116ab4d64de5fa06a114808d6af05b79ba1869e5
|
|
| MD5 |
7280720e8b2a8457d0455b64409e4f20
|
|
| BLAKE2b-256 |
b86c4deb7502cd75c3d0d0c7046f1c45d88f36346b6aad5784b188e0b45d18cf
|
File details
Details for the file datamimic_ce-1.2.0-py3-none-any.whl.
File metadata
- Download URL: datamimic_ce-1.2.0-py3-none-any.whl
- Upload date:
- Size: 12.9 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c91a6df68b0a8def5cce207818b58bf4371a153106e403d47b52e68e1c5164cc
|
|
| MD5 |
f078f274988d7ca0fd7fa05eb1f01e09
|
|
| BLAKE2b-256 |
54af162b7e8ffc0fac1c95ef2b6e8e8278a944359bedb60d7c536a7c8499c3eb
|