Jean_Luc (OP)
|
|
February 20, 2019, 02:31:36 PM Last edit: May 23, 2019, 08:26:39 PM by Jean_Luc Merited by ABCbits (69), Welsh (50), malevolent (30), EFS (28), DarkStar_ (25), hugeblack (21), NotATether (17), mprep (15), foroplus (15), LoyceV (12), vapourminer (11), dbshck (10), joniboini (10), 1miau (10), Nestade (10), OgNasty (5), Avirunes (5), AB de Royse777 (5), nc50lc (5), yogg (5), xandry (4), math09183 (4), Dabs (3), Halab (3), franckuestein (3), o_e_l_e_o (2), jacktheking (2), asche (2), DiamondCardz (2), BitMaxz (1), Husna QA (1), DireWolfM14 (1), TheBeardedBaby (1), vv181 (1), arulbero (1), PX-Z (1), cryptobaboon (1), nullama (1), citb0in (1), MrFreeDragon (1), Sat0shisGhost (1), Timelord2o67 (1), GreenPanda (1), escope (1) |
|
Hello, I would like to present a new bitcoin prefix address finder called VanitySearch. It is very similar to Vanitygen. The main differences with Vanitygen are that VanitySearch is not using the heavy OpenSSL for CPU calculation and that the kernel is written in Cuda in order to take full advantage of inline PTX assembly. On my Intel Core i7-4770, VanitySearch runs ~4 times faster than vanitygen64. (1.32 Mkey/s -> 5.27 MK/s) On my GeForce GTX 645, VanitySearch runs ~1.5 times faster than oclvanitygen. (9.26 Mkey/s -> 14.548 MK/s) If you want to compare VanitySearch and Vanitygen result, use the -u option for searching uncompressed address. VanitySearch may not compute a good gridsize for your GPU, so make several tries using -g options in order to find best performances. Using compressed addresses is roughly 20% faster. VanitySearch is available from https://github.com/JeanLucPons/VanitySearchBenchmarks for various hardware (By DaveF): https://bitcointalk.org/index.php?topic=5112311.msg50823897#msg50823897There is still lots of improvement to do. Feel free to test it and to submit issue. Thanks. Sorry for my bad English. Jean-Luc
|
|
|
|
joniboini
Legendary
Offline
Activity: 2310
Merit: 1803
|
|
February 21, 2019, 02:56:03 AM |
|
Do you have any plan to write this for Linux? Or provide a guide to compile it on Linux? I might try it on my Linux and will compare it with Vanitygen (my laptop is old, so it might worth to compare directly here).
|
| CHIPS.GG | | | ▄▄███████▄▄ ▄████▀▀▀▀▀▀▀████▄ ▄███▀░▄░▀▀▀▀▀░▄░▀███▄ ▄███░▄▀░░░░░░░░░▀▄░███▄ ▄███░▄░░░▄█████▄░░░▄░███▄ ███░▄▀░░░███████░░░▀▄░███ ███░█░░░▀▀▀▀▀░░░▀░░░█░███ ███░▀▄░▄▀░▄██▄▄░▀▄░▄▀░███ ▀███░▀░▀▄██▀░▀██▄▀░▀░███▀ ▀███░▀▄░░░░░░░░░▄▀░███▀ ▀███▄░▀░▄▄▄▄▄░▀░▄███▀ ▀████▄▄▄▄▄▄▄████▀ █████████████████████████ | | ▄▄███████▄▄ ▄███████████████▄ ▄█▀▀▀▄█████████▄▀▀▀█▄ ▄██████▀▄█▄▄▄█▄▀██████▄ ▄████████▄█████▄████████▄ ████████▄███████▄████████ ███████▄█████████▄███████ ███▄▄▀▀█▀▀█████▀▀█▀▀▄▄███ ▀█████████▀▀██▀█████████▀ ▀█████████████████████▀ ▀███████████████████▀ ▀████▄▄███▄▄████▀ ████████████████████████ | | 3000+ UNIQUE GAMES | | | 12+ CURRENCIES ACCEPTED | | | VIP REWARD PROGRAM | | ◥ | Play Now |
|
|
|
Jean_Luc (OP)
|
|
February 21, 2019, 10:14:10 AM |
|
Yes, For the CPU code it should not be a problem unless some intrinsics are missing with gcc. I have to check. Concerning CUDA, I have to install the Cuda SDK on a Linux machine and try to compile, that should not be a big deal. There is only few Windows specific functions (concerning high resolution timer) but I can easily make a linux code for it using gettimeofday(). I let you informed.
|
|
|
|
Jean_Luc (OP)
|
|
February 22, 2019, 09:36:41 AM |
|
Hello I've just published a new release. There is also a makefile for Linux but it supports only CPU release. CUDA release for Linux is coming. I'm very interested in knowing performance you get on your hardware (Linux/Windows/CPU/GPU). Thanks for testing and reporting issues.
|
|
|
|
Jean_Luc (OP)
|
|
February 22, 2019, 07:46:02 PM |
|
Thanks for testing The 2 "Check" fields are here especially for debugging/checking purposes. The 2 'checked' addresses are recomputed from the private key by a direct multiplication. To reach the desired address, during the search, generator points are added one by one. You're right by default, if you just add the -gpu option, all CPU cores are used and it slows down much the system and even the GPU. The CPU cannot handle GPU/CPU transfer efficiently. I wrote few words about this on the README but I will let one CPU core free if the gpu is selected.
|
|
|
|
OgNasty
Donator
Legendary
Offline
Activity: 4858
Merit: 4604
Leading Crypto Sports Betting & Casino Platform
|
|
February 22, 2019, 09:55:23 PM |
|
Great to see someone continuing to develop an open source vanity application. I'll have to check this out when I get an opportunity.
|
..Stake.com.. | | | ▄████████████████████████████████████▄ ██ ▄▄▄▄▄▄▄▄▄▄ ▄▄▄▄▄▄▄▄▄▄ ██ ▄████▄ ██ ▀▀▀▀▀▀▀▀▀▀ ██████████ ▀▀▀▀▀▀▀▀▀▀ ██ ██████ ██ ██████████ ██ ██ ██████████ ██ ▀██▀ ██ ██ ██ ██████ ██ ██ ██ ██ ██ ██ ██████ ██ █████ ███ ██████ ██ ████▄ ██ ██ █████ ███ ████ ████ █████ ███ ████████ ██ ████ ████ ██████████ ████ ████ ████▀ ██ ██████████ ▄▄▄▄▄▄▄▄▄▄ ██████████ ██ ██ ▀▀▀▀▀▀▀▀▀▀ ██ ▀█████████▀ ▄████████████▄ ▀█████████▀ ▄▄▄▄▄▄▄▄▄▄▄▄███ ██ ██ ███▄▄▄▄▄▄▄▄▄▄▄▄ ██████████████████████████████████████████ | | | | | | ▄▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▄ █ ▄▀▄ █▀▀█▀▄▄ █ █▀█ █ ▐ ▐▌ █ ▄██▄ █ ▌ █ █ ▄██████▄ █ ▌ ▐▌ █ ██████████ █ ▐ █ █ ▐██████████▌ █ ▐ ▐▌ █ ▀▀██████▀▀ █ ▌ █ █ ▄▄▄██▄▄▄ █ ▌▐▌ █ █▐ █ █ █▐▐▌ █ █▐█ ▀▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▀█ | | | | | | ▄▄█████████▄▄ ▄██▀▀▀▀█████▀▀▀▀██▄ ▄█▀ ▐█▌ ▀█▄ ██ ▐█▌ ██ ████▄ ▄█████▄ ▄████ ████████▄███████████▄████████ ███▀ █████████████ ▀███ ██ ███████████ ██ ▀█▄ █████████ ▄█▀ ▀█▄ ▄██▀▀▀▀▀▀▀██▄ ▄▄▄█▀ ▀███████ ███████▀ ▀█████▄ ▄█████▀ ▀▀▀███▄▄▄███▀▀▀ | | | ..PLAY NOW.. |
|
|
|
Jean_Luc (OP)
|
|
February 23, 2019, 08:17:48 AM |
|
Hello, Thank you for your interest and for reporting issues I just published a new release (v1.2): -Updated probability calculation for very large prefix -Avoid that default configuration hangs the system when gpu is enabled -Performance increase (~10%)
|
|
|
|
Jean_Luc (OP)
|
Hello, I published a new release (1.3) with a ~15% global performance increase, (~20% on GPU). On my hardware, VanitySearch is now 2 times faster (GPU) than oclvanitygen. My goal was to reach a 8 characters (case sensitive) prefix in a reasonable time on my 6 years old hardware, it still need 2 weeks of computation for a 50% probability. I'm not sure I will reach my goal of 2 or 3 days without changing my hardware The next step will be to handle multiple GPU and to support CUDA for linux.
|
|
|
|
Lolo54
Member
Offline
Activity: 117
Merit: 32
|
|
February 27, 2019, 03:28:04 PM |
|
Hello jean_luc I would like to send you an MP but it would be necessary if you would like to activate this option in your profile because otherwise the New can not.
|
|
|
|
Jean_Luc (OP)
|
|
February 27, 2019, 03:40:38 PM |
|
Hello, No problem. Done
|
|
|
|
arulbero
Legendary
Offline
Activity: 1915
Merit: 2074
|
|
February 27, 2019, 07:25:46 PM |
|
Hello,
I would like to present a new bitcoin prefix address finder called VanitySearch. It is very similar to Vanitygen. The main differences with Vanitygen are that VanitySearch is not using the heavy OpenSSL for CPU calculation and that the kernel is written in Cuda in order to take full advantage of inline PTX assembly. On my Intel Core i7-4770, VanitySearch runs ~4 times faster than vanitygen64. (1.32 Mkey/s -> 5.27 MK/s) On my GeForce GTX 645, VanitySearch runs ~1.5 times faster than oclvanitygen. (9.26 Mkey/s -> 14.548 MK/s) If you want to compare VanitySearch and Vanitygen result, use the -u option for searching uncompressed address.
There is still lots of improvement to do. Feel free to test it and to submit issue.
Are you using affine or jacobian coordinates for the points?
|
|
|
|
Jean_Luc (OP)
|
|
February 28, 2019, 08:10:41 AM Last edit: February 28, 2019, 08:52:26 AM by Jean_Luc |
|
Hello,
Affine coordinates for search (faster): Each group perform p = startP + i*G, i in [1..group_size] where i*G is a pre-computed table containing G,2G,3G,.... in affine coordinates. The inversion of deltax (dx1-dx2) is done once per group (1 ModInv and 256*3 mult). group_size is 256 key long.
Protective coordinates for EC multiplication (computation of starting keys). Normalization of the key is done after the multiplication for starting key.
Edit: You also may have noticed that I have an innovative implementation of modular inversion (DRS62) which is almost 2 times faster than the Montgomery one. Some benchmark and comments are available in IntMop.cpp.
|
|
|
|
Jean_Luc (OP)
|
|
February 28, 2019, 08:35:23 AM |
|
Hello, Some news: I just published (1.4) a new release with few fixes (especially for Linux) but the un-initialized memory bug may also affect Windows (I didn't manage to reproduced this bug on Windows but it can be random). I managed to get back an old PC from my company (~8 years old) with 2 Quadro 600 inside Unfortunately the Quadro 600 (fermi) has only compute capability 2.1 and I will have to set-up CUDA SDK 8.0 (the last one which supports fermi). I set up Ubuntu on this PC and I will try to develop the multi GPU release under Linux. Hope I will manage to get good drivers for the Quadro 600 and to make it work.
|
|
|
|
arulbero
Legendary
Offline
Activity: 1915
Merit: 2074
|
|
February 28, 2019, 06:27:37 PM |
|
Hello,
Affine coordinates for search (faster): Each group perform p = startP + i*G, i in [1..group_size] where i*G is a pre-computed table containing G,2G,3G,.... in affine coordinates. The inversion of deltax (dx1-dx2) is done once per group (1 ModInv and 256*3 mult). group_size is 256 key long.
Protective coordinates for EC multiplication (computation of starting keys). Normalization of the key is done after the multiplication for starting key.
Edit: You also may have noticed that I have an innovative implementation of modular inversion (DRS62) which is almost 2 times faster than the Montgomery one. Some benchmark and comments are available in IntMop.cpp.
Ok. two questions: 1) why only 256 for the group size? There is a memory problem? Less inversions are better 2) the field multiplication a*b = c mod p ; why do you use Montgomery, are you sure it is worth it?
|
|
|
|
Jean_Luc (OP)
|
|
February 28, 2019, 06:46:52 PM |
|
A group size of 512 does not bring significant improvement (less than 1%). The DRS62 ModInv is fast and almost negligible with a group size of 256. If you have a modular mult faster than the digit serial Montgomery mult on a 256bit field, I'm obviously fully open. A folding does not improve thing on 256 bit when working with 64bit digits. I'm not sure if Barrett could be faster, I must say I didn't try and for "medium size field", there can be traps.
|
|
|
|
arulbero
Legendary
Offline
Activity: 1915
Merit: 2074
|
|
February 28, 2019, 07:40:49 PM |
|
A group size of 512 does not bring significant improvement (less than 1%). The DRS62 ModInv is fast and almost negligible with a group size of 256. If you have a modular mult faster than the digit serial Montgomery mult on a 256bit field, I'm obviously fully open. A folding does not improve thing on 256 bit when working with 64bit digits. I'm not sure if Barrett could be faster, I must say I didn't try and for "medium size field", there can be traps.
On my pc: VanitySearch -stop -u -t 1 1tryme --> 1,2 MKeys/s my ecc library --> 2,0 MKeys/s (17 M Public keys/s) EDIT: I use: a) group of 4096 points b) a * b = c mod p a*b --> 8 * 64 bit, then first 4 limbs * (2**256 - p) + lower 4 limbs. c) exploit some properties of secp256k1 curve
|
|
|
|
Jean_Luc (OP)
|
|
February 28, 2019, 07:47:00 PM |
|
Linux or windows ? Is it open source ? Can i try it ?
|
|
|
|
arulbero
Legendary
Offline
Activity: 1915
Merit: 2074
|
|
February 28, 2019, 07:56:24 PM |
|
Linux or windows ? Is it open source ? Can i try it ?
Linux. You have a PM
|
|
|
|
Jean_Luc (OP)
|
|
February 28, 2019, 07:57:47 PM |
|
b) a * b = c mod p a*b --> 8 * 64 bit, then first 4 limbs * (2**256 - p) + lower 4 limbs.
I tried this. ~same performance as the multiplication by P (for secpk1) for mmult can be reduced in a single 64bit mult. So I'm interested in c. OK, on linux, performace are still bad, i'm sorry. Some problem with intrinsic....
|
|
|
|
Jean_Luc (OP)
|
|
February 28, 2019, 08:12:26 PM |
|
I have to way 1 hour to answer to your last MP It's time for me to go to sleep. See you
|
|
|
|
|