| //@ runBigIntEnabled |
| |
| // Copyright (C) 2017 Robin Templeton. All rights reserved. |
| // This code is governed by the BSD license found in the LICENSE file. |
| |
| assert = { |
| sameValue: function (input, expected, message) { |
| if (input !== expected) |
| throw new Error(message); |
| } |
| }; |
| |
| function testMul(x, y, z) { |
| assert.sameValue(x * y, z, x + " * " + y + " = " + z); |
| assert.sameValue(y * x, z, y + " * " + x + " = " + z); |
| } |
| |
| testMul(0xFEDCBA9876543210n, 0xFEDCBA9876543210n, 0xFDBAC097C8DC5ACCDEEC6CD7A44A4100n); |
| testMul(0xFEDCBA9876543210n, 0xFEDCBA98n, 0xFDBAC097530ECA86541D5980n); |
| testMul(0xFEDCBA9876543210n, 0x1234n, 0x121F49F49F49F49F4B40n); |
| testMul(0xFEDCBA9876543210n, 0x3n, 0x2FC962FC962FC9630n); |
| testMul(0xFEDCBA9876543210n, 0x2n, 0x1FDB97530ECA86420n); |
| testMul(0xFEDCBA9876543210n, 0x1n, 0xFEDCBA9876543210n); |
| testMul(0xFEDCBA9876543210n, 0x0n, 0x0n); |
| testMul(0xFEDCBA9876543210n, BigInt("-1"), BigInt("-18364758544493064720")); |
| testMul(0xFEDCBA9876543210n, BigInt("-2"), BigInt("-36729517088986129440")); |
| testMul(0xFEDCBA9876543210n, BigInt("-3"), BigInt("-55094275633479194160")); |
| testMul(0xFEDCBA9876543210n, BigInt("-4660"), BigInt("-85579774817337681595200")); |
| testMul(0xFEDCBA9876543210n, BigInt("-4275878551"), BigInt("-78525477154691874604502820720")); |
| testMul(0xFEDCBA987654320Fn, 0xFEDCBA987654320Fn, 0xFDBAC097C8DC5ACAE132F7A6B7A1DCE1n); |
| testMul(0xFEDCBA987654320Fn, 0xFEDCBA97n, 0xFDBAC09654320FECDEEC6CD9n); |
| testMul(0xFEDCBA987654320Fn, 0x3n, 0x2FC962FC962FC962Dn); |
| testMul(0xFEDCBA987654320Fn, 0x2n, 0x1FDB97530ECA8641En); |
| testMul(0xFEDCBA987654320Fn, 0x1n, 0xFEDCBA987654320Fn); |
| testMul(0xFEDCBA987654320Fn, 0x0n, 0x0n); |
| testMul(0xFEDCBA987654320Fn, BigInt("-1"), BigInt("-18364758544493064719")); |
| testMul(0xFEDCBA987654320Fn, BigInt("-2"), BigInt("-36729517088986129438")); |
| testMul(0xFEDCBA987654320Fn, BigInt("-3"), BigInt("-55094275633479194157")); |
| testMul(0xFEDCBA987654320Fn, BigInt("-4275878551"), BigInt("-78525477154691874600226942169")); |
| testMul(0xFEDCBA987654320Fn, BigInt("-18364758544493064720"), BigInt("-337264356397531028976608289633615613680")); |
| testMul(0xFEDCBA98n, 0xFEDCBA98n, 0xFDBAC096DD413A40n); |
| testMul(0xFEDCBA98n, 0x1234n, 0x121F49F496E0n); |
| testMul(0xFEDCBA98n, 0x3n, 0x2FC962FC8n); |
| testMul(0xFEDCBA98n, 0x2n, 0x1FDB97530n); |
| testMul(0xFEDCBA98n, 0x1n, 0xFEDCBA98n); |
| testMul(0xFEDCBA98n, 0x0n, 0x0n); |
| testMul(0xFEDCBA98n, BigInt("-1"), BigInt("-4275878552")); |
| testMul(0xFEDCBA98n, BigInt("-2"), BigInt("-8551757104")); |
| testMul(0xFEDCBA98n, BigInt("-3"), BigInt("-12827635656")); |
| testMul(0xFEDCBA98n, BigInt("-4275878551"), BigInt("-18283137387177738152")); |
| testMul(0xFEDCBA98n, BigInt("-18364758544493064720"), BigInt("-78525477173056633148995885440")); |
| testMul(0x3n, 0x3n, 0x9n); |
| testMul(0x3n, 0x2n, 0x6n); |
| testMul(0x3n, 0x1n, 0x3n); |
| testMul(0x3n, 0x0n, 0x0n); |
| testMul(0x3n, BigInt("-1"), BigInt("-3")); |
| testMul(0x3n, BigInt("-2"), BigInt("-6")); |
| testMul(0x3n, BigInt("-3"), BigInt("-9")); |
| testMul(0x3n, BigInt("-4660"), BigInt("-13980")); |
| testMul(0x3n, BigInt("-4275878552"), BigInt("-12827635656")); |
| testMul(0x3n, BigInt("-18364758544493064720"), BigInt("-55094275633479194160")); |
| testMul(0x0n, 0x0n, 0x0n); |
| testMul(0x0n, BigInt("-1"), 0x0n); |
| testMul(0x0n, BigInt("-2"), 0x0n); |
| testMul(0x0n, BigInt("-3"), 0x0n); |
| testMul(0x0n, BigInt("-4275878551"), 0x0n); |
| testMul(0x0n, BigInt("-18364758544493064719"), 0x0n); |
| testMul(BigInt("-1"), BigInt("-1"), 0x1n); |
| testMul(BigInt("-1"), BigInt("-2"), 0x2n); |
| testMul(BigInt("-1"), BigInt("-3"), 0x3n); |
| testMul(BigInt("-1"), BigInt("-4660"), 0x1234n); |
| testMul(BigInt("-1"), BigInt("-4275878551"), 0xFEDCBA97n); |
| testMul(BigInt("-1"), BigInt("-4275878552"), 0xFEDCBA98n); |
| testMul(BigInt("-1"), BigInt("-18364758544493064719"), 0xFEDCBA987654320Fn); |
| testMul(BigInt("-1"), BigInt("-18364758544493064720"), 0xFEDCBA9876543210n); |
| testMul(BigInt("-3"), BigInt("-3"), 0x9n); |
| testMul(BigInt("-3"), BigInt("-4660"), 0x369Cn); |
| testMul(BigInt("-3"), BigInt("-4275878551"), 0x2FC962FC5n); |
| testMul(BigInt("-3"), BigInt("-4275878552"), 0x2FC962FC8n); |
| testMul(BigInt("-3"), BigInt("-18364758544493064719"), 0x2FC962FC962FC962Dn); |
| testMul(BigInt("-3"), BigInt("-18364758544493064720"), 0x2FC962FC962FC9630n); |
| testMul(BigInt("-18364758544493064720"), BigInt("-18364758544493064720"), 0xFDBAC097C8DC5ACCDEEC6CD7A44A4100n); |
| |