# **Intel® Array Building Blocks**

#### Productivity, Performance, and Portability with Intel® Parallel Building Blocks

Intel SW Products Workshop 2010 CERN openlab

**Optimization Notice** 



Software & Services Group, Developer Products Division

11/29/2010

Copyright© 2010, Intel Corporation. All rights reserved. \*Other brands and names are the property of their respective owners.

#### Agenda

| Part A - Introduction into Intel ArBB                                                                             | 3 hours    |
|-------------------------------------------------------------------------------------------------------------------|------------|
| <ul> <li>Intel ArBB Overview, and Q&amp;A</li> <li>LAB 1: "scalar", "scoped_timer"</li> </ul>                     | 60m<br>45m |
| <ul> <li>Functions and Kernels, Containers and Parallelism<br/>LAB 2: "binding", "range", "for_vs_map"</li> </ul> | 15m<br>60m |
|                                                                                                                   |            |
| Part B - Advanced Topics                                                                                          | 4 hours    |
| <ul> <li>User-defined Types and Memory Model</li> <li>LAB 1: "complex", "interval"</li> </ul>                     | 10m<br>50m |
| <ul> <li>Performance Optimization Hints</li> <li>LAB 2: "matrix_vector", "closure", "meta"</li> </ul>             | 15m<br>60m |
| <ul> <li>Software Design Aspects</li> <li>LAB 3: "heat", Demo(s)/Break</li> </ul>                                 | 05m<br>40m |
| <ul> <li>Intel ArBB Virtual Machine API</li> <li>IAB 4: "scalar ym"</li> </ul>                                    | 10m        |
| <ul> <li>ArBB Release Schedule (KNF etc.)</li> </ul>                                                              | 20m<br>10m |
| – Summary, Contact/Feedback, Q&A                                                                                  | 20m        |



Software & Services Group, Developer Products Division

**Optimization Notice** 

 $\triangleright$ 

## **Legal Information**

- INFORMATION IN THIS DOCUMENT IS PROVIDED IN CONNECTION WITH INTEL® PRODUCTS. NO LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE, TO ANY INTELLECTUAL PROPETY RIGHTS IS GRANTED BY THIS DOCUMENT. EXCEPT AS PROVIDED IN INTEL'S TERMS AND CONDITIONS OF SALE FOR SUCH PRODUCTS, INTEL ASSUMES NO LIABILITY WHATSOEVER, AND INTEL DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY, RELATING TO SALE AND/OR USE OF INTEL® PRODUCTS INCLUDING LIABILITY OR WARRANTIES RELATING TO FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT.
- Intel may make changes to specifications and product descriptions at any time, without notice.
- All products, dates, and figures specified are preliminary based on current expectations, and are subject to change without notice.
- Intel, processors, chipsets, and desktop boards may contain design defects or errors known as errata, which may cause the product to deviate from published specifications. Current characterized errata are available on request.
- Any code names and other code names featured are used internally within Intel to identify products that are in development and not yet publicly announced for release. Customers, licensees and other third parties are not authorized by Intel to use code names in advertising, promotion or marketing of any product or services and any such use of Intel's internal code names is at the sole risk of the user
- Performance tests and ratings are measured using specific computer systems and/or components and reflect the
  approximate performance of Intel products as measured by those tests. Any difference in system hardware or software
  design or configuration may affect actual performance.
- Intel, Intel® Streaming SIMD Extensions (Intel® SSE), Intel® Advanced Vector Extensions (Intel® AVX), Intel® Parallel Building Blocks (Intel® PBB), Intel® Threading Building Blocks (Intel® TBB), Intel® Array Building Blocks (Intel® ArBB), Intel® Math Kernel Library (Intel® MKL), Intel® Integrated Performance Primitives (Intel® IPP), Intel® Cilk Plus and the Intel logo are trademarks of Intel Corporation in the United States and other countries.
- \*Other names and brands may be claimed as the property of others.
- Copyright ©2010 Intel Corporation.



Copyright© 2010, Intel Corporation. All rights reserved. \*Other brands and names are the property of their respective owners.

## **Optimization Notice**

Intel<sup>®</sup> compilers, associated libraries and associated development tools may include or utilize options that optimize for instruction sets that are available in both Intel<sup>®</sup> and non-Intel microprocessors (for example SIMD instruction sets), but do not optimize equally for non-Intel microprocessors. In addition, certain compiler options for Intel compilers, including some that are not specific to Intel micro-architecture, are reserved for Intel microprocessors. For a detailed description of Intel compiler options, including the instruction sets and specific microprocessors they implicate, please refer to the "Intel<sup>®</sup> Compiler User and Reference Guides" under "Compiler Options". Many library routines that are part of Intel<sup>®</sup> compiler products are more highly optimized for Intel microprocessors than for other microprocessors. While the compilers and libraries in Intel<sup>®</sup> compiler products offer optimizations for both Intel and Intel-compatible microprocessors, depending on the options you select, your code and other factors, you likely will get extra performance on Intel microprocessors.

Intel<sup>®</sup> compilers, associated libraries and associated development tools may or may not optimize to the same degree for non-Intel microprocessors for optimizations that are not unique to Intel microprocessors. These optimizations include Intel<sup>®</sup> Streaming SIMD Extensions 2 (Intel<sup>®</sup> SSE2), Intel<sup>®</sup> Streaming SIMD Extensions 3 (Intel<sup>®</sup> SSE3), and Supplemental Streaming SIMD Extensions 3 (Intel<sup>®</sup> SSSE3) instruction sets and other optimizations. Intel does not guarantee the availability, functionality, or effectiveness of any optimization on microprocessors not manufactured by Intel. Microprocessor-dependent optimizations in this product are intended for use with Intel microprocessors.

While Intel believes our compilers and libraries are excellent choices to assist in obtaining the best performance on Intel<sup>®</sup> and non-Intel microprocessors, Intel recommends that you evaluate other compilers and libraries to determine which best meet your requirements. We hope to win your business by striving to offer the best performance of any compiler or library; please let us know if you find we do not.

Notice revision #20101101



Software & Services Group, Developer Products Division



#### Contact

Hans Pabst, Software Engineer TCE Performance and Productivity Libraries hans.pabst@intel.com



Software & Services Group, Developer Products Division

**Optimization Notice** 

Copyright© 2010, Intel Corporation. All rights reserved. \*Other brands and names are the property of their respective owners.





Software & Services Group, Developer Products Division

11/29/2010 6 11/29/2010

Copyright© 2010, Intel Corporation. All rights reserved. \*Other brands and names are the property of their respective owners.

Optimization Notice

6