Skip to content
basanders edited this page Sep 16, 2014 · 11 revisions

This page describes the changes in Sial V2

Required changes to existing program

  • Blocks now use square brackets instead of parentheses. a(i,j,k,l) --> a[i,j,k,l]
  • Upper and lower bounds of ranges are now separated by a colon instead of a comma. aoindex i = 1,norb --> aoindex i = 1:norb
  • An int type has been added to the language (previously int variables had to be predefined). As a consequence, some programs that previously used scalars to hold what are really int values, may want to redefine the types of some variables. Coercion between int and scalar is not longer supported, but this can be achieved by explicit casts. ( (scalar)i or (int)x ). In the current implementation, a cast from scalar to int will round to the nearest int.

New features

  • Contiguous local arrays. Previously, the only contiguously allocated arrays were static, which are required to contain the whole array, and exist for the entire lifetime of the sial program. Contiguous local arrays can contain multiple, contiguously allocated blocks of an array but need not include the entire array, and can be dynamically allocated and deallocate like normal local arrays. Contiguous local arrays are declared with the contiguous local modifier: contiguous local loc1[i,j]. Contiguous regions can be allocated with the allocate contiguous command: allocate contiguous loc1[3:4,3:4]. Elsewhere in the sial program, contiguous local regions are referred to by giving the range for each index. The SIA runtime extracts the desired subregion: 'tmp[i,j] = loc1[i:i,j:j]' extracts the [i,j] block. Subregions are automatically extracted and inserted similar to the features offered for blocks of static arrays. The ranges of the indices are expressions (int values), rather than index names, so we could say 'loc1[i:i+1, j:j+1]' or 'loc1[1:norb, 1:1].
  • Expressions. Previously, expressions were limited in SIAL to binary expressions. So to add together x, y, and z, one would need two lines of code: t = x + y followed by r = t + z. Now it is possible to say r = x + y + z, and use parentheses, etc as one can do in most programming languages. Operations where the result is a block remain exceptions. Each operation that results in a block must specify the destination, so these operations remain limited to binary operations.
  • Scalar valued blocks. Blocks of arrays that are all simple indices, and thus actually a single value are interchangeable with scalars everywhere except contraction and tensor expressions. Thus, if i,j, and k are simple indices, b[i,j] * c[k] is a contraction with result, r[i,j,k], not the multiplication of two scalars.
  • Polymorphic print statements. print and println now take any type of argument (including blocks) and have replaced print_int, print_index, etc. The module in the SIA runtime implementing these is easily replaced to provide custom formatting.
Clone this wiki locally