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.log10();
|
||
|
}
|
||
|
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: 2149588
|
||
|
// gas legacy: 2561184
|
||
|
// gas legacyOptimized: 1874610
|
||
|
// div(int256,int256): 3141592653589793238, 88714123 -> 35412542528203691288251815328
|
||
|
// gas irOptimized: 22303
|
||
|
// gas legacy: 22767
|
||
|
// gas legacyOptimized: 22282
|
||
|
// exp(int256): 3141592653589793238 -> 4971498726941338506
|
||
|
// gas irOptimized: 31438
|
||
|
// gas legacy: 32933
|
||
|
// gas legacyOptimized: 30322
|
||
|
// exp2(int256): 3141592653589793238 -> 8824977827076287620
|
||
|
// gas irOptimized: 24808
|
||
|
// gas legacy: 24864
|
||
|
// gas legacyOptimized: 24110
|
||
|
// gm(int256,int256): 3141592653589793238, 88714123 -> 16694419339601
|
||
|
// gas irOptimized: 23573
|
||
|
// gas legacy: 23228
|
||
|
// gas legacyOptimized: 22683
|
||
|
// log10(int256): 3141592653589793238 -> 4971498726941338506
|
||
|
// gas irOptimized: 31328
|
||
|
// gas legacy: 32934
|
||
|
// gas legacyOptimized: 30323
|
||
|
// log2(int256): 3141592653589793238 -> 1651496129472318782
|
||
|
// gas irOptimized: 29484
|
||
|
// gas legacy: 31067
|
||
|
// gas legacyOptimized: 28426
|
||
|
// mul(int256,int256): 3141592653589793238, 88714123 -> 278703637
|
||
|
// gas irOptimized: 22414
|
||
|
// gas legacy: 22807
|
||
|
// gas legacyOptimized: 22295
|
||
|
// pow(int256,uint256): 3141592653589793238, 5 -> 306019684785281453040
|
||
|
// gas irOptimized: 22974
|
||
|
// gas legacy: 23508
|
||
|
// gas legacyOptimized: 22921
|
||
|
// sqrt(int256): 3141592653589793238 -> 1772453850905516027
|
||
|
// gas irOptimized: 23246
|
||
|
// gas legacy: 22802
|
||
|
// gas legacyOptimized: 22422
|
||
|
// benchmark(int256): 3141592653589793238 -> 998882724338592125, 1000000000000000000, 1000000000000000000
|
||
|
// gas irOptimized: 43323
|
||
|
// gas legacy: 36673
|
||
|
// gas legacyOptimized: 34729
|