Genericized intrin parsing from Ambience

This commit is contained in:
2026-04-04 00:44:48 -04:00
parent 7516da6aa8
commit 1c0f028de0
3 changed files with 175 additions and 36 deletions
@@ -994,13 +994,16 @@ void OpenClCollatingAndMeshingEngine::produceAmbienceStimulusFrame(
float* averageIntensityAverages = reinterpret_cast<float*>( float* averageIntensityAverages = reinterpret_cast<float*>(
averageIntensityBufferPtr); averageIntensityBufferPtr);
uint32_t ambiencePassbandCount = 0;
if (ambienceCountComparator.has_value())
{
// Count frames whose average intensity matches the configured comparator. // Count frames whose average intensity matches the configured comparator.
uint32_t ambienceCount = 0;
for (uint32_t i = 0; i < nSucceeded; ++i) for (uint32_t i = 0; i < nSucceeded; ++i)
{ {
float avg = averageIntensityAverages[i]; float avg = averageIntensityAverages[i];
if (ambienceCountComparator(avg)) { if (ambienceCountComparator.value()(avg)) {
++ambienceCount; ++ambiencePassbandCount;
}
} }
} }
@@ -1010,7 +1013,7 @@ void OpenClCollatingAndMeshingEngine::produceAmbienceStimulusFrame(
::PcloudAmbienceStimulusValue; ::PcloudAmbienceStimulusValue;
PcloudAmbienceStimVal* ambienceValue = reinterpret_cast< PcloudAmbienceStimVal* ambienceValue = reinterpret_cast<
PcloudAmbienceStimVal*>(ambienceFrame.slotDesc.vaddr); PcloudAmbienceStimVal*>(ambienceFrame.slotDesc.vaddr);
ambienceValue[0] = ambienceCount; ambienceValue[0] = ambiencePassbandCount;
} }
class OpenClCollatingAndMeshingEngine::CompactCollateAndMeshFrameReq class OpenClCollatingAndMeshingEngine::CompactCollateAndMeshFrameReq
@@ -3,6 +3,7 @@
#include <cstdint> #include <cstdint>
#include <memory> #include <memory>
#include <optional>
#include <stdexcept> #include <stdexcept>
#include <user/deviceAttachmentSpec.h> #include <user/deviceAttachmentSpec.h>
@@ -34,7 +35,7 @@ struct ParamComparator
} }
}; };
inline ParamComparator parsePcloudAmbienceParamComparator( inline std::optional<ParamComparator> parseOptionalPcloudAmbienceParamComparator(
const std::shared_ptr<device::DeviceAttachmentSpec>& deviceAttachmentSpec) const std::shared_ptr<device::DeviceAttachmentSpec>& deviceAttachmentSpec)
{ {
const auto& params = deviceAttachmentSpec->qualeIfaceApiParams; const auto& params = deviceAttachmentSpec->qualeIfaceApiParams;
@@ -53,24 +54,21 @@ inline ParamComparator parsePcloudAmbienceParamComparator(
if (gtVal != kParamNotSpecified) if (gtVal != kParamNotSpecified)
{ {
return ParamComparator{ return std::optional<ParamComparator>(ParamComparator{
.op = OP_CMP_GT, .op = OP_CMP_GT,
.value = static_cast<uint32_t>(gtVal), .value = static_cast<uint32_t>(gtVal),
}; });
} }
if (ltVal != kParamNotSpecified) if (ltVal != kParamNotSpecified)
{ {
return ParamComparator{ return std::optional<ParamComparator>(ParamComparator{
.op = OP_CMP_LT, .op = OP_CMP_LT,
.value = static_cast<uint32_t>(ltVal), .value = static_cast<uint32_t>(ltVal),
}; });
} }
return ParamComparator{ return std::nullopt;
.op = OP_CMP_LT,
.value = 8U,
};
} }
} // namespace stim_buff } // namespace stim_buff
@@ -5,6 +5,7 @@
#include <cstdint> #include <cstdint>
#include <list> #include <list>
#include <cstddef> #include <cstddef>
#include <optional>
#include <vector> #include <vector>
#include <string> #include <string>
#include <user/stimulusBuffer.h> #include <user/stimulusBuffer.h>
@@ -17,15 +18,143 @@
namespace smo { namespace smo {
namespace stim_buff { namespace stim_buff {
inline intrin::ParsedThresholdParam parsePostrinInterestParam( enum class IntrinStatus
const std::shared_ptr<device::DeviceAttachmentSpec>& deviceAttachmentSpec)
{ {
return intrin::parseOptionalThresholdParam( DISABLED,
deviceAttachmentSpec->qualeIfaceApiParams, NEGTRIN,
intrin::kPosIntPcParamNames, POSTRIN,
intrin::kPosIntThrParamNames, };
90,
intrin::ThresholdUnit::Percentage); struct ParsedAmbienceIntrinConfig
{
IntrinStatus status;
uint32_t interestPercentage;
uint32_t interestThreshold;
};
inline bool isAmbienceIntrinEnabled(IntrinStatus intrinStatus)
{
return intrinStatus != IntrinStatus::DISABLED;
}
inline intrin::ParsedThresholdParam parseAmbienceThresholdParam(
const std::string& paramName,
const std::string& paramValue,
intrin::ThresholdUnit unit)
{
try
{
return intrin::ParsedThresholdParam{
.value = std::stoi(paramValue),
.unit = unit,
.matchedName = paramName,
.wasSpecified = true,
};
}
catch (const std::exception& e)
{
throw std::runtime_error(
"Failed to parse '" + paramName + "' param value '" + paramValue
+ "' as integer: " + e.what());
}
}
inline ParsedAmbienceIntrinConfig buildAmbienceIntrinConfig(
IntrinStatus status,
const intrin::ParsedThresholdParam& thresholdParam,
size_t nDgramsPerFrame)
{
return ParsedAmbienceIntrinConfig{
.status = status,
.interestPercentage =
thresholdParam.unit == intrin::ThresholdUnit::Percentage
? static_cast<uint32_t>(thresholdParam.value)
: 0U,
.interestThreshold = intrin::resolveThresholdValue(
thresholdParam, nDgramsPerFrame),
};
}
inline std::optional<ParsedAmbienceIntrinConfig> tryParseAmbienceIntrinConfig(
const std::string& paramName,
const std::string& paramValue,
size_t nDgramsPerFrame)
{
using intrin::ThresholdUnit;
if (intrin::namesContain(intrin::kPosIntPcParamNames, paramName))
{
return buildAmbienceIntrinConfig(
IntrinStatus::POSTRIN,
parseAmbienceThresholdParam(
paramName, paramValue, ThresholdUnit::Percentage),
nDgramsPerFrame);
}
if (intrin::namesContain(intrin::kPosIntThrParamNames, paramName))
{
return buildAmbienceIntrinConfig(
IntrinStatus::POSTRIN,
parseAmbienceThresholdParam(
paramName, paramValue, ThresholdUnit::Absolute),
nDgramsPerFrame);
}
if (intrin::namesContain(intrin::kNegIntPcParamNames, paramName))
{
return buildAmbienceIntrinConfig(
IntrinStatus::NEGTRIN,
parseAmbienceThresholdParam(
paramName, paramValue, ThresholdUnit::Percentage),
nDgramsPerFrame);
}
if (intrin::namesContain(intrin::kNegIntThrParamNames, paramName))
{
return buildAmbienceIntrinConfig(
IntrinStatus::NEGTRIN,
parseAmbienceThresholdParam(
paramName, paramValue, ThresholdUnit::Absolute),
nDgramsPerFrame);
}
return std::nullopt;
}
inline ParsedAmbienceIntrinConfig parseAmbienceIntrinConfig(
const std::shared_ptr<device::DeviceAttachmentSpec>& deviceAttachmentSpec,
size_t nDgramsPerFrame)
{
const auto& params = deviceAttachmentSpec->qualeIfaceApiParams;
for (auto paramIt = params.rbegin(); paramIt != params.rend(); ++paramIt)
{
const auto& [paramName, paramValue] = *paramIt;
const auto parsedConfig = tryParseAmbienceIntrinConfig(
paramName, paramValue, nDgramsPerFrame);
if (parsedConfig.has_value())
{ return parsedConfig.value(); }
}
return ParsedAmbienceIntrinConfig{
.status = IntrinStatus::DISABLED,
.interestPercentage = 0U,
.interestThreshold = 0U,
};
}
inline void validateAmbienceIntrinComparatorConfig(
IntrinStatus intrinStatus,
const std::optional<ParamComparator>& ambienceCountComparator)
{
if (isAmbienceIntrinEnabled(intrinStatus)
&& !ambienceCountComparator.has_value())
{
throw std::runtime_error(
"A pcloudAmbience stim buff instance with an intrin threshold "
"must also specify either 'ambience-count-gt-val' or "
"'ambience-count-lt-val'");
}
} }
// Forward declaration // Forward declaration
@@ -56,16 +185,16 @@ public:
intrin::validateNoForbiddenUnitlessIntrinParams( intrin::validateNoForbiddenUnitlessIntrinParams(
deviceAttachmentSpec->qualeIfaceApiParams); deviceAttachmentSpec->qualeIfaceApiParams);
const auto postrinInterestParam = const auto intrinConfig = parseAmbienceIntrinConfig(
parsePostrinInterestParam(deviceAttachmentSpec); deviceAttachmentSpec, nDgramsPerFrame_);
postrinInterestPercentage = intrinStatus = intrinConfig.status;
postrinInterestParam.unit == intrin::ThresholdUnit::Percentage intrinInterestPercentage = intrinConfig.interestPercentage;
? static_cast<uint32_t>(postrinInterestParam.value) intrinInterestThreshold = intrinConfig.interestThreshold;
: 0U;
postrinInterestThreshold = intrin::resolveThresholdValue( ambienceCountComparator = parseOptionalPcloudAmbienceParamComparator(
postrinInterestParam, nDgramsPerFrame_);
ambienceCountComparator = parsePcloudAmbienceParamComparator(
deviceAttachmentSpec); deviceAttachmentSpec);
validateAmbienceIntrinComparatorConfig(
intrinStatus, ambienceCountComparator);
// Construct stencils and add to list (FIFO behavior) // Construct stencils and add to list (FIFO behavior)
for (size_t i = 0; i < nStencils; ++i) { for (size_t i = 0; i < nStencils; ++i) {
@@ -75,6 +204,14 @@ public:
~PcloudAmbienceStimulusBuffer() = default; ~PcloudAmbienceStimulusBuffer() = default;
bool shouldTriggerIntrinEvent(uint32_t ambiencePassbandCount) const
{
if (!isAmbienceIntrinEnabled(intrinStatus))
{ return false; }
return ambiencePassbandCount >= intrinInterestThreshold;
}
// Non-copyable, non-movable: inherited pinner lifetime is instance-bound // Non-copyable, non-movable: inherited pinner lifetime is instance-bound
PcloudAmbienceStimulusBuffer(const PcloudAmbienceStimulusBuffer&) = delete; PcloudAmbienceStimulusBuffer(const PcloudAmbienceStimulusBuffer&) = delete;
PcloudAmbienceStimulusBuffer& operator=(const PcloudAmbienceStimulusBuffer&) = delete; PcloudAmbienceStimulusBuffer& operator=(const PcloudAmbienceStimulusBuffer&) = delete;
@@ -82,9 +219,10 @@ public:
PcloudAmbienceStimulusBuffer& operator=(PcloudAmbienceStimulusBuffer&&) = delete; PcloudAmbienceStimulusBuffer& operator=(PcloudAmbienceStimulusBuffer&&) = delete;
public: public:
uint32_t postrinInterestPercentage; IntrinStatus intrinStatus;
uint32_t postrinInterestThreshold; uint32_t intrinInterestPercentage;
ParamComparator ambienceCountComparator; uint32_t intrinInterestThreshold;
std::optional<ParamComparator> ambienceCountComparator;
size_t nStencils; size_t nStencils;
std::list<LG1PcloudAmbienceStencil> stencils; std::list<LG1PcloudAmbienceStencil> stencils;
}; };