BeRo1985 / besen

Complete ECMAScript Fifth Edition Implemention in Object Pascal
GNU Lesser General Public License v2.1
217 stars 48 forks source link

change hash function gives up to 22% speedup #14

Open tigrazone opened 7 years ago

edwinyzh commented 7 years ago

Wow! Is the 22% speedup affects the entire library when executing JS code?

tigrazone commented 7 years ago

not always. 3%-10% speedup when executing JS code. Maybe you rewrite my hash function in assembler? bottlenecks is copy functions, .Name = .Name + and balansed tree not too fast. I also change BESENANSIPos to Pos, BESENANSIPosChar to Pos, BESENANSIUpperCase to UpperCase and BESENANSITrim to Trim. It give me -500 bytes in exe ;-) Look at my last commit.

tigrazone commented 7 years ago

.Name = .Name +can be changed to add widechars to array and then fast copy to .Name at finish of cycle

data-man commented 7 years ago

@tigrazone

Maybe you rewrite my hash function in assembler?

Why just assembler? :) Try this: (taken from awesome blog (in russian))

function ShaPerfectHashStr(const s: RawByteString): integer;
var
  i: integer;
begin;
  Result:=0;
  for i:=0 to Length(s)-1 do Result:=(Result + ord(s[i+1]) + 1507220783) * 1041204193;
end;

Well, and assembler :) CRC32 parallel calculation CRC64 parallel calculation

data-man commented 7 years ago

A few words about Aleksandr Sharahov. See Fastcode Winner's List Overview

tigrazone commented 7 years ago

my hash function is simpler and faster function thrHashKey(const Key:TBESENString):TBESENHash; var i,h:longword; begin if length(key)<1 then begin result:=0; exit; end;

h:=ord(Key[1]); for i:=2 to length(Key) do begin h:=(h shl 5) - h + ord(Key[i]); end;

result:=h; end;

data-man commented 7 years ago

@tigrazone Why do you call it your function? It is called X31Hash and it was invented by Karl Nelson more than 17 years ago.

tigrazone commented 7 years ago

yes! it's X31Hash. same function used in TFPHashList Function FPHash(const s:shortstring):LongWord; var p,pmax : PChar; begin {$push} {$Q-} Result:=0; p:=@s[1]; pmax:=@s[length(s)+1]; while (p<pmax) do begin Result:=LongWord(LongInt(Result shl 5) - LongInt(Result)) xor LongWord(P^); Inc(p); end; {$pop} end;

data-man commented 7 years ago

Well, then the FP developers also do not respect the merits and work of other people. This is not accepted in the open source community. Honest people are not accepted that way. And you had impudence to name a function by your name.

@BeRo1985 don't merge this PR, please.