国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何生成具有硬陰影的完全光線追蹤場景

Dbwd_Imgtec ? 來源:Imagination Tech ? 作者:Imagination Tech ? 2022-04-06 12:59 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

在任何視覺圖形的場景中,為了讓用戶獲得更真實的體驗,陰影往往發揮著重要作用。不過,它們長期以來一直是實時應用程序中在速度和質量方面最難完成的功能之一。隨著硬件的改進和硬件加速光線追蹤技術的普及,開發人員獲得了比以往任何時候都更準確、更快地渲染陰影的能力。在Imagination,我們相信光線追蹤在未來實時渲染中的潛力,并一直在尋求可能的界限突破。這篇博文將簡要介紹如何生成具有硬陰影的完全光線追蹤場景,以及Khronos Vulkan光線追蹤擴展的高級概述。對于那些已經閱讀了我們之前《Vulkan中的環境遮擋》的讀者來說,這是很好的后續內容,從完全通過光柵化的光照技術到現在使用完整的光線追蹤。正如《Vulkan中的環境遮擋》一樣,我們的PowerVR SDK中有一個完全光線追蹤硬陰影的代碼示例,您可以在空閑時間探索。

當前的陰影技術

在過去十年中,實時渲染陰影的流行方法是使用陰影貼圖。這是場景從光源視角再次渲染到離屏深度緩沖區(稱為陰影貼圖)的地方,然后在著色過程中對陰影貼圖進行采樣,以使用深度比較計算可見性。雖然這種方法已經成功地應用于許多應用中,但它也有一些缺點。

最常見的問題是陰影鋸齒——這是在陰影貼圖的分辨率過低的地方,導致出現塊狀陰影。雖然可以通過使用更高分辨率的陰影貼圖來解決,但會增加內存占用和帶寬利用率,可能會對性能產生負面影響,尤其是在移動設備上。即使使用更高分辨率的陰影貼圖,某些微觀細節也很難保留,這要后續的屏幕空間陰影通道來細化。但是,在使用光線追蹤時,可以在屏幕上為每個像素分配一條光線,這將產生像素完美的硬陰影。

光線追蹤管線

光線生成

當在命令緩沖區調用 vkCmdTraceRaysKHR ,將為當前綁定的光線追蹤流水線調用用戶定義的光線生成著色器。追蹤光線的命令允許開發人員為調度的線程設置各種參數。我們的演示是完全光線追蹤的,這意味著最好為屏幕上的每個像素分配一個光線生成著色器線程。

每次調用光線生成著色器都必須指定將主光線發射到場景中所需的變量。光線需要有原點(視點)和行進方向??梢酝ㄟ^將逆視圖矩陣應用于(0,0,0,1)來計算原點。要計算方向,需要當前像素的屏幕空間位置??梢允褂?gl_LaunchIDEXT 從光線生成著色器查詢分派坐標。使用此內置擴展,屏幕空間坐標和光線方向可以按如下方式計算:

const vec2 pixelCenter = vec2(gl_LaunchIDEXT.xy) + vec2(0.5);const vec2 inUV = pixelCenter / vec2(gl_LaunchSizeEXT.xy);vec2 screenspace = inUV * 2.0 - 1.0;
vec4 target = mInvProjectionMatrix * vec4(screenspace.xy, 1, 1);vec4 direction = mInvViewMatrix * vec4(normalize(target.xyz), 0);

從這里,我們可以使用 traceRayEXT 函數將主光線發射到場景中。然后,它將遍歷加速結構,在該結構中,它將命中或錯過場景中的幾何體,并調用相應著色器組。執行的著色器組將取決于其命中內容,并將像素顏色存儲在有效負載結構中?!拔疵小敝髦皇菍⒐饩€的顏色設置為硬編碼的清除顏色。

命中組著色器

一旦光線與場景中的對象發生碰撞,就會執行命中著色器。頂點緩沖區、索引緩沖區和材質等模型數據都附著到“命中組”著色器。光線追蹤擴展允許我們獲取命中對象的實例ID。在本演示中,每個模型都是唯一的,因此實例ID直接對應于模型ID。模型ID可用于查找上述緩沖區。

// Since each object is unique in this scene, instance ID is enough to identify which buffers to look upuint objID = gl_InstanceID;
// indices of the triangle we hitivec3 ind = ivec3(indices[nonuniformEXT(objID)].i[3 * gl_PrimitiveID + 0], //    indices[nonuniformEXT(objID)].i[3 * gl_PrimitiveID + 1], //    indices[nonuniformEXT(objID)].i[3 * gl_PrimitiveID + 2]); //
// Vertices of the hit triangleVertex v0 = vertices[nonuniformEXT(objID)].v[ind.x];Vertex v1 = vertices[nonuniformEXT(objID)].v[ind.y];Vertex v2 = vertices[nonuniformEXT(objID)].v[ind.z];

gl_PrimitiveID可以用來告訴我們使用哪些索引來查找命中的頂點,然后使用重心插值系數在它們之間進行插值,該插值系數來自命中著色器中聲明為hitAttributeEXT類型的全局變量。然后,我們使用世界矩陣將插值頂點值轉換到世界空間,并旋轉法線值。

// Get the interpolation coefficientsconst vec3 barycentrics = vec3(1.0 - attribs.x - attribs.y, attribs.x, attribs.y); // Interpolate the position and normal vector for this rayvec4 modelNormal = vec4(v0.nrm * barycentrics.x + v1.nrm * barycentrics.y + v2.nrm * barycentrics.z, 1.0);vec4 modelPos = vec4(v0.pos * barycentrics.x + v1.pos * barycentrics.y + v2.pos * barycentrics.z, 1.0); // Transform the position and normal vectors from model space to world spacemat4 worldTransform = transforms[nonuniformEXT(objID)];vec3 worldPos = (worldTransform * modelPos).xyz; // Don't translate the normal vector, only rotate and scalemat3 worldRotate = mat3(worldTransform[0].xyz, worldTransform[1].xyz, worldTransform[2].xyz);vec3 worldNormal = worldRotate * modelNormal.xyz;

使用擊中點的法線和世界位置,我們可以計算光線相對于場景中靜態光源的Phong照明分量。然后,我們使用一個新的命中和未命中組從該點向光源發射另一條光線。我們可以將次光線的最大長度設置為擊中點和光源之間的距離。如果光線在這個距離內與加速度結構中的任何物體碰撞,我們可以得出結論,在碰撞點和光源之間有一個物體,因此該點處于陰影中。如果次光線未擊中距離集內的任何對象,則會執行“未命中”著色器,我們可以假定該點不在陰影中。

如何生成具有硬陰影的完全光線追蹤場景

在這個圖中,我們可以看到兩個例子。光線從視口(1)發射,第一條光線擊中點3,第二條光線發射,在到達光源的途中不會擊中任何幾何體。視點的第二條光線在點4處照射,但在到達光源的過程中,在點5處再次發生碰撞。因此,我們可以得出結論,點4在陰影中,但點3不在陰影中。

優化

雖然光線追蹤陰影提供了比傳統方法更高的逼真度,但它們仍然不完全完美。因此,就實時計算而言,光線追蹤算法需要更多的硬件,這是一個明顯的缺點。除此之外,還可以采取一些不同的優化措施來改進本文概述的技術。

陰影檢查

我們可以減少第一組用來檢查硬陰影的二次光線的數量;這是通過首先檢查已計算的Phong光照分量來完成的。如果由于曲面背向光源,光照分量已為0,則檢查硬陰影沒有意義,因為該點已處于黑暗中。

這將光線預算從屏幕上像素數的大約1.8倍減少到大約1.5倍。這顯然取決于場景和其中的對象,因為它隨未命中場景的主光線的比例以及通過或未通過陰影檢查的主光線的比例而變化。

混合渲染一般來說,光線追蹤核心將比傳統的光柵化流水線慢(至少目前是這樣)。有幾個可能的原因,但主要的原因是光線追蹤硬件仍然相對較新,因此與光柵化相比,GPU仍然沒有為其投入更多的空間。這意味著可以計算一個標準的G緩沖區,并使用位置附件來定位從哪個位置發射陰影檢查光線。G緩沖區在《Vulkan中的環境遮擋》中有介紹,所以如果你還沒有看到,一定要看一看。簡而言之,G緩沖區可以替代主光線,從而產生更好的任務重疊和更小的光線預算。

