我有一个BigDecimal计算结果,我需要舍入到最近的指定区间(在这种情况下,它是金融市场的标记大小).
例如价格[Tick Size] - > Rounded Price
100.1 [0.25] -> 100 100.2 [0.25] -> 100.25 100.1 [0.125] -> 100.125 100.2 [0.125] -> 100.25
谢谢.
更新:schnaader的解决方案,翻译成Java/BigDecimal术语:
price = price.divide(tick).setScale(0, RoundingMode.HALF_UP).multiply(tick)
schnaader.. 13
您可以标准化刻度尺寸,然后使用通常的舍入方法:
100.1 [0.25] -> * (1/0.25) -> 400.4 [1] -> round -> 400 -> / (1/0.25) -> 100 100.2 [0.25] -> * (1/0.25) -> 400.8 [1] -> round -> 401 -> / (1/0.25) -> 100.25
所以它应该是:
Price = Round(Price / Tick) * Tick;
另请注意,您似乎必须为BigDecimals设置正确的舍入模式.例如,请参阅BigDecimal Docs.因此,您应确保将此设置正确并编写一些测试以检查代码的正确性.
您可以标准化刻度尺寸,然后使用通常的舍入方法:
100.1 [0.25] -> * (1/0.25) -> 400.4 [1] -> round -> 400 -> / (1/0.25) -> 100 100.2 [0.25] -> * (1/0.25) -> 400.8 [1] -> round -> 401 -> / (1/0.25) -> 100.25
所以它应该是:
Price = Round(Price / Tick) * Tick;
另请注意,您似乎必须为BigDecimals设置正确的舍入模式.例如,请参阅BigDecimal Docs.因此,您应确保将此设置正确并编写一些测试以检查代码的正确性.