FAQ

Questions & Answers

Contact us for more

What is a hardware IP core?
Hardware IP cores are IP (Intellectual Property) cores that are used to program (configure) hardware accelerators like FPGA devices. The IP cores can be in several forms including source code, netlist or configuration files.
What kind of IP cores are provided by InAccel?
InAccel provides any required form of IP cores (source code (HLS or OpenCL), netlist or configuration file) depending on the application's and client's requirements.
Can I use the IP cores to accelerate my applications if I don't own an FPGA?
Yes. Amazon, Azure, Alibaba and many other cloud vendors allow users to rent FPGA modules as a service through their portal. The user can rent the FPGA resources per hour or per month and then is able to instantiate the IP cores for the configuration of the FPGAs. The pricing model for the use of the IP cores is relevant to the pricing model of the FPGAs rental.
What is the cost of the IP cores?
The cost of the IP cores depends on the format that is required. The purchase of the source code allow users to modify the core based on the application requirements and can be used in many projects but it has a higher initial cost. The use of IP cores as a service (e.g. through Amazon AWS) allows users to pay as much as the IP core is used (pay-as-you-go).
How do I connect my application with an IP core?
InAccel provides all the required APIs for the seamless integration of the IP cores with your application. The current supported APIs include C/C++, Java, Python, and Scala. InAccel also provides the required libraries for the integration of the IP cores from widely-used programming frameworks like Apache Spark and Scikit Learn. These APIs render possible the integration of the IP cores with zero changes in your source code.
How can I use the IP cores from Apache Spark?
InAccel provides the required library, compatible with Spark, that allow users to utilize the IP cores without any changes in the Spark application. The only change that is required is the replacement of the MLlib library with the InAccel library that enables the FPGA acceleration.
Do I need to also rent typical compute units to run the IP cores?
No. When users rent an FPGA unit, they also get access to the host device that is communicating with the FPGA. However, users can also rent additional typical compute units and communicate with the FPGAs too.
How is the speedup measured?
The speedup of the accelerator (IP core) is evaluated compared to a single thread contemporary processor (e.g. C4 compute unit from Amazon AWS).
Do the IP cores support any type of machine learning algorithm/parameters?
Hardware IP cores have lower flexibility compared to software as they are made to be mapped directly into a hardware circuit. This means that if the user needs to change some of the parameters of the code, a new design (core) may be required. However, most of the cores support a maximum number of parameters that satisfy most of the applications. For example, the LR (Logistic Regression) IP core supports up to 64 classes.