-
Notifications
You must be signed in to change notification settings - Fork 699
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Probable restrictions #3361
Probable restrictions #3361
Conversation
…probable. This is a hack for now and it should be restriction:probable
… 0 and ignore all probable restrictions.
@@ -2091,8 +2091,14 @@ function rels_proc (kv, nokeys) | |||
end | |||
|
|||
if (kv["type"] == "route" or kv["type"] == "restriction") then | |||
if kv["restriction:probable"] then | |||
if kv["restriction"] or kv["restriction:conditional"] then | |||
kv["restriction:probable"] = nil |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
a user entered restriction always wins over a probable one
src/sif/autocost.cc
Outdated
constexpr float kDefaultUseTolls = 0.5f; // Default preference of using toll roads 0-1 | ||
constexpr float kDefaultUseTracks = 0.f; // Default preference of using tracks 0-1 | ||
constexpr float kDefaultUseDistance = 0.f; // Default preference of using distance vs time 0-1 | ||
constexpr uint32_t kDefaultProbability = 100; // Default percentage of allowing probable restrictions |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
currently only care about restrictions with a probability of 100
valhalla/sif/dynamiccost.h
Outdated
@@ -410,6 +410,13 @@ class DynamicCost { | |||
// Iterate through the restrictions | |||
const EdgeLabel* first_pred = &pred; | |||
for (const auto& cr : restrictions) { | |||
if (cr->type() == baldr::RestrictionType::kNoProbable || | |||
cr->type() == baldr::RestrictionType::kOnlyProbable) { | |||
if (probability_ == 0 || probability_ > cr->probablity()) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
never use a probable restriction that is 0
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why not?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wouldn't that be the logical way to disable probable restrictions?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@purew yes that is exactly what this is doing. probability_ = 0 shuts off looking at any probable restrictions
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tiny nit, just saw the spelling issue with probablity
-> probability
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@purew 🦅 👁️
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What if probabiity_==0
and cr->probability()==0
? (This would be odd?)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@ktatterso probabiity_==0 would be true and we would just continue
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@ktatterso I forgot to mention that we never have a complex restriction with a probability of 0. It means you have no faith in the probable restriction at all
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@gknisely Thanks, I guess I meant the second part, what does cr->probability()==0
mean? And you just answered it. 🙂
valhalla/sif/dynamiccost.h
Outdated
@@ -907,6 +917,8 @@ class DynamicCost { | |||
destination_only_penalty_ = costing_options.destination_only_penalty(); | |||
maneuver_penalty_ = costing_options.maneuver_penalty(); | |||
|
|||
probability_ = costing_options.probability(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To re-confirm this is the logic that allows the probability threshold to be passed through in the payload under the costing_options
key, right?
"costing_options": {"auto": {"probability": prob}}
Where prob
is some values 0-100.
This means that, even though we default to 100, we can, when running Valhalla ourselves, pass in alternative thresholds when testing new PRRs/thresholds.
(cc @denmoroz)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@kuanb this is correct
valhalla/baldr/complexrestriction.h
Outdated
* Get the probability for the restriction. | ||
* @return Returns the probability for this restriction. | ||
*/ | ||
uint64_t probablity() const { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this a value between 0 and 100 that means percentage? If so could this be mentioned in doc-string and return type be set to uint8_t?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@purew all set.
* Set the probability for the restriction. | ||
* @param probability probability for this restriction. | ||
*/ | ||
void set_probability(const uint64_t probability) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same comment as above, doc-string should mention what unit this is and input type should likely be shrunk to uint8_t
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@purew looks like a lot of the set and gets need to be fixed. Let me fix them.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@purew done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Left some more comments
src/sif/autocost.cc
Outdated
@@ -76,6 +78,7 @@ constexpr ranged_default_t<float> kUseTollsRange{0, kDefaultUseTolls, 1.0f}; | |||
constexpr ranged_default_t<float> kUseDistanceRange{0, kDefaultUseDistance, 1.0f}; | |||
constexpr ranged_default_t<float> kAutoHeightRange{0, kDefaultAutoHeight, 10.0f}; | |||
constexpr ranged_default_t<float> kAutoWidthRange{0, kDefaultAutoWidth, 10.0f}; | |||
constexpr ranged_default_t<float> kProbabilityRange{0, kDefaultProbability, 100}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The probability elsewhere is a uint8_t
, should this kProbabilityRange
be the same?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes copy & paste fail
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@purew I made this uint32_t to be consistent with the other options https://github.com/valhalla/valhalla/blob/master/proto/options.proto
src/sif/autocost.cc
Outdated
// probability | ||
pbf_costing_options->set_probability( | ||
kProbabilityRange(rapidjson::get_optional<uint32_t>(*json_costing_options, "/probability") | ||
.get_value_or(kDefaultProbability))); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we sanity check the option from the user, check that it is between 0 and 100 since it comes from an end-user?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@purew no need. this checks it for us constexpr ranged_default_t<uint8_t> kProbabilityRange{0, kDefaultProbability, 100};
{{"/date_time/type", std::to_string(GetParam())}, | ||
{"/date_time/value", "2021-04-02T19:20"}}); | ||
gurka::assert::raw::expect_path(result, {"AB", "BC", "CF"}); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you add a test where the probable restriction value is set as part of the request?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@purew sure. will do
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@purew done
Seems like |
proto/options.proto
Outdated
@@ -132,6 +132,7 @@ message CostingOptions { | |||
optional bool include_hov2 = 74; | |||
optional bool include_hov3 = 75; | |||
optional bool exclude_cash_only_tolls = 76; | |||
optional uint32 probability = 77; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
name needs to be more descriptive - something like: restriction_probability
src/sif/autocost.cc
Outdated
constexpr float kDefaultUseTolls = 0.5f; // Default preference of using toll roads 0-1 | ||
constexpr float kDefaultUseTracks = 0.f; // Default preference of using tracks 0-1 | ||
constexpr float kDefaultUseDistance = 0.f; // Default preference of using distance vs time 0-1 | ||
constexpr uint32_t kDefaultProbability = 100; // Default percentage of allowing probable restrictions |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
naming again: kDefaultRestrictionProbability
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
made two naming change requests so it is more descriptive - other than that , it looks good to me
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Check out my comment about default value/behaviour. I believe we can drop probability_ = 0
case from the code
#3361 (comment)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good 👍
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🚢
Going to RAD / QT test one more time due to all the changes |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If RAD testing looks good then 🚢
@ktatterso going to have a small follow up pr for this as this has been like this for some time. Just don't want to mess up the functionality and this shouldn't, but you never know. |
Issue
This PR consumes and utilizes probable route restrictions. The lowest probability allowed is set in the costing. Currently, only using probable restrictions that have a 100% probability.
Tasklist
Requirements / Relations
Link any requirements here. Other pull requests this PR is based on?