SimLab is an internet laboratory where anyone can freely add and share their desired simulations. It's a platform that helps make scientific and mathematical concepts easier to understand through interactive, visual demonstrations.
SimLab aims to:
- Provide interactive visualizations of scientific and mathematical concepts
- Make complex ideas more approachable through hands-on simulations
- Offer a platform where anyone can share their educational simulations
- Build a collection of high-quality, web-based learning tools
- Interactive Simulations: Visual demonstrations of various scientific and mathematical concepts
- Modern UI: Clean, responsive design that works across all devices
- Real-time Updates: Immediate visual feedback for parameter adjustments
- Contributor System: Simple process for adding new simulations
- Firebase Backend: Reliable infrastructure for simulation management and analytics
To streamline the simulation creation process, you can use SimLab_Generator - a dedicated tool for generating SimLab-compatible simulation code. This tool helps maintain consistency and reduce development time when creating new simulations.
Before submitting your simulation, you can test it locally using the provided test app in the repository:
- Navigate to the
testapp
directory - Place your simulation code in
YourSimulation.jsx
- In
App.js
, update the imports and component usage:
// App.js
import YourSimulation from './YourSimulation'; // Update import
function App() {
return (
<div className="App">
<YourSimulation /> {/* Replace TemplateSimulation with your component */}
</div>
);
}
- Run the test app to verify your simulation works correctly:
cd testapp
npm install
npm start
This will allow you to test your simulation in isolation and ensure it functions properly before submitting your contribution.
Anyone can add new simulations to SimLab! To contribute:
- Fork the repository
- Reference the
TemplateSimulation
andExampleSimulation
folders to understand the structure - Create your simulation component and its metadata JSON file
- Submit a Pull Request
- After review and approval, your simulation will be added to SimLab
The repository provides template files and examples to help you get started. You'll need to create both the simulation component and a metadata file that includes information about your simulation.
Your simulation should:
- Be interactive and educational
- Work responsively across different screen sizes
- Include clear instructions and explanations
- Use React and follow our code style
- Be well-documented with comments
You can contribute by referring to the TemplateSimulation
and ExampleSimulation
folders in the repository. Each simulation contribution should include:
- Simulation Component File (
YourSimulation.jsx
):
const YourSimulation = () => {
// Your simulation logic
return (
<div className="simulation-container">
{/* Your simulation JSX */}
</div>
);
};
export default YourSimulation;
- Metadata File (
simulation.json
):
{
"componentName": "YourSimulation",
"contributorGithub": "your-github-username",
"contributorImage": "https://avatars.githubusercontent.com/u/your-id?v=4&size=64",
"createdAt": 0,
"description": "Detailed description in markdown format converted to string",
"githubRepo": "your-github-username/SimLab",
"likes": 0,
"name": "Your Simulation Name",
"simulationFilename": "YourSimulation",
"thumbnailPath": "path/to/thumbnail/image",
"updatedAt": 0,
"views": 0
}
Metadata Fields Explanation:
componentName
: Name of your React componentcontributorGithub
: Your GitHub usernamecontributorImage
: URL to your GitHub profile picturecreatedAt
: Leave as 0 (will be set automatically)description
: Markdown string explaining your simulationgithubRepo
: Your GitHub repository pathlikes
: Leave as 0 (will be updated automatically)name
: Display name of your simulationsimulationFilename
: Name of your simulation file without extensionthumbnailPath
: Path to your simulation's thumbnailupdatedAt
: Leave as 0 (will be updated automatically)views
: Leave as 0 (will be tracked automatically)
Note: For the description
field, provide your explanation as a markdown string. This allows for rich formatting including:
- Mathematical equations using KaTeX
- Code blocks
- Lists and tables
- Images and diagrams
Example markdown structure:
# Simulation Title
## Introduction
Brief overview of the concept...
## Mathematical Background
Key equations and explanations...
## How to Use
1. Adjust parameter X
2. Observe effect Y
3. ...
## Additional Resources
- Reference 1
- Reference 2
- React: UI components
- Firebase: Backend services (Firestore, Storage)
- Tailwind CSS: Styling
- React Router: Navigation
- Lucide Icons: UI elements
- KaTeX: Mathematical expressions
When submitting a simulation, please include:
- Description of the concept being demonstrated
- Clear user instructions
- Scientific/mathematical background
- Code comments explaining complex logic
- References or additional resources
For questions about SimLab:
- Email: [email protected]
- GitHub: Royaltyprogram
While SimLab is a personal project, anyone can freely contribute simulations. The project's core codebase is maintained privately.
Created and maintained by Royaltyprogram