Is the Go result correct?
xeoncross opened this issue · 3 comments
The results from your test showed go was really slow. For simplicity I combined everything into it's own file. I'm getting a result of 110 ms
(vs 37879
). I may be misunderstanding something.
package main
/*
#include <stdio.h>
#include <sys/time.h>
int plus(int x, int y)
{
return x + y;
}
int plusone(int x)
{
return x + 1;
}
long long current_timestamp()
{
struct timeval te;
gettimeofday(&te, NULL); // get current time
long long milliseconds = te.tv_sec*1000LL + te.tv_usec/1000; // caculate milliseconds
return milliseconds;
}
*/
import "C"
import "fmt"
import "os"
import "strconv"
func run(count C.int) {
start := C.current_timestamp()
var x C.int = 0
for x < count {
x = C.plusone(x)
}
fmt.Println(C.current_timestamp() - start)
}
func main() {
if (len(os.Args) == 1) {
fmt.Println("First arg (0 - 2000000000) is required.")
return
}
count, err := strconv.Atoi(os.Args[1])
if err != nil || count <= 0 || count > 2000000000 {
fmt.Println("Must be a positive number not exceeding 2 billion.");
return
}
// load
C.plusone(C.int(C.current_timestamp()))
// start
run(C.int(count))
}
go version go1.9.2 darwin/amd64
Core i5 Mac
Did you use 500 million or 1 million? His test results used 500 million.
Also he used Go 1.8, it would be interesting to see if you can run it with both, to see if things have improved.
You are correct. I didn't pay close enough attention to the second run-all (500000000). Running it again (compared to the C baseline) I get.
# Go
./app 500000000
53058
# C
./a.out 500000000
1989
I have no idea how LuaJit could be faster than C. I assume the compiler is doing something fishy.
Here is my baseline C version
#include <stdio.h>
#include <sys/time.h>
int plus(int x, int y)
{
return x + y;
}
int plusone(int x)
{
return x + 1;
}
long long current_timestamp()
{
struct timeval te;
gettimeofday(&te, NULL); // get current time
long long milliseconds = te.tv_sec*1000LL + te.tv_usec/1000; // caculate milliseconds
return milliseconds;
}
void run(int count)
{
long long start = current_timestamp();
long long end;
int x = 0;
while (x < count)
x = plusone(x);
printf("%lld\n", current_timestamp() - start);
}
int main(int argc, char** argv)
{
if (argc == 1) {
printf("First arg is required \n");
return 1;
}
int count = atoi(argv[1]);
if (count <= 0 || count > 2000000000) {
printf("Must be a positive number not exceeding 2 billion.\n");
return 1;
}
// start immediately
run(count);
return 0;
}
I have no idea how LuaJit could be faster than C. I assume the compiler is doing something fishy.
It's not doing anything fishy, it's leveraging JITing to skip the PLT indirection.
You could get similar performances in C by using dlsym to get a direct handle to the function or compiling with -fno-plt
. But given that's neither the default nor habitual I think the PLT-using version makes sense and is more honest, it's what most people would effectively get.