com.syncleus.aparapi.examples.extension.SwapExample 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.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;
public class SwapExample{
interface Swapper extends OpenCL{
@Kernel("{\n"//
+ " const size_t id = get_global_id(0);\n"//
+ " float temp=lhs[id];" + " lhs[id] = rhs[id];\n"//
+ " rhs[id] = temp;\n"//
+ "}\n")//
public Swapper swap(//
Range _range,//
@GlobalReadWrite("lhs") float[] lhs,//
@GlobalReadWrite("rhs") float[] rhs);
}
public static void main(String[] args) {
final int size = 32;
final float[] lhs = new float[size];
for (int i = 0; i < size; i++) {
lhs[i] = i;
}
final float[] rhs = new float[size];
final Range range = Range.create(size);
final Device device = KernelManager.instance().bestDevice();
if (device instanceof OpenCLDevice) {
final OpenCLDevice openclDevice = (OpenCLDevice) device;
final Swapper swapper = openclDevice.bind(Swapper.class);
for (int i = 0; i < size; i++) {
System.out.println(lhs[i] + " " + rhs[i]);
}
swapper.swap(range, lhs, rhs);
for (int i = 0; i < size; i++) {
System.out.println(lhs[i] + " " + rhs[i]);
}
swapper.swap(range, lhs, rhs);
for (int i = 0; i < size; i++) {
System.out.println(lhs[i] + " " + rhs[i]);
}
swapper.swap(range, rhs, lhs);
for (int i = 0; i < size; i++) {
System.out.println(lhs[i] + " " + rhs[i]);
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy