Hi Carter,

D is very interesting and I've written some code with it and gotten to know it a bit. I'm close, but not quite ready to take the plunge of using it as my primary high performance language. Although there are claims about it being the same in speed as C or C++ I have found it to be roughly 35% slower for programs coded in the same fashion. On the other hand, it probably has the potential to be faster than C once it matures.

D is basically C or C++ cleaned up significantly and with higher level features such as garbage collection and iterators and it's really a joy to use - and if you know C you will be comfortable right away with D. D is low level which is the appeal for me. You can use it right along with C, link in the object files with very little trouble. All the data types are the same. For instance if you want that 30% I talked about you can write the core engine in C but do the hard stuff in D. The big issue with Java is memory. I cannot see building a high performance program that makes sophisticated use of lots of memory. I think you could build a small fairly high performance program in Java, but modern Monte Carlo programs would be serious memory hogs with Java. When several of us tested Mogo in the big scalability study, memory was a big issue EVEN though it was written in C (or C++.) The issue was that Mogo allocates a certain fixed number of nodes to the UCT tree contained in memory and when you run Mogo at a high level, these nodes are exhausted. Mogo compensates by pruning and re-using certain nodes, but there is likely some performance loss. This of course is not an issue confined to Mogo, but all the high performance MC programs need to deal with the same issues since the current techniques build as much of the game tree in memory as possible. I don't want to start a flame war, but I think performance is an issue with Java too. It's true that you can write some programs that are very fast in Java, even comparable to C, but you definitely lose the low level flexibility of C. It makes it harder to shoot yourself in the foot but it still limits your performance. Of course you can always pick and choose your benchmarks to find one that verifies the conclusions you want to believe in, but I believe you will ALWAYS be able to write high performance code in C (even if it's ugly) but with Java you will only be able to write some high performance code. (This is rather analogous to assembly vs C, no restrictions in assembly so there are still a few corners where you cannot get all the speed out of C - it's even more-so with high level languages such as Java. But I believe D doesn't suffer any more than C and is probably even more optimizable, although the compilers are not there yet.)

The only feasible choice that I can imagine currently is C, C++ or D for super high performance programs. I personally would consider D a much better choice than Java if you are looking for something higher level than C and C++ and don't mind taking a small performance hit. It seems likely to me that the performance hit of D will go away in time but I'm not a prophet. This is claimed of Java, but I don't believe it will every be true in general, although it will probably be true in specific cases. Of concern is 64 bit support in D. I don't know where that is now. I'm still using C but I'm keeping a close eye on D.

- Don







Carter Cheng wrote:
Thanks for the responses.

1) I guess for this seki question I was wondering if it was as easy to define 
as liveness without seki. The reason I am interested in this is I am curious 
about absolutely correct scoring functions and whether they currently cope well 
with advanced seki situations or not. I have been looking at some of the cases 
listed on the Sensei's Library. A cursory look seems to indicate that they are 
very difficult to classify- and any seki classifier might need some knowledge 
of killing shapes.

2) You are correct Jason I transposed the symbols for some reason I actually meant 3^(n^2) but typed it in backwards.
3) Also thanks for the links. I have taken a look at some of the code. I am not sure I 
will be writing in Java or D and most likely will be implementing the system in something 
like C++. I am worried about Java's speed since it's interpreted (which still means a x2 
slowdown even with the JIT and Hotspot compilation and selective inlining). D I am just 
not too familiar with I am wondering what advantages it brings over C++. I am primarily 
concerned about maturity issues. I am not trying to start a discussion on which language 
is "better", but those are my initial impressions.

I am primarily interested in creating a very basic go bot at this point and use it for primarily data gathering. I have been curious about certain aspects of game searches and how they apply to go and how reinforcement learning works etc. I figure being a complete beginner at this it will take some time before I have any meaningful insights into how everything works to contribute anything.
Regards,

Carter.







      
____________________________________________________________________________________
Be a better friend, newshound, and know-it-all with Yahoo! Mobile. Try it now. http://mobile.yahoo.com/;_ylt=Ahu06i62sR8HDtDypao8Wcj9tAcJ
_______________________________________________
computer-go mailing list
computer-go@computer-go.org
http://www.computer-go.org/mailman/listinfo/computer-go/

_______________________________________________
computer-go mailing list
computer-go@computer-go.org
http://www.computer-go.org/mailman/listinfo/computer-go/

Reply via email to