com.syncleus.aparapi.examples.extension.SquareExample Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aparapi-examples Show documentation
Show all versions of aparapi-examples Show documentation
A collection of examples for the aparapi framework.
The newest version!
/**
* This product currently only contains code developed by authors
* of specific components, as identified by the source code files.
*
* Since product implements StAX API, it has dependencies to StAX API
* classes.
*
* For additional credits (generally to people who reported problems)
* see CREDITS file.
*/
package com.syncleus.aparapi.examples.extension;
import com.syncleus.aparapi.ProfileInfo;
import com.syncleus.aparapi.Range;
import com.syncleus.aparapi.device.Device;
import com.syncleus.aparapi.device.OpenCLDevice;
import com.syncleus.aparapi.internal.kernel.*;
import com.syncleus.aparapi.opencl.OpenCL;
import com.syncleus.aparapi.opencl.OpenCL.Resource;
import com.syncleus.aparapi.opencl.OpenCL.Source;
import java.util.List;
public class SquareExample{
interface Squarer extends OpenCL{
@Kernel("{\n"//
+ " const size_t id = get_global_id(0);\n"//
+ " out[id] = in[id]*in[id];\n"//
+ "}\n")//
public Squarer square(//
Range _range,//
@GlobalReadWrite("in") float[] in,//
@GlobalReadWrite("out") float[] out);
}
@Resource("com/syncleus/aparapi/examples/extension/squarer.cl") interface SquarerWithResource extends OpenCL{
public SquarerWithResource square(//
Range _range,//
@GlobalReadWrite("in") float[] in,//
@GlobalReadWrite("out") float[] out);
}
@Source("\n"//
+ "__kernel void square (\n" //
+ " __global float *in,\n"//
+ " __global float *out\n" + "){\n"//
+ " const size_t id = get_global_id(0);\n"//
+ " out[id] = in[id]*in[id];\n"//
+ "}\n") interface SquarerWithSource extends OpenCL{
public SquarerWithSource square(//
Range _range,//
@GlobalReadOnly("in") float[] in,//
@GlobalWriteOnly("out") float[] out);
}
public static void main(String[] args) {
final int size = 32;
final float[] in = new float[size];
for (int i = 0; i < size; i++) {
in[i] = i;
}
final float[] squares = new float[size];
final float[] quads = new float[size];
final Range range = Range.create(size);
final Device device = KernelManager.instance().bestDevice();
if (device instanceof OpenCLDevice) {
final OpenCLDevice openclDevice = (OpenCLDevice) device;
for (int l=0; l<5; l++){
final SquarerWithResource squarer = openclDevice.bind(SquarerWithResource.class);
squarer.square(range, in, squares);
for (int i = 0; i < size; i++) {
System.out.println(l+" "+in[i] + " " + squares[i]);
}
squarer.square(range, squares, quads);
for (int i = 0; i < size; i++) {
System.out.println(l+" "+ in[i] + " " + squares[i] + " " + quads[i]);
}
final List profileInfo = squarer.getProfileInfo();
if ((profileInfo != null) && (profileInfo.size() > 0)) {
for (final ProfileInfo p : profileInfo) {
System.out.print(" " + p.getType() + " " + p.getLabel() + " " + (p.getStart() / 1000) + " .. "
+ (p.getEnd() / 1000) + " " + ((p.getEnd() - p.getStart()) / 1000) + "us");
System.out.println();
}
}
squarer.dispose();
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy