SIMION® 8.1¶
SIMION® 8.1 makes a number of enhancements over SIMION® 8.0. Major areas of emphasis include speed, accuracy, array refining enhancements, and programming APIs.
Schedule: The first 8.1.0 production release was in Aug 2011, and further 8.1.x.y releases are being posted as free updates.
Changes between 8.0.x and 8.1.1 are detailed in SIMION Software Change Log, but the main differences are summarized here:
- Use large arrays on 64-bit systems.
A 64-bit executable of SIMION is now provided, which allows taking advantage of larger array sizes (up to 190 GB, ~20 billion point arrays in 8.1.0.30). When the 64-bit SIMION executable is run on a 64-bit Windows, SIMION can utilize all available system RAM. SIMION can use arrays with the number of points being approximately 1/10 the number of bytes in free physical RAM. For example, a system with 16 GB of RAM, 14 GB of which is free, can use a 1.5 billion point array. A 32-bit executable of SIMION 8.1 is also included for compatibility but (like SIMION 8.0) is limited to array sizes of roughly 2 GB (~200 million points).
The 64-bit version requires a 64-bit Windows, which in turn requires a 64-bit CPU. The 64-bit executable is currently only supported on 64-bit Windows (or 64-bit Windows running in a virtual machine on Linux or Mac OS X). Running 64-bit SIMION on Wine64 on Linux is experimentally supported but needs further testing. 32-bit Windows, as well as 32- and 64-bit versions of Linux and Mac OS X using Wine/CrossOver (32-bit), currently require using the 32-bit version of SIMION 8.1, which is limited in memory sizes, but you’ll still be able to take advantage of enhancements like multicore support.) See 64-bit CPU support.
- Refine a few times faster (Multi-core CPU support).
SIMION can now fully utilize multiple CPU cores to improve performance. This requires a system having a multi-core CPU or multiple CPUs (each in turn possibly with multiple cores). Presently, Refining (e.g. Laplace/Poisson solving) and some other operations like the GEM processing, Modify OpenGL view, and some 3D view renderings are parallelized, but particle flying currently is not in the initial 8.1.0 release (unless you run multiple instances of SIMION as before). Benchmarking indicates that an eight CPU cores system (dual processor, four cores per processor) can speed up refines by a factor of ~3-7x, depending on whether the array size is under the CPU cache size. See Multicore CPU support.
- Fly’m performance on Linux and Mac (Wine/CrossOver)
has improved to near Windows speeds (as of 8.1.1.23). See Linux and Mac OS.
- Use rectangular, non-square grid cells (anisotropically scaled grid cells).
SIMION 8.1 supports grid cells that have different scales in the x, y, and z directions. In some systems, non-rectangular grids can conserve memory and improve accuracy. See Anisotropically Scaled Grid Cells in SIMION.
- Proper Neumann boundaries
SIMION 8.1 treats all open edges of PAs with proper Neumann boundary conditions, regardless whether mirror planes are defined on them. SIMION 8.0 only did this explicitly for edges with mirror planes; other edges were approximately very close to Neumann but differed very slightly. This change can slightly improve accuracy for things like repeating wire grid patterns. See Neumann Boundary Condition.
- Additional Scripting APIs:
New programming interfaces have been added that are accessible inside SIMION user programs:
simion - a few assorted new interfaces added
simion.pas - manipulate SIMION PA’s directly in SIMION’s memory (Issue-I 492). Note: SIMION 8.0 only allowed this via C++/Perl/Python API’s that operated outside of SIMION (SL Libraries)
simion.wb - manipulate PA instance positions in workbenches (Issue-I 496).
simion.experimental - programmatically draw 3D lines on the View screen. This is used for scalar and vector field plotting (SIMION Example: contour is much simplified), including magnetic field plotting (SIMION Example: solenoid and SIMION Example: helmholtz_coil) (as well as drawing wires used for Biot-Savart calculations) and gas flow plotting (SIMION Example: collision_sds). (Issue-I 564).
- Refine accuracy/Surface Enhancement
SIMION can now improve Refine accuracy by an order of magnitude or more in the case when electrode surfaces don’t perfectly align to grid points. Note: This feature was significantly improved in 8.1.1.10, but the feature is undergoing active development and some features of SIMION do not yet utilize it (e.g. it’s currently supported in GEM import but not yet CAD or Modify). See Electrode Surface Enhancement / Fractional Grid Units for latest details.
- Poisson solver
SIMION 8.1’s Refine function can solve the Poisson equation, which takes into account a known charge density as a function of position (x,y,z), defined as a separate space-charge array (PA). It’s important to note, however, that this Poisson equation solving capability alone is necessary but possibly not sufficient for solving space-charge problems that you may have. The Poisson equation requires that you know what the space-charge distribution is, but it may be that this distribution is not known a priori. A typical case is when simulating a system with a high current beam, where the electric field controls the path of the particle beam, but the particle beam itself generates an electric field (and sometimes a magnetic field) that in turn in turn affects the path of the particle beam. In such a system, the refine and particle trajectory integration cannot be done independently but must be done simultaneously. SIMION includes some user programs that achieve this (poisson examples), but it is advanced and still somewhat experimental at this time. See Poisson Solver in SIMION.
Update: 8.1.0.42 supports
.PA#
Poisson solving (not just.PA
). 8.1.0.43 piclib adds mode optimizing time-independent case.- Dielectric solver
SIMION Refine function has been extended to solve the Laplace (or Poisson) equation in the presence of dielectrics, which takes into account the dielectric constant as a function of position (x,y,z), defined as a separate relative dielectric constant array (PA). Dielectrics are implemented in 8.1.1.0, and this is compatible with space-charge too. See Dielectrics.
- New workbench user program segments: New
flym
,initialize_run
, terminate_run
[8.1.0.40] andload
[8.1.1.0] segments were added to simplify user programming concerning multiple run automation and reliability. Many examples such as SIMION Example: geometry_optimize, SIMION Example: tune, and SIMION Example: spectrum utilize these. See Workbench Program Extensions in SIMION 8.1.- Supplementary Documentation:
Supplementary electronic documentation (first added in 8.0) and SIMION info pages (on the simion.com web site) have been merged and can be accessed in Windows Help format from the Help > Browse Documentation menu.
Assorted other changes:
Refining/Simulation:
Cell sizes in mm are now stored in the PA file (not just the IOB). This is used in Anisotropically Scaled Grid Cells in SIMION, Poisson Solver in SIMION, and visualization. Using a value other than 1 mm also affects the interpretation of various parameters including PA instance scale factor, PA instance working origin, Magnetic PA scaling factor (ng), and distance units in GEM files. See Anisotropically Scaled Grid Cells in SIMION for details.
Physical Constants updated to CODATA2010 ; Issue-I 494
Max Electrodes - PA# electrode limit increased to 1000.
Disable relativistic effects option added to the Particles tab, mainly to help see the extent of relativistic effects on particle trajectories. (This can be used in conjunction with the Keep button to compare trajectories with and without relativistic effects.)
Issue-I 503 - Refine .PA# solution arrays individually (note: the multicore support largely supplants this unless you want to refine these arrays on multiple computers)
IOB
PA files automatically created from GEM files on loading IOB’s. [Added in 8.1.0.40]
Programming:
New workbench program reserved variables:
ion_run
,ion_effective_charge
,sim_repulsion_amount
,sim_repulsion
(8.1.0.43), andsim_grouped
(8.1.0.43). See Workbench Program Extensions in SIMION 8.1,New workbench program segments:
segment.initialize_run()
,segment.terminate_run()
(8.1.0.32).Issue-I 182 - If GUI enabled, “fly” batch mode command display run in View screen.
Issue-I 498 - Resize SIMION window programmatically:
simion.window
Issue-I 521 - New
simion.print_screen()
function to print current image.Issue-I 518 - Access memory dump:
simion.debug.memory_dump()
.Issue-I 243 - Manipulate/save/load View display programmatically (experimental; may be delayed to 8.2)
simion.experimental.display
Printing:
Issue-I 523 - Printing to BMP, PNG, and JPG files now supported.
Data Recording:
Issue-I 231 - Allow splitting data recording output into multiple files.
Examples:
SIMION Example: poisson: various poisson solving examples [8.1.0/8.1.0.45]
SIMION Example: dielectric: dielectric examples [8.1.1.0]
SIMION Example: electrostatic_induction Issue-I 499: induced current/charge example [8.1.0]
SIMION Example: nonideal_grid (pa_jump) Issue-I 515: PA instance jumping trick example [8.1.0]
SIMION Example: waveform: segmented waveform example [8.1.0]
SIMION Example: bradbury_nielson_grid Issue-I 502: Bradbury-Nielson Grid example [8.1.0]
SIMION Example: faims: FAIMS example [8.1.0]
SIMION Example: gnuplot: plotting in gnuplot (similar to Excel examples) [8.1.0.20]
SIMION Example: magnetic_sector: extensive magnetic sector examples [8.1.1.0]
SIMION Example: field_emission: field emission example. Illustrates (1) refining coarse and refine PA’s in a dependent manner for higher accuracy in certain regions, (2) quickly rebuilding/re-refining PA’s based on changes to geometric parameters in adjustable variables, without leaving the View screen, and (3) emission from arbitrary curved surface. [8.1.1.0]
SIMION Example: kingdon_trap: new Kingdon trap / quadro-logarithmic / orbitrap-like example. [8.1.1.0]
SIMION Example: count_transmission: % transmission calculation example [8.1.1.0]
SIMION Example: pseudopotential: pseudo-potential calc/plotting in RF trap [8.1.0.47]
SIMION Example: spectrum spectrum acquisition/plotting [8.1.0.22]
SIMION Example: mfield_adjust: example demonstrating basic usage of mfield_adjust [8.1.0.22]
SIMION Example: experimentalenhanced_refine: add “experimental” enhanced Refine accuracy for non-grid unit aligned electrodes example [8.1.0.18]
SIMION Example: tandem_van_de_graaff: tandem Van de Graaff system, with electron stripping [8.1.0]
SIMION Example: geometry_optimization: improved in 8.1 to perform optimizations entirely from a workbench user program (View screen), without resorting to batch mode. Also added sub-example automating runs at different PA grid cell sizes and Refine convergence objectives. [8.1.0.40-8.1.1.14]
and others, as well as improvements to many existing examples…
Other Notes¶
GUI: SIMION GUI remains largely unchanged in 8.1 following the significant changes in 8.0. Further significant user interface changes will likely not occur until 8.2beta.
Manual: SIMION 8.1.0 does not come with a new printed manual but rather reuses the 8.0.4 manual (update: an 8.1.0.31 manual with small updates has since been printed). Upgrades from 8.0 are not normally shipping with a new printed manual (unless requested), but new licenses and upgrades from 7.0 are shipping with a new manual. Much of the core content described in the manual remains unchanged. However, we provide 8.1 specific notes in the “supplemental documentation” in electronic format (Windows Help). Major manual changes will likely not occur until 8.2.
File formats/Compatibility: File formats remain largely unchanged in 8.1.0. 8.0 simulations can be run unchanged in 8.1, and most 8.1 simulations can be run unchanged in 8.0 (unless the new features are used). More significant changes may be delayed to 8.1.x or 8.2. An extension was made to the PA (and IOB) format to optionally allow grid cell sizes in mm (in X, Y, and Z directions) to be stored in the PA file, as required for the new Anisotropically Scaled Grid Cells in SIMION and Poisson Solver in SIMION features, but only arrays that use this option are saved in the new format. PA# files also recognize 1000 adjustable electrodes (1..1000) now.
System requirements: For details, see System Requirements. Requirements are similar to SIMION 8.0 except that SIMION 8.1 can optionally take advantage of 64-bit memory (for modeling at higher accuracy) and multicore/multiprocessor CPU’s (for faster speed, mainly in Refine’s and some aspects of 3D rendering). Some > 10 year old systems (e.g. Windows 2000 and non-SSE CPUs) are no longer officially supported 8.1 unless requested. A 64-bit Windows 7, multi-core (or dual processor) workstation can provide optimal results.
Pricing: A discount is provided to existing SIMION 7.0 and 8.0 users. See Ordering Info.
Upgrades: Free SIMION 8.1.x releases will follow for at least the following year to improve on these features and perhaps add new ones similar in nature. A paid upgrade (8.2) is expected sometime after that. 8.1 users will be able to beta test some 8.2beta features as they become available (similarly to what we did in 8.0 early access).
Support for old versions:
SIMION 8.0 remains actively supported. Patches will continue to be provided. However, major “new” features added are now going instead into 8.1. Both 8.0 and 8.1 can be installed and run simultaneously.
SIMION 7.0 will still be supported to some degree since there are still users, and many of the concepts remain the same in 8.0. Both 7.0 and 8.0 can be installed and run simultaneously. In fact, 8.0 includes a copy of the 7.0 binary. The software is stable, and very few patches to 7.0 have been released in recent years.
SIMION 6.0, released in ~ 1996, is no longer formally supported due to OS compatibility issues, but we may answer occasional questions on it in the user group as they also pertain to newer versions. Very few people still use this version.
SIMION SL is now incorporated into SIMION 8.0. It is no longer sold separately, but it will still be supported. Major new functionality is now going instead into SIMION 8.1.
Related: SIMION® Roadmap (8.2 and Beyond).