M. T. Homer Reid MIT Home Page
Physics Problems Research teaching My Music About Me Miscellany


Material descriptions in scuff-em

scuff-em allows the frequency-dependent electrical properties (dielectric permittivity and magnetic permeability) of materials to be specified in one of several ways:

  1. You can use a built-in material like PEC or Vacuum.
  2. You can specify a material with constant (frequency-independent) permittivity and permeability.
  3. You can specify a data file containing tabulated permittivity and permeability values over a range of frequencies; in this case, scuff-em will interpolate between values in your file to estimate material properties at arbitrary frequencies.
  4. You can define your own material with arbitrary frequency-dependent material properties, specified using mathematical expressions.

Materials are generally specified to scuff-em by including a line like

 MATERIAL MyMaterialName

in the .scuffgeo file; here MyMaterialName is a string constructed in different ways depending on which of the above types of material specification you have in mind, as detailed below.

Note that material specification in scuff-em are case-insensitive. The strings TEFLON, Teflon, and teflon all refer to the same material.

Material specifications in scuff-em
1. Built-in materials
2. Frequency-independent materials
3. Materials specified using tabulated data
4. User-defined materials
5. PlotEpsMu: A command-line utility for verifying material properties

1. Built-In Materials

The two built-in materials are Vacuum and PEC. The former describes a material with ε=μ=1 at all frequencies, while the latter describes a Perfect Electrical Conductor.

2. Frequency-independent materials

For a non-magnetic material with frequency-independent permittivity ε, you can use a material specification of the form


where you would replace 11.8 with the constant value of the permittivity. (Note that CONST_EPS_11.8 is all one word, with no spaces.)

For a material with frequency-independent permittivity ε and frequency-indepedent permeability μ≠1, you can use a material-property designation of the form


where you would replace 0.8 with the constant value of the permeability. (Again, all one word, no spaces.)

You can also specify materials with negative and/or complex permittivity:


Of course, a dielectric function with a frequency-independent imaginary part is unphysical, but no problems will arise as long as you are only doing computations at a single frequency.

3. Materials specified using tabulated data

If you have tabulated frequency data for the permittivity and/or permeability of your material, you can specify this to scuff-em using a material specification of the form

    MATERIAL FILE_MyDataFile.dat

where the FILE_ part of the string is fixed, and the remainder is the name of your data file (which is of course case-sensitive.) Again, note that the material property specification is all one word with no spaces.

The data file is interpreted by scuff-em in the following way:

  • Blank lines and comments (lines beginning with #) are ignored.
  • All other lines must have the format

    ω Eps(ω) [Mu(ω)]

where ω is an angular frequency, Eps(ω) is the relative permittivity at that frequency, and the optional Mu(ω) is the relative permeability.

The values specified for Eps and Mu may be complex numbers.

Note that ω values in material data files are always specified in units of radians per second, not the specialized frequency units that are used in some of the scuff-em application codes.

4. User-defined materials

For more general materials, you will want to define your own frequency-dependent material designations. You do this by first creating an entry in a database file that describes your material, and then referring back to that entry in .scuffgeo files and anywhere else you need to specify a material property designation. (Alternatively, you can define the material on-the-fly inside your .scuffgeo file; see here for more details.)

The location of the database file

libmatprop looks in the following three places for its database file:

  1. The file ${HOME}/.matprop.dat (i.e. a file named .matprop.dat in the top-level directory for your user account.)
  2. A file named matprop.dat in the current working directory. (Note the absence of a leading period as compared with the previous item.)
  3. The file named by the environment variable MATPROPFILE.

Personally, I think the first of these options is the most convenient; it allows you to create and maintain a single database file that contains all the materials you will ever need to use.

Entries in the database file

A typical entry in the database file looks like this:

MATERIAL SiliconCarbide

   EpsInf = 6.7;
   a0     = -3.32377e28;
   a1     = +8.93329e11;
   b0     = -2.21677e28;
   b1     = 8.93329e11;

   Eps(w) = EpsInf * ( w^2 + a1*i*w + a0 ) / ( w^2 + b1*i*w + b0);


The first line defines the name of the material (the name you would supply as an argument to the MATERIAL keyword in a .scuffgeo file, for example).

The next few lines define some constants. These constant definitions are specific to this particular MATERIAL; two different MATERIAL sections in the database file may define the same constant to have two different values.

The line Eps(w) = ... defines the frequency-dependent relative permittivity of your material. The expression to the right of the = sign is parsed and interpreted as a function of the single variable w, the angular frequency. The expression may refer to any of the constants you have defined for the present material; it may also use the symbols i and I to denote the imaginary unit.

Again, ω values in material property specifications are always interpreted in units of radians per second, not the specialized angular-frequency units that are used in some of the scuff-em application codes.

If your material has μ≠1, you may optionally also include a line of the form

 Mu(w) = some-function(w)

A Sample Database File

Here is a sample database file. I recommend you rename this file to ${HOME}/.matprop.dat and augment it as necessary for your applications.

5. scuff-plotEpsMu: A command-line utility for verifying material properties

The scuff-em distribution comes with an application program named scuff-plotEpsMu that you can use to make sure that a material property designation is interpreted the way you intended. You can run this command with no arguments to get usage information:

 % scuff-plotEpsMu 

 error: --material option is mandatory (aborting)

 usage: scuff-plotEpsMu [options]


  --material xx  (name of material)
  --OmegaMin xx  (minimum angular frequency)
  --OmegaMax xx  (maximum angular frequency)
  --gnuplot      (use GNUPLOT to plot results)
  --geometry xx  (.scuffgeo file containing material definition)

Running scuff-plotEpsMu --material MyMaterial will produce an output file name MyMaterial.epsmu, which will contain 7 columns of data, representing the permittivity and permeability of your material at various angular frequencies on both the real and imaginary ω axes:

Column 1 2 3 4 5 6 7
Quantity ω Re ε(ω) Im ε(ω) Re μ(ω) Im μ(ω) ε(iω) μ(iω)

If gnuplot is installed on your system, then you can use the --GnuPlot option to generate pop-up plots of ε and μ vs. frequency for your material specification.

You can use --OmegaMin/--OmegaMax to set the range of angular frequencies over which material properties will be plotted. The defaults are equivalent to specifying --OmegaMin 1e8 and --OmegaMax 1e16, respectively.

If your material is defined on-the-fly in a .scuffgeo file, you can pass that file to scuff-plotEpsMu using the --geometry option. (If your material is defined in a material database file then this option is not needed.)

For example, in this example we used a material named SiliconCarbide, which was defined in a geometry file named SiCSphere.scuffgeo. To check the the frequency-dependent permittivity of this material, we can say

 % scuff-plotEpsMu --material SiliconCarbide --geometry SiCSphere.scuffgeo --gnuplot

This will pop up four graphs, of which one looks something like this:

Core Library

Material Property Designations in SCUFF-EM, by Homer Reid
Last Modified: 11/16/16