Close Menu
    DevStackTipsDevStackTips
    • Home
    • News & Updates
      1. Tech & Work
      2. View All

      CodeSOD: A Unique Way to Primary Key

      July 22, 2025

      BrowserStack launches Figma plugin for detecting accessibility issues in design phase

      July 22, 2025

      Parasoft brings agentic AI to service virtualization in latest release

      July 22, 2025

      Node.js vs. Python for Backend: 7 Reasons C-Level Leaders Choose Node.js Talent

      July 21, 2025

      The best CRM software with email marketing in 2025: Expert tested and reviewed

      July 22, 2025

      This multi-port car charger can power 4 gadgets at once – and it’s surprisingly cheap

      July 22, 2025

      I’m a wearables editor and here are the 7 Pixel Watch 4 rumors I’m most curious about

      July 22, 2025

      8 ways I quickly leveled up my Linux skills – and you can too

      July 22, 2025
    • Development
      1. Algorithms & Data Structures
      2. Artificial Intelligence
      3. Back-End Development
      4. Databases
      5. Front-End Development
      6. Libraries & Frameworks
      7. Machine Learning
      8. Security
      9. Software Engineering
      10. Tools & IDEs
      11. Web Design
      12. Web Development
      13. Web Security
      14. Programming Languages
        • PHP
        • JavaScript
      Featured

      The Intersection of Agile and Accessibility – A Series on Designing for Everyone

      July 22, 2025
      Recent

      The Intersection of Agile and Accessibility – A Series on Designing for Everyone

      July 22, 2025

      Zero Trust & Cybersecurity Mesh: Your Org’s Survival Guide

      July 22, 2025

      Execute Ping Commands and Get Back Structured Data in PHP

      July 22, 2025
    • Operating Systems
      1. Windows
      2. Linux
      3. macOS
      Featured

      A Tomb Raider composer has been jailed — His legacy overshadowed by $75k+ in loan fraud

      July 22, 2025
      Recent

      A Tomb Raider composer has been jailed — His legacy overshadowed by $75k+ in loan fraud

      July 22, 2025

      “I don’t think I changed his mind” — NVIDIA CEO comments on H20 AI GPU sales resuming in China following a meeting with President Trump

      July 22, 2025

      Galaxy Z Fold 7 review: Six years later — Samsung finally cracks the foldable code

      July 22, 2025
    • Learning Resources
      • Books
      • Cheatsheets
      • Tutorials & Guides
    Home»Development»Machine Learning»Step-by-Step Guide to Creating Synthetic Data Using the Synthetic Data Vault (SDV)

    Step-by-Step Guide to Creating Synthetic Data Using the Synthetic Data Vault (SDV)

    May 25, 2025

    Real-world data is often costly, messy, and limited by privacy rules. Synthetic data offers a solution—and it’s already widely used:

    • LLMs train on AI-generated text
    • Fraud systems simulate edge cases
    • Vision models pretrain on fake images

    SDV (Synthetic Data Vault) is an open-source Python library that generates realistic tabular data using machine learning. It learns patterns from real data and creates high-quality synthetic data for safe sharing, testing, and model training.

    In this tutorial, we’ll use SDV to generate synthetic data step by step.

    Copy CodeCopiedUse a different Browser
    pip install sdv

    We will first install the sdv library:

    Copy CodeCopiedUse a different Browser
    from sdv.io.local import CSVHandler
    
    connector = CSVHandler()
    FOLDER_NAME = '.' # If the data is in the same directory
    
    data = connector.read(folder_name=FOLDER_NAME)
    salesDf = data['data']
    

    Next, we import the necessary module and connect to our local folder containing the dataset files. This reads the CSV files from the specified folder and stores them as pandas DataFrames. In this case, we access the main dataset using data[‘data’].

    Copy CodeCopiedUse a different Browser
    from sdv.metadata import Metadata
    metadata = Metadata.load_from_json('metadata.json')

    We now import the metadata for our dataset. This metadata is stored in a JSON file and tells SDV how to interpret your data. It includes:

    • The table name
    • The primary key
    • The data type of each column (e.g., categorical, numerical, datetime, etc.)
    • Optional column formats like datetime patterns or ID patterns
    • Table relationships (for multi-table setups)

    Here is a sample metadata.json format:

    Copy CodeCopiedUse a different Browser
    {
      "METADATA_SPEC_VERSION": "V1",
      "tables": {
        "your_table_name": {
          "primary_key": "your_primary_key_column",
          "columns": {
            "your_primary_key_column": { "sdtype": "id", "regex_format": "T[0-9]{6}" },
            "date_column": { "sdtype": "datetime", "datetime_format": "%d-%m-%Y" },
            "category_column": { "sdtype": "categorical" },
            "numeric_column": { "sdtype": "numerical" }
          },
          "column_relationships": []
        }
      }
    }
    Copy CodeCopiedUse a different Browser
    from sdv.metadata import Metadata
    
    metadata = Metadata.detect_from_dataframes(data)

    Alternatively, we can use the SDV library to automatically infer the metadata. However, the results may not always be accurate or complete, so you might need to review and update it if there are any discrepancies.

    Copy CodeCopiedUse a different Browser
    from sdv.single_table import GaussianCopulaSynthesizer
    
    synthesizer = GaussianCopulaSynthesizer(metadata)
    synthesizer.fit(data=salesDf)
    synthetic_data = synthesizer.sample(num_rows=10000)
    
    

    With the metadata and original dataset ready, we can now use SDV to train a model and generate synthetic data. The model learns the structure and patterns in your real dataset and uses that knowledge to create synthetic records.

    You can control how many rows to generate using the num_rows argument.

    Copy CodeCopiedUse a different Browser
    from sdv.evaluation.single_table import evaluate_quality
    
    quality_report = evaluate_quality(
        salesDf,
        synthetic_data,
        metadata)

    The SDV library also provides tools to evaluate the quality of your synthetic data by comparing it to the original dataset. A great place to start is by generating a quality report

    You can also visualize how the synthetic data compares to the real data using SDV’s built-in plotting tools. For example, import get_column_plot from sdv.evaluation.single_table to create comparison plots for specific columns:

    Copy CodeCopiedUse a different Browser
    from sdv.evaluation.single_table import get_column_plot
    
    fig = get_column_plot(
        real_data=salesDf,
        synthetic_data=synthetic_data,
        column_name='Sales',
        metadata=metadata
    )
       
    fig.show()

    We can observe that the distribution of the ‘Sales’ column in the real and synthetic data is very similar. To explore further, we can use matplotlib to create more detailed comparisons—such as visualizing the average monthly sales trends across both datasets.

    Copy CodeCopiedUse a different Browser
    import pandas as pd
    import matplotlib.pyplot as plt
    
    # Ensure 'Date' columns are datetime
    salesDf['Date'] = pd.to_datetime(salesDf['Date'], format='%d-%m-%Y')
    synthetic_data['Date'] = pd.to_datetime(synthetic_data['Date'], format='%d-%m-%Y')
    
    # Extract 'Month' as year-month string
    salesDf['Month'] = salesDf['Date'].dt.to_period('M').astype(str)
    synthetic_data['Month'] = synthetic_data['Date'].dt.to_period('M').astype(str)
    
    # Group by 'Month' and calculate average sales
    actual_avg_monthly = salesDf.groupby('Month')['Sales'].mean().rename('Actual Average Sales')
    synthetic_avg_monthly = synthetic_data.groupby('Month')['Sales'].mean().rename('Synthetic Average Sales')
    
    # Merge the two series into a DataFrame
    avg_monthly_comparison = pd.concat([actual_avg_monthly, synthetic_avg_monthly], axis=1).fillna(0)
    
    # Plot
    plt.figure(figsize=(10, 6))
    plt.plot(avg_monthly_comparison.index, avg_monthly_comparison['Actual Average Sales'], label='Actual Average Sales', marker='o')
    plt.plot(avg_monthly_comparison.index, avg_monthly_comparison['Synthetic Average Sales'], label='Synthetic Average Sales', marker='o')
    
    plt.title('Average Monthly Sales Comparison: Actual vs Synthetic')
    plt.xlabel('Month')
    plt.ylabel('Average Sales')
    plt.xticks(rotation=45)
    plt.grid(True)
    plt.legend()
    plt.ylim(bottom=0)  # y-axis starts at 0
    plt.tight_layout()
    plt.show()

    This chart also shows that the average monthly sales in both datasets are very similar, with only minimal differences.

    In this tutorial, we demonstrated how to prepare your data and metadata for synthetic data generation using the SDV library. By training a model on your original dataset, SDV can create high-quality synthetic data that closely mirrors the real data’s patterns and distributions. We also explored how to evaluate and visualize the synthetic data, confirming that key metrics like sales distributions and monthly trends remain consistent. Synthetic data offers a powerful way to overcome privacy and availability challenges while enabling robust data analysis and machine learning workflows.


    Check out the Notebook on GitHub. All credit for this research goes to the researchers of this project. Also, feel free to follow us on Twitter and don’t forget to join our 95k+ ML SubReddit and Subscribe to our Newsletter.

    The post Step-by-Step Guide to Creating Synthetic Data Using the Synthetic Data Vault (SDV) appeared first on MarkTechPost.

    Source: Read More 

    Facebook Twitter Reddit Email Copy Link
    Previous ArticleCVE-2025-5156 – H3C GR-5400AX Buffer Overflow Vulnerability
    Next Article NVIDIA Releases Llama Nemotron Nano 4B: An Efficient Open Reasoning Model Optimized for Edge AI and Scientific Tasks

    Related Posts

    Machine Learning

    How to Evaluate Jailbreak Methods: A Case Study with the StrongREJECT Benchmark

    July 22, 2025
    Machine Learning

    Boolformer: Symbolic Regression of Logic Functions with Transformers

    July 22, 2025
    Leave A Reply Cancel Reply

    For security, use of Google's reCAPTCHA service is required which is subject to the Google Privacy Policy and Terms of Use.

    Continue Reading

    PyQSO – contact logging tool for amateur radio operators

    Linux

    CVE-2025-30360 – Webpack-dev-server Cross-site WebSocket Hijacking Vulnerability

    Common Vulnerabilities and Exposures (CVEs)

    CVE-2025-46688 – QuickJS Buffer Overflow Vulnerability

    Common Vulnerabilities and Exposures (CVEs)

    Elden Ring Nightreign classes: All 8 Nightfarer characters in FromSoftware’s co-op spinoff explained

    News & Updates

    Highlights

    Your favorite AI chatbot is lying to you all the time

    June 10, 2025

    Next time you chat with your favorite AI bot, maybe you should do some fact-checking,…

    CVE-2025-30640 – Trend Micro Deep Security Privilege Escalation Vulnerability

    June 17, 2025

    Microsoft wants Windows 10 users to upgrade to Windows 11 or Copilot + PCs

    April 28, 2025

    Deploying AI Agents? Learn to Secure Them Before Hackers Strike Your Business

    May 9, 2025
    © DevStackTips 2025. All rights reserved.
    • Contact
    • Privacy Policy

    Type above and press Enter to search. Press Esc to cancel.