#![warn(clippy::suboptimal_flops, clippy::imprecise_flops)] #![allow(clippy::unnecessary_cast)] // FIXME(f16_f128): add tests for these types when `powf` is available fn main() { let x = 3f32; let _ = 2f32.powf(x); let _ = 2f32.powf(3.1); let _ = 2f32.powf(-3.1); let _ = std::f32::consts::E.powf(x); let _ = std::f32::consts::E.powf(3.1); let _ = std::f32::consts::E.powf(-3.1); let _ = x.powf(1.0 / 2.0); let _ = x.powf(1.0 / 3.0); let _ = (x as f32).powf(1.0 / 3.0); let _ = x.powf(3.0); let _ = x.powf(-2.0); let _ = x.powf(16_777_215.0); let _ = x.powf(-16_777_215.0); let _ = (x as f32).powf(-16_777_215.0); let _ = (x as f32).powf(3.0); let _ = (1.5_f32 + 1.0).powf(1.0 / 3.0); let _ = 1.5_f64.powf(1.0 / 3.0); let _ = 1.5_f64.powf(1.0 / 2.0); let _ = 1.5_f64.powf(3.0); macro_rules! m { ($e:expr) => { 5.5 - $e }; } let _ = 2f32.powf(1f32 + m!(2.0)); // Cases where the lint shouldn't be applied let _ = x.powf(2.1); let _ = x.powf(-2.1); let _ = x.powf(16_777_216.0); let _ = x.powf(-16_777_216.0); let x = 3f64; let _ = 2f64.powf(x); let _ = 2f64.powf(3.1); let _ = 2f64.powf(-3.1); let _ = std::f64::consts::E.powf(x); let _ = std::f64::consts::E.powf(3.1); let _ = std::f64::consts::E.powf(-3.1); let _ = x.powf(1.0 / 2.0); let _ = x.powf(1.0 / 3.0); let _ = x.powf(3.0); let _ = x.powf(-2.0); let _ = x.powf(-2_147_483_648.0); let _ = x.powf(2_147_483_647.0); // Cases where the lint shouldn't be applied let _ = x.powf(2.1); let _ = x.powf(-2.1); let _ = x.powf(-2_147_483_649.0); let _ = x.powf(2_147_483_648.0); }