Handle floating point numbers in update_qai.py
#1075
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This commit addresses an issue in
update_qai.py
where the script failed when encountering floating point numbers instead of exact integers, which became apparent when running the script independently outside of its typical pipeline.The problem lies in the strict interpretation of certain numeric fields (namely 'count', 'demultiplexed', 'v3loop', 'on.score', 'off.score', 'min.coverage', 'which.key.pos') as integers. When a floating point number was encountered in one of these fields, it created a ValueError, terminating the execution of the script. This falls under the category of 'data type mismatch' problems, when the data provided to a function or operation doesn't match the expected type.
To fix this, a new function
read_int
has been introduced which tries to convert numeric inputs into integers but tolerates floating point numbers without automatic truncation or rounding errors. If a number cannot be converted exactly into an integer, a ValueError is raised. This modification improves the script's flexibility and resilience, now accommodating floating point numbers in these specified fields without error.Data type mismatch issues, where the data provided to a function or operation doesn't match the expected type, can pose significant challenges in script execution. A common example of this error surfaces when a function expressly expects an integer input but receives a floating-point number. At its core, this problem arises from the inherent rigidity of type systems in programming, which while ensuring data consistency and integrity, can sometimes limit flexibility.
This particular revision serves as a practical example of addressing the data type mismatch problem, showcasing that with mindful updates, it's possible to maintain data integrity while allowing for greater operational flexibility in our codebases. It highlights that while strict typing can prevent certain types of errors, it's equally important to ensure our code is resilient to variations in data type, especially when interfacing with varying data sources or when scripts run in isolation outside their regular pipelines.