A set of classes for simulating various business-related scenarios for educational use
Project description
SimLab: Comprehensive Simulation Toolkit
SimLab is a Python package providing a versatile set of simulation tools for modeling complex systems across various domains. It offers a unified interface for different simulation paradigms, making it ideal for educational, research, and business applications.
Installation
To install SimLab with all features:
pip install sim-lab
For specific interfaces only:
# CLI only
pip install sim-lab[cli]
# Web interface
pip install sim-lab[web]
# TUI (terminal interface)
pip install sim-lab[tui]
Key Features
- Unified Interface: All simulators share a consistent API
- Registry System: Dynamic discovery and instantiation of simulation models
- Multiple Interfaces: CLI, TUI, Web, and Python API
- Visualization Tools: Built-in plotting and visualization capabilities
- Data Import/Export: Support for common data formats
- Parameter Validation: Comprehensive input validation
- Stochastic Processes: Support for random processes with seed control
Simulation Categories
SimLab includes a wide range of simulation types:
Basic Simulations
- Stock Market: Model stock price fluctuations with volatility, drift, and market events
- Resource Fluctuations: Simulate resource price dynamics with supply disruptions
- Product Popularity: Model product demand considering growth, marketing, and promotions
Discrete Event Simulations
- Discrete Event: General-purpose event-driven simulation engine
- Queueing: Model service systems with arrivals, queues, and servers
Statistical Simulations
- Monte Carlo: Sample random processes to estimate numerical results
- Markov Chain: Model stochastic processes with the Markov property
Agent-Based Simulation
- Model complex systems through interactions of autonomous agents
System Dynamics
- Model systems with stocks, flows, and feedback loops
Network Simulations
- Model processes on complex networks with different topologies
Ecological Simulations
- Predator-Prey: Model population dynamics using Lotka-Volterra equations
Domain-Specific Simulations
- Epidemiological: SIR/SEIR disease spread models
- Cellular Automaton: Grid-based models with local update rules
- Supply Chain: Model multi-tier supply chains with inventory management
Basic Usage
from sim_lab.core import SimulatorRegistry
# Create a simulation using the registry
sim = SimulatorRegistry.create(
"StockMarket",
start_price=100.0,
days=252,
volatility=0.02,
drift=0.0005,
random_seed=42
)
# Run the simulation
prices = sim.run_simulation()
# Visualize the results
import matplotlib.pyplot as plt
plt.figure(figsize=(10, 6))
plt.plot(prices)
plt.title('Stock Price Simulation')
plt.xlabel('Trading Days')
plt.ylabel('Price ($)')
plt.grid(True)
plt.show()
Command Line Interface
# Run a stock market simulation
simlab stock-market run --start-price 100 --days 365 --volatility 0.02 --drift 0.001 --output prices.csv
# Get help for all commands
simlab --help
Terminal UI
# Launch the interactive terminal UI
simlab-tui
Web Interface
# Start the web server
simlab-web
# Then visit http://localhost:8000 in your browser
Educational Applications
SimLab is designed with education in mind, helping students:
- Understand complex systems through hands-on simulation
- Explore the impact of parameters on system dynamics
- Develop data analysis and visualization skills
- Apply theoretical concepts to practical scenarios
- Create and test hypotheses in a simulated environment
Documentation
For comprehensive documentation, visit:
Development
SimLab uses modern Python development tools:
- uv for dependency management
- Ruff for linting and formatting
- pytest for testing
- MkDocs for documentation
To set up a development environment:
# Clone the repository
git clone https://github.com/teaching-repositories/sim-lab.git
cd sim-lab
# Run the setup script
./scripts/setup_dev.sh
# Or manually
uv venv
source .venv/bin/activate # On Windows: .venv\Scripts\activate
uv pip install -e .[dev]
See DEVELOPMENT.md for more details.
Registry System
SimLab features a powerful registry system for dynamically discovering and instantiating simulators:
from sim_lab.core import SimulatorRegistry, BaseSimulation
# Register a custom simulator
@SimulatorRegistry.register("MySimulator")
class MyCustomSimulation(BaseSimulation):
# Your implementation here
pass
# List available simulators
simulators = SimulatorRegistry.list_simulators()
print(f"Available simulators: {simulators}")
# Create an instance
sim = SimulatorRegistry.create("MySimulator", days=100, random_seed=42)
For more information, see the Registry System documentation.
Contributing
We welcome contributions to the SimLab project! See the Contributing Guide for more details.
License
This project is licensed under the MIT License. See the LICENSE file for more details.
Project details
Release history Release notifications | RSS feed
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 sim_lab-0.4.0.tar.gz.
File metadata
- Download URL: sim_lab-0.4.0.tar.gz
- Upload date:
- Size: 53.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8de197abb412be328d329ad8924afbc0074083891c95322c2a1189928e60aa27
|
|
| MD5 |
2abd4c5e9f0b047b0172c93e62ab2f6d
|
|
| BLAKE2b-256 |
dde6df7d76f3cf7a82077dd6c5f7320e14757bb4a8e2ab6d5e550903aef8b892
|
File details
Details for the file sim_lab-0.4.0-py3-none-any.whl.
File metadata
- Download URL: sim_lab-0.4.0-py3-none-any.whl
- Upload date:
- Size: 63.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cc4680b3d1226eee74c8184f432407a40798dceba74688fd43ce0b2292cc6323
|
|
| MD5 |
50929c2dd5ef9e167cfcd96473baadc8
|
|
| BLAKE2b-256 |
b5c6848317293492f381a691210641a6f5bfb3f3dc0c175e4e4e4d6bb90676cb
|