mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
96 lines
3.0 KiB
Solidity
96 lines
3.0 KiB
Solidity
==== ExternalSource: _prbmath/PRBMathCommon.sol ====
|
|
==== ExternalSource: _prbmath/PRBMathSD59x18.sol ====
|
|
==== Source: prbmath.sol ====
|
|
import "_prbmath/PRBMathSD59x18.sol";
|
|
|
|
contract test {
|
|
using PRBMathSD59x18 for int256;
|
|
|
|
function div(int256 x, int256 y) external pure returns (int256 ret) {
|
|
ret = x.div(y);
|
|
}
|
|
function exp(int256 x) external pure returns (int256 ret) {
|
|
ret = x.exp();
|
|
}
|
|
function exp2(int256 x) external pure returns (int256 ret) {
|
|
ret = x.exp2();
|
|
}
|
|
function gm(int256 x, int256 y) external pure returns (int256 ret) {
|
|
ret = x.gm(y);
|
|
}
|
|
function log10(int256 x) external pure returns (int256 ret) {
|
|
ret = x.log10();
|
|
}
|
|
function log2(int256 x) external pure returns (int256 ret) {
|
|
ret = x.log2();
|
|
}
|
|
function mul(int256 x, int256 y) external pure returns (int256 ret) {
|
|
ret = x.mul(y);
|
|
}
|
|
function pow(int256 x, uint256 y) external pure returns (int256 ret) {
|
|
ret = x.pow(y);
|
|
}
|
|
function sqrt(int256 x) external pure returns (int256 ret) {
|
|
ret = x.sqrt();
|
|
}
|
|
function benchmark(int256 x) external pure returns (int256 ret, int256 z1, int256 z2) {
|
|
int256 y = x.mul(3).ceil();
|
|
int256 z = y.div(x);
|
|
for (uint i = 0; i < 10; i++)
|
|
z = z.sqrt();
|
|
ret = z;
|
|
|
|
// Check precision
|
|
z1 = z.ceil();
|
|
z2 = z.sqrt().pow(2).ceil();
|
|
assert(z1 == z2);
|
|
}
|
|
}
|
|
// ====
|
|
// compileViaYul: also
|
|
// ----
|
|
// constructor()
|
|
// gas irOptimized: 1965559
|
|
// gas legacy: 2602700
|
|
// gas legacyOptimized: 1874490
|
|
// div(int256,int256): 3141592653589793238, 88714123 -> 35412542528203691288251815328
|
|
// gas irOptimized: 22244
|
|
// gas legacy: 22767
|
|
// gas legacyOptimized: 22282
|
|
// exp(int256): 3141592653589793238 -> 23140692632779268978
|
|
// gas irOptimized: 24358
|
|
// gas legacy: 25203
|
|
// gas legacyOptimized: 24357
|
|
// exp2(int256): 3141592653589793238 -> 8824977827076287620
|
|
// gas irOptimized: 24125
|
|
// gas legacy: 24864
|
|
// gas legacyOptimized: 24110
|
|
// gm(int256,int256): 3141592653589793238, 88714123 -> 16694419339601
|
|
// gas irOptimized: 23057
|
|
// gas legacy: 23228
|
|
// gas legacyOptimized: 22683
|
|
// log10(int256): 3141592653589793238 -> 4971498726941338506
|
|
// gas irOptimized: 30112
|
|
// gas legacy: 32934
|
|
// gas legacyOptimized: 30323
|
|
// log2(int256): 3141592653589793238 -> 1651496129472318782
|
|
// gas irOptimized: 28300
|
|
// gas legacy: 31067
|
|
// gas legacyOptimized: 28426
|
|
// mul(int256,int256): 3141592653589793238, 88714123 -> 278703637
|
|
// gas irOptimized: 22335
|
|
// gas legacy: 22807
|
|
// gas legacyOptimized: 22295
|
|
// pow(int256,uint256): 3141592653589793238, 5 -> 306019684785281453040
|
|
// gas irOptimized: 22861
|
|
// gas legacy: 23508
|
|
// gas legacyOptimized: 22921
|
|
// sqrt(int256): 3141592653589793238 -> 1772453850905516027
|
|
// gas irOptimized: 22702
|
|
// gas legacy: 22802
|
|
// gas legacyOptimized: 22422
|
|
// benchmark(int256): 3141592653589793238 -> 998882724338592125, 1000000000000000000, 1000000000000000000
|
|
// gas irOptimized: 37899
|
|
// gas legacy: 36673
|
|
// gas legacyOptimized: 34729
|