Skip to content

Commit

Permalink
[DAPHNE-daphne-eu#830] Replace lambda function using invalid C++ with…
Browse files Browse the repository at this point in the history
… local static template function

std::pair<bool, auto> was used as a convenience function in DaphneDSLVisitor.cpp. According to [1] this is invalid and only works with GCC. Replacing it with a templated local function makes Clang compile it too. Further improvements to this file will be considered in future commit.

[1] https://stackoverflow.com/questions/59578575/stdpairauto-auto-return-type
  • Loading branch information
corepointer committed Sep 24, 2024
1 parent 6bb56fe commit dc15ce7
Showing 1 changed file with 34 additions and 40 deletions.
74 changes: 34 additions & 40 deletions src/parser/daphnedsl/DaphneDSLVisitor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1474,89 +1474,83 @@ DaphneDSLVisitor::visitCondExpr(DaphneDSLGrammarParser::CondExprContext *ctx) {
valueOrErrorOnVisit(ctx->elseExpr)));
}

// convenience function
template<typename VT, typename T>
static void fillRes(std::shared_ptr<VT[]>& constValues, std::vector<int64_t>& nonConstValsIdx, int64_t i,
std::pair<bool, T> constValue) {
// currently supported types for matrix literals support conversions
// to (most general) array's value type. if unsigned integers are
// added, this can lead to conflicts
if (constValue.first)
constValues.get()[i] = constValue.second; // FIXME: consider casting to unsigned char here suggested by clang tidy
else {
constValues.get()[i] = 0;
nonConstValsIdx.emplace_back(i);
}
}

template <typename VT>
mlir::Value DaphneDSLVisitor::buildColMatrixFromValues(
mlir::Location loc, const std::vector<mlir::Value> &values,
const std::vector<mlir::Type> &valueTypes, mlir::Type matrixVt) {
std::shared_ptr<VT[]> constValues =
std::shared_ptr<VT[]>(new VT[values.size()]);
mlir::Value DaphneDSLVisitor::buildColMatrixFromValues(mlir::Location loc, const std::vector<mlir::Value> &values,
const std::vector<mlir::Type> &valueTypes, mlir::Type matrixVt) {
auto constValues = std::make_shared<VT[]>(values.size());
std::vector<int64_t> nonConstValsIdx;

// convenience function
auto fillRes = [&constValues, &nonConstValsIdx](
int64_t i, std::pair<bool, auto> constValue) {
if (constValue.first) {
// currently supported types for matrix literals support conversions
// to (most general) array's value type. if unsigned integers are
// added, this can lead to conflicts
constValues.get()[i] = constValue.second;
} else {
constValues.get()[i] = 0;
nonConstValsIdx.emplace_back(i);
}
};

for (int64_t i = 0; i < static_cast<int64_t>(values.size()); ++i) {
mlir::Value currentValue = values[i];
mlir::Type currentType = valueTypes[i];

if (mlir::IntegerType valueIntType =
currentType.dyn_cast<mlir::IntegerType>()) {
if (auto valueIntType = currentType.dyn_cast<mlir::IntegerType>()) {
if (currentType.isSignedInteger()) {
switch (valueIntType.getWidth()) {
case 64:
fillRes(i,
CompilerUtils::isConstant<int64_t>(currentValue));
fillRes(constValues, nonConstValsIdx, i, CompilerUtils::isConstant<int64_t>(currentValue));
break;
case 32:
fillRes(i,
CompilerUtils::isConstant<int32_t>(currentValue));
fillRes(constValues, nonConstValsIdx, i, CompilerUtils::isConstant<int32_t>(currentValue));
break;
case 8:
fillRes(i, CompilerUtils::isConstant<int8_t>(currentValue));
fillRes(constValues, nonConstValsIdx, i, CompilerUtils::isConstant<int8_t>(currentValue));
break;
default:
throw ErrorHandler::compilerError(
loc, "DSLVisitor",
"matrix literal of invalid value type");
}
} else if (currentType.isUnsignedInteger()) {
}
else if (currentType.isUnsignedInteger()) {
switch (valueIntType.getWidth()) {
case 64:
fillRes(i,
CompilerUtils::isConstant<uint64_t>(currentValue));
break;
fillRes(constValues, nonConstValsIdx, i, CompilerUtils::isConstant<uint64_t>(currentValue));
break;
case 32:
fillRes(i,
CompilerUtils::isConstant<uint32_t>(currentValue));
fillRes(constValues, nonConstValsIdx, i, CompilerUtils::isConstant<uint32_t>(currentValue));
break;
case 8:
fillRes(i,
CompilerUtils::isConstant<uint8_t>(currentValue));
fillRes(constValues, nonConstValsIdx, i, CompilerUtils::isConstant<uint8_t>(currentValue));
break;
default:
throw ErrorHandler::compilerError(
loc, "DSLVisitor",
"matrix literal of invalid value type");
}
} else if (currentType.isSignlessInteger(1))
fillRes(i, CompilerUtils::isConstant<bool>(currentValue));
fillRes(constValues, nonConstValsIdx, i, CompilerUtils::isConstant<bool>(currentValue));
else
throw ErrorHandler::compilerError(
loc, "DSLVisitor", "matrix literal of invalid value type");

} else if (currentType.isF64())
fillRes(i, CompilerUtils::isConstant<double>(currentValue));
}
else if (currentType.isF64())
fillRes(constValues, nonConstValsIdx, i, CompilerUtils::isConstant<double>(currentValue));
else if (currentType.isF32())
fillRes(i, CompilerUtils::isConstant<float>(currentValue));
fillRes(constValues, nonConstValsIdx, i, CompilerUtils::isConstant<float>(currentValue));
else {
throw ErrorHandler::compilerError(
loc, "DSLVisitor", "matrix literal of invalid value type");
}
}

auto mat = DataObjectFactory::create<DenseMatrix<VT>>(values.size(), 1,
constValues);
auto mat = DataObjectFactory::create<DenseMatrix<VT>>(values.size(), 1, constValues);

// Create a MatrixConstantOp backed by a DenseMatrix containing the
// parse-time constant values from the DaphneDSL matrix literal (and zeros
Expand Down

0 comments on commit dc15ce7

Please sign in to comment.