Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 1 | " test float functions |
| 2 | |
Bram Moolenaar | b46fecd | 2019-06-15 17:58:09 +0200 | [diff] [blame] | 3 | source check.vim |
| 4 | CheckFeature float |
Bram Moolenaar | 3cfa5b1 | 2021-06-06 14:14:39 +0200 | [diff] [blame] | 5 | source vim9.vim |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 6 | |
| 7 | func Test_abs() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 8 | call assert_equal('1.23', string(abs(1.23))) |
| 9 | call assert_equal('1.23', string(abs(-1.23))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 10 | eval -1.23->abs()->string()->assert_equal('1.23') |
| 11 | |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 12 | call assert_equal('0.0', string(abs(0.0))) |
| 13 | call assert_equal('0.0', string(abs(1.0/(1.0/0.0)))) |
| 14 | call assert_equal('0.0', string(abs(-1.0/(1.0/0.0)))) |
| 15 | call assert_equal('inf', string(abs(1.0/0.0))) |
| 16 | call assert_equal('inf', string(abs(-1.0/0.0))) |
| 17 | call assert_equal('nan', string(abs(0.0/0.0))) |
Bram Moolenaar | 17aca70 | 2019-05-16 22:24:55 +0200 | [diff] [blame] | 18 | call assert_equal('12', string(abs('12abc'))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 19 | call assert_equal('12', string(abs('-12abc'))) |
| 20 | call assert_fails("call abs([])", 'E745:') |
| 21 | call assert_fails("call abs({})", 'E728:') |
| 22 | call assert_fails("call abs(function('string'))", 'E703:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 23 | endfunc |
| 24 | |
| 25 | func Test_sqrt() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 26 | call assert_equal('0.0', string(sqrt(0.0))) |
| 27 | call assert_equal('1.414214', string(sqrt(2.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 28 | eval 2.0->sqrt()->string()->assert_equal('1.414214') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 29 | call assert_equal('inf', string(sqrt(1.0/0.0))) |
| 30 | call assert_equal('nan', string(sqrt(-1.0))) |
| 31 | call assert_equal('nan', string(sqrt(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 32 | call assert_fails('call sqrt("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 33 | endfunc |
| 34 | |
| 35 | func Test_log() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 36 | call assert_equal('0.0', string(log(1.0))) |
| 37 | call assert_equal('-0.693147', string(log(0.5))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 38 | eval 0.5->log()->string()->assert_equal('-0.693147') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 39 | call assert_equal('-inf', string(log(0.0))) |
| 40 | call assert_equal('nan', string(log(-1.0))) |
| 41 | call assert_equal('inf', string(log(1.0/0.0))) |
| 42 | call assert_equal('nan', string(log(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 43 | call assert_fails('call log("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 44 | endfunc |
| 45 | |
| 46 | func Test_log10() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 47 | call assert_equal('0.0', string(log10(1.0))) |
| 48 | call assert_equal('2.0', string(log10(100.0))) |
| 49 | call assert_equal('2.079181', string(log10(120.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 50 | eval 120.0->log10()->string()->assert_equal('2.079181') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 51 | call assert_equal('-inf', string(log10(0.0))) |
| 52 | call assert_equal('nan', string(log10(-1.0))) |
| 53 | call assert_equal('inf', string(log10(1.0/0.0))) |
| 54 | call assert_equal('nan', string(log10(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 55 | call assert_fails('call log10("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 56 | endfunc |
| 57 | |
| 58 | func Test_exp() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 59 | call assert_equal('1.0', string(exp(0.0))) |
| 60 | call assert_equal('7.389056', string(exp(2.0))) |
| 61 | call assert_equal('0.367879', string(exp(-1.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 62 | eval -1.0->exp()->string()->assert_equal('0.367879') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 63 | call assert_equal('inf', string(exp(1.0/0.0))) |
| 64 | call assert_equal('0.0', string(exp(-1.0/0.0))) |
| 65 | call assert_equal('nan', string(exp(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 66 | call assert_fails('call exp("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 67 | endfunc |
| 68 | |
| 69 | func Test_sin() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 70 | call assert_equal('0.0', string(sin(0.0))) |
| 71 | call assert_equal('0.841471', string(sin(1.0))) |
| 72 | call assert_equal('-0.479426', string(sin(-0.5))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 73 | eval -0.5->sin()->string()->assert_equal('-0.479426') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 74 | call assert_equal('nan', string(sin(0.0/0.0))) |
| 75 | call assert_equal('nan', string(sin(1.0/0.0))) |
| 76 | call assert_equal('0.0', string(sin(1.0/(1.0/0.0)))) |
| 77 | call assert_equal('-0.0', string(sin(-1.0/(1.0/0.0)))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 78 | call assert_fails('call sin("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 79 | endfunc |
| 80 | |
| 81 | func Test_asin() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 82 | call assert_equal('0.0', string(asin(0.0))) |
| 83 | call assert_equal('1.570796', string(asin(1.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 84 | eval 1.0->asin()->string()->assert_equal('1.570796') |
| 85 | |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 86 | call assert_equal('-0.523599', string(asin(-0.5))) |
| 87 | call assert_equal('nan', string(asin(1.1))) |
| 88 | call assert_equal('nan', string(asin(1.0/0.0))) |
| 89 | call assert_equal('nan', string(asin(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 90 | call assert_fails('call asin("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 91 | endfunc |
| 92 | |
| 93 | func Test_sinh() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 94 | call assert_equal('0.0', string(sinh(0.0))) |
| 95 | call assert_equal('0.521095', string(sinh(0.5))) |
| 96 | call assert_equal('-1.026517', string(sinh(-0.9))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 97 | eval -0.9->sinh()->string()->assert_equal('-1.026517') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 98 | call assert_equal('inf', string(sinh(1.0/0.0))) |
| 99 | call assert_equal('-inf', string(sinh(-1.0/0.0))) |
| 100 | call assert_equal('nan', string(sinh(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 101 | call assert_fails('call sinh("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 102 | endfunc |
| 103 | |
| 104 | func Test_cos() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 105 | call assert_equal('1.0', string(cos(0.0))) |
| 106 | call assert_equal('0.540302', string(cos(1.0))) |
| 107 | call assert_equal('0.877583', string(cos(-0.5))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 108 | eval -0.5->cos()->string()->assert_equal('0.877583') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 109 | call assert_equal('nan', string(cos(0.0/0.0))) |
| 110 | call assert_equal('nan', string(cos(1.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 111 | call assert_fails('call cos("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 112 | endfunc |
| 113 | |
| 114 | func Test_acos() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 115 | call assert_equal('1.570796', string(acos(0.0))) |
| 116 | call assert_equal('0.0', string(acos(1.0))) |
| 117 | call assert_equal('3.141593', string(acos(-1.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 118 | eval -1.0->acos()->string()->assert_equal('3.141593') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 119 | call assert_equal('2.094395', string(acos(-0.5))) |
| 120 | call assert_equal('nan', string(acos(1.1))) |
| 121 | call assert_equal('nan', string(acos(1.0/0.0))) |
| 122 | call assert_equal('nan', string(acos(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 123 | call assert_fails('call acos("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 124 | endfunc |
| 125 | |
| 126 | func Test_cosh() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 127 | call assert_equal('1.0', string(cosh(0.0))) |
| 128 | call assert_equal('1.127626', string(cosh(0.5))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 129 | eval 0.5->cosh()->string()->assert_equal('1.127626') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 130 | call assert_equal('inf', string(cosh(1.0/0.0))) |
| 131 | call assert_equal('inf', string(cosh(-1.0/0.0))) |
| 132 | call assert_equal('nan', string(cosh(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 133 | call assert_fails('call cosh("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 134 | endfunc |
| 135 | |
| 136 | func Test_tan() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 137 | call assert_equal('0.0', string(tan(0.0))) |
| 138 | call assert_equal('0.546302', string(tan(0.5))) |
| 139 | call assert_equal('-0.546302', string(tan(-0.5))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 140 | eval -0.5->tan()->string()->assert_equal('-0.546302') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 141 | call assert_equal('nan', string(tan(1.0/0.0))) |
| 142 | call assert_equal('nan', string(cos(0.0/0.0))) |
| 143 | call assert_equal('0.0', string(tan(1.0/(1.0/0.0)))) |
| 144 | call assert_equal('-0.0', string(tan(-1.0/(1.0/0.0)))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 145 | call assert_fails('call tan("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 146 | endfunc |
| 147 | |
| 148 | func Test_atan() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 149 | call assert_equal('0.0', string(atan(0.0))) |
| 150 | call assert_equal('0.463648', string(atan(0.5))) |
| 151 | call assert_equal('-0.785398', string(atan(-1.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 152 | eval -1.0->atan()->string()->assert_equal('-0.785398') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 153 | call assert_equal('1.570796', string(atan(1.0/0.0))) |
| 154 | call assert_equal('-1.570796', string(atan(-1.0/0.0))) |
| 155 | call assert_equal('nan', string(atan(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 156 | call assert_fails('call atan("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 157 | endfunc |
| 158 | |
| 159 | func Test_atan2() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 160 | call assert_equal('-2.356194', string(atan2(-1, -1))) |
| 161 | call assert_equal('2.356194', string(atan2(1, -1))) |
| 162 | call assert_equal('0.0', string(atan2(1.0, 1.0/0.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 163 | eval 1.0->atan2(1.0/0.0)->string()->assert_equal('0.0') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 164 | call assert_equal('1.570796', string(atan2(1.0/0.0, 1.0))) |
| 165 | call assert_equal('nan', string(atan2(0.0/0.0, 1.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 166 | call assert_fails('call atan2("", -1)', 'E808:') |
| 167 | call assert_fails('call atan2(-1, "")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 168 | endfunc |
| 169 | |
| 170 | func Test_tanh() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 171 | call assert_equal('0.0', string(tanh(0.0))) |
| 172 | call assert_equal('0.462117', string(tanh(0.5))) |
| 173 | call assert_equal('-0.761594', string(tanh(-1.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 174 | eval -1.0->tanh()->string()->assert_equal('-0.761594') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 175 | call assert_equal('1.0', string(tanh(1.0/0.0))) |
| 176 | call assert_equal('-1.0', string(tanh(-1.0/0.0))) |
| 177 | call assert_equal('nan', string(tanh(0.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 178 | call assert_fails('call tanh("")', 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 179 | endfunc |
| 180 | |
| 181 | func Test_fmod() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 182 | call assert_equal('0.13', string(fmod(12.33, 1.22))) |
| 183 | call assert_equal('-0.13', string(fmod(-12.33, 1.22))) |
| 184 | call assert_equal('nan', string(fmod(1.0/0.0, 1.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 185 | eval (1.0/0.0)->fmod(1.0)->string()->assert_equal('nan') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 186 | " On Windows we get "nan" instead of 1.0, accept both. |
| 187 | let res = string(fmod(1.0, 1.0/0.0)) |
| 188 | if res != 'nan' |
| 189 | call assert_equal('1.0', res) |
| 190 | endif |
| 191 | call assert_equal('nan', string(fmod(1.0, 0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 192 | call assert_fails("call fmod('', 1.22)", 'E808:') |
| 193 | call assert_fails("call fmod(12.33, '')", 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 194 | endfunc |
| 195 | |
| 196 | func Test_pow() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 197 | call assert_equal('1.0', string(pow(0.0, 0.0))) |
| 198 | call assert_equal('8.0', string(pow(2.0, 3.0))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 199 | eval 2.0->pow(3.0)->string()->assert_equal('8.0') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 200 | call assert_equal('nan', string(pow(2.0, 0.0/0.0))) |
| 201 | call assert_equal('nan', string(pow(0.0/0.0, 3.0))) |
| 202 | call assert_equal('nan', string(pow(0.0/0.0, 3.0))) |
| 203 | call assert_equal('inf', string(pow(2.0, 1.0/0.0))) |
| 204 | call assert_equal('inf', string(pow(1.0/0.0, 3.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 205 | call assert_fails("call pow('', 2.0)", 'E808:') |
| 206 | call assert_fails("call pow(2.0, '')", 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 207 | endfunc |
| 208 | |
| 209 | func Test_str2float() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 210 | call assert_equal('1.0', string(str2float('1'))) |
Bram Moolenaar | 08243d2 | 2017-01-10 16:12:29 +0100 | [diff] [blame] | 211 | call assert_equal('1.0', string(str2float(' 1 '))) |
| 212 | call assert_equal('1.0', string(str2float(' 1.0 '))) |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 213 | call assert_equal('1.23', string(str2float('1.23'))) |
| 214 | call assert_equal('1.23', string(str2float('1.23abc'))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 215 | eval '1.23abc'->str2float()->string()->assert_equal('1.23') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 216 | call assert_equal('1.0e40', string(str2float('1e40'))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 217 | call assert_equal('-1.23', string(str2float('-1.23'))) |
| 218 | call assert_equal('1.23', string(str2float(' + 1.23 '))) |
Bram Moolenaar | 08243d2 | 2017-01-10 16:12:29 +0100 | [diff] [blame] | 219 | |
| 220 | call assert_equal('1.0', string(str2float('+1'))) |
| 221 | call assert_equal('1.0', string(str2float('+1'))) |
| 222 | call assert_equal('1.0', string(str2float(' +1 '))) |
| 223 | call assert_equal('1.0', string(str2float(' + 1 '))) |
| 224 | |
| 225 | call assert_equal('-1.0', string(str2float('-1'))) |
| 226 | call assert_equal('-1.0', string(str2float('-1'))) |
| 227 | call assert_equal('-1.0', string(str2float(' -1 '))) |
| 228 | call assert_equal('-1.0', string(str2float(' - 1 '))) |
| 229 | |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 230 | call assert_equal('0.0', string(str2float('+0.0'))) |
| 231 | call assert_equal('-0.0', string(str2float('-0.0'))) |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 232 | call assert_equal('inf', string(str2float('1e1000'))) |
| 233 | call assert_equal('inf', string(str2float('inf'))) |
| 234 | call assert_equal('-inf', string(str2float('-inf'))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 235 | call assert_equal('inf', string(str2float('+inf'))) |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 236 | call assert_equal('inf', string(str2float('Inf'))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 237 | call assert_equal('inf', string(str2float(' +inf '))) |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 238 | call assert_equal('nan', string(str2float('nan'))) |
| 239 | call assert_equal('nan', string(str2float('NaN'))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 240 | call assert_equal('nan', string(str2float(' nan '))) |
| 241 | |
Bram Moolenaar | 2950065 | 2021-08-08 15:43:34 +0200 | [diff] [blame] | 242 | call assert_equal('123456.789', string(str2float("123'456.789", 1))) |
| 243 | call assert_equal('123456.789', string(str2float("12'34'56.789", 1))) |
| 244 | call assert_equal('123456.789', string(str2float("1'2'3'4'5'6.789", 1))) |
| 245 | call assert_equal('1.0', string(str2float("1''2.3", 1))) |
| 246 | call assert_equal('123456.7', string(str2float("123'456.7'89", 1))) |
| 247 | |
| 248 | call assert_equal(1.2, str2float(1.2, 0)) |
Yegappan Lakshmanan | 4490ec4 | 2021-07-27 22:00:44 +0200 | [diff] [blame] | 249 | call CheckDefAndScriptFailure2(['str2float(1.2)'], 'E1013: Argument 1: type mismatch, expected string but got float', 'E1174: String required for argument 1') |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 250 | call assert_fails("call str2float([])", 'E730:') |
| 251 | call assert_fails("call str2float({})", 'E731:') |
| 252 | call assert_fails("call str2float(function('string'))", 'E729:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 253 | endfunc |
| 254 | |
Bram Moolenaar | 2950065 | 2021-08-08 15:43:34 +0200 | [diff] [blame] | 255 | def Test_float_quotes() |
| 256 | call assert_equal('123456.789', string(123'456.789)) |
| 257 | call assert_equal('123456.789', string(12'34'56.789)) |
| 258 | call assert_equal('123456.789', string(1'2'3'4'5'6.789)) |
| 259 | |
| 260 | call assert_fails("echo string(1''2.3)", 'E116:') |
| 261 | call assert_fails("echo string(123'456.7'89)", 'E116:') |
| 262 | enddef |
| 263 | |
Bram Moolenaar | 863e80b | 2017-06-04 20:30:00 +0200 | [diff] [blame] | 264 | func Test_float2nr() |
| 265 | call assert_equal(1, float2nr(1.234)) |
| 266 | call assert_equal(123, float2nr(1.234e2)) |
| 267 | call assert_equal(12, float2nr(123.4e-1)) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 268 | eval 123.4e-1->float2nr()->assert_equal(12) |
Bram Moolenaar | 863e80b | 2017-06-04 20:30:00 +0200 | [diff] [blame] | 269 | let max_number = 1/0 |
| 270 | let min_number = -max_number |
| 271 | call assert_equal(max_number/2+1, float2nr(pow(2, 62))) |
| 272 | call assert_equal(max_number, float2nr(pow(2, 63))) |
| 273 | call assert_equal(max_number, float2nr(pow(2, 64))) |
| 274 | call assert_equal(min_number/2-1, float2nr(-pow(2, 62))) |
| 275 | call assert_equal(min_number, float2nr(-pow(2, 63))) |
| 276 | call assert_equal(min_number, float2nr(-pow(2, 64))) |
| 277 | endfunc |
| 278 | |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 279 | func Test_floor() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 280 | call assert_equal('2.0', string(floor(2.0))) |
| 281 | call assert_equal('2.0', string(floor(2.11))) |
| 282 | call assert_equal('2.0', string(floor(2.99))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 283 | eval 2.99->floor()->string()->assert_equal('2.0') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 284 | call assert_equal('-3.0', string(floor(-2.11))) |
| 285 | call assert_equal('-3.0', string(floor(-2.99))) |
| 286 | call assert_equal('nan', string(floor(0.0/0.0))) |
| 287 | call assert_equal('inf', string(floor(1.0/0.0))) |
| 288 | call assert_equal('-inf', string(floor(-1.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 289 | call assert_fails("call floor('')", 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 290 | endfunc |
| 291 | |
| 292 | func Test_ceil() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 293 | call assert_equal('2.0', string(ceil(2.0))) |
| 294 | call assert_equal('3.0', string(ceil(2.11))) |
| 295 | call assert_equal('3.0', string(ceil(2.99))) |
| 296 | call assert_equal('-2.0', string(ceil(-2.11))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 297 | eval -2.11->ceil()->string()->assert_equal('-2.0') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 298 | call assert_equal('-2.0', string(ceil(-2.99))) |
| 299 | call assert_equal('nan', string(ceil(0.0/0.0))) |
| 300 | call assert_equal('inf', string(ceil(1.0/0.0))) |
| 301 | call assert_equal('-inf', string(ceil(-1.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 302 | call assert_fails("call ceil('')", 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 303 | endfunc |
| 304 | |
| 305 | func Test_round() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 306 | call assert_equal('2.0', string(round(2.1))) |
| 307 | call assert_equal('3.0', string(round(2.5))) |
| 308 | call assert_equal('3.0', string(round(2.9))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 309 | eval 2.9->round()->string()->assert_equal('3.0') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 310 | call assert_equal('-2.0', string(round(-2.1))) |
| 311 | call assert_equal('-3.0', string(round(-2.5))) |
| 312 | call assert_equal('-3.0', string(round(-2.9))) |
| 313 | call assert_equal('nan', string(round(0.0/0.0))) |
| 314 | call assert_equal('inf', string(round(1.0/0.0))) |
| 315 | call assert_equal('-inf', string(round(-1.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 316 | call assert_fails("call round('')", 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 317 | endfunc |
| 318 | |
| 319 | func Test_trunc() |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 320 | call assert_equal('2.0', string(trunc(2.1))) |
| 321 | call assert_equal('2.0', string(trunc(2.5))) |
| 322 | call assert_equal('2.0', string(trunc(2.9))) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 323 | eval 2.9->trunc()->string()->assert_equal('2.0') |
Bram Moolenaar | 6247361 | 2017-01-08 19:25:40 +0100 | [diff] [blame] | 324 | call assert_equal('-2.0', string(trunc(-2.1))) |
| 325 | call assert_equal('-2.0', string(trunc(-2.5))) |
| 326 | call assert_equal('-2.0', string(trunc(-2.9))) |
| 327 | call assert_equal('nan', string(trunc(0.0/0.0))) |
| 328 | call assert_equal('inf', string(trunc(1.0/0.0))) |
| 329 | call assert_equal('-inf', string(trunc(-1.0/0.0))) |
Bram Moolenaar | 8720041 | 2017-01-10 16:31:20 +0100 | [diff] [blame] | 330 | call assert_fails("call trunc('')", 'E808:') |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 331 | endfunc |
| 332 | |
Bram Moolenaar | fda1bff | 2019-04-04 13:44:37 +0200 | [diff] [blame] | 333 | func Test_isinf() |
| 334 | call assert_equal(1, isinf(1.0/0.0)) |
| 335 | call assert_equal(-1, isinf(-1.0/0.0)) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 336 | eval (-1.0/0.0)->isinf()->assert_equal(-1) |
Bram Moolenaar | fda1bff | 2019-04-04 13:44:37 +0200 | [diff] [blame] | 337 | call assert_false(isinf(1.0)) |
| 338 | call assert_false(isinf(0.0/0.0)) |
| 339 | call assert_false(isinf('a')) |
| 340 | call assert_false(isinf([])) |
| 341 | call assert_false(isinf({})) |
| 342 | endfunc |
| 343 | |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 344 | func Test_isnan() |
Bram Moolenaar | fda1bff | 2019-04-04 13:44:37 +0200 | [diff] [blame] | 345 | call assert_true(isnan(0.0/0.0)) |
| 346 | call assert_false(isnan(1.0)) |
| 347 | call assert_false(isnan(1.0/0.0)) |
Bram Moolenaar | 93cf85f | 2019-08-17 21:36:28 +0200 | [diff] [blame] | 348 | eval (1.0/0.0)->isnan()->assert_false() |
Bram Moolenaar | fda1bff | 2019-04-04 13:44:37 +0200 | [diff] [blame] | 349 | call assert_false(isnan(-1.0/0.0)) |
| 350 | call assert_false(isnan('a')) |
| 351 | call assert_false(isnan([])) |
| 352 | call assert_false(isnan({})) |
Bram Moolenaar | 453b576 | 2017-01-08 17:59:14 +0100 | [diff] [blame] | 353 | endfunc |
Bram Moolenaar | 863e80b | 2017-06-04 20:30:00 +0200 | [diff] [blame] | 354 | |
| 355 | " This was converted from test65 |
| 356 | func Test_float_misc() |
| 357 | call assert_equal('123.456000', printf('%f', 123.456)) |
| 358 | call assert_equal('1.234560e+02', printf('%e', 123.456)) |
| 359 | call assert_equal('123.456', printf('%g', 123.456)) |
| 360 | " += |
| 361 | let v = 1.234 |
| 362 | let v += 6.543 |
| 363 | call assert_equal('7.777', printf('%g', v)) |
| 364 | let v = 1.234 |
| 365 | let v += 5 |
| 366 | call assert_equal('6.234', printf('%g', v)) |
| 367 | let v = 5 |
| 368 | let v += 3.333 |
| 369 | call assert_equal('8.333', string(v)) |
| 370 | " == |
| 371 | let v = 1.234 |
| 372 | call assert_true(v == 1.234) |
| 373 | call assert_false(v == 1.2341) |
| 374 | " add-subtract |
| 375 | call assert_equal('5.234', printf('%g', 4 + 1.234)) |
| 376 | call assert_equal('-6.766', printf('%g', 1.234 - 8)) |
| 377 | " mult-div |
| 378 | call assert_equal('4.936', printf('%g', 4 * 1.234)) |
| 379 | call assert_equal('0.003241', printf('%g', 4.0 / 1234)) |
| 380 | " dict |
| 381 | call assert_equal("{'x': 1.234, 'y': -2.0e20}", string({'x': 1.234, 'y': -2.0e20})) |
| 382 | " list |
| 383 | call assert_equal('[-123.4, 2.0e-20]', string([-123.4, 2.0e-20])) |
| 384 | endfunc |
| 385 | |
| 386 | " vim: shiftwidth=2 sts=2 expandtab |