From 49836e059e5234619307df18f853da0d624b723d Mon Sep 17 00:00:00 2001
From: AlbertoBSD <alberto.bsd@gmail.com>
Date: Wed, 10 Mar 2021 08:19:15 +0100
Subject: [PATCH] bloom filter update to solve some limits, error percent
 update in keyhunt

---
 CHANGELOG.md  |   1 +
 README.md     |  79 +++++++++++++++++++----------
 bPfile.c      |   2 +-
 bloom/bloom.c |   8 +--
 bloom/bloom.h |   6 +--
 keyhunt.c     | 136 ++++----------------------------------------------
 6 files changed, 72 insertions(+), 160 deletions(-)

diff --git a/CHANGELOG.md b/CHANGELOG.md
index 5c51161..3194475 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -2,6 +2,7 @@
 - Added K factor for BSGS
 - Added bPfile.c to generate a precalculated file
 - Remove unused files about keccak and sha3
+- Change Bloom filter limits and % of error from 0.001 to 0.00001 in bloomfilter.
 
 #Version 0.1.20210112 BSGS
 - Added mode BSGS this work with a file with uncompressed keys
diff --git a/README.md b/README.md
index 08e3dcc..4525004 100644
--- a/README.md
+++ b/README.md
@@ -14,11 +14,11 @@ and then execute:
 
 ``./keyhunt``
 
-you need to have tome file called **adddress.txt** or specify other file with the **-f** opcion
+you need to have some file called **adddress.txt** or specify other file with the **-f** option
 
 ``./keyhunt -f ~/some/path/to/other/file.txt``
 
-if you want more thereads use the **-t** option
+if you want more threads use the **-t** option
 
 ``./keyhunt -f ~/some/path/to/other/file.txt -t 8``
 
@@ -32,7 +32,7 @@ The default behaivor ot keyhunt is to choose a random key and check secuentialy
 
 # BSGS ( Baby step giant step)
 
-The new version of keyhunt implement the bsgs algorithm to search privatekeys for a knowed publickey.
+The new version of keyhunt implement the BSGS algorimth to search privatekeys for a knowed publickey.
 
 The address.txt file need to have a 130 hexadecimal characters uncompress publickey per line any other word followed by an space is ignored example of the file:
 
@@ -52,7 +52,7 @@ btw any word followed by and space after the publickey is ignored the file can b
 
 To try to find those privatekey this is the line of execution:
 
-`` ./keyhunt -m bsgs -f test_120.txt -r 800000000000000000000000000000:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFF ``
+`` ./keyhunt -m bsgs -f test_120.txt -b 800000000000000000000000000000:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFF``
 
 Output:
 
@@ -86,13 +86,13 @@ Test the puzzle 120 with the next publickey:
 ```
 
 Line of execution in random mode **-R**
-``./keyhunt -m bsgs -f 120.txt -r 800000000000000000000000000000:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFF -R`` 
+``./keyhunt -m bsgs -f 120.txt -b 120 -R`` 
 
 
 Example Output:
 
 ```
-$ ./keyhunt -m bsgs -f 120.txt -r 800000000000000000000000000000:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFF -R
+$ ./keyhunt -m bsgs -f 120.txt -b 120 -R
 [+] Version 0.1.20210112 BSGS
 [+] Setting mode BSGS
 [+] Setting random mode.
@@ -116,39 +116,66 @@ Good speed no? 1.1 Terakeys/s for one single thread
 
 **Total 35184372088832 keys in 30 seconds: 1172812402961 keys/s**
 
-We can speed up our process selecting a bigger n value **-n value** btw the n value is the total length of item tested in the radom range, and bigger n value means more ram to be use:
+We can speed up our process selecting a bigger K value **-k value** btw the n value is the total length of item tested in the radom range, a bigger k value means more ram to be use:
 
 Example:
-``$ ./keyhunt -m bsgs -f 120.txt -r 800000000000000000000000000000:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFF -R -n 1000000000000000 -s 120``
+``$ ./keyhunt -m bsgs -f 120.txt -b 120 -k 20``
 
 Example output:
 
 ```
-$ ./keyhunt -m bsgs -f 120.txt -r 800000000000000000000000000000:FFFFFFFFFFFFFFFFFFFFFFFFFFFFFF -R -n 1000000000000000 -s 120
-[+] Version 0.1.20210112 BSGS
+$ ./keyhunt -m bsgs -f 120.txt -b 120 -k 20 -R -p ~/keyhunt/bPfile.bin
+[+] Version 0.1.20210306 K*BSGS
 [+] Setting mode BSGS
+[+] Min range: 800000000000000000000000000000
+[+] Max range: ffffffffffffffffffffffffffffff
+[+] Setting k factor to 20
 [+] Setting random mode.
-[+] Stats output every 120 seconds
 [+] Opening file 120.txt
 [+] Added 1 points from file
-[+] Setting N up to 1000000025191729.
-[+] Init bloom filter for 31622777 elements : 54.00 MB
-[+] Allocating 965.00 MB for aMP Points
-[+] Precalculating 31622777 aMP points
-[+] Allocating 1085.00 MB for bP Points
-[+] precalculating 31622777 bP points
-[+] Sorting 31622777 elements
-[+] Thread 0: 0000000000000000000000000000000000f7e37bb1f8b39dc749ff0c6be2b918
-[+] Thread 0: 0000000000000000000000000000000000fe37e21c957baf3823262cf7270d67
-Total 1000000025191729 keys in 120 seconds: 8333333543264 keys/s
-[+] Thread 0: 0000000000000000000000000000000000af1723ee0314a3381a58b5421bce63
-Total 2000000050383458 keys in 240 seconds: 8333333543264 keys/s
-
+[+] Bit Range 120
+[+] Setting N up to 17592253153280.
+[+] Init bloom filter for 83886080 elements : 239.00 MB
+[+] Allocating 6.00 MB for aMP Points
+[+] Precalculating 209716 aMP points
+[+] Allocating 1280.00 MB for bP Points
+[+] precalculating 83886080 bP points
+[+] Sorting 83886080 elements
+(Thread output omited....)
+Total 562952100904960 keys in 30 seconds: 18765070030165 keys/s
+(Thread output omited....)
+Total 2445323188305920 keys in 120 seconds: 20377693235882 keys/s
 ```
 
-**8.3 Terakeys/s for one single thread**
+**20 Terakeys/s for one single thread**
+
+Want to more Speed use a bigger -k value like 120, it will use some 9 GB of RAM
+
+
+```
+[+] Version 0.1.20210306 K*BSGS
+[+] Setting mode BSGS
+[+] Min range: 800000000000000000000000000000
+[+] Max range: ffffffffffffffffffffffffffffff
+[+] Setting k factor to 120
+[+] Setting random mode.
+[+] Opening file 120.txt
+[+] Added 1 points from file
+[+] Bit Range 120
+[+] Setting N up to 17592420925440.
+[+] Init bloom filter for 503316480 elements : 1437.00 MB
+[+] Allocating 1.00 MB for aMP Points
+[+] Precalculating 34953 aMP points
+[+] Allocating 7680.00 MB for bP Points
+[+] precalculating 503316480 bP points
+[+] Sorting 503316480 elements
+(Thread output omited....)
+Total 3465706922311680 keys in 30 seconds: 115523564077056 keys/s
+````
+
+**~100 Terakeys/s for one single thread**
+
 
-Please be careful with the n value and test it first by you own, againts a knowed publickey/privatekey, some values of n are bugging and I need to solve the errors, please report any extrage behaivor of the tool.
 
 # Dependencies
 - libgmp
diff --git a/bPfile.c b/bPfile.c
index 9c0117a..510cee1 100644
--- a/bPfile.c
+++ b/bPfile.c
@@ -84,7 +84,7 @@ int main(int argc, char **argv)	{
 	mpz_init_set(P.x,G.x);
 	mpz_init_set(P.y,G.y);
 
-	p_file = fopen(argv[2],"w+b");
+	p_file = fopen(argv[2],"wb");
 
 	if(p_file == NULL)	{
 		printf("Can't create file %s\n",argv[2]);
diff --git a/bloom/bloom.c b/bloom/bloom.c
index 374d25f..36089ba 100644
--- a/bloom/bloom.c
+++ b/bloom/bloom.c
@@ -80,13 +80,13 @@ static int bloom_check_add(struct bloom * bloom,
 
 
 // DEPRECATED - Please migrate to bloom_init2.
-int bloom_init(struct bloom * bloom, int entries, double error)
+int bloom_init(struct bloom * bloom, unsigned long long int entries, double error)
 {
-  return bloom_init2(bloom, (unsigned int)entries, error);
+  return bloom_init2(bloom, entries, error);
 }
 
 
-int bloom_init2(struct bloom * bloom, unsigned int entries, double error)
+int bloom_init2(struct bloom * bloom, unsigned long long int entries, double error)
 {
   memset(bloom, 0, sizeof(struct bloom));
 
@@ -144,7 +144,7 @@ void bloom_print(struct bloom * bloom)
   printf("bloom at %p\n", (void *)bloom);
   if (!bloom->ready) { printf(" *** NOT READY ***\n"); }
   printf(" ->version = %d.%d\n", bloom->major, bloom->minor);
-  printf(" ->entries = %u\n", bloom->entries);
+  printf(" ->entries = %lu\n", bloom->entries);
   printf(" ->error = %f\n", bloom->error);
   printf(" ->bits = %llu\n", bloom->bits);
   printf(" ->bits per elem = %f\n", bloom->bpe);
diff --git a/bloom/bloom.h b/bloom/bloom.h
index 5c0edbc..12b271a 100644
--- a/bloom/bloom.h
+++ b/bloom/bloom.h
@@ -24,7 +24,7 @@ struct bloom
   // These fields are part of the public interface of this structure.
   // Client code may read these values if desired. Client code MUST NOT
   // modify any of these.
-  unsigned int entries;
+  unsigned long long int entries;
   unsigned long long int bits;
   unsigned long long int bytes;
   unsigned char hashes;
@@ -68,7 +68,7 @@ struct bloom
  *     1 - on failure
  *
  */
-int bloom_init2(struct bloom * bloom, unsigned int entries, double error);
+int bloom_init2(struct bloom * bloom, unsigned long long int entries, double error);
 
 
 /**
@@ -76,7 +76,7 @@ int bloom_init2(struct bloom * bloom, unsigned int entries, double error);
  * Kept for compatibility with libbloom v.1. To be removed in v3.0.
  *
  */
-int bloom_init(struct bloom * bloom, int entries, double error);
+int bloom_init(struct bloom * bloom, unsigned long long int entries, double error);
 
 
 /** ***************************************************************************
diff --git a/keyhunt.c b/keyhunt.c
index 0f3ad4c..73292fb 100644
--- a/keyhunt.c
+++ b/keyhunt.c
@@ -1,4 +1,3 @@
-
 /*
 Develop by Luis Alberto
 email: alberto.bsd@gmail.com
@@ -101,7 +100,6 @@ const char *minus_params[2] = {"quiet","help"};
 
 pthread_t *tid = NULL;
 pthread_mutex_t write_keys;
-pthread_mutex_t write_range;
 pthread_mutex_t write_random;
 pthread_mutex_t threads_end;
 pthread_mutex_t bsgs_thread;
@@ -427,16 +425,13 @@ int main(int argc, char **argv)	{
       break;
     }
   }
-	/*
-	gmp_printf("[+] %Zu\n",EC.p);
-	gmp_printf("[+] %Zu\n",EC.n);
-	*/
+
 	if(FLAGMODE != MODE_BSGS  && FLAGRANDOM == 1)	{
 		FLAGRANGE = 0;
 	}
 	if(DEBUGCOUNT  > N_SECUENTIAL_MAX)	{
 		DEBUGCOUNT = N_SECUENTIAL_MAX - 1;
-		//printf("Setting debug count to %u",N_SECUENTIAL_MAX);
+
 	}
 	if(FLAGFILE == 0) {
 		filename =(char*) default_filename;
@@ -503,7 +498,6 @@ int main(int argc, char **argv)	{
 		    hextemp = fgets(aux,1000,fd);
 				if(hextemp == aux)	{
 			    trim(aux," \t\n\r");
-					//printf("reading %s\n",aux);
 			    r = strlen(aux);
 			    if(r > 10)  { //Any length for invalid Address?
 			      if(r > MAXLENGTHADDRESS)  {
@@ -532,13 +526,13 @@ int main(int argc, char **argv)	{
 		}
 	  printf("[+] Initializing bloom filter for %u elements.\n",N);
 		if(N <= 10000)	{
-			if(bloom_init2(&bloom,10000,0.0001)  == 1){
+			if(bloom_init2(&bloom,10000,0.00001)  == 1){
 				fprintf(stderr,"[E] error bloom_init for 10000 elements.\n");
 				exit(0);
 			}
 		}
 		else	{
-			if(bloom_init2(&bloom,N,0.0001)  == 1){
+			if(bloom_init2(&bloom,N,0.00001)  == 1){
 				fprintf(stderr,"[E] error bloom_init for %u elements.\n",N);
 				fprintf(stderr,"[+] man enough is enough stop it\n");
 				exit(0);
@@ -796,13 +790,13 @@ int main(int argc, char **argv)	{
 
 		printf("[+] Setting N up to %llu.\n",(long long unsigned int)DEBUGCOUNT);
 		if(bsgs_m > 1000)	{
-			if(bloom_init2(&bloom_bPx,bsgs_m,0.001)  == 1){
+			if(bloom_init2(&bloom_bPx,bsgs_m,0.00001)  == 1){
 				fprintf(stderr,"[E] error bloom_init for %lu elements\n",bsgs_m);
 				exit(0);
 			}
 		}
 		else	{
-			if(bloom_init2(&bloom_bPx,1000,0.001)  == 1){
+			if(bloom_init2(&bloom_bPx,1000,0.00001)  == 1){
 				fprintf(stderr,"[E] error bloom_init for 1000 elements\n");
 				exit(0);
 			}
@@ -1040,9 +1034,11 @@ int main(int argc, char **argv)	{
 	mpz_init(debugcount_mpz);
 	sprintf(temporal,"%llu",(long long unsigned int)DEBUGCOUNT);
 	mpz_set_str(debugcount_mpz,temporal,10);
+	/*
 	printf("DEBUGCOUNT: %llu\n",DEBUGCOUNT);
 	gmp_printf("debugcount_mpz: %Zu\n",debugcount_mpz);
 	printf("NTHREADS: %i\n",NTHREADS);
+	*/
   do  {
     sleep(1);
     seconds+=1;
@@ -1064,7 +1060,6 @@ int main(int argc, char **argv)	{
         i = 0;
         while(i < NTHREADS) {
 					mpz_mul_ui(pretotal,debugcount_mpz,steps[i]);
-					/*printf("steps: %i\n",steps[i]);*/
 					mpz_add(total,total,pretotal);
           i++;
         }
@@ -1106,105 +1101,10 @@ void Point_Doubling(struct Point *P, struct Point *R)	{
 	mpz_clear(slope);
 }
 
-
-/*
-void Point_Doubling(struct Point *P, struct Point *R)	{
-	mpz_t slope, temp;
-	mpz_init(temp);
-	mpz_init(slope);
-	if(mpz_cmp_ui(P->y, 0) != 0) {
-		mpz_mul_ui(temp, P->y, 2);
-		mpz_invert(temp, temp, EC.p);
-		mpz_mul(slope, P->x, P->x);
-		mpz_mul_ui(slope, slope, 3);
-		mpz_mul(slope, slope, temp);
-		mpz_mod(slope, slope, EC.p);
-		mpz_mul(R->x, slope, slope);
-		mpz_sub(R->x, R->x, P->x);
-		mpz_sub(R->x, R->x, P->x);
-		mpz_mod(R->x, R->x, EC.p);
-		mpz_sub(temp, P->x, R->x);
-		mpz_mul(R->y, slope, temp);
-		mpz_sub(R->y, R->y, P->y);
-		mpz_mod(R->y, R->y, EC.p);
-	} else {
-		mpz_set_ui(R->x, 0);
-		mpz_set_ui(R->y, 0);
-	}
-	mpz_clear(temp);
-	mpz_clear(slope);
-}
-*/
-
-/*
 void Point_Addition(struct Point *P, struct Point *Q, struct Point *R)	{
 	mpz_t PA_temp,PA_slope;
 	mpz_init(PA_temp);
 	mpz_init(PA_slope);
-	mpz_mod(Q->x, Q->x, EC.p);
-	mpz_mod(Q->y, Q->y, EC.p);
-	mpz_mod(P->x, P->x, EC.p);
-	mpz_mod(P->y, P->y, EC.p);
-	if(mpz_cmp_ui(P->x, 0) == 0 && mpz_cmp_ui(P->y, 0) == 0) {
-		mpz_set(R->x, Q->x);
-		mpz_set(R->y, Q->y);
-	}
-	else	{
-		if(mpz_cmp_ui(Q->x, 0) == 0 && mpz_cmp_ui(Q->y, 0) == 0) {
-			mpz_set(R->x, P->x);
-			mpz_set(R->y, P->y);
-		}
-		else	{
-			if(mpz_cmp_ui(Q->y, 0) != 0) {
-				mpz_sub(PA_temp, EC.p, Q->y);
-				mpz_mod(PA_temp, PA_temp, EC.p);
-			}
-			else	{
-				mpz_set_ui(PA_temp, 0);
-			}
-			if(mpz_cmp(P->y, PA_temp) == 0 && mpz_cmp(P->x, Q->x) == 0) {
-				mpz_set_ui(R->x, 0);
-				mpz_set_ui(R->y, 0);
-			}
-			else	{
-				if(mpz_cmp(P->x, Q->x) == 0 && mpz_cmp(P->y, Q->y) == 0)	{
-					Point_Doubling(P, R);
-				}
-				else {
-					mpz_set_ui(PA_slope, 0);
-					mpz_sub(PA_temp, P->x, Q->x);
-					mpz_mod(PA_temp, PA_temp, EC.p);
-					mpz_invert(PA_temp, PA_temp, EC.p);
-					mpz_sub(PA_slope, P->y, Q->y);
-					mpz_mul(PA_slope, PA_slope, PA_temp);
-					mpz_mod(PA_slope, PA_slope, EC.p);
-					mpz_mul(R->x, PA_slope, PA_slope);
-					mpz_sub(R->x, R->x, P->x);
-					mpz_sub(R->x, R->x, Q->x);
-					mpz_mod(R->x, R->x, EC.p);
-					mpz_sub(PA_temp, P->x, R->x);
-					mpz_mul(R->y, PA_slope, PA_temp);
-					mpz_sub(R->y, R->y, P->y);
-					mpz_mod(R->y, R->y, EC.p);
-				}
-			}
-		}
-	}
-	mpz_clear(PA_temp);
-	mpz_clear(PA_slope);
-}
-*/
-
-void Point_Addition(struct Point *P, struct Point *Q, struct Point *R)	{
-	mpz_t PA_temp,PA_slope;
-	mpz_init(PA_temp);
-	mpz_init(PA_slope);
-	/*
-	mpz_mod(Q->x, Q->x, EC.p);
-	mpz_mod(Q->y, Q->y, EC.p);
-	mpz_mod(P->x, P->x, EC.p);
-	mpz_mod(P->y, P->y, EC.p);
-	*/
 	if(mpz_cmp_ui(P->x, 0) == 0 && mpz_cmp_ui(P->y, 0) == 0) {
 		mpz_set(R->x, Q->x);
 		mpz_set(R->y, Q->y);
@@ -1430,16 +1330,8 @@ void *thread_process(void *vargp)	{
 		pthread_mutex_unlock(&write_random);
     hextemp  = malloc(65);
 		gmp_sprintf(hextemp,"%0.64Zx",random_key_mpz);
-		pthread_mutex_lock(&write_range);
 		printf("Thread %i : Setting up base key: %s\n",thread_number,hextemp);
-		/*
-		range_file = fopen("./ranges.txt","a+");
-		if(range_file != NULL)	{
-			fprintf(range_file,"%s\n",hextemp);
-			fclose(range_file);
-		}
-		*/
-		pthread_mutex_unlock(&write_range);
+
 		free(hextemp);
 		Scalar_Multiplication(G, &R, random_key_mpz);
     count = 0;
@@ -1633,15 +1525,7 @@ void *thread_process_range(void *vargp)	{
 		exit(0);
 	}
 	printf("Thread %i : Setting up base key: %s\n",thread_number,tt->rs);
-  pthread_mutex_lock(&write_range);
-	/*
-  range_file = fopen("./ranges.txt","a+");
-  if(range_file != NULL)	{
-    fprintf(range_file,"%s\n",tt->rs);
-    fclose(range_file);
-  }
-	*/
-  pthread_mutex_unlock(&write_range);
+
   free(tt->rs);
   free(tt->rpt);
   free(tt);