結束

雖然完全光線追蹤的硬陰影在寫這篇博文的時候可能不是最佳解決方案,但它們仍然提供了傳統流水線難以模擬的細節和準確性。一如既往,我們強烈建議大家看看PowerVR SDK及其代碼示例,以了解我們如何實現這些技術和實現這些算法的確切機制。我們也總是通過支持門戶或論壇發送電子郵件。

如果您有興趣了解更多關于各種圖形技術的信息,請查看我們的文檔網站,或者在SDK Github中探索我們的其他代碼示例。

原文標題:Vulkan完全光線追蹤硬陰影

文章出處:【微信公眾號:Imagination Tech】歡迎添加關注!文章轉載請注明出處。

審核編輯:湯梓紅


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 代碼
    +關注

    關注

    30

    文章

    4968

    瀏覽量

    73971
  • Vulkan
    +關注

    關注

    0

    文章

    31

    瀏覽量

    6129
  • 光線追蹤
    +關注

    關注

    0

    文章

    185

    瀏覽量

    22097

原文標題:Vulkan完全光線追蹤硬陰影

文章出處:【微信號:Imgtec,微信公眾號:Imagination Tech】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    自動駕駛場景生成方法及優選方案:康謀aiSim 3DGS方案重塑行業標準

    在自動駕駛技術飛速發展的當下,仿真測試的重要性愈發凸顯,而 自動駕駛場景生成 作為仿真測試的核心環節,其技術水平直接決定了測試的效率與可靠性。面對傳統場景生成方式的諸多痛點,基于
    的頭像 發表于 02-02 17:39 ?353次閱讀

    DLInfer聯手沐曦股份實現數據生成場景的實際落地

    近期,上海 AI 實驗室 DeepLink 團隊推出的 DLInfer 通過支持 LMDeploy 主流模型推理,助力沐曦股份曦云 C500 落地 MinerU 多模態數據生成場景,Graph 模式下實現性能加速 60%。
    的頭像 發表于 12-09 14:55 ?714次閱讀
    DLInfer聯手沐曦股份實現數據<b class='flag-5'>生成</b><b class='flag-5'>場景</b>的實際落地

    如何選擇適合的智駕仿真工具進行場景生成和測試?

    在自動駕駛技術日益發展的背景下,選擇合適的智駕仿真工具進行場景生成和測試顯得尤為重要。該工具不僅需要支持高精度的場景重建,還需滿足多種環境條件和傳感器模型的兼容性。本文將深入探討如何評估不同智駕仿真
    的頭像 發表于 11-25 10:32 ?378次閱讀
    如何選擇適合的智駕仿真工具進行<b class='flag-5'>場景</b><b class='flag-5'>生成</b>和測試?

    桂花網M1000:輕量型藍牙網關的場景落地與客戶實踐

    :移動資產的動態追蹤 M1000 的 4G 廣域覆蓋與輕量化設計,成為車載、物流等移動場景的 “連接中樞”。 1. 冷鏈運輸環境監控 某冷鏈物流企業為冷藏車部署 M1000,搭配藍牙溫濕度傳感器,實現
    發表于 11-12 16:59

    物聯網RFID物流追蹤技術是什么?其技術原理和應用場景

    本文深入探討RFID在物流追蹤中的技術原理、應用場景、行業數據與落地策略,面向供應鏈與技術負責人,幫助你理解并推進從倉儲、運輸到最后一公里的 RFID 項目。
    的頭像 發表于 11-11 10:58 ?716次閱讀
    物聯網RFID物流<b class='flag-5'>追蹤</b>技術是什么?其技術原理和應用<b class='flag-5'>場景</b>

    目標追蹤的簡易實現:模板匹配

    一、目標追蹤和圖像識別 一般來說,提到機器視覺這個概念都會想到圖像識別,比如人臉識別、文本識別等等,目標追蹤這個概念在平時接觸的相對比較少。但實際上,目標追蹤可以理解為圖像識別的動態過程:圖像識別
    發表于 10-28 07:21

    拼多多商品推廣鏈接生成API:社交裂變的轉化追蹤利器

    ? 在社交電商時代,拼多多通過 商品推廣鏈接生成API 為商家提供了精準的流量轉化解決方案。該工具不僅簡化了社交裂變活動的落地,更實現了全鏈路轉化效果追蹤,成為提升營銷效率的核心引擎。 一、核心
    的頭像 發表于 09-08 16:22 ?754次閱讀
    拼多多商品推廣鏈接<b class='flag-5'>生成</b>API:社交裂變的轉化<b class='flag-5'>追蹤</b>利器

    告別數月等待:數字孿生場景生成從此進入“日級”時代

    告別數月等待:數字孿生場景生成從此進入“日級”時代
    的頭像 發表于 09-05 17:33 ?2563次閱讀
    告別數月等待:數字孿生<b class='flag-5'>場景</b><b class='flag-5'>生成</b>從此進入“日級”時代

    CoolSiC? MOSFET G2如何正確選型 開關與軟開關場景解析

    在功率電子領域,英飛凌的CoolSiCMOSFETG2以其卓越性能備受關注。本文將重點分析如何在開關和軟開關兩種應用場景下,正確選型CoolSiCMOSFETG2,以實現最佳系統性能。
    的頭像 發表于 08-26 09:04 ?5278次閱讀
    CoolSiC? MOSFET G2如何正確選型 <b class='flag-5'>硬</b>開關與軟開關<b class='flag-5'>場景</b>解析

    生成式 AI 重塑自動駕駛仿真:4D 場景生成技術的突破與實踐

    生成式AI驅動的4D場景技術正解決傳統方法效率低、覆蓋不足等痛點,如何通過NeRF、3D高斯潑濺等技術實現高保真動態建模?高效生成極端天氣等長尾場景?本文為您系統梳理AI驅動的4D
    的頭像 發表于 08-06 11:20 ?5152次閱讀
    <b class='flag-5'>生成</b>式 AI 重塑自動駕駛仿真:4D <b class='flag-5'>場景</b><b class='flag-5'>生成</b>技術的突破與實踐

    光線跳線怎么用

    光線跳線(光纖跳線)是用于連接光纖設備(如交換機、路由器、光模塊、光纖收發器等)或實現光信號靈活分配的關鍵組件,其使用方法需結合具體場景和設備類型。以下是詳細的使用指南: 一、光線跳線的基本組
    的頭像 發表于 07-18 09:40 ?933次閱讀

    資產追蹤與室內導航

    在數字化轉型的浪潮中,資產追蹤與室內導航作為兩項關鍵技術,正在改變企業管理空間和資源的方式。從醫院高效管理醫療設備,到商場為顧客提供無縫導航體驗,這兩項技術在提升效率、降低成本和優化用戶體驗方
    的頭像 發表于 07-04 18:22 ?541次閱讀

    超125款游戲和應用支持DLSS 4多幀生成

    在 COMPUTEX 2025,NVIDIA 發布多項內容。現在已有超過 125 款游戲和應用支持 DLSS 4 多幀生成,并有 10 款新游戲即將發布,《毀滅戰士:黑暗時代》將于 6 月更新支持路徑追蹤與 DLSS 光線重建,
    的頭像 發表于 05-22 10:10 ?1529次閱讀

    光線追蹤及降噪技術綜述

    過程傳遞3D場景的結果。渲染主要包括光柵化(rasterization)[5]和光線追蹤[6]兩種方式。光柵化渲染采用局部光照原理,根據光源照射到物體上直接可見的
    的頭像 發表于 04-01 11:31 ?1034次閱讀
    <b class='flag-5'>光線</b><b class='flag-5'>追蹤</b>及降噪技術綜述

    一種多模態駕駛場景生成框架UMGen介紹

    端到端自動駕駛技術的快速發展對閉環仿真器提出了迫切需求,而生成式模型為其提供了一種有效的技術架構。然而,現有的駕駛場景生成方法大多側重于圖像模態,忽略了其他關鍵模態的建模,如地圖信息、智能交通參與者等,從而限制了其在真實駕駛
    的頭像 發表于 03-24 15:57 ?1687次閱讀
    一種多模態駕駛<b class='flag-5'>場景</b><b class='flag-5'>生成</b>框架UMGen介紹