Instrument and Site Characteristics

A number of observatories are implemented in PhoSim through the use of the Instrument and Site Characteristics Files (ISC). These are directories located in phosim/data. If you want to put a new observatory into PhoSim you can create a new directory there, and then run PhoSim as usual with the "-i newDirectory" option to point to the ISC files.

The ISC files have a complex tiered format and this format does get modified as PhoSim is improved, so it may be necessary to email us when getting into the details. However, the details of the ISC are designed to be tiered, so that simple important characteristics can be implemented without worrying about the additional details.


Instrument and Site File Hierarchy in PhoSim

Primary ISC files:

1) optics_?.txt files (required)

The first line of the optics file specifies the approximate properties of the whole system. These values are not used for simulating the system, but only for various approximations to decide what should be simulated. If you are inputting an untested optical design

optics X1 X2 X3 X4 X5 X6 X7 X8

X1 is name of configuration, X2 is the shortest wavelength of the system (not filter short wavelength) in microns, X3 is the longest wavelength of the system (not filter long wavelength) in microns, X4 is the approximate average wavelength of the configuration in microns, X5 is the approximate plate scale in microns per degree, X6 is -1 if the focal plane is flipped in x and 1 if it is not, X7 is if the focal plane is flipped in y and 1 if it is not, and X7 is 1 if x and y are swapped and 0 if it is not


The next lines specify the full details of the optical design. The columns are as follows:

Column 1: name of optic

Column 2: optic type (either mirror, filter, lens, det (detector plane), grating, or none (dummy surface))

Column 3: radius of curvature (mm)

Column 4: distance from last optic (mm)

Column 5: outer radius (mm)

Column 6: inner radius (mm)

Column 7: conic constant

Column 8-22:  polynomial constants starting at 2nd degree

Column 9:  coating properties file (none=assumes perfect transmission/reflection; uncoated=calculates as if uncoated)

Column 10:  material optical properties file

Column 11:  material mechanical properties file 


For a grating (column 2) the column meanings change to: 

Column 1:   name of optic

Column 2:   grating

Column 3:  Must be 0.0;  All gratings are assumed to be flat

Column 4:  distance from last optic

Column 5:  outer radius

Column 6:  inner radius

Column 7:  Not used

Column 8:  transmission blaze angle in degrees

Column 9:  Number of illuminated ruled grating lines

Column 10:  Spacing of ruled lines (mm)

Column 11:   Lower wavelength (nm) for table

Column 12:  Upper wavelength (nm) for table

Column 13:  Lower input angle (deg) for table

Column 14:  Upper input angle (deg) for table

Column 15:  Lower input angle (deg) for table

Column 16:  Upper input angle (deg) for table


Additional notes on gratings:  PhoSim will pre-calculate a table one time that takes minutes, and then this file will be used the next time PhoSim to be able to run quickly.  The grating is nominally oriented in the y-direction.  See data/gratingtest/optics_1.txt file for an example.


2) focalplanelayout.txt file (required)

The rows are the sensors in the focal plane. The columns are as follows:

Column 1: name of sensor (gets used with the -s option as well as the file naming convention)

Column 2 and 3: x position in focal plane in microns and y position in focal plane in microns

Column 4: pixel size in microns

Column 5 and 6:  number of x pixels, number of y pixels

Column 7:  sensor material (silicon or MCT)

Column 8:  device type either CCD or CMOS (note CMOS also means Fast Frame CCD, and CCD with 0 readout time also means CMOS where you can set the exposure)

Column 9: readout integration mode (frame or sequence)

Column 10: readout time (CCD) or frame rate (CMOS) in seconds

Column 11: photosensitive layer thickness in microns

Column 12: group of sensors named group0, group1, etc. This is used for the camera configuration which is a bit mask for each type.

Column 13-15: 3 euler rotations in degrees

Column 16-18:  3 translations in mm

Column 19:  name of sensor file

Column 20:  additional defocus relative to focal plane in mm


3) site.txt file (optional)

A set of commands in any order. All commands are optional as each have their defaults. In particular, if you just specify the first three (latitude, longitude, and ground level), the global representations will predict all of the other distributions and parameters. Basic commands:

latitude X:  latitude in degrees (N from equator)

longitude X:  longitude in degrees (E from prime meridian is positive)

groundlevel X:  ground level in meters


