Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/7irelo/gymon
Engineering Render Engine (C++, OpenGL, GLFW, DirectX)
https://github.com/7irelo/gymon
cpp directx glfw opengl
Last synced: about 2 months ago
JSON representation
Engineering Render Engine (C++, OpenGL, GLFW, DirectX)
- Host: GitHub
- URL: https://github.com/7irelo/gymon
- Owner: 7irelo
- License: mit
- Created: 2024-05-13T10:51:52.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-11-09T14:29:36.000Z (2 months ago)
- Last Synced: 2024-11-09T15:28:09.196Z (2 months ago)
- Topics: cpp, directx, glfw, opengl
- Language: C++
- Homepage:
- Size: 14.1 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Gymon Rendering Engine
Welcome to the Gymon 3D Rendering Engine repository! Gymon is a specialized 3D rendering engine tailored for engineering applications, particularly in biomedical, aeronautical, and mechanical engineering. By enabling complex simulations and visualizations, Gymon has contributed to significant advancements in these fields, making it an invaluable tool for research and development.
## Table of Contents
- [Introduction](#introduction)
- [Features](#features)
- [Technologies Used](#technologies-used)
- [Getting Started](#getting-started)
- [Contributing](#contributing)
- [License](#license)## Introduction
Gymon is a cross-platform 3D rendering engine designed to meet the rigorous demands of engineering applications. Leveraging the power and flexibility of C++ with advanced graphics APIs like OpenGL, DirectX, and Vulkan, Gymon facilitates detailed simulations and visualizations that are critical in fields such as biomedical, aeronautical, and mechanical engineering. Whether you're conducting research, developing new technologies, or visualizing complex data, Gymon provides the tools and framework to bring your projects to life.
## Features
- **Tailored for Engineering:** Specifically designed for engineering applications, with a focus on biomedical, aeronautical, and mechanical engineering, enabling precise and accurate simulations.
- **Cross-Platform Compatibility:** Supports multiple platforms, including Windows, macOS, and Linux, allowing for widespread deployment and collaboration across different environments.
- **Advanced Rendering Options:** Supports multiple graphics APIs including OpenGL, DirectX (Direct3D), and Vulkan, offering flexibility and performance tailored to specific platforms and project needs.
- **Custom Shaders:** Implement custom shaders using GLSL, HLSL (for DirectX), or SPIR-V (for Vulkan) to achieve advanced visual effects tailored to engineering simulations.
- **Scene Management:** Efficiently manage complex scenes, entities, and assets, with an intuitive system optimized for engineering projects.
- **Physics Integration:** Seamlessly integrate physics simulations with libraries like Bullet Physics or PhysX, essential for accurate modeling in aeronautical and mechanical engineering.
- **High Precision Rendering:** Ensures the accuracy and precision necessary for biomedical simulations and mechanical engineering visualizations.
- **GPU Computing:** Utilize GPU computing with technologies like CUDA (NVIDIA) or DirectCompute (DirectX) for intensive parallel processing tasks.
- **Input Handling:** Supports various input devices, facilitating interactive simulations and real-time data manipulation.
- **Scripting Support:** Extend and automate functionalities using scripting languages such as Lua or Python, integrated directly into the engine.
- **Customizable:** Highly customizable to meet the specific needs of different engineering disciplines and projects.## Technologies Used
- **C++**: Core programming language for building the engine.
- **Graphics APIs**:
- **OpenGL**: Cross-platform rendering.
- **DirectX**: Specifically Direct3D for Windows-based rendering.
- **Vulkan**: For advanced, low-level cross-platform rendering.
- **Metal** (for macOS/iOS): High-performance rendering on Apple devices.
- **GLFW**: For cross-platform window and input management.
- **GLEW**: For managing OpenGL extensions.
- **GLM (OpenGL Mathematics)**: Handling vectors, matrices, and other math operations.
- **Bullet Physics/PhysX**: For physics simulations.
- **CUDA/DirectCompute**: For GPU-accelerated computing.
- **GLSL/HLSL/SPIR-V**: For writing custom shaders.
- **Assimp**: For loading 3D model formats.
- **ImGui**: For creating simple GUI interfaces.## Getting Started
To get started with Gymon, follow these steps:
1. **Clone the Repository:** Clone this repository to your local machine using Git:
```bash
git clone https://github.com/7irelo/gymon.git
```2. **Build the Engine:** Build Gymon using your preferred build system (e.g., CMake, Makefile). Detailed instructions on building the engine for your platform are provided in the repository documentation.
3. **Explore the Examples:** Review the example projects included with Gymon, which demonstrate how to utilize the engine's features and capabilities. Experiment with these examples to gain an understanding of how Gymon can be applied to your specific engineering needs.
4. **Start Developing:** Once you're comfortable with Gymon, begin developing your own simulations or visualizations. Use the provided tools and libraries to create detailed and accurate engineering models. Refer to the documentation and example projects for guidance.
5. **Contribute:** If you have ideas for improvements or encounter any issues, contribute to the repository by submitting bug reports, feature requests, or pull requests. Your contributions help enhance Gymon for the entire engineering community.
## Contributing
Contributions to the Gymon 3D Rendering Engine project are welcome and encouraged. Whether you're fixing bugs, adding new features, or improving documentation, your contributions help make Gymon a better tool for engineers and researchers. To contribute, fork the repository, make your changes, and submit a pull request. Please follow the contribution guidelines provided in the repository documentation.
## License
This project is licensed under the [MIT License](LICENSE), which means you are free to use, modify, and distribute the code for both personal and commercial purposes. By contributing to this project, you agree to license your contributions under the same terms.