Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3434789ybt; Sat, 4 Jul 2020 17:35:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzGrTXDVcRj1Yl2Ix9UwZyUTsBrlr7CqqZillpz0emvDJ3PWtTearuKXbXnrZUa26mhA/As X-Received: by 2002:a17:906:fb99:: with SMTP id lr25mr37919938ejb.49.1593909332901; Sat, 04 Jul 2020 17:35:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593909332; cv=none; d=google.com; s=arc-20160816; b=tHaxr0wOW7LNVPJCBSPn492ufoGpktHoNxpRUjG1mhvhtQ0D/3l0D0qH7aCroR0f+g ZHjzPe7K5MTr0cPkY6QZZ7adlVHRQavsyjH1AENf4HeSiMKMbsARecDxrgpWax+cg0o3 g6oUEzG4EK9SRIU78RydzhQnpfI5qcMHbLpwYv1pr6pl1pR10ERTXY32G1OhzSkShKQV TD9XK85AxT5A0FkPjdMA6dr6NtxnRWKh2s/hrQo/X5/zyLBsMEw8mP11yKYRTr4nWwpS hdNBt8kXzDZUMKohfiOvK+V0YdxAsicvOJhQ6vZ1bVL90SUzCjsEQpSId6mpbXSoFnxq sUYQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language:mime-version:user-agent :date:message-id:subject:from:to:dkim-signature; bh=DSh/Jwvy65gqNgEUvzillgjncz9/zO3XiLAWGc8Crwg=; b=v60yDLBSfDcTc3U3yF3uJ1ateOK1zpayHzxyLDC8eOs5UqAR7VskmyO9IhSnF8R7LW f/J/w1CD//FmtgrHK9dYAiq1N/3EpyDkUACYX5uqVOzMVEoX+FYhLh2U3uuFNKglb1qk /0vTKBvl3M+Wta/bHnFWIG620eshwlGacLe5iSk+/zHe4+HbV6R7YY1Lxx4KCrepwEwA BNIihwALCKl4fTxqdUvf/l8j2Lr6OP7qkT64bD47J/g2idc+2160PXtkmynrxLKkwTUQ rf2wXlo9NxAc7mPOXXGMg0RJJk/HzayrdbLIQ4ydG4/CiN3hoeLxpheiBqvdGz3kKrAU F4nA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=au1fFnyI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m15si10214648eje.623.2020.07.04.17.34.56; Sat, 04 Jul 2020 17:35:32 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=au1fFnyI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728010AbgGEAbm (ORCPT + 99 others); Sat, 4 Jul 2020 20:31:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46008 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727041AbgGEAbl (ORCPT ); Sat, 4 Jul 2020 20:31:41 -0400 Received: from mail-wm1-x32c.google.com (mail-wm1-x32c.google.com [IPv6:2a00:1450:4864:20::32c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 91BF5C061794 for ; Sat, 4 Jul 2020 17:31:41 -0700 (PDT) Received: by mail-wm1-x32c.google.com with SMTP id o8so35549082wmh.4 for ; Sat, 04 Jul 2020 17:31:41 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=to:from:subject:message-id:date:user-agent:mime-version :content-language; bh=DSh/Jwvy65gqNgEUvzillgjncz9/zO3XiLAWGc8Crwg=; b=au1fFnyI+/hEHdy0F3zh4Y8MY2NyTolhs2uCMpU+e1nLSOmewGGstp9+nJX+PZNPrY /sKHbdT8YnDNBQxWK9zzP5cz/obiT2iWn68ediWdyu7dy8QDn5jYIyz/O6TZ3OFjIv7S MRPskFUrUd4CNYrU/rdccW/fREqMwjPTp6Dpe0i+s7ZieZ9778p3x5pkWJBtbaYYJ7/w llv1+sX4PIyBQX3oxY1IGE3XzwETRdRXX0DepB7xJ1W4yNQIuNqL3IwgmPGu16mXgnM2 BxDx/AfuO2j71csyapFnS3a9n+NfceSN/a2S30H7aM1GuCDhGHIxbzmdJUb56gMfDIiN qDcg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:to:from:subject:message-id:date:user-agent :mime-version:content-language; bh=DSh/Jwvy65gqNgEUvzillgjncz9/zO3XiLAWGc8Crwg=; b=OdQ5Ewr7PEUWHb0au0V/BpOJtcktql0lQayloF34iqttUv3+mEegJTSMHx/zSYr+69 763jAJsGV95JdpRR4LYmnTKi78BQqsl8Mthp2gYDDe8G1ccKK3h4YttCorRyV4dm+uhs 8eKRscaQKO1dXauC0hR7XNqQUq1sbS7g1Hb7VJLr55T17uf/d1DHVLJt+lQdPbt275tB PRZk0pfmk6eo81TMuL6grPOkpH9u2bVqMEKpZzAxb2TW7AzP3AxqefeA3XWvOBXbI8gB LWvdN2jSS+LHBwYDTE30lo38+ZWvVMpZyXsvBp6gg1BLJsLq8chkUAYfSkpERtkSJE24 qWJg== X-Gm-Message-State: AOAM530M8EcZ9R1gcXK+zsUa/DQBHZvpA4SJ0+ajPL0s9O2efYSiwHQX wwnOf9Y089eemJCo8xBEI6W3WdgE X-Received: by 2002:a1c:bb43:: with SMTP id l64mr44183919wmf.151.1593909099954; Sat, 04 Jul 2020 17:31:39 -0700 (PDT) Received: from [192.168.1.64] (bl8-158-27.dsl.telepac.pt. [85.241.158.27]) by smtp.gmail.com with ESMTPSA id v12sm5952959wrt.31.2020.07.04.17.31.38 for (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Sat, 04 Jul 2020 17:31:39 -0700 (PDT) To: linux-kernel@vger.kernel.org From: Andre Coelho Subject: fast binary calculator Message-ID: <2199f3d5-cac9-99d8-3b69-55f0d8b245a0@gmail.com> Date: Sun, 5 Jul 2020 01:31:37 +0100 User-Agent: Mozilla/5.0 (X11; Linux i686; rv:68.0) Gecko/20100101 Thunderbird/68.9.0 MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="------------192E6EDDE2BA7E8FAF798DA4" Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is a multi-part message in MIME format. --------------192E6EDDE2BA7E8FAF798DA4 Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit ey Ive made a program, that uses bit flips to quickly represent binary numbers for instance, if i use a 128bit number than the algorithm uses 128+128+128 (and not 128*128) for each bit. Basically, it assigns slots to bits, so for instance pos 1    pos 2 pos 3 0             0       0 1            1      1 so that reduces the time it takes to scan them. I also use bit flips to change the bit on a particular slot. i wrote both c and java files. later Here is the code in c #include char flipBit(char c); char flipBit(char c) {     if (c == '0')         return '1';     else         return '0'; } int main() {                         char binaryNumber[] = { '0','0','0','0',0 };                         int slot1,slot2,slot3,slot4;                         for (slot1=0 ; slot1 < 2 ; slot1++) {                             printf("\n%s",binaryNumber);                             for (slot2 =1 ; slot2 < 2 ; slot2++) {                                 binaryNumber[slot2] = flipBit(binaryNumber[slot2]);                                 printf("\n%s",binaryNumber);                                 for (slot3=2 ; slot3 < 3 ; slot3++) {                                     binaryNumber[slot3] = flipBit(binaryNumber[slot3]);                                     printf("\n%s",binaryNumber);                                     for (slot4=3 ; slot4 < 4 ; slot4++) {                                         binaryNumber[slot4] = flipBit(binaryNumber[slot4]); printf("\n%s",binaryNumber);                                     }                                 }                             }                             binaryNumber[slot1] = flipBit(binaryNumber[slot1]);                             printf("\n");                         } } -- André Albergaria Coelho andrealbergaria@gmail.com --------------192E6EDDE2BA7E8FAF798DA4 Content-Type: text/x-csrc; charset=UTF-8; name="binPath.c" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename="binPath.c" #include char flipBit(char c); char flipBit(char c) { if (c == '0') return '1'; else return '0'; } int main() { char binaryNumber[] = { '0','0','0','0',0 }; int slot1,slot2,slot3,slot4; for (slot1=0 ; slot1 < 2 ; slot1++) { printf("\n%s",binaryNumber); for (slot2 =1 ; slot2 < 2 ; slot2++) { binaryNumber[slot2] = flipBit(binaryNumber[slot2]); printf("\n%s",binaryNumber); for (slot3=2 ; slot3 < 3 ; slot3++) { binaryNumber[slot3] = flipBit(binaryNumber[slot3]); printf("\n%s",binaryNumber); for (slot4=3 ; slot4 < 4 ; slot4++) { binaryNumber[slot4] = flipBit(binaryNumber[slot4]); printf("\n%s",binaryNumber); } } } binaryNumber[slot1] = flipBit(binaryNumber[slot1]); printf("\n"); } } --------------192E6EDDE2BA7E8FAF798DA4 Content-Type: text/x-java; charset=UTF-8; name="binPath.java" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename="binPath.java" import java.io.UnsupportedEncodingException; import java.util.Arrays; public class binPath { // ao inves de se usar o numero , usas a posicao dele na posicao do numero (na array) // ao inves de se usar o sistema de numeros (cada posicao ocupa um elemento vezes a base) public static void main(String[] args) { byte[] plaintext = {0,0,0,1,1,1,0,1}; // prints bits and positions /*byte[] b = {0,0,0,0,0,0,0,0}; byte[] b2 = {1,1,1,1,1,1,1,1}; for (int pos=0; pos < 8; pos++) { System.out.println("position "+pos+" "+b[pos]); System.out.println("position "+pos+" "+b2[pos]); } */ byte[] t = { 0,0,0,0 }; for (int slot1 = 0 ; slot1 < 2 ; slot1++) { System.out.println(); System.out.print(Arrays.toString(t)); for (int slot2 = 1; slot2 < 2 ; slot2++) { t[slot2] = bitFlip(t[slot2]); System.out.println(); System.out.print(Arrays.toString(t)); for (int slot3 = 2; slot3 < 3 ; slot3++) { t[slot3] = bitFlip(t[slot3]); System.out.println(); System.out.print(Arrays.toString(t)); for (int slot4=3; slot4 < 4 ; slot4++) { t[slot4] = bitFlip(t[slot4]); System.out.println(); System.out.print(Arrays.toString(t)); } } } t[slot1] = bitFlip(t[slot1]); } } // Flips bits public static byte bitFlip(byte b) { if (b == 0) return 1; else return 0; } } --------------192E6EDDE2BA7E8FAF798DA4--