Alternatively, there is a very large library of sites for most major cities in the World as well as many telescope sites.  They can be found in data/standard/location.    They can be used by either copying the chosen file to the instrument and site directory, or the existing site can be overridden with the --site=x command line option.  Note:  in the second case you should not use the .txt extension.


More advanced commands that are only necessary if want to override PhoSim distributions:

xtellocation X:  offset from nominal location in x (useful for simulating telescopes on same site)

ytellocation X:  offset from nominal location in y

outerscalemean X:  mean outer scale of the turbulent free atmosphere

outerscalemedian X:  median outer scale of the turbulent free atmosphere

domeseeingmean X:   dome seeing mean in arc seconds

domeseeingmedian X:  dome seeing median in arc seconds

turbulence X1 X2 X3 X4 X5 X6 X7 X8 X9 X10 X11:  turbulence statistics for location in atmosphere

X1 is low range altitude, X2 is mean altitude, X3 is high range altitude, X4 is low range Cn2, X5 is median Cn2, X6 is high range Cn2, X7 is log variance of Cn2, X8 is low range Cn2 for ground layer, X9 is median Cn2 for ground layer, X10 is high range Cn2 for ground layer, X11 is log variance of Cn2

bortle X:  the Bortle index of the site's artificial light contribution

artificial X:  the artificial brightness in mag/sq. arcsecond (redundant with Bortle)


4) structure.txt file (optional)

windjitter X:  variation in wind direction degrees

rotationjitter X: variation in rotation tracking (arcseconds)

elevationjitter X: variation in elevation tracking (arcseconds)

azimuthjitter X: variation in azimuth tracking (arcseconds)

windshake X: variation in wind shake (arcseconds)

rotationconstraint X: +/- angular in rotation of camera (degrees)

crossx X1 X2 X3 X4 X5 X6: X1=height of structure in x direction (mm), X2= width of structure (mm), X3=offset of structure from center (mm), X4=depth of structure (mm), X5=tilt of structure (degrees), X6=reference point where tilt occurs (mm)

crossy X1 X2 X3 X4 X5 X6: X1=height of structure in y direction (mm), X2= width of structure (mm), X3=offset of structure from center (mm), X4=depth of structure (mm), X5=tilt of structure (degrees), X6=reference point where tilt occurs (mm)


5) perturbation.txt file (optional)

The perturbation file described deviations from the ideal optic shape through a wide variety of mechanisms. It is also used to deal with complex geometries (non-cylindrically symmetric systems). Some perturbations can be static and some can be dynamic.

Column 1:   name

Column 2:   optic number (for more than one you can string together as 0|1|2)

Column 3:   perturbation type (map, zernike, zlist, body, shape)

Column 4:   perturbation value

Column 5:   perturbation degree of freedom

Column 6:   actuator number (for moving the degree of freedom with move command)

Column 7:   actuator scaling

Column 8:   actuator scaling constant

Column 9:   actuator scaling angle

Column 10:   actuator scaling cosine coefficient

Column 11:   actuator scaling sine conefficient

Column 12:   actuator scaling uniform random

Column 13:   actuator component

Column 14:   actuator component scaling


For the mechanical surface distortion, column 3 should be set to shape, and then the remaining columns follow

Column 4:   tolerance

Column 5:  control flag

Column 6:   wavefront error

Column 7:  actuator error

Column 8:  angular tolerance

Column 9:  initial step

Column 10:  zernike start

Column 11:  actuator start


6) segmentation.txt file (required)

The segmentation file describes the readout properties of the system.

For each chip an initial line describes the number of lines. The chip name should be consistent with the focal plane file.

chip_name number_of_amplifiers pixels_x pixels_y

chip_name:   name describing chip (should match with focalplanelayout.txt file)

number_of_amplifiers:   number of amplifiers for this chip

pixels_x: pixels in the x-direction

pixels_y: pixels in the y-direction


Then the next lines should be for each amplifier which defines which pixels are part of the amplifier as follows (all numbers are on a single line). The variation parameter are given in percentage. The cross-talk probability with other amplifiers end the line and there should be one element per amplifier.

