NVScaler.h 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. // The MIT License(MIT)
  2. //
  3. // Copyright(c) 2022 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
  4. //
  5. // Permission is hereby granted, free of charge, to any person obtaining a copy of
  6. // this software and associated documentation files(the "Software"), to deal in
  7. // the Software without restriction, including without limitation the rights to
  8. // use, copy, modify, merge, publish, distribute, sublicense, and / or sell copies of
  9. // the Software, and to permit persons to whom the Software is furnished to do so,
  10. // subject to the following conditions :
  11. //
  12. // The above copyright notice and this permission notice shall be included in all
  13. // copies or substantial portions of the Software.
  14. //
  15. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  17. // FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE AUTHORS OR
  18. // COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  19. // IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  20. // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  21. #pragma once
  22. #include <dxgi1_4.h>
  23. #include <d3d12.h>
  24. #include <iostream>
  25. #include "DXUtilities.h"
  26. #include "DeviceResources.h"
  27. #include "Utilities.h"
  28. #include "NIS_Config.h"
  29. #include "d3dx12.h"
  30. extern "C" {
  31. #include <dxcapi.h>
  32. }
  33. class NVScaler {
  34. public:
  35. NVScaler(DeviceResources& deviceResources, const std::vector<std::string>& shaderPaths);
  36. void update(float sharpness, uint32_t inputWidth, uint32_t inputHeight, uint32_t outputWidth, uint32_t outputHeight);
  37. void uploadCoefficients();
  38. ID3D12PipelineState* getComputePSO() { return m_computePSO.Get(); }
  39. ID3D12Resource* getConstantBuffer() { return m_constatBuffer.Get(); }
  40. ID3D12RootSignature* getRootSignature() { return m_computeRootSignature.Get(); }
  41. std::vector<UINT> getDispatchDim() {
  42. return {UINT(std::ceil(m_outputWidth / float(m_blockWidth))), UINT(std::ceil(m_outputHeight / float(m_blockHeight))), 1 };
  43. }
  44. ID3D12Resource* getCoefScaler() { return m_coefScaler.Get(); }
  45. ID3D12Resource* getCoefUSM() { return m_coefUSM.Get(); }
  46. protected:
  47. void createAlignedCoefficients(uint16_t* data, std::vector<uint16_t>& coef, uint32_t rowPitchAligned);
  48. private:
  49. DeviceResources& m_deviceResources;
  50. NISConfig m_config;
  51. ComPtr<ID3D12RootSignature> m_computeRootSignature;
  52. ComPtr<ID3D12PipelineState> m_computePSO;
  53. ComPtr<ID3D12Resource> m_constatBuffer;
  54. ComPtr<ID3D12Resource> m_stagingBuffer;
  55. ComPtr<ID3D12Resource> m_coefScaler;
  56. ComPtr<ID3D12Resource> m_coefUSM;
  57. ComPtr<ID3D12Resource> m_coefScalerUpload;
  58. ComPtr<ID3D12Resource> m_coefUSMUpload;
  59. std::vector<uint16_t> m_coefScalerHost;
  60. std::vector<uint16_t> m_coefUSMHost;
  61. uint32_t m_rowPitch;
  62. uint32_t m_outputWidth;
  63. uint32_t m_outputHeight;
  64. uint32_t m_blockWidth;
  65. uint32_t m_blockHeight;
  66. };