Outputs: For each magnetization configuration, three standard outputs are provided by all energy terms: the scalar output “Energy,” which is the total energy in joules contributed by this energy term, the scalar field output “Energy density,” which is a cell-by-cell map of the energy density in J/m3, and the three-component vector field output “Field,” which is the pointwise field in A/m. If the code was compiled with the macro NDEBUG not defined, then there will be an additional scalar output, “Calc count,” which counts the number of times the term has been calculated in the current simulation. This is intended for debugging purposes only; this number should agree with the “Energy calc count” value provided by the evolver.
Anisotropy Energy
- Specify Oxs_UniaxialAnisotropy:name {
- K1 K
- Ha H
- axis u
- }
Exactly one of either K1 or Ha should be specified, where K1 is the crystalline anisotropy constant (in J/m3), and Ha is the anistropy field (in A/m). In either case, axis is the anisotropy direction. K1, Ha, and axis may each be varied cellwise across the mesh: K1 and Ha are initialized with scalar field objects, while axis takes a vector field object. (A constant value will be interpreted as a uniform field object having the stated value, as usual.) The axis direction must be non-zero at each point, and will be normalized to unit magnitude before being used.
The axis direction is an easy axis if K1 (or Ha)
is 0, in which case the cellwise anisotropy energy density (in
J/m
) is given by
- Specify Oxs_CubicAnisotropy:name {
- K1 K
- Ha H
- axis1 u1
- axis2 u2
- }
Exactly one of either K1 or Ha should be
specified, where K1 is the crystalline anisotropy constant
(in
J/m3),
and Ha is the anistropy field (in A/m). In either case,
axis1 and axis2 are two anisotropy directions;
the third anisotropy axis is computed as the vector product,
. For each cell, the axis directions are easy axes if
K1 (or Ha) is
0, or hard axes if
K1 (or Ha) is
0. All may be varied cellwise
across the mesh. K1 or Ha is initialized with a
scalar field object, and the axis directions are initialized with
vector field objects. (Constant values will be interpreted as uniform
fields with the indicated value, as usual.) The axis1 and
axis2 directions must be mutually orthogonal and non-zero
at each point (
and
are automatically scaled to unit
magnitude before use).
Exchange Energy
The Specify block for this term has the form
- Specify Oxs_Exchange6Ngbr:name {
- default_A value
- atlas atlas_spec
- A {
}
- region-1 region-1 A11
- region-1 region-2 A12
- ...
- region-m region-n Amn
- }
or
- Specify Oxs_Exchange6Ngbr:name {
- default_lex value
- atlas atlas_spec
- lex {
}
- region-1 region-1 lex11
- region-1 region-2 lex12
- ...
- region-m region-n lexmn
- }
where lex specifies the magnetostatic-exchange length, in
meters, defined by
.
In the first case, the A block specifies values
on a region by region basis, where the regions are labels declared by
atlas_spec. This allows for specification of
both
inside a given region (e.g.,
) and along interfaces between
regions (e.g.,
). By symmetry, if
is specified,
then the same value is automatically assigned to
as well.
The default_A value is applied to any otherwise
unassigned
.
In the second case, one specifies the magnetostatic-exchange length
instead of , but the interpretation is otherwise analogous.
Although one may specify (resp.
) for any
pair of regions
and
, it is only required and only active if
the region pair are in contact. If long-range exchange interaction
is required, use Oxs_TwoSurfaceExchange.
In addition to the standard energy and field outputs, Oxs_Exchange6Ngbr provides three scalar outputs involving the angle between spins at neighboring cells:
- Specify Oxs_ExchangePtwise:name {
- A scalarfield_spec
- }
where scalarfield_spec is an arbitrary scalar field object returning the desired exchange coefficient in J/m.
- Specify Oxs_RandomSiteExchange:name {
- linkprob probability
- Amin A_lower_bound
- Amax A_upper_bound
- }
Each adjacent pair of cells ,
, is given linkprob
probability of having a non-zero exchange coefficient
. Here
two cells are adjacent if they lie in each other's 6-neighborhood.
If a pair is found to have a non-zero exchange coefficient, then
is drawn uniformly from the range
.
The exchange energy is computed using (7.1), the
formula used by the Oxs_Exchange6Ngbr energy object. The
value
for each pair of cells is determined during problem
initialization, and is held fixed thereafter. The limits
A_lower_bound and A_upper_bound may be any real
numbers; negative values may be used to weaken the exchange
interaction arising from other exchange energy terms. The only
restriction is that A_lower_bound must not be greater than
A_upper_bound. The linkprob value probability
must lie in the range
.
- Specify Oxs_TwoSurfaceExchange:name {
- sigma value
- sigma2 value
- surface1 {
}
- atlas atlas_spec
- region region_label
- scalarfield scalarfield_spec
- scalarvalue fieldvalue
- scalarside side
- surface2 {
}
- atlas atlas_spec
- region region_label
- scalarfield scalarfield_spec
- scalarvalue fieldvalue
- scalarside side
- report_max_spin_angle report_angle
- }
Here sigma and sigma2 are the bilinear and
biquadratic surface (interfacial) exchange energies, in
J/m. Either is optional, with default value 0.
Specify Oxs_MultiAtlas:atlas { atlas { Oxs_BoxAtlas { name top xrange {0 500e-9} yrange {0 250e-9} zrange {6e-9 9e-9} } } atlas { Oxs_BoxAtlas { name spacer xrange {0 500e-9} yrange {0 250e-9} zrange {3e-9 6e-9} } } atlas { Oxs_BoxAtlas { name bottom xrange {0 500e-9} yrange {0 250e-9} zrange {0 3e-9} } } } Specify Oxs_LinearScalarField:zheight { vector {0 0 1} norm 1.0 } Specify Oxs_TwoSurfaceExchange:AF { sigma -1e-4 surface1 { atlas :atlas region bottom scalarfield :zheight scalarvalue 3e-9 scalarside <= } surface2 { atlas :atlas region top scalarfield :zheight scalarvalue 6e-9 scalarside >= } }
Self-Magnetostatic Energy
- Specify Oxs_Demag:name {
- asymptotic_order error_order
- demag_tensor_error relerror
- }
The demag kernel is computed using a combination of analytic formulae
for near field terms, high-order asymptotic formulae for far field
terms, and summed subdivided cell asymptotic formulae for midrange
terms, where the offset between cell pairs determines the field
range (based on extensions of earlier work[18]).
The transition
values are selected to give the best computation
speed while meeting the error requested by relerror. The
demag kernel computation is a one-time operation performed during
problem initialization, so the kernel computation time is generally
of relatively minor concern, and accordingly the default value for
relerror is 1e-15, i.e., nearly full double-precision
accuracy.
Asymptotic formulae are used to compute the demag kernel for larger
cell offset pair distances . By default an expansion with error
is used, but lower orders can be
requested through the error_order option. Valid values for
error_order are 5, 7, 9, and 11, where
error_order=5 is the dipole approximation.
There is also backward support for the now deprecated option asymptotic_radius, which set the cutoff between the analytic and asymptotic computation forms in units of cells. If asymptotic_radius is specified then it is converted to a more-or-less equivalent value for relerror, with the special values of 0 and -1 mapping to relerror=1 and 1e-16, respectively.
The example file demagtensor.mif can be used to extract the computed demagnetization tensor coefficients for a specified cell geometry; see the description at the top of that file for usage details.
Zeeman Energy
The fields specified in the range entry are nominally in A/m, but these values are multiplied by multiplier, which may be used to effectively change the units. For example,
- Specify Oxs_UZeeman {
- multiplier 795.77472
- Hrange {
}
- { 0 0 0 10 0 0 2 }
- { 10 0 0 0 0 0 1 }
- }
The applied field steps between 0 mT, 5 mT, 10 mT and back to 0 mT, for four stages in total. If the first field in the second range sublist was different from the second field in the first range sublist, then a step would have been added between those field values, so five stages would have resulted. In this example, note that 795.77472=0.001/µ0.
In addition to the standard energy and field outputs, the Oxs_UZeeman class provides these four scalar outputs:
- Specify Oxs_FixedZeeman:name {
- field vector_field_spec
- multiplier multiplier
- }
The default value for multiplier is 1. The field units, after scaling by multiplier, should be A/m.
- Specify Oxs_ScriptUZeeman:name {
- script_args { args_request }
- script Tcl_script
- multiplier multiplier
- stage_count number_of_stages
- }
Here script indicates the Tcl script to use. The script is called once each iteration. Appended to the script are the arguments requested by script_args, in the manner explained in the User Defined Support Procedures section of the MIF 2 file format documentation. The value args_request should be a subset of {stage stage_time total_time base_state_id current_state_id}. The units for the time options are seconds. The two state_id options are intended for use with the MIF GetStateData command; refer to the documentation on that command in the MIF 2.1 section for details. If script_args is not specified, the default argument list is {stage stage_time total_time}.
proc SineField { total_time } { set PI [expr {4*atan(1.)}] set Amp 800.0 set Freq [expr {1e9*(2*$PI)}] set Hx [expr {$Amp*sin($Freq*$total_time)}] set dHx [expr {$Amp*$Freq*cos($Freq*$total_time)}] return [list $Hx 0 0 $dHx 0 0] } Specify Oxs_ScriptUZeeman { script_args total_time script SineField }
- Specify Oxs_TransformZeeman:name {
- field vector_field_spec
- type transform_type
- script Tcl_script
- script_args { args_request }
- multiplier multiplier
- stage_count number_of_stages
- }
The field specified by vector_field_spec is evaluated during problem initialization and held throughout the life of the problem. On each iteration, the specified Tcl script is called once. Appended to the script are the arguments requested by script_args, as explained in the User Defined Support Procedures section of the MIF 2 file format documentation. The value for script_args should be a subset of {stage stage_time total_time}. The default value for script_args is the complete list in the aforementioned order. The time arguments are specified in seconds.
proc Rotate { freq stage stagetime totaltime } { global PI set w [expr {$freq*2*$PI}] set ct [expr {cos($w*$totaltime)}] set mct [expr {-1*$ct}] ;# "mct" is "minus cosine (w)t" set st [expr {sin($w*$totaltime)}] set mst [expr {-1*$st}] ;# "mst" is "minus sine (w)t" return [list $ct $mst 0 \ $st $ct 0 \ 0 0 1 \ [expr {$w*$mst}] [expr {$w*$mct}] 0 \ [expr {$w*$ct}] [expr {$w*$mst}] 0 \ 0 0 0] } Specify Oxs_TransformZeeman { type general script {Rotate 1e9} field {0 1000. 0} }
- Specify Oxs_StageZeeman:name {
- script Tcl_script
- files { list_of_files }
- stage_count number_of_stages
- multiplier multiplier
- }
The initialization string should specify either script or files, but not both. If a script is specified, then each time a new stage is started in the simulation, a Tcl command is formed by appending to Tcl_script the 0-based integer stage number. This command should return a reference to an Oxs_VectorField object, as either the instance name of an object defined via a top-level Specify block elsewhere in the MIF file, or as a two item list consisting of the name of an Oxs_VectorField class and an appropriate initialization string. In the latter case the Oxs_VectorField object will be created as a temporary object via an inlined Specify call.
proc SlidingField { xcutoff xrel yrel zrel } { if {$xrel>$xcutoff} { return [list 0. 0. 0.] } return [list 2e4 0. 0.] } proc SlidingFieldSpec { stage } { set xcutoff [expr {double($stage)/10.}] set spec Oxs_ScriptVectorField lappend spec [subst { atlas :atlas script {SlidingField $xcutoff} }] return $spec } Specify Oxs_StageZeeman { script SlidingFieldSpec stage_count 11 }
Oxs_ScriptVectorField { atlas :atlas script {SlidingField 0.5} }
:atlas
reference is to an Oxs_Atlas object defined
elsewhere in the MIF file.
proc FileField { stage } { set filelist { field-a.ohf field-b.ohf field-c.ohf } set spec Oxs_FileVectorField lappend spec [subst { atlas :atlas file [lindex $filelist $stage] }] return $spec } Specify Oxs_StageZeeman { script FileField stage_count 3 }
Specify Oxs_StageZeeman { files { field-a.ohf field-b.ohf field-c.ohf } }