com.nativelibs4java.opencl.util.fft.DoubleFFTProgram Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of javacl Show documentation
Show all versions of javacl Show documentation
JavaCL is an Object-Oriented API that makes the C OpenCL API available to Java in a very natural way.
It hides away the complexity of cross-platform C bindings, has a clean OO design (with generics, Java enums, NIO buffers, fully typed exceptions...), provides high-level features (OpenGL-interop, array reductions) and comes with samples and demos.
For more info, please visit http://code.google.com/p/nativelibs4java/wiki/OpenCL.
package com.nativelibs4java.opencl.util.fft;
import com.nativelibs4java.opencl.CLAbstractUserProgram;
import com.nativelibs4java.opencl.CLBuffer;
import com.nativelibs4java.opencl.CLBuildException;
import com.nativelibs4java.opencl.CLContext;
import com.nativelibs4java.opencl.CLEvent;
import com.nativelibs4java.opencl.CLKernel;
import com.nativelibs4java.opencl.CLProgram;
import com.nativelibs4java.opencl.CLQueue;
import java.io.IOException;
/// Wrapper around the OpenCL program DoubleFFTProgram
public class DoubleFFTProgram extends CLAbstractUserProgram {
public DoubleFFTProgram(CLContext context) throws IOException {
super(context, readRawSourceForClass(DoubleFFTProgram.class));
}
public DoubleFFTProgram(CLProgram program) throws IOException {
super(program, readRawSourceForClass(DoubleFFTProgram.class));
}
CLKernel rotateValue2_kernel;
public synchronized CLEvent rotateValue2(CLQueue commandQueue, double value[], double sinCos[], int globalWorkSizes[], int localWorkSizes[], CLEvent... eventsToWaitFor) throws CLBuildException {
if (rotateValue2_kernel == null)
rotateValue2_kernel = createKernel("rotateValue2");
checkArrayLength(value, 2, "value");
checkArrayLength(sinCos, 2, "sinCos");
rotateValue2_kernel.setArgs(value, sinCos);
return rotateValue2_kernel.enqueueNDRange(commandQueue, globalWorkSizes, localWorkSizes, eventsToWaitFor);
}
CLKernel cooleyTukeyFFTCopy_kernel;
public synchronized CLEvent cooleyTukeyFFTCopy(CLQueue commandQueue, CLBuffer X, CLBuffer Y, int N, CLBuffer offsetsX, double factor, int globalWorkSizes[], int localWorkSizes[], CLEvent... eventsToWaitFor) throws CLBuildException {
if (cooleyTukeyFFTCopy_kernel == null)
cooleyTukeyFFTCopy_kernel = createKernel("cooleyTukeyFFTCopy");
cooleyTukeyFFTCopy_kernel.setArgs(X, Y, N, offsetsX, factor);
return cooleyTukeyFFTCopy_kernel.enqueueNDRange(commandQueue, globalWorkSizes, localWorkSizes, eventsToWaitFor);
}
CLKernel cooleyTukeyFFTTwiddleFactors_kernel;
public synchronized CLEvent cooleyTukeyFFTTwiddleFactors(CLQueue commandQueue, int N, CLBuffer twiddleFactors, int globalWorkSizes[], int localWorkSizes[], CLEvent... eventsToWaitFor) throws CLBuildException {
if (cooleyTukeyFFTTwiddleFactors_kernel == null)
cooleyTukeyFFTTwiddleFactors_kernel = createKernel("cooleyTukeyFFTTwiddleFactors");
cooleyTukeyFFTTwiddleFactors_kernel.setArgs(N, twiddleFactors);
return cooleyTukeyFFTTwiddleFactors_kernel.enqueueNDRange(commandQueue, globalWorkSizes, localWorkSizes, eventsToWaitFor);
}
CLKernel cooleyTukeyFFT_kernel;
public synchronized CLEvent cooleyTukeyFFT(CLQueue commandQueue, CLBuffer Y, int N, CLBuffer twiddleFactors, int inverse, int globalWorkSizes[], int localWorkSizes[], CLEvent... eventsToWaitFor) throws CLBuildException {
if (cooleyTukeyFFT_kernel == null)
cooleyTukeyFFT_kernel = createKernel("cooleyTukeyFFT");
cooleyTukeyFFT_kernel.setArgs(Y, N, twiddleFactors, inverse);
return cooleyTukeyFFT_kernel.enqueueNDRange(commandQueue, globalWorkSizes, localWorkSizes, eventsToWaitFor);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy