Tychos MathJs Language Reference
The following reference guide identifies the language syntax, built in variables, functions, and classes that are used to code your simulations in Tychos. Tychos uses the MathNotepad language. We have included documentation here for some of the helpful functions defined in the MathNotepad language. This is not a complete list of all functions available in MathNotepad, just ones that might be commonly used in Tychos for building scenarios as well as defining goals for those scenarios.
Comments
Comments are statements that you can insert in your code that do not get interpreted and executed by Tychos. To create a comment, you simply indicate a comment by using a hashtag:
Variables
To define a variable in Tychos all you need to do is identify a name for the variable. You then type an =
sign to assign a value to the variable. The following demonstrates various variable declarations
Built-in Scenario Variables
There are a few variables that are built into Tychos. These variables are:
t
— How many seconds has passed since this Scenario was started?dt
— Time between frames as seconds, e.g. 0.1 is 1/10th of a second.frame_count
— How many frames have passed? e.g. 1, 2, 3...X
,Y
,Z
— These are shortcuts for indexing the first two elements of 3-D matrices, e.g.my_particle.pos[X]
Common Math Operators and Functions
These are some common mathematical operators and functions for performing various calculations.
Mathematical Operators
Tychos uses the following operators to perform basic math calculations:
+
— Addition-
— Subtraction*
- Multiplication/
- Division^
- Exponent%
- Modulo
Basic Math Functions
You can also use the following basic math functions:
pow(base, power)
The pow(base, power)
function takes two arguments, raising the base
by the power
.
sqrt(positive_number)
The sqrt(positive_number)
function takes a single non negative number and returns the real square root of the number.
abs(number)
The abs(number)
function returns the absolute value of a number.
Trigonometric Functions
The following functions all use radians as the angle measurement. You can use pi
to represent PI.
sin(angle)
The sin(angle)
function is used to evaluate the trigonometric sine value for a given input angle. The input angle must be provided in radians.
cos(angle)
The cos(angle)
function is used to evaluate the trigonometric cosine value for a given input angle. The input angle must be provided in radians.
tan(angle)
The tan(angle)
function is used to evaluate the trigonometric tangent value for a given input angle. The input angle must be provided in radians.
asin(value)
The asin(value)
function is used to evaluate the trigonometric arcsine value (inverse sine) for a given input. The output angle is given in radians.
acos(value)
The acos(value)
function is used to evaluate the trigonometric arccosine value (inverse cosine) for a given input. The output angle is given in radians.
atan2(X, Y)
The atan2(value)
function is used to evaluate the trigonometric arctangent value (inverse tangent) for a given X and Y input. The output angle is given in radians.
deg_to_rad(angle)
See below.
radians(angle)
The deg_to_rad(angle)
function is not part of the MathNotepad language but is provided as a helper function to make the conversion from degree angles to radians easier. The input is an angle measurement in degrees and the output is the angle measurement in radians.
rad_to_deg(angle)
See below.
degrees(angle)
The degrees(angle)
function is not part of the MathNotepad language but is provided as a helper function to make the conversion from radian angles to degrees easier. The input is an angle measurement in radians and the output is the angle measurement in degrees.
Matrix Functions
The following functions provide operations for matrix calculations.
dot(x, y)
Calculates the dot product of two vectors. The dot product of x = [a1, a2, a3, ..., an]
and y = [b1, b2, b3, ..., bn]
is defined as:
dot(x, y) = a1 * b1 + a2 * b2 + a3 * b3 + … + an * bn
cross
Calculates the cross product for two vectors in three dimensional space. The cross product of x = [a1, a2, a3]
and y = [b1, b2, b3]
is defined as:
cross(x, y) = [ a2 * b3 - a3 * b2, a3 * b1 - a1 * b3, a1 * b2 - a2 * b1 ]
If one of the input vectors has a dimension greater than 1, the output vector will be a 1x3 (2-dimensional) matrix.
Other Useful Functions
Some other useful functions...
random(min, max)
Return a random number larger or equal to min and smaller than max using a uniform distribution. If now min or max are given, then it returns a random value from 0 to 1. If just one value is given, then it returns a random number between 0 and the input value.
string(object)
Create a string or convert any object into a string. Elements of Arrays and Matrices are processed element wise.
format(value, precision)
Formats a value into a string. You have several options for how this value will be formatted:
concat(A, B...dim)
Concatenate two or more matrices. This function can also be used to concatenate strings together.
dim: number
is a zero-based dimension over which to concatenate the matrices. By default the last dimension of the matrices.
drawArrow (deprecated)
This function has been deprecated and you should instead use the class Arrow
to represent arrows in your simulations. See below for more details.
The drawArrow
function draws an arrow and is commonly used to illustrate vectors for a particle. drawArrow should be called in the Calculations editor because it only draws the arrow for the current frame. If you call drawArrow() in the Initial State editor, you will not see anything.
drawArrow(pos=[0,0], size=[1,0], color="black", components=false, thickness=1)
-> returns and draws an Arrow object
pos
— coordinates for the starting point of the arrow as an [X,Y] matrix.size
— the vector to illustrate, e.g. [10, 0] will draw an arrow 10 units to the right.color
— Optional HTML color value for your arrow, e.g. "red" or "#ff0000".components
— Optional flag that determines if vector components are drawn, a value oftrue
displays the components.thickness
— Optional stroke value that determines the visual thickness of the arrow.
drawLine (deprecated)
This function has been deprecated and you should instead use the class Line
to represent lines in your simulations. See below for more details.
The drawLine
function draws a line and is commonly used to illustrate some connecting member like a string or cable, but could really represent anything you like. drawLine
should be called in the Calculations editor because it only draws the line for the current frame. If you call drawLine
in the Initial State editor, you will not see anything.
drawLine(pos=[0,0], pos2=[10,0], color="black", thickess=1)
-> returns and draws an Line object
pos
— coordinates for the starting point of the line as an [X,Y] matrix.pos2
— the coordinates of the end point of the line as an [X,Y] matrix.color
— Optional HTML color value for the line, e.g. "red" or "#ff0000".thickness
— Optional stroke value that determines the visual thickness of the line.
Example — The illustration above was drawn using this command:
unit_vector
This function returns a unit vector representation of the given input vector. Its magnitude is 1 and the direction matches the direction of the input vector. This can be useful if you need just the direction of a vector, but not its magnitude.
unit_vector(vec)
-> returns a vector of length 1, and in same direction as vec
.
vec
- any two dimensional vector as a [X, Y] matrix.
Example:
magnitude
This function returns the scaler magnitude of any given vector. This is helpful when you want to know the length of a vector, for example, if you want the magnitude of a vector, but not its direction.
magnitude(vec)
-> returns the scaler magnitude of the vector vec
.
vec
- any two dimensional vector as a [X, Y] matrix.
Example:
direction
This function returns a scalar angle measurement. This is helpful when you want to know the direction of a vector, like the direction of a velocity vector, or the direction of a force vector. The default return angle is given in radians, but can also be expressed in degrees.
direction(vec, units="rad")
-> returns the scaler angle measurement of the vector vec
heading in radian form or in degree form.
vec
- any two dimensional vector as a [X, Y] matrix.units
- optionaldeg
for degree measurement or the default ofrad
for radians.
Example:
polar
This function returns a two-dimensional matrix representing the cartesian components of a polar coordinate corresponding to the magnitude of the radius and the radial angle.
polar(radius, angle, units="rad")
-> returns a two dimensional vector as a [X, Y] matrix.
radius
- scalar quantity representing the scalar distance of the radius of theangle
- scalar quantity representing the angle measurement of the polar coordinate.units
- optionaldeg
for degree measurement or the default ofrad
for radians.
Example:
stop
This function actually evaluates a boolean test and then stops the simulation once the boolean test succeeds. This can be useful if you want the simulation to stop when some condition has been met within your simulation.
stop(test)
-> returns a either false or true. If true is returned, the simulation stops.
test
- a boolean statement that can be evaluated totrue
orfalse
.
Example:
Collision Functions
The following functions are meant to help users model collisions more easily. These functions could be used for other purposes rather than modeling collisions as Tychos is not a physics engine. These functions could be thought of as "overlap" functions. They return information about the overlap of objects.
hasCollided
This function returns a boolean true/false value when two objects are given as the source and target. It returns false if the two objects are not determined to be overlapping.
hasCollided(source, target)
-> returns a boolean true
or false
.
source
-Circle
orRectangle
objecttarget
-Circle
orRectangle
object
Example:
getIntersect
This function returns a two dimensional matrix representing the minimum translation vector (MTV) that would be needed to separate two objects when they overlap. This can be used to simulate collision forces or to move objects apart based on the magnitude and direction of the MTV.
getIntersect(source, target)
-> returns a two dimensional matrix.
source
-Circle
orRectangle
objecttarget
-Circle
orRectangle
object
Example:
Comparison Functions
The following functions are used to compare two values as being equal or unequal as well as testing if one value is larger or smaller than another. These are very helpful when writing goals for students.
equal(a, b)
or a == b
equal(a, b)
or a == b
The function tests if two values (x and y) are equal. It returns a boolean value of true
or false
.
deepEqual(a, b)
This function is similar to equal
, but it tests element wise whether two matrices are equal. It returns a boolean value of true
or false
. The code below demonstrates the difference between equal
and deepEqual
:
larger(a, b)
or a > b
larger(a, b)
or a > b
The function tests if one value (a) is larger than another (b). It returns a boolean value of true
or false
.
smaller(a, b)
or a < b
smaller(a, b)
or a < b
The function tests if one value (a) is smaller than another (b). It returns a boolean value of true
or false
.
unequal(a, b)
or a != b
unequal(a, b)
or a != b
The function tests if two values (a and b) are unequal. It returns a boolean value of true
or false
.
Comparison operators return true
or false
but these also evaluate to 1 (true) or 0 (false). This can allow you to conditionally assign a value to a variable depending on the evaluation of the comparison. See the code below as an example:
if(test, true_result, false_result)
if(test, true_result, false_result)
The if()
function returns true_result
or false_result
depending on test
.
Logical Operators
The following operators are used to execute logical AND and OR comparisons for the use of evaluating logical statements.
and
This is used for performing a logical AND conjunction. For example, "A and B" is true only if A is true and B is true. "A and B" is false if either A or B is false.
You can use the and
operator to test if two comparisons are both true:
or
This is used for performing a logical OR conjunction. For example, "A or B" is true if A or B is true. "A or B" is false only if A and B are both false.
You can use the or
operator to test if one of two comparisons are true:
Built-in Classes
Tychos has only a few classes that are used to create the basic simulated objects in the Tychos universe as well as a few tools for analyzing those objects in the simulated world. The graphical objects in Tychos that can be used are the Cirlcle
, the Rectangle
, the Arrow
, the Line
, the Label
, and the Spring
The tools that can be used for analyzing the behavior of your simulations are the Graph
, the Gauge
and the Meter
. There are also user input objects that can be added to your simulations to make them more interactive: the Toggle
, the Slider
, the Input
, and the Menu
controls.
Circle
A Circle
is drawn as a colored circle in the World View. A Circle
has a position, a radius, a color, an opacity, a flag for setting its visibility state, and a flag for determining if a motion map should be attached.
Below is the constructor for the Circle
class that shows its default values:
Circle(
{pos:[0,0],
radius:10,
color:default_color,
image: "",
opacity: 1,
visible: true,
motion_map: false,
label: {text: "", color: default_color}
}
)
pos
— The initial position of yourCircle
in[X,Y]
coordinates.radius
— The radius of the circle that is drawn in the World View to represent this particle.color
— The circle will be drawn in this color. Use HTML colors e.g. "#ff3300", "blue".image
— A URL that identifies a JPEG, GIF, SVG or PNG image.opacity
— The circle will be drawn with an opacity between 1 and 0, representing 100% opaque to 100% transparent.visible
— The circle can be hidden from view by setting this flag tofalse
.motion_map
— This flag tells Tychos to attach a series of strobe images called a motion map.label
- You can attach a label to theCircle
object by indicating a thetext
andcolor
of the label.
These attributes may also be modified on the Circle
after it is created. In particular, one will usually change the pos
attribute of a Circle
in the Calculations editor to show movement. e.g.
Circle.rotate()
Circle
objects can be rotated.
Circle.rotate(angle=0, axis=[0, 0])
— Rotates the Circle
object by a given angle value in radian units. You can also provide an optional matrix that identifies the axis of rotation. This method should only be called from the Calculations code editor.
Circle.image
Circle
objects can also be represented with an image by setting the image attribute of the object. The text must be a URI link to a graphic file that can be a PNG, SVG, GIF, or JPEG image.
The above image also demonstrates the use of the direction
function as well as the rotate
method:
rocket.rotate(direction(rocket.v))
Circle.label
Circle
objects can also be given a text label. This is similar to the Label
object.
c.label = {text:"Hello", color:"green"}
— This adds a text label to the Circle
object that scales to fit inside the circle.
Rectangle
A Rectangle
is very similar to a Circle
but it is represented as a colored rectangle in the World View. A Rectangle
has position, width, height, color, opacity, visibility, a motion map flag, as well as a label. Just as with the Circle
, Tychos only uses the width and height attributes for display. You can define how these attributes change given the rules of the simulation that you define.
Below is the constructor for the Rectangle
class that shows its default values:
Rectangle(
{pos:[0,0],
size:[10,10],
color:default_color,
image: "",
opacity: 1,
visible: true,
motion_map: false,
label: {text: "", color: default_color}
}
)
pos
— The initial position of yourRectangle
in[X,Y]
coordinates.size
— The width and height of theRectangle
that is drawn in the World View to represent this particle.color
— TheRectangle
will be drawn in this color. Use HTML colors e.g. "#ff3300", "blue".image
— A URL that identifies a JPEG, GIF, SVG or PNG image.opacity
— TheRectangle
will be drawn with an opacity between 1 and 0, representing 100% opaque to 100% transparent.visible
— TheRectangle
can be hidden from view by setting this flag tofalse
.motion_map
— This flag tells Tychos to attach a series of strobe images called a motion map.label
- You can attach a label to theRectangle
object by indicating a thetext
andcolor
of the label.
These attributes may also be modified on the Rectangle
object after it is created. In particular, one will usually change the pos
attribute in the Calculations editor to show movement. e.g.
Rectangle.rotate
You can also rotate a Rectangle
object in order to simulate rotational behavior.
Rectangle.rotate(angle=0, axis=[0, 0])
— Rotates the Rectangle
object by a given angle value in radian units. You can also provide an optional matrix that identifies the center of rotation. This method should only be called from the Calculations code editor.
Example:
Rectangle.image
Just as with Circle
objects, Rectangle
objects can also be represented with an image by setting the image attribute of the object.
Rectangle.label
Rectangle
objects can also be given a text label. This is similar to the Label
object.
This adds a text label to the Rectangle
object.
Arrow
The Arrow
class represents a graphical arrow and is commonly used to illustrate vectors, but can be used for representing anything in your simulations.
Below is the constructor for the Arrow
class that shows its default values:
Arrow(
{pos:[0,0],
size:[1,0],
color:default_color,
componets: false,
stroke: 1,
opacity: 1,
visible: true,
motion_map: false
}
)
pos
— coordinates for the starting point of theArrow
as an[X,Y]
matrix.size
— the vector to illustrate, e.g.[10, 0]
will draw anArrow
10 units to the right.color
— HTML color value for yourArrow
, e.g. "red" or "#ff0000".components
— A flag that determines if X and Y components are drawn, a value oftrue
displays the components.stroke
— Stroke value that determines the visual thickness of theArrow
.opacity
— TheArrow
will be drawn with an opacity between 1 and 0, representing 100% opaque to 100% transparent.visible
— TheArrow
can be hidden from view by setting this flag tofalse
.motion_map
— This flag tells Tychos to attach a series of strobe images called a motion map.
Example — The illustrations above were drawn using these commands:
Line
The Line
class draws a line and is commonly used to illustrate some connecting member like a string or cable, but could really represent anything you like.
Below is the constructor for the Line
class that shows its default values:
Line(
{pos:[0,0],
pos2:[1,0],
color:default_color,
stroke: 1,
opacity: 1,
visible: true,
motion_map: false
}
)
pos
— coordinates for the starting point of theLine
as an[X,Y]
matrix.pos2
— coordinates of the termination point of theLine
as an[X,Y]
matrixcolor
— HTML color value for yourLine
, e.g. "red" or "#ff0000".stroke
— Stroke value that determines the visual thickness of theLine
. This is measured in pixels.opacity
— TheLine
will be drawn with an opacity between 1 and 0, representing 100% opaque to 100% transparent.visible
— TheLine
can be hidden from view by setting this flag tofalse
.motion_map
— This flag tells Tychos to attach a series of strobe images called a motion map.
Example:
PolyLine
The PolyLine
class displays a sequence of straight lines between points, and is commonly used to illustrate a more complex shape or path.
Below is the constructor for the Line
class that shows its default values:
PolyLine(
{pos:[0,0],
color:default_color,
stroke: 1,
opacity: 1,
visible: true,
style: "none",
retain: 100
}
)
pos
— coordinates for the starting point of theLine
as an[X,Y]
matrix.color
— HTML color value for yourLine
, e.g. "red" or "#ff0000".stroke
— Stroke value that determines the visual thickness of theLine
. This is measured in pixels.opacity
— TheLine
will be drawn with an opacity between 1 and 0, representing 100% opaque to 100% transparent.visible
— TheLine
can be hidden from view by setting this flag tofalse
.
Example:
Spring
A Spring
is a visual representation of a common elastic connector that displays a given number of coils that dynamically change shape once the dimensions of the Spring
are changed in the Calculations Pane.
Below is the constructor for the Spring
class that shows its default values:
Spring(
{pos:[0,0],
pos2:[1,0],
color:default_color,
coils: 5,
width: 10,
stroke: 1,
opacity: 1,
visible: true,
motion_map: false
}
)
pos
— coordinates for the starting point of theSpring
as an[X,Y]
matrix.pos2
— coordinates of the termination point of theSpring
as an[X,Y]
matrixcolor
— HTML color value for yourSpring
, e.g. "red" or "#ff0000".coils
— The number "coil" zig-zags.width
— The width of the "coil" zig-zags.stroke
— Stroke value that determines the visual thickness of theSpring
. This is measured in pixels.opacity
— TheSpring
will be drawn with an opacity between 1 and 0, representing 100% opaque to 100% transparent.visible
— TheSpring
can be hidden from view by setting this flag tofalse
.motion_map
— This flag tells Tychos to attach a series of strobe images called a motion map.
The code below shows the three different Spring
objects above that have different lengths, widths and coil numbers. The Circle
objects are shown just for reference.
These attributes may also be modified after the Spring
is created.
Label
You can add text labels to any scenario using the Label
class.
Below is the constructor for the Label
class that shows its default values:
Label(
{pos:[0,0],
size:[10,10],
text: "",
color:default_color,
opacity: 1,
visible: true,
motion_map: false
}
)
pos
— coordinates for the center point of theLabel
as an[X,Y]
matrix.size
— The width and height of theLabel
as an[X,Y]
matrixtext
— The text of theLabel
as a string.color
— HTML color value for yourLabel
, e.g. "red" or "#ff0000".opacity
— TheLabel
will be drawn with an opacity between 1 and 0, representing 100% opaque to 100% transparent.visible
— TheLabel
can be hidden from view by setting this flag tofalse
.motion_map
— This flag tells Tychos to attach a series of strobe images called a motion map.
These attributes may also be modified after the Label
object is created. Here is an example of how to make several Label
objects:
Label.rotate
Just as with a Block
object or a Particle
object, you can rotate a label as shown above:
World
The world object represents the viewable area of the scenario.
world.set_extents
You can set the viewable extents of the world in the Settings Pane, or by calling the following method on the world object:
The inputs are two vector objects representing the center position of the view of the world, and secondly the size of the viewable world.
Particle (deprecated)
This class has been deprecated. Past scenarios that used this class will NO LONGER work. Please use the Circle
class.
Block (deprecated)
This class has been deprecated. Past scenarios that used this class will NO LONGER work, Please use theRectangle
class.
Interface Widgets
Tychos also provides several "widgets" for displaying data in different ways as well as adding user interactivity so that your simulations can respond to input.
Graph
A Graph
is a 2-dimensional chart of data that you specify in the Calculations editor. Each Graph
that is created will appear on the right side of the World View. Your program needs to add points to the graph with the plot
command.
Here is the constructor for creating a Graph
object:
Graph({title:"Graph", y_axis:"Y", x_axis:"X"})
-> Returns a Graph
title
= Optional text that will appear at the top of the graph.y_axis
= Optional text that will appear on the left side of the graph as the vertical axis label.x_axis
= Optional text that will appear at the bottom of the graph as the horizontal axis label.
Graph.plot
graph.plot(x, y, color=default_color)
— Adds a data point to your graph.
Graph.integrate
graph.integrate(color=default_color)
— When you call the plot
function of a graph, you create a new plot set. You can then integrate this plot set. This is done by referencing the plot set's color. This returns the calculated area based on the trapezoidal method of approximation.
Meter
A Meter
is a numeric display of data that you specify in the Calculations editor. Each Meter
that is created will appear on the left side of the World View. Your program needs to tell the Meter
what value it needs to display by using the display
command.
Below is the constructor for the Meter
widget and default values:
Meter({title:"Meter", color:default_color})
title
= Optional text that will appear at the top of theGauge
widget.color
— HTML color value for yourGauge
, e.g. "red" or "#ff0000".
Meter.display
meter.display(value, units)
— Displays the value on the Meter.
value
= Numeric value to be displayed.units
= Optional string representing the unit label to be displayed.
Example:
Gauge
A Gauge
is an analog display of data that is very similar to a Meter
that you specify in the Initial Sate pane. Each Gauge
that is created will appear on the left side of the World View. Gauges also need to to be set up with a specific minimum and maximum value for identifying the range of the Gauge
. Your scenario needs to tell the Gauge
what value it needs to display by using the display
command.
Below is the constructor for the Gauge
widget and default values:
Gauge({title:"Gauge", min:0, max:100, color:default_color})
title
= Optional text that will appear at the top of theGauge
widget.min
= The minimum value of theGauge
max
= The maximum value of theGauge
color
— HTML color value for yourGauge
, e.g. "red" or "#ff0000".
Gauge.display
gauge.display(value)
— Displays the value in the Gauge.
Example:
Toggle
A Toggle
is an interactive widget that allows you associate a boolean value (true or false) with the state of the Toggle
widget.
Below is the constructor for the Toggle
widget and default values:
Toggle({title:"Toggle"})
title
= Optional text that will appear at the top of theToggle
widget.
Toggle.value
x = toggle.value
— Returns the current value of the Toggle. This is read/write.
Example:
Slider
A Slider
is an interactive widget that allows you to link a value in your scenario to the current value of a horizontal slider.
Below is the constructor for the Slider
widget and default values:
Slider({title:"Input", min:0, max:100, step:1})
title
= Optional text that will appear at the top of theSlider
widget.min
= The minimum value of theSlider
max
= The maximum value of theSlider
step
= The step increment of theSlider
Slider.value
x = slider.value
— Returns the current value of the Slider. This is read/write.
Example:
Input
An Input
is an interactive widget that allows you to link a value in your scenario to the current value of a text box. The input values are limited to numerical inputs.
Below is the constructor for the Input
widget:
Input({title:"Input"})
title
— The text title of theInput
min
= The minimum value that the user can enter in theInput
max
= The maximum value that the user can enter in theInput
step
= The step increment of theInput
Input.value
x = input.value
— Returns the current value of the Input
.
Example:
Menu
A Menu
is an interactive widget that allows you to link a value in your scenario to the current value selected from a drop-down menu.
Below is the constructor for the Menu
widget:
Menu({title:"Menu", choices:[], values:[]})
title
— The text title of theInput
choices
— An array of menu choices.values
— An optional array of corresponding menu values for each choice. If no values are given, the values are assumed to be the choices.
Menu.value
x = menu.value
— Returns the current value of the Menu
.
Example:
Interactivity
The following section describes additional interactivity that you can add through the use of keyboard
and mouse
objects.
keyboard
The keyboard
object represents your computers keyboard and has commands to see if any keys are pressed during a simulation.
keyboard.is_down
keyboard.is_down(key)
-> boolean
— Return 1/0 whether key
is currently down
keyboard.last_pressed
keyboard.last_pressed(key)
-> boolean
— was key
typed? i.e. key was pushed down then released.
mouse
The mouse
object represents your computer's mouse.
mouse.pos
mouse.pos
-> vec
— Returns two dimensional vector as a [X, Y] matrix representing the position of the mouse in the simulation space.
mouse.is_down
mouse.is_down(button_num=0)
-> boolean
— Returns whether the mouse button is pressed. button_num
— Which button to check? 0 = primary button, 1 = secondary, etc.
mouse.is_over
mouse.is_over(object)
-> boolean
— Returns whether the mouse is positioned over an object that is either a Circle
or a Rectangle
. object
— A simulation object.
Audio
The audio
object can be used to add sound to your scenarios. This can be done by creating an oscillator
that plays a continuous frequency using a specified wave type, or by creating a sound
object that plays an audio file given a URL, or finally by just playing a specified tone for a specified amount of time.
audio.sound
To create a sound object, you need to specify a URL for the location of the .wav, .ogg, or .mp3 file
my_sound = audio.sound({url:"https://www.example.com/my_cool_sound.wav"})
The sound object has these methods and attributes:
sound.play()
- Plays the sound file.sound.stop()
- If the sound file is currently playing, it stops the sound file.sound.volume
- A numeric value that determines the volume that the sound file will play at. Value must be larger than 0 to hear the sound.sound.playback_rate
- A numeric value that determines the playback speed of the file. If a negative value is given, the file plays backwards.
audio.oscillator
An oscillator object is created using this constructor method:
my_oscillator = audio.oscillator({freq:400, volume:1, type:"sine"})
The oscillator object has these methods and attributes:
oscillator.start()
- Starts the oscillation.oscillator.stop()
- Stops generating the oscillation.oscillator.freq
- A numeric value that determines the frequency of the sound wave that the oscillator will generate.oscillator.volume
- A numeric value that determines the volume of the sound wave that the oscillator will generate. Value must be larger than 0 to hear the sound.oscillator.type
- A string value of "sine", "square", "sawtooth", or "triangle" that detemines the type of oscillation.
Finally, you can also call a method directly on the audio
object for generating a tone for a specified amount of time:
audio.play_tone
audio.play_tone(freq, volume, time)
— Produces an audio tone for the specified time at the specified frequency (freq
) and volume.
CSV Files
Comma separated files can be loaded into the current session of Tychos, and then the data can be read into your scenarios.
You need to upload the file through the interface, found in the Settings Tab of the Hack Panel:
Once this has been done, you can access the data in the file using the csvFiles
array.
csvFiles
This array is a list of data objects representing the data contained in each file.
Note, this array is actually not 0 indexed. The first file is actually identified at index of 1.
You access each file as you would any array in Tychos:
CSV file
For example, let's say your CSV file has the name "my_data.csv"
and looks like this:
The file object has two read-only attributes, one representing the name of the file, and the other representing the data in the file:
The data attribute is itself a list, representing the rows of the data in the file. Each row is a dictionary whose keys correspond to the column headers in the CSV file:
Then to access the X value in the file located at row 1 of the data then you would type:
It is important to note that the values stored in the data objects are all string values. As long as the values can be easily parsed to numerical values, Tychos will do the parsing automatically if the value is used in a mathematical calculation.
Last updated