amplifier_name x_min x_max y_min y_max serial_read_dir parallel_read_dir gain gain_variation bias bias_variation 

   read_noise read_noise_variation dark_current dark_current_variation parallel_prescan serial_overscan serial_prescan parallel_overscan hot_pixel_rate hot_column_rate 

   read_out_bits cross_talk_prob_1 cross_talk_prob_2 cross_talk_prob_3....cross_talk_prob_n ipc10 ipc11 ipc20 ipc21 ipc22 ppc


amplifier_name: amplifier name

x_min: starting pixel value in x

x_max: ending pixel value in x

y_min: starting pixel value in y

y_max: ending pixel value in y

serial_read_dir: direction of serial read (either +/- 1)

parallel_read_dir: direction of parallel read (either +/- 1)

gain: gain of amplifier

gain_variation: gain variation in percentage

bias: bias value of amplifier

bias_variation: bias variation in percentage

read_noise: read noise average value in electrons

read_noise_variation: read noise variation in percentage

dark_current: dark current in electrons per second

dark_current_variation: dark current variation in percentage

parallel_prescan:   number of extra values in the prescan in the parallel direction

serial_prescan:   number of extra values in the prescan in the serial direction

parallel_overscan:   number of extra values in the overcan in the parallel direction

serial_overscan:   number of extra values in the overscan in the serial direction

hot_pixel_rate:     probability of having a hot pixel

hot_column_rate: probability of having a hot column

readout_bits: number of bits in the readout A/D conversion

cross_talk_prob_X: matrix value for cross-talk interaction with amplifier X

ipc10: relative inter-pixel capacitance in neighboring pixels

ipc11: relative inter-pixel capacitance in diagonals pixels

ipc20: relative inter-pixel capacitance in neighboring pixels 2 pixels away

ipc21: relative inter-pixel capacitance in pixels 2 pixels over and 1 pixel up/down

ipc22: relative inter-pixel capacitance in diagnoal pixels 2 pixels away

ppc: relative post-pixel coupling

Secondary ISC files:

7) coating files (optional)


 This file contains the information to describe the interaction with coatings on the optics or detectors.  There are three formats of input:  1) a set of standard coatings, 2) full specification by interference physics method and 3) full specification by the full numerical table format.

First, there are a set of standard coatings that are found in data/coating/standard.   These include:

Detector Anti-Reflective:   detector_ar

Lens Anti-Reflective:  lens_ar

Johnson-Cousins Filters:   jc_u, jc_b, jc_v, jc_r, and jc_i

SDSS Filters:   sdss_u, sdss_g, sdss_r, sdss_i, and sdss_z

Mauna Kea Observatory Near-IR Filters:   mko_y, mko_h, mko_j, mko_k, mko_kp, mko_ks, mko_lp, and mko_mp

All of these coatings can simply by used by putting the names above in the optics file.  Then, no file is necessary in the instrument and site directory.  These coating files can be very useful in implementing a new telescope quickly.

Second, full interference physics can be calculated for a variety of coatings when the details are knownThis may be more accurate than the table method below depending on the information in the table.

For a single layer use:

monolayer material_name thickness

where the thickness is in microns.  The material name is found in the data/material/optical directory.  This would be most common for an A/R coating on a lens.

For a semi-infinite coating (typically on a mirror) use:

thicklayer material_name

For a semi-infinite coating (typically on a mirror) with a single layer coating use:

protectedlayer material_name substrate_name thickness

where the thickness is in microns, and the first material is for the single layer, and the second layer is for the semi-infinite coating.

For all coatings, the coatings can be deposited in an non-uniform manner by adding on the following command.

nonuniform NTERM TERM1 TERM2 ...

where NTERM is the number of terms (zernike polynomials for optics and chebyshev polynomials for sensors) and then the coefficient in microns for each term.

Third, the coating file can specify the transmission and reflection through a full table format.

For coatings on lenses (including filters) the format is

angle wavelength transmission_probability reflection_probability


The angle is given in degrees, and the wavelength is given in microns. The difference in the sum of transmission and reflection from 1 is the absorption probability. 

For coatings on mirrors the format is:

angle wavelength reflection_probability transmission_probability


The angle is given in degrees, and the wavelength is given in microns. The difference in the sum of transmission and reflection from 1 is the absorption probability.  Note the columns are flipped from the lens formats. 


If only 1 angle is given, then PhoSim will approximate the angular dependence.



8) material optical properties files (optional)

This file has two columns to represent the index of refraction as a function of wavelength. The wavelength is in microns. The spacing of the wavelength grid can be variable.

wavelength  index_of_refraction imaginary_part_of_index_of_refraction


9) material mechanical properties files (optional)

The material mechanical properties files describes the material properties and mounting properties of any optic. This file is optional and is used for the full mechanical simulation of a given optic. The commands can be given in any order.

mountPoint X: mounting points in one direction

mountVertical X: mounting points in vertical direction

mountRim X: mounting points around rim of surface

mountType X: X=0 mounted from bottom; X=1 mounted from top; X=2 mounted from side

mountHexagon X: mounting points across hexagonal object

mountSubHexagon X mounting points in each hexagon

segmentHexagon X: sets the number of hexagonal segments

heatCapacity X:  X is the heat capacity 

thickness X:   X is the thickness of the optic in mm

density X:   X is the density in kg per cubic meter

fillFactor X:   X is the fill factor of the given material

thermalConductivity X:  X is the thermal conductivity

youngsModulus X:  X is the Young's modulus of the material

poissonRatio X:   X is the Poisson ratio of the material

nominalTemperature X:  X is the nominal temperature optic is created for in degrees Celcius

nominalGravity X:  X is the nominal gravity factor (1=Earth, 0=no gravity) the optic is designed for

thermalExpansionCoefficient X:   X is the thermal expansion coefficient

constraintSize X: size of actuator footprint (m)

constraintRim X: size of actuator footprint on rim mounts (m)

blankType X: X=0:  flat surface; X=1:  constant thickness

firstFocus X: effective focus scaling factor

secondFocus X: effective focus scaling factor for secondary optics

coolingPerformanceRate X: effective cooling rate, if additional (W)


10) sensor properties files (optional)

The sensor properties files shows the detailed properties of an individual sensor.  This sensor propeties file is optional as well as all of the commands are optional.   There are a set of standard sensor properties for three sensor types:

Silicon:  p_type, n_type

Mercury Cadmium Telluride:   mct

The three sensor file names can simply be added in the focalplane file to get a default set of properties.   They are located in data/standard/sensor.

Alternatively, the details can be specified.   By default, the values will default to an ideal perfect sensor. The commands below can be entered in any order.

edgeSurfaceCharge X:  X is the effective charge density per sq. cm

treeRingPeriod X:  X is the tree ring period in microns

treeRingAmplitude X:  X is the tree ring amplitude

treeRingRatio X:  X is the ratio of sensor to wafer size

treeRingVariation X:  X is the variation of the period in microns

treeRingDecay X:  X is the decay in microns of the tree ring patter

deadLayerDepth X:  X is the depth in microns of the dead layer

deadLayerWidth X:  X is the width of the laser annealing pattern in microns

deadLayerHeight X:  X is the height of the laser annealing pattern in microns

deadLayerXoverlap X:  X is the offset in microns of the annealing pattern

deadLayerYoverlap X:  X is the offset in microns of the annealing pattern

deadLayerXinit X Y:  X is the number of pattern and Y is the offset in microns

deadLayerYinit X Y:  X is the number of pattern and Y is the offset in microns

deadLayerAngle X Y:  X is the number of the pattern and Y is the angle in degrees

pixelVarX X:  X is the lithographic pixel size variation fraction in the x direction

pixelVarY X:  X is the lithographic pixel size variation fraction in the y direction

wellDepth X:  X is the full well depth in microns

nbulk X:  X is the doping charge density per cubic cm

nf X:  X is the front side charge density

nb X:  X is the back size charge density

sf X:  X is the scaling length of the front side doping

sb X:  X is the scaling length of the back side doping

spaceChargeShield X:  X is the suppression factor of the accumulated charge field

spaceChargeSpreadX X:  X is the effective full well charge spread in microns 

spaceChargeSpreadY X:  X is the effective full well charge spread in microns 

chargeStopCharge X:  X is the effective charge density of charge stops

siliconType X:  X is the silicon type (-1 is electron/ 1 is holes)

sensorTempNominal X:  X is the nominal temperature in Kelvin

shapeType X:  X is the non-flatness method (either zern or cheb)

shapeValue X Y Z:  X is the coefficient number, Y is the mean value in microns, Z is the variance in microns

inactiveX X:   X is the number of shielded pixels in the x-direction (no photons)

inactiveY X:   X is the number of shielded pixels in the y-direction (no photons)