Convert Figma logo to code with AI

KhronosGroup logoVulkan-Samples

One stop solution for all Vulkan samples

4,266
636
4,266
72

Top Related Projects

17,909

Filament is a real-time physically based rendering engine for Android, iOS, Windows, Linux, macOS, and WebGL2

10,285

C++ examples for the Vulkan graphics API

Ray tracing examples and tutorials using VK_KHR_ray_tracing

A beginner-friendly Vulkan path tracing tutorial in under 300 lines of C++.

15,196

Cross-platform, graphics API agnostic, "Bring Your Own Engine/Framework" style rendering library.

Quick Overview

Vulkan-Samples is a comprehensive collection of open-source samples and tutorials for the Vulkan graphics API. Maintained by the Khronos Group, this repository serves as a valuable resource for developers learning Vulkan or seeking to implement advanced graphics techniques using the API.

Pros

  • Extensive collection of samples covering various Vulkan features and techniques
  • Well-documented code with detailed explanations and comments
  • Regular updates and contributions from the Vulkan community
  • Cross-platform support for Windows, Linux, Android, and macOS (MoltenVK)

Cons

  • Steep learning curve for beginners due to Vulkan's complexity
  • Some samples may require powerful hardware to run efficiently
  • Limited coverage of certain advanced topics or niche use cases
  • Occasional inconsistencies in coding style across different samples

Code Examples

Here are a few short code examples from the Vulkan-Samples repository:

  1. Creating a Vulkan instance:
vk::ApplicationInfo app_info("Example", 1, "Example", 1, VK_API_VERSION_1_0);
vk::InstanceCreateInfo instance_info({}, &app_info);
vk::Instance instance = vk::createInstance(instance_info);
  1. Creating a Vulkan device:
vk::DeviceQueueCreateInfo queue_info({}, queue_family_index, 1, &queue_priority);
vk::DeviceCreateInfo device_info({}, 1, &queue_info);
vk::Device device = physical_device.createDevice(device_info);
  1. Creating a Vulkan command buffer:
vk::CommandPoolCreateInfo pool_info(vk::CommandPoolCreateFlagBits::eResetCommandBuffer, queue_family_index);
vk::CommandPool command_pool = device.createCommandPool(pool_info);

vk::CommandBufferAllocateInfo alloc_info(command_pool, vk::CommandBufferLevel::ePrimary, 1);
std::vector<vk::CommandBuffer> command_buffers = device.allocateCommandBuffers(alloc_info);

Getting Started

To get started with Vulkan-Samples:

  1. Clone the repository:

    git clone https://github.com/KhronosGroup/Vulkan-Samples.git
    
  2. Install the required dependencies (Vulkan SDK, CMake, etc.)

  3. Build the project:

    cd Vulkan-Samples
    cmake -G "<generator>" .
    cmake --build .
    
  4. Run a sample:

    ./bin/vulkan_samples sample_name
    

For more detailed instructions, refer to the repository's README and documentation.

Competitor Comparisons

17,909

Filament is a real-time physically based rendering engine for Android, iOS, Windows, Linux, macOS, and WebGL2

Pros of Filament

  • Cross-platform rendering engine with support for multiple APIs (OpenGL, Vulkan, Metal)
  • Comprehensive material system with physically-based rendering (PBR) support
  • Extensive documentation and examples for various use cases

Cons of Filament

  • Steeper learning curve due to its comprehensive feature set
  • Larger codebase and potentially higher overhead for simple projects
  • Less focused on Vulkan-specific optimizations and best practices

Code Comparison

Filament (C++):

FilamentApp& app = FilamentApp::get();
Engine* engine = app.getEngine();
Scene* scene = engine->createScene();

Vulkan-Samples (C++):

vkb::PlatformUniquePtr platform = vkb::platform::create_unique_platform();
vkb::WindowUniquePtr window = platform->create_window("Vulkan Sample");
vkb::Context context(std::move(platform), std::move(window));

Summary

