From 5cab917514ed54f49b10796b7f0d820451592773 Mon Sep 17 00:00:00 2001 From: "William S. Moses" Date: Mon, 9 Dec 2024 13:14:21 -0500 Subject: [PATCH] Add loose types for extract --- enzyme/Enzyme/AdjointGenerator.h | 27 +++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/enzyme/Enzyme/AdjointGenerator.h b/enzyme/Enzyme/AdjointGenerator.h index 2eae03312b7..96b8494302e 100644 --- a/enzyme/Enzyme/AdjointGenerator.h +++ b/enzyme/Enzyme/AdjointGenerator.h @@ -1840,14 +1840,25 @@ class AdjointGenerator : public llvm::InstVisitor { } unsigned size = nextStart - start; if (!dt.isKnown()) { - - std::string str; - raw_string_ostream ss(str); - ss << "Cannot deduce type of extract " << EVI << vd.str() - << " start: " << start << " size: " << size - << " extractSize: " << storeSize; - EmitNoTypeError(str, EVI, gutils, Builder2); - break; + bool found = false; + if (looseTypeAnalysis) { + if (EVI.getType()->isFPOrFPVectorTy()) { + dt = ConcreteType(EVI.getType()->getScalarType()); + found = true; + } else if (EVI.getType()->isIntOrIntVectorTy() || + EVI.getType()->isPointerTy()) { + dt = BaseType::Integer; + found = true; + } + } + if (!found) { + std::string str; + raw_string_ostream ss(str); + ss << "Cannot deduce type of extract " << EVI << vd.str() + << " start: " << start << " size: " << size + << " extractSize: " << storeSize; + EmitNoTypeError(str, EVI, gutils, Builder2); + } } if (auto FT = dt.isFloat()) ((DiffeGradientUtils *)gutils)