1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
//! Trait for converting various numeric types to f32
//!
//! This module defines the [ToF32] trait which provides a method for converting
//! different numeric types to f32. It includes implementations for all primitive
//! numeric types including unsigned integers, signed integers and floating point numbers.
/// A trait for converting a value to f32
///
/// This trait provides a standardized way to convert various numeric types to f32.
/// It is automatically implemented for all primitive numeric types.
///
/// # Examples
///
/// ```
/// use toto::traits::tof32::ToF32;
///
/// let x: u8 = 42;
/// let y: f32 = x.to_f32();
/// assert_eq!(y, 42.0_f32);
///
/// let z: i32 = -100;
/// let w: f32 = z.to_f32();
/// assert_eq!(w, -100.0_f32);
/// ```
/// Implementation of ToF32 for u8
///
/// Converts a u8 value to f32 using the `as` operator.
/// Implementation of ToF32 for u16
///
/// Converts a u16 value to f32 using the `as` operator.
/// Implementation of ToF32 for u32
///
/// Converts a u32 value to f32 using the `as` operator.
/// Implementation of ToF32 for u64
///
/// Converts a u64 value to f32 using the `as` operator.
/// Implementation of ToF32 for u128
///
/// Converts a u128 value to f32 using the `as` operator.
/// Implementation of ToF32 for i8
///
/// Converts an i8 value to f32 using the `as` operator.
/// Implementation of ToF32 for i16
///
/// Converts an i16 value to f32 using the `as` operator.
/// Implementation of ToF32 for i32
///
/// Converts an i32 value to f32 using the `as` operator.
/// Implementation of ToF32 for i64
///
/// Converts an i64 value to f32 using the `as` operator.
/// Implementation of ToF32 for i128
///
/// Converts an i128 value to f32 using the `as` operator.
/// Implementation of ToF32 for f64
///
/// Converts an f64 value to f32 using the `as` operator.
/// Note that this may involve precision loss due to the difference in
/// floating-point representation between f64 and f32.