Credit Card validation (v12)

Revision 12 of this benchmark created on


Description

Compare Credit Card validation with luhn algorithm

Setup

var ccNum = "4984421209470251";
    
    // https://gist.github.com/2134376
    // Phil Green (ShirtlessKirk)
    
    function luhnChk(luhn) {
      var len = luhn.length,
        mul = 0,
        prodArr = [
          [0, 1, 2, 3, 4, 5, 6, 7, 8, 9],
          [0, 2, 4, 6, 8, 1, 3, 5, 7, 9]
        ],
        sum = 0;
    
      while (len--) {
        sum += prodArr[mul][parseInt(luhn.charAt(len), 10)];
        mul ^= 1;
      }
    
      return sum % 10 === 0 && sum > 0;
    };
    
    // https://github.com/PawelDecowski/jQuery-CreditCardValidator/
    // Pawel Decowski
    
    function is_valid_luhn(number) {
      var digit, n, sum, _len, _ref;
      sum = 0;
      _ref = number.split('').reverse().join('');
      for (n = 0, _len = _ref.length; n < _len; n++) {
        digit = _ref[n];
        digit = +digit;
        if (n % 2) {
          digit *= 2;
          if (digit < 10) {
            sum += digit;
          } else {
            sum += digit - 9;
          }
        } else {
          sum += digit;
        }
      }
      return sum % 10 === 0;
    };
    
    // Luhn algorithm validator, by Avraham Plotnitzky. (aviplot at gmail)
    
    function luhnCheckFast(luhn) {
      var ca, sum = 0,
        mul = 0;
      var len = luhn.length;
      while (len--) {
        ca = parseInt(luhn.charAt(len), 10) << mul;
        sum += ca - (-(ca > 9)) | 9
        // 1 <--> 0 toggle.
        mul = 1 - mul;
      };
      return (sum % 10 === 0) && (sum > 0);
    };
    
    function luhnCheckFast2(luhn) {
      var ca, sum = 0,
        mul = 1;
      var len = luhn.length;
      while (len--) {
        ca = parseInt(luhn.charAt(len), 10) * mul;
        sum += ca - (-(ca > 9)) | 9
        // 1 <--> 2 toggle.
        mul = 3 - mul;
      };
      return (sum % 10 === 0) && (sum > 0);
    };
    
    //http://www.notesbit.com/index.php/web-mysql/web-scripts/luhn-algorithm-for-credit-card-check-using-javascript/
    
    
    function isCreditCard(CC) {
      if (CC.length > 19) return (false);
    
      sum = 0;
      mul = 1;
      l = CC.length;
      for (i = 0; i < l; i++) {
        digit = CC.substring(l - i - 1, l - i);
        tproduct = parseInt(digit, 10) * mul;
        if (tproduct >= 10) sum += (tproduct % 10) + 1;
        else sum += tproduct;
        if (mul == 1) mul++;
        else mul--;
      }
      if ((sum % 10) == 0) return (true);
      else return (false);
    }
    
    
    // http://imei.sms.eu.sk/
    // Javascript code copyright 2009 by Fiach Reid : www.webtropy.com
    // This code may be used freely, as long as this copyright notice is intact.
    
    
    function Calculate(Luhn) {
      var sum = 0;
      for (i = 0; i < Luhn.length; i++) {
        sum += parseInt(Luhn.substring(i, i + 1));
      }
      var delta = new Array(0, 1, 2, 3, 4, -4, -3, -2, -1, 0);
      for (i = Luhn.length - 1; i >= 0; i -= 2) {
        var deltaIndex = parseInt(Luhn.substring(i, i + 1));
        var deltaValue = delta[deltaIndex];
        sum += deltaValue;
      }
      var mod10 = sum % 10;
      mod10 = 10 - mod10;
      if (mod10 == 10) {
        mod10 = 0;
      }
      return mod10;
    }
    
    function Validate(Luhn) {
      var LuhnDigit = parseInt(Luhn.substring(Luhn.length - 1, Luhn.length));
      var LuhnLess = Luhn.substring(0, Luhn.length - 1);
      if (Calculate(LuhnLess) == parseInt(LuhnDigit)) {
        return true;
      }
      return false;
    }
    
    
    
    
    
    
    
    //http://www.brainjar.com/js/validation/default2.asp
    
    
    function checkCC(s) {
      var i, n, c, r, t;
      // First, reverse the string and remove any non-numeric characters.
      r = "";
      for (i = 0; i < s.length; i++) {
        c = parseInt(s.charAt(i), 10);
        if (c >= 0 && c <= 9)
          r = c + r;
      }
    
    
    
      // Check for a bad string.
      if (r.length <= 1)
        return false;
      // Now run through each single digit to create a new string. Even digits
      // are multiplied by two, odd digits are left alone.
      t = "";
      for (i = 0; i < r.length; i++) {
        c = parseInt(r.charAt(i), 10);
        if (i % 2 != 0)
          c *= 2;
        t = t + c;
      }
    
    
    
      // Finally, add up all the single digits in this string.
      n = 0;
      for (i = 0; i < t.length; i++) {
        c = parseInt(t.charAt(i), 10);
        n = n + c;
      }
    
    
    
      // If the resulting sum is an even multiple of ten (but not zero), the
      // card number is good.
      if (n != 0 && n % 10 == 0)
        return true;
      else return false;
    }
    
    // Combination of ShirtlessKirk and Plotnitzky
    
    function luhnCheckV1(str) {
      var luhnArr = [0, 2, 4, 6, 8, 1, 3, 5, 7, 9];
      var ca, sum = 0;
      var len = str.length;
      var mul = (len & 1) ^ 1;
      while (len--) {
        ca = parseInt(str.charAt(len), 10);
        sum += mul ? luhnArr[ca] : ca;
        mul ^= 1; // 1 <--> 0 switch.
      };
      return (sum % 10 === 0) && (sum > 0);
    };
    
    function luhnCheckV2(str) {
      var luhnArr = [0, 2, 4, 6, 8, 1, 3, 5, 7, 9];
      var ca, sum = 0;
      var len = str.length;
      var mul = len & 1;
      while (len--) {
        ca = parseInt(str.charAt(len), 10);
        sum += mul ? ca : luhnArr[ca];
        mul ^= 1; // 1 or 0 swich.
      };
      return (sum % 10 === 0) && (sum > 0);
    };
    
    // unkelpehr variant 1
    // unkelpehr@gmail.com
    var needForSpeed = (function(arr) {
      return function(value) {
        var len = value.length,
          bit = 1,
          sum = 0;
    
        while (len--) {
          sum += !(bit ^= 1) ? parseInt(value[len], 10) : arr[value[len]];
        }
    
        return sum % 10 === 0 && sum > 0;
      };
    }([0, 2, 4, 6, 8, 1, 3, 5, 7, 9]));

Test runner

Ready to run.

Testing in
TestOps/sec
1. notesbit
// async test
4263540108277053
ready
2. webtropy
Validate(ccNum);
ready
3. brainjar
checkCC(ccNum);
ready
4. plotnitzky
luhnCheckFast(ccNum);
ready
5. plotnitzky variant
luhnCheckFast2(ccNum);
ready
6. decowski plugin
is_valid_luhn(ccNum);
ready
7. ShirtlessKirk
luhnChk(ccNum);
ready
8. ShirtlessKirk variant
luhnCheckV1(ccNum);
ready
9. ShirtlessKirk variant
luhnCheckV2(ccNum);
ready
10. unkelpehr
needForSpeed(ccNum);
ready

Revisions

You can edit these tests or add more tests to this page by appending /edit to the URL.