The Automated Data Scientist is an advanced AI-driven solution designed to automate and optimize the entire data science workflow. By leveraging large language models and external APIs, it dynamically plans, executes, and refines data analyses, making it ideal for environments that demand rapid, data-driven decision-making.
This application automates the data preparation, analysis planning, code generation, execution, and result interpretation processes, with the ability to adapt based on intermediate results. It ensures that the most relevant and insightful analyses are performed on the data, significantly reducing the manual effort required for complex data science tasks.
- Automated Data Handling: Efficiently loads, cleans, and preprocesses data using configurable settings defined in
config.py
. Thedata_handling.py
module facilitates this process by managing data from multiple sources. - Dynamic Analysis Planning: Utilizes language models through API calls to generate an initial analysis plan based on data characteristics. This is achieved by the
analysis_planning.py
module, which communicates with external APIs. - Code Generation: The
code_generation.py
module generates Python code snippets dynamically for each analysis step. It transforms high-level analytical tasks into executable code using language model APIs. - Execution Management: The
execution.py
module executes generated scripts, captures outputs, and manages errors or exceptions. The process is tightly integrated with themain.py
script, which orchestrates the entire workflow. - Result Interpretation: The
interpretation.py
module provides context-aware interpretations of analysis results, identifying patterns, anomalies, and key insights. - Notebook Management: The
notebook_manager.py
module integrates with Jupyter Notebook environments to facilitate interactive data analysis and visualization. - Testing Framework: Includes comprehensive testing scripts (
test_automated_data_scientist.py
andtest_notebook_manager.py
) to ensure reliability and correctness. - Configuration Management: The
config.py
file allows users to configure environment variables, API keys, and other settings for customized data analysis. - Scalability and Adaptability: Supports flexible limits on analysis steps and can handle varying data sizes, from small exploratory datasets to large-scale production data.
-
Environment Setup: The application initializes by loading environment variables, setting up logging, and preparing the environment through the
main.py
script. -
Data Handling:
- The
DataHandler
class indata_handling.py
is responsible for loading and preparing the data. It supports different data formats and performs initial cleaning and preprocessing to ensure data is ready for analysis.
- The
-
Initial Analysis Planning:
- The
AnalysisPlanner
inanalysis_planning.py
generates an initial plan using API calls to external language models. It sends prompts to an AI service (e.g., OpenAI GPT or Anthropic) to determine a sequence of analytical tasks, including EDA, hypothesis testing, and modeling based on the dataset's characteristics.
- The
-
Code Generation:
- The
CodeGenerator
incode_generation.py
creates Python code dynamically for each analysis step. It uses API calls to convert high-level analytical tasks into executable Python scripts tailored to the data.
- The
-
Execution of Analysis:
- The
CodeExecutor
inexecution.py
runs the generated scripts, captures outputs (results, logs, and visualizations), and handles exceptions. It integrates closely with themain.py
script to manage the entire execution workflow.
- The
-
Interpretation of Results:
- The
ResultInterpreter
ininterpretation.py
reviews the outputs of each analysis step, providing context-aware interpretations and insights that highlight patterns, anomalies, or other significant findings.
- The
-
Notebook Management:
- The
NotebookManager
innotebook_manager.py
facilitates integration with Jupyter Notebooks, enabling users to interactively analyze data, visualize results, and refine their analyses.
- The
-
Adaptive Planning and Execution:
- After each analysis step, the application uses the
review_and_update_plan
method inanalysis_planning.py
to refine the analysis plan based on intermediate findings. This iterative process ensures that new insights or anomalies are explored further.
- After each analysis step, the application uses the
-
Testing and Validation:
- The testing scripts (
test_automated_data_scientist.py
andtest_notebook_manager.py
) provide a comprehensive framework for validating the functionality of all modules, ensuring reliability and robustness.
- The testing scripts (
-
Configurable Control:
- Users can set a maximum number of analyses and configure various parameters in
config.py
to balance thoroughness and efficiency.
- Users can set a maximum number of analyses and configure various parameters in
-
Completion and Logging:
- Upon completing the analysis, all results, including logs and outputs, are stored in designated directories, providing a clear trail of all activities and findings.
- Automation and Efficiency: Minimizes manual intervention by automating data preparation, analysis planning, code generation, and execution.
- Flexibility and Adaptability: Dynamically adjusts the analysis process in response to new findings, ensuring that the most relevant data insights are explored.
- Comprehensive Insights: Provides in-depth, context-aware interpretations of results, enhancing decision-making speed and quality.
- Scalability: Easily configurable to handle datasets of varying sizes and complexity.
flowchart TD
A[Initialize Application] --> B[Load Environment Variables and Configuration]
B --> C[Set up Logging and Environment]
C --> D[Load Data using DataHandler]
D --> E[Clean and Preprocess Data]
E --> F[Generate Initial Analysis Plan]
F --> G[API Calls to Language Models]
G --> H[Generate Python Code for Each Step]
H --> I[Use Language Model APIs for Code Generation]
I --> J[Execute Generated Code]
J --> K[Capture Outputs and Handle Exceptions]
K --> L[Interpret Analysis Results]
L --> M[Provide Context-Aware Insights]
J --> N[Integrate with Jupyter Notebook]
N --> O[Facilitate Interactive Analysis and Visualization]
M --> P[Review Outputs and Update Plan]
P --> Q[Iterate Based on New Findings]
Q --> F
P --> U[Store Results and Logs]
U --> V[Complete Analysis Workflow]
-
Clone the Repository:
git clone https://github.com/yourusername/automated-data-scientist.git cd automated-data-scientist
-
Set Up a Virtual Environment:
python -m venv venv source venv/bin/activate # On Windows, use `venv\Scripts\activate`
-
Install Dependencies:
pip install -r requirements.txt
-
Configure Environment Variables: Create a
.env
file in the project root with the following content:OPENAI_API_KEY=your_openai_api_key ANTHROPIC_API_KEY=your_anthropic_api_key PRODUCTION_CSV_PATH=/path/to/your/production_data.csv DATA_DICT_PATH=/path/to/your/data_dictionary.md
-
Prepare Your Data: Place your production CSV data and data dictionary in the appropriate locations (or update the paths in the
.env
file).
To run the automated data science process:
python main.py
Check the output
directory for the generated report, visualizations, and other outputs.
You can modify the behavior of the Automated Data Scientist by editing the config.py
file. This includes settings for data handling, API usage, analysis limits, and output formatting.
Run the test scripts to validate the functionality of the project:
python test_automated_data_scientist.py
python test_notebook_manager.py
If you'd like to contribute to this project, please fork the repository and submit a pull request. Ensure that your contributions align with the project’s objectives and adhere to coding standards.
This project is licensed under the MIT License - see the LICENSE file for details.
For any questions or further information, please contact Timothy Driscoll at [email protected].