diff options
| author | Yong He <yonghe@outlook.com> | 2023-02-01 14:18:57 -0800 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-02-01 14:18:57 -0800 |
| commit | bbd1e1786401bb88c34802b987d4da72e2364503 (patch) | |
| tree | 99a4be95ae517fd710fc032a1debdac917dd3ac2 /source/slang/slang-ir.cpp | |
| parent | c5895fb0b82fd14fbe45b58d5fc7f75d67625d15 (diff) | |
Support `out` parameters in backward differentiation. (#2619)
* Support `out` parameters in backward differentiation.
* Fixes.
* Fix cleanup.
---------
Co-authored-by: Yong He <yhe@nvidia.com>
Diffstat (limited to 'source/slang/slang-ir.cpp')
| -rw-r--r-- | source/slang/slang-ir.cpp | 35 |
1 files changed, 15 insertions, 20 deletions
diff --git a/source/slang/slang-ir.cpp b/source/slang/slang-ir.cpp index 2a4ae59a7..4814726cf 100644 --- a/source/slang/slang-ir.cpp +++ b/source/slang/slang-ir.cpp @@ -3745,15 +3745,7 @@ namespace Slang IRInst* IRBuilder::emitDifferentialPairGetDifferential(IRType* diffType, IRInst* diffPair) { - return emitIntrinsicInst( - diffType, - kIROp_DifferentialPairGetDifferential, - 1, - &diffPair); - } - - IRInst* IRBuilder::emitDifferentialPairAddressDifferential(IRType* diffType, IRInst* diffPair) - { + SLANG_ASSERT(as<IRDifferentialPairType>(diffPair->getDataType())); return emitIntrinsicInst( diffType, kIROp_DifferentialPairGetDifferential, @@ -3763,7 +3755,7 @@ namespace Slang IRInst* IRBuilder::emitDifferentialPairGetPrimal(IRInst* diffPair) { - auto valueType = as<IRDifferentialPairType>(diffPair->getDataType())->getValueType(); + auto valueType = cast<IRDifferentialPairType>(diffPair->getDataType())->getValueType(); return emitIntrinsicInst( valueType, kIROp_DifferentialPairGetPrimal, @@ -3771,16 +3763,6 @@ namespace Slang &diffPair); } - IRInst* IRBuilder::emitDifferentialPairAddressPrimal(IRInst* diffPair) - { - auto valueType = as<IRDifferentialPairType>( - as<IRPtrTypeBase>(diffPair->getDataType())->getValueType())->getValueType(); - return emitIntrinsicInst( - this->getPtrType(kIROp_PtrType, valueType), - kIROp_DifferentialPairGetPrimal, - 1, - &diffPair); - } IRInst* IRBuilder::emitMakeMatrix( IRType* type, @@ -4240,6 +4222,18 @@ namespace Slang return inst; } + IRInst* IRBuilder::emitLoadReverseGradient(IRType* type, IRInst* diffValue) + { + auto inst = createInst<IRLoadReverseGradient>( + this, + kIROp_LoadReverseGradient, + type, + diffValue); + + addInst(inst); + return inst; + } + IRInst* IRBuilder::emitLoad( IRType* type, IRInst* ptr) @@ -6818,6 +6812,7 @@ namespace Slang case kIROp_MakeTuple: case kIROp_GetTupleElement: case kIROp_Load: // We are ignoring the possibility of loads from bad addresses, or `volatile` loads + case kIROp_LoadReverseGradient: case kIROp_ImageSubscript: case kIROp_FieldExtract: case kIROp_FieldAddress: |