Filament offers a more comprehensive rendering solution with cross-platform support, while Vulkan-Samples focuses specifically on Vulkan best practices and optimizations. Filament provides a higher-level abstraction, which can be beneficial for complex projects but may introduce overhead for simpler ones. Vulkan-Samples, on the other hand, offers a more direct approach to Vulkan development, making it ideal for learning and implementing Vulkan-specific techniques.

10,285

C++ examples for the Vulkan graphics API

Pros of Vulkan

  • More extensive collection of samples covering a wider range of Vulkan features and techniques
  • Includes advanced rendering techniques and compute shader examples
  • Samples are well-documented with detailed explanations and comments

Cons of Vulkan

  • Less frequently updated compared to Vulkan-Samples
  • May not always reflect the latest Vulkan best practices or features
  • Some samples might be more complex for beginners to understand

Code Comparison

Vulkan:

void VulkanExample::buildCommandBuffers()
{
    VkCommandBufferBeginInfo cmdBufInfo = vks::initializers::commandBufferBeginInfo();
    for (int32_t i = 0; i < drawCmdBuffers.size(); ++i)
    {
        VK_CHECK_RESULT(vkBeginCommandBuffer(drawCmdBuffers[i], &cmdBufInfo));
        // ... (rendering commands)
        VK_CHECK_RESULT(vkEndCommandBuffer(drawCmdBuffers[i]));
    }
}

Vulkan-Samples:

void VulkanSample::build_command_buffers()
{
    VkCommandBufferBeginInfo begin_info = vkb::initializers::command_buffer_begin_info();
    for (auto &cmd_buf : command_buffers)
    {
        VK_CHECK(vkBeginCommandBuffer(cmd_buf, &begin_info));
        // ... (rendering commands)
        VK_CHECK(vkEndCommandBuffer(cmd_buf));
    }
}

Both repositories provide similar command buffer creation patterns, but Vulkan-Samples uses more modern naming conventions and error checking macros.

Ray tracing examples and tutorials using VK_KHR_ray_tracing

Pros of vk_raytracing_tutorial_KHR

  • Focused specifically on ray tracing, providing in-depth examples and tutorials
  • Includes NVIDIA-specific optimizations and best practices
  • Smaller, more manageable codebase for those primarily interested in ray tracing

Cons of vk_raytracing_tutorial_KHR

  • Limited scope compared to Vulkan-Samples, which covers a broader range of Vulkan features
  • May not be as frequently updated or maintained as the official Khronos Group repository
  • Potentially less portable across different hardware vendors

Code Comparison

vk_raytracing_tutorial_KHR:

void HelloVulkan::createBottomLevelAS()
{
  // ... (BLAS creation code)
  m_rtBuilder.buildBlas(m_blas, VK_BUILD_ACCELERATION_STRUCTURE_PREFER_FAST_TRACE_BIT_KHR);
}

Vulkan-Samples:

void VulkanSample::create_acceleration_structure()
{
  // ... (Acceleration structure creation code)
  vkCreateAccelerationStructureKHR(get_device().get_handle(), &as_info, nullptr, &acceleration_structure);
}

The vk_raytracing_tutorial_KHR example uses a higher-level abstraction (m_rtBuilder) for building acceleration structures, while Vulkan-Samples demonstrates a more low-level approach using direct Vulkan API calls.

A beginner-friendly Vulkan path tracing tutorial in under 300 lines of C++.

Pros of vk_mini_path_tracer

  • Focused specifically on path tracing, providing a deep dive into this advanced rendering technique
  • Compact and streamlined codebase, making it easier to understand the core concepts
  • Includes NVIDIA-specific optimizations, potentially offering better performance on supported hardware

Cons of vk_mini_path_tracer

  • Limited in scope compared to Vulkan-Samples, which covers a broader range of Vulkan features and techniques
  • Less comprehensive documentation and fewer explanatory comments in the code
  • May not be as portable or widely applicable as Vulkan-Samples due to its focus on NVIDIA hardware

Code Comparison

Vulkan-Samples (initialization):

VkApplicationInfo app_info{};
app_info.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO;
app_info.pApplicationName = "Vulkan Sample";
app_info.applicationVersion = VK_MAKE_VERSION(1, 0, 0);
app_info.pEngineName = "No Engine";
app_info.engineVersion = VK_MAKE_VERSION(1, 0, 0);

vk_mini_path_tracer (initialization):

VkApplicationInfo app_info = {};
app_info.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO;
app_info.pApplicationName = "vk_mini_path_tracer";
app_info.applicationVersion = 1;
app_info.pEngineName = "vk_mini_path_tracer";
app_info.engineVersion = 1;

Both repositories provide valuable resources for learning Vulkan, with Vulkan-Samples offering a broader scope and vk_mini_path_tracer focusing on advanced path tracing techniques.

15,196

Cross-platform, graphics API agnostic, "Bring Your Own Engine/Framework" style rendering library.

Pros of bgfx

  • Cross-platform support for multiple rendering APIs (OpenGL, Direct3D, Vulkan, etc.)
  • Lightweight and performance-focused design
  • Extensive set of examples and tools for various rendering techniques

Cons of bgfx

  • Steeper learning curve due to its lower-level API
  • Less focus on Vulkan-specific features and optimizations
  • Smaller community and less frequent updates compared to Vulkan-Samples

Code Comparison

bgfx:

bgfx::init(bgfx::RendererType::Vulkan);
bgfx::setViewClear(0, BGFX_CLEAR_COLOR | BGFX_CLEAR_DEPTH, 0x303030ff, 1.0f, 0);
bgfx::setViewRect(0, 0, 0, uint16_t(width), uint16_t(height));

Vulkan-Samples:

vkb::Instance instance{};
vkb::PhysicalDevice physical_device = instance.get_suitable_physical_device();
vkb::Device device = physical_device.create_device({});
vkb::Swapchain swapchain{device, window.get_surface(), window.get_extent()};

The bgfx code demonstrates its abstraction layer for multiple rendering APIs, while Vulkan-Samples focuses specifically on Vulkan setup and usage.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

////

  • Copyright (c) 2019-2024, Arm Limited and Contributors
  • SPDX-License-Identifier: Apache-2.0
  • Licensed under the Apache License, Version 2.0 the "License";
  • you may not use this file except in compliance with the License.
  • You may obtain a copy of the License at
  • http://www.apache.org/licenses/LICENSE-2.0
    
  • Unless required by applicable law or agreed to in writing, software
  • distributed under the License is distributed on an "AS IS" BASIS,
  • WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  • See the License for the specific language governing permissions and
  • limitations under the License.

//// = Vulkan Samples // omit in toc :pp: {plus}{plus} ifndef::site-gen-antora[] :toc: endif::[]

image::banner.jpg[Vulkan Samples banner]

ifndef::site-gen-antora[] == Vulkan Documentation Site

Documentation for the samples is best viewed at the new link:https://docs.vulkan.org/samples/latest/README.html[Vulkan Documentation Site]. The documentation uses AsciiDoc which isn't fully supported by github.

endif::[]

== Introduction

The Vulkan Samples is collection of resources to help you develop optimized Vulkan applications.

If you are new to Vulkan the xref:samples/api/README.adoc[API samples] are the right place to start. Additionally you may find the following links useful:

ifdef::site-gen-antora[]

  • xref:guide:ROOT:index.adoc[Vulkan Guide]
  • xref:tutorial:ROOT:00_Introduction.adoc[Get Started in Vulkan] endif::[]

ifndef::site-gen-antora[]

xref:samples/performance/README.adoc[Performance samples] show the recommended best practice together with real-time profiling information. They are more advanced but also contain a detailed tutorial with more in-detail explanations.

=== Goals

  • Create a collection of resources that demonstrate best-practice recommendations in Vulkan
  • Create tutorials that explain the implementation of best-practices and include performance analysis guides
  • Create a xref:framework/README.adoc[framework] that can be used as reference material and also as a sandbox for advanced experimentation with Vulkan

== Samples

  • xref:./samples/README.adoc[Listing of all samples available in this repository]

== General information

  • Project Basics ** xref:./docs/misc.adoc#controls[Controls] ** xref:./docs/misc.adoc#debug-window[Debug window] ** xref:./scripts/README.adoc[Create a Sample]
  • Vulkan Essentials ** xref:./samples/vulkan_basics.adoc[How does Vulkan compare to OpenGL ES? What should you expect when targeting Vulkan?]
  • Misc ** xref:./docs/misc.adoc#driver-version[Driver version] ** xref:./docs/memory_limits.adoc[Memory limits]

== Setup

Prerequisites: https://git-scm.com/downloads[git] with https://docs.github.com/en/repositories/working-with-files/managing-large-files/installing-git-large-file-storage[git large file storage (git-lfs)].

Clone the repo with submodules using the following command:


git clone --recurse-submodules https://github.com/KhronosGroup/Vulkan-Samples.git cd Vulkan-Samples

Follow build instructions for your platform below.

[NOTE]

The full repository is very large, and some ISPs appear to have trouble providing a robust connection to github while the clone is being made.

If you notice problems such as submodules downloading at reported rates in the tens of kB/s, or fatal timeout errors occurring, these may be due to network routing issues to github within your ISP's internal network, rather than anything wrong in your own networking setup.

It can be very difficult to get ISPs to acknowledge such problems exist, much less to fix them.

One workaround is to switch the repository to use ssh protocol prior to the submodule download, which can be done via e.g.

[source,sh]

git clone git@github.com:KhronosGroup/Vulkan-Samples.git cd Vulkan-Samples perl -i -p -e 's|https://(.*?)/|git@\1:|g' .gitmodules git submodule sync git submodule update

While this can be a good alternative if you are running into this connection issue, you must have GitHub ssh key authentication setup to use ssh protocol - see link:https://docs.github.com/en/authentication/connecting-to-github-with-ssh[Connecting to GitHub with SSH] for details. So it is a not a solution we can implement as the repository default.

Another option which may help is to run github through a VPN service.

== Build

=== Supported Platforms

  • Windows - xref:./docs/build.adoc#windows[Build Guide]
  • Linux - xref:./docs/build.adoc#linux[Build Guide]
  • Android - xref:./docs/build.adoc#android[Build Guide]
  • macOS - xref:./docs/build.adoc#macos[Build Guide]
  • iOS - xref:./docs/build.adoc#ios[Build Guide]

== Usage

The following shows some example command line usage on how to configure and run the Vulkan Samples.

Make sure that you are running the samples from the root directory of the repository. Otherwise the samples will not be able to find the assets. ./build/app/bin///vulkan_samples


For the entire usage use

vulkan_samples --help

For subcommand usage use

vulkan_samples <sub_command> --help

Run Swapchain Images sample

vulkan_samples sample swapchain_images

Run AFBC sample in benchmark mode for 5000 frames

vulkan_samples sample afbc --benchmark --stop-after-frame 5000

Run compute nbody using headless_surface and take a screenshot of frame 5

Note: headless_surface uses VK_EXT_headless_surface.

This will create a surface and a Swapchain, but present will be a no op.

The extension is supported by Swiftshader(https://github.com/google/swiftshader).

It allows to quickly test content in environments without a GPU.

vulkan_samples sample compute_nbody --headless_surface -screenshot 5

Run all the performance samples for 10 seconds in each configuration

vulkan_samples batch --category performance --duration 10

Run Swapchain Images sample on an Android device

adb shell am start-activity -n com.khronos.vulkan_samples/com.khronos.vulkan_samples.SampleLauncherActivity -e sample swapchain_images

== License

See link:LICENSE[LICENSE].

This project has several xref:./third_party/README.adoc[third-party dependencies]

This project uses assets from https://github.com/KhronosGroup/Vulkan-Samples-Assets[vulkan-samples-assets]. Each one has its own license.

=== Trademarks

Vulkan is a registered trademark of the Khronos Group Inc.

== Contributions

Donated to Khronos by Arm, with further contributions by Sascha Willems and Adam Sawicki. See xref:CONTRIBUTORS.adoc[CONTRIBUTORS] for the full contributor list.

Also see xref:CONTRIBUTING.adoc[CONTRIBUTING] for contribution guidelines.

== Related resources