Java-Gaming.org
Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
Featured games (78)
games approved by the League of Dukes
Games in Showcase (404)
games submitted by our members
Games in WIP (289)
games currently in development
News: Read the Java Gaming Resources, or peek at the official Java tutorials
 
    Home     Help   Search   Login   Register   
Pages: [1]
  ignore  |  Print  
  Any optimisations on Math.log() and Math.exp() ?  (Read 3649 times)
0 Members and 1 Guest are viewing this topic.
Offline genki

Junior Member


Projects: 1



« Posted 2009-01-17 20:00:38 »

Hi,

I'm writing a program which will need to call Math.log() and Math.exp() quite a bit, and knowing that these are pretty intensive functions, was wondering if anyone has written any accurate faster math optimisations of them ?

Also Math.sqrt(), I'm aware of some bitwise operation routines which are faster on some JVMs, but it seems more recent JVMs are pretty well optimised in Math.sqrt() already ?

Cheers

Offline Riven
« League of Dukes »

JGO Overlord


Medals: 437
Projects: 4


Hand over your head.


« Reply #1 - Posted 2009-01-17 20:40:51 »

Write it in C, using SSE2.

If you're really looking for performance, it makes no sense to work with the JVM that doesn't support SIMD.

http://gruntthepeon.free.fr/ssemath/

Hi, appreciate more people! Σ ♥ = ¾
Learn how to award medals... and work your way up the social rankings
Projects: Revenge of the Titans, Titan Attacks, Droid Assault, and Ultratron
Offline genki

Junior Member


Projects: 1



« Reply #2 - Posted 2009-01-17 21:07:01 »

yuk.

Could I use JNI into that C module, or is that just silly ?

Games published by our own members! Check 'em out!
Legends of Yore - The Casual Retro Roguelike
Offline Riven
« League of Dukes »

JGO Overlord


Medals: 437
Projects: 4


Hand over your head.


« Reply #3 - Posted 2009-01-17 21:08:25 »

Yes, use JNI, but you have to work with fairly large datasets per call, preferably in a native FloatBuffer or DoubleBuffer

Hi, appreciate more people! Σ ♥ = ¾
Learn how to award medals... and work your way up the social rankings
Projects: Revenge of the Titans, Titan Attacks, Droid Assault, and Ultratron
Offline Roquen

JGO Ninja


Medals: 66



« Reply #4 - Posted 2009-01-30 17:20:22 »

Tons of options here.  More info is needed, such as any range limitations, precision requirements
and what your using them for.

Depending on usage a pure Java approximation method could be faster than going to native, assuming
that no significant batching is possible.  But even if going to native, knowledge of how the functions are
to be used is important in these kind of questions.
Offline genki

Junior Member


Projects: 1



« Reply #5 - Posted 2009-01-31 11:20:29 »

Hi there, thanks for the response.

Actually so far in the build, the speed of the programme is holding up very well, there's plenty of time left in each cycle, so I don't think calling the Math functions is causing me any performance problems.  I'll leave them in for now, for the accuracy they give.

Of course I might come back if they do start to be too intensive down the road.

Cheers

Pages: [1]
  ignore  |  Print  
 
 
You cannot reply to this message, because it is very, very old.

Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
 
Get high quality music tracks for your game!

Add your game by posting it in the WIP section,
or publish it in Showcase.

The first screenshot will be displayed as a thumbnail.

The invasion has landed! On Mars! And you're there to beat 'em!
cubemaster21 (37 views)
2013-05-17 21:29:12

alaslipknot (46 views)
2013-05-16 21:24:48

gouessej (75 views)
2013-05-16 00:53:38

gouessej (75 views)
2013-05-16 00:17:58

theagentd (83 views)
2013-05-15 15:01:13

theagentd (77 views)
2013-05-15 15:00:54

StreetDoggy (119 views)
2013-05-14 15:56:26

kutucuk (143 views)
2013-05-12 17:10:36

kutucuk (143 views)
2013-05-12 15:36:09

UnluckyDevil (153 views)
2013-05-12 05:09:57
Complex number cookbook
by Roquen
2013-04-24 12:47:31

2D Dynamic Lighting
by Oskuro
2013-04-17 16:46:12

2D Dynamic Lighting
by Oskuro
2013-04-17 16:45:57

2D Dynamic Lighting
by Oskuro
2013-04-17 16:23:20

Noise (bandpassed white)
by Roquen
2013-04-05 17:36:01

Noise (bandpassed white)
by Roquen
2013-04-03 16:17:38

Java Data structures
by Roquen
2013-03-29 13:21:12

Topic Request
by kutucuk
2013-03-22 21:42:01
Powered by MySQL Powered by PHP Powered by SMF 1.1.18 | SMF © 2013, Simple Machines | Managed by Enhanced Four Valid XHTML 1.0! Valid CSS!
Page created in 0.119 seconds with 21 queries.