• Advertisement


  • Content count

  • Joined

  • Last visited

Community Reputation

125 Neutral

About DavidM

  • Rank
  1. [quote name='Bacterius' timestamp='1350348048' post='4990568'] Heya, it's been forever since I worked with Tessendorf waves but I recommend [url="http://www.keithlantz.net/2011/10/ocean-simulation-part-one-using-the-discrete-fourier-transform/"]this website[/url], it shows how to generate the waves along with the normals using the FFT, code included. Note there are two parts! Or if you are not using the FFT method, there is a - admittedly rather arcane - description of the normal for Gerstner waves in this [url="http://http.developer.nvidia.com/GPUGems/gpugems_ch01.html"]GPU Gems[/url] article, have you looked at it? If everything fails, you can always use good old finite difference approximation to evaluate the normal, which is a bit more expensive since you have to sample the wave multiple times, but at least is general-purpose. [/quote] Thanks, but... im a beginner. I got the gpu gems example working right. That sample is a bit more easy. Mine has a difference, the [b](K/k)[/b] * wave, and the movement both in XY and Z, not just the vertical (z for me). Its just a math thing.
  2. Hi there, I have read some threads here asking a similar question. But the examples are different, or more easy than this. I have tested first the most simple wave and I got the normal working properly. For me this is the case: float k=2.0*3.1416/L; float3 w=sqrt(9.81*k)*t; float theta =dot(K, wp) -w; float2 XY=(K/k)* A * sin(theta ); float Z= A* cos (theta ); return float3(XY.x.x,XY.y, Z); As explained in tessendorf, K is the wind vector and L is lambda. So the question here would be how to derivate this and finally how to get the normal. Thanks!
  3. Paradox Interactive publishing Armored Warfare!

    Congratulations Danny, you have big balls
  • Advertisement