SenseTalkの算術計算
SenseTalkでは、数 学的な演算子やさまざまなコマンドや関数を使用して数学的な操作を実行することができます。演算子の使用方法についての詳細な情報は、Expressions ページを参照してください。このページではSenseTalkで表現を使用する基本的な方法を説明し、特定の数学演算子(+、-、*、その他の演算子)と比較や論理演算子などの他の有用な概念について説明するページへのリンクがあります。
SenseTalkの算術コマンドと関数は、数値を操作するための便利なツールを提供しています。算術コマンドは、コンテナに格納された数値を変更するために使用できます。これらのコマンドは+、-、*、/の演算子と同じ算術関数を実行します。違いは、これらのコマンドがオペランドの一つをコンテナから取り出し、計算結果をそのコンテナに戻すことです。算術関数は数値を操作します。これらの関数を使用して、さまざまな方法で数値を操作することができます。
算術計算に関連する話題であるPoints and Rectanglesでは、SenseTalkが幾何学的な点と矩形の概念をどのように理解しているかについて説明しています。任意の2つの数のリスト、またはコンマで区切られた2つの数からなるテキスト文字列は、点として扱うことができます。Points and Rectanglesのページで説明されている関数は、点や矩形の各成分値を抽出するために使用できます。
算術コマンド
算術コマンドは4つあります:
これらを使用して、コンテナに格納された値を変更します。これらのコマンドは+、-、*、/の演算子と同じ算術関数を実行します。違いは、これらのコマンドがオペランドの一つをコンテナから取り出し、計算結果をそのコンテナに戻すことです。
Add コマンド
Behavior: add コマンドは、コンテナ内の値に数値を追加し、合計によりコンテナ内の値を置き換える場合に使用します。値のリストを追加することもできますが、ソースリストと宛先リストの両方が同じ数のアイテムを含んでいる必要があります。ソースリストからの各アイテムは、宛先コンテナの対応するアイテムに追加されます。 NumExpr はソース表現です。これは数値、任意の数式、または他のコンテナであることができます。 Chunk は、コンテナの一部を説明するチャンク表現です(行、単語、アイテム、または文字)。 Container は任意のコンテナです。
Syntax: add numExpr to {chunk of} container
例:
add amount to dollarsVariable
add 37 to item 2 of line 3 of scores
add speed * time to item 1 of distances
add [10,5] to centerPoint
文法:
Subtract コマンド
Behavior: subtract コマンドは、コンテナ内の値から数値を引く場合に使用します。結果によりコンテナ内の値を置き換えます。値のリストを引くことができますが、ソースリストと宛先リストの両方が同じ数のアイテムを含んでいる必要があります。ソースリストからの各アイテムは、宛先コンテナの対応するアイテムから引かれます。 NumExpr はソース表現です。これは数値、任意の数式、または他のコンテナであることができます。 Chunk は、コンテナの一部を説明するチャンク表現です(行、単語、アイテム、または文字)。 Container は任意のコンテナです。
Syntax: subtract numExpr from {chunk of} container
例:
subtract checkAmt from accountBalance
subtract 1 from property CountDown of gameController
subtract rate * pmt from line 4 of amortization
subtract [1,2] from boxDimensions
関連:
Multiply コマンド
Behavior: multiply コマンドは、コンテナ内の値を別の数値で掛ける場合に使用します。結果によりコンテナ内の値を置き換えます。値のリストを掛けることができますが、ソースリストと宛先リストの両方が同じ数のアイテムを含んでいる、またはソースが単一の値であることが必要です。宛先コンテナの各アイテムは、ソースリストの対応するアイテム、またはソース値で掛けられます。 NumExpr はソース表現です。これは数値、任意の数式、または他のコンテナであることができます。 Chunk は、コンテナの一部を説明するチャンク表現です(行、単語、アイテム、または文字)。 Container は任意のコンテナです。
Syntax: multiply {chunk of} container by numExpr
例:
multiply score by weightingFactor
multiply accountBalance by 1 + interestRate
multiply item 3 of line x of table by 2
関連:
Divide コマンド
Behavior: divide コマンドは、コンテナ内の値を別の数値で除算する場合に使用します。結果によりコンテナ内の値を置き換えます。値のリストを除算することができます が、ソースリストと宛先リストの両方が同じ数のアイテムを含んでいる、またはソースが単一の値であることが必要です。宛先コンテナの各アイテムは、ソースリストの対応するアイテム、またはソース値で除算されます。 NumExpr はソース表現です。これは数値、任意の数式、または他のコンテナであることができます。 Chunk は、コンテナの一部を説明するチャンク表現です(行、単語、アイテム、または文字)。 Container は任意のコンテナです。
Syntax: divide {chunk of} container by numExpr
例:
divide score by totalCount
divide item 1 of balances by 12
関連:
算術関数
これらの関数を使用して数値を操作します。
Abs, As a positive number, As a negative number Functions
Behavior: 数値パラメータの絶対値を返します。絶対値はその数値の大きさであり、その符号に関わらず常に正またはゼロです。
Syntax: abs( numExpr ) the abs of numFactor numFactor as a positive number numFactor as a negative number
例:
put abs(-11) --> 11
put the abs of -11 --> 11
例
if height is a negative number then put abs(height) into height
Example
put (3 - 16) as a positive number --> 13
put 500 as a negative number --> -500
例: ACos関数
Behavior: 値の三角円弧余弦を計算し、ラジアンで表された角度として結果を返します。
Syntax: acos( numExpr ) {the} acos of numFactor
例:
put acos(0) --> 1.570796 radians
put the acos of 0 --> 1.570796 radians
put acos(0.5) as degrees --> 60 degrees
関連項目:
ACosh 関数
Behavior: 値の逆双曲余弦を計算し、結果をラジアンで表した角度として返します。
Syntax: {the} acosh of numFactor
例:
put acosh(2.509178) rounded to the nearest degree --> 90 degrees
put the acosh of 1 --> 0 radians
関連項目:
関連: annuity関数
Behavior: 指定された期間ごとの利息率と期間数に基づき、一単位の支払いを伴う普通年金の現在価値を計算します。
Syntax: annuity( interest, periods )
例
put annuity(1%, 32)
関連項目:
ASin 関数
Behavior: 値の三角円弧余弦を計算し、ラジアンで表された角度として結果を返します。
Syntax: {the} asin of numFactor
例
put asin(0) --> 0 radians
put asin of 1 --> 1.570796 radians
put asin(0.5) as degrees --> 30 degrees
関連項目:
ASinh 関数
Behavior: 値の逆双曲線サインを計算し、ラジアンで表される角度として結果を返します。
Syntax: asinh( numExpr ) {the} asinh of numFactor
例
put asinh(0) --> 0 radians
put the asinh of 2.301299 rounded to the nearest degree --> 90 degrees
関連項目:
ATan関数
Behavior: パラメータの逆三角関数をラジアンで表現した角度として返します。
Syntax: atan( numExpr ) {the} tan of numFactor
Example
put atan(19) --> 1.518213 radians
put the atan of 5 --> 1.373401 radians
関連:
ATanh 関数
Behavior: 値の逆双曲正接を計算し、結果をラジアンで表した角度として返します。
Syntax: atanh( numExpr ) {the} atanh of numFactor
例
put atanh(0.917152) rounded to the nearest degree --> 90 degrees
put the atanh of 0 --> 0 radians
関連:
ATanPt 関数
Behavior: ポイントの三角円弧接線を計算し、ラジアンで表された角度として結果を返します。
構文: atanPt( aPoint ) atanPt( xCoord , yCoord ) {the} atanPt of aPoint
'atanPt' 関数は、他の言語の atan2 関数と同じ機能を提供しますが、パラメータとして 1 つの点または座標を y,x ではなく、x,y 順に受け取ります。
例
put atanPt(123,0) --> 0 radians
put the atanPt of [11,56] --> 1.376837 radians
例
set myPoint to [50,50]
put atanPt(myPoint) as degrees --> 45 degrees
関連項目:
Average 関数
動作: パラメータの平均を返します。
構文: average( numList ) {the} average of numList
Behavior: パラメータの合計を返します。numList は数値のリスト、カンマで区切られた数値のリストを評価する式、またはこれらの組み合わせであり、任意の深さでネストすることができます。
例
put average(8, 10, 12) -- 10を表示
例:
この例は、機能の使用方法を示すためのコードの不完全な部分です
if the average of [x,y,z] is greater than z then
put "Z is below average!"
end if
文法:
Compound関数
Behavior: 指定された利率と期間に基づいて、1単位の投資に対する元本プラス利息を計算します。
構文: compound( interest, periods )
例:
put compound(7,25%, 6) -- 1.521892を表示
例
put 10 into initialinvestment
put initialInvestment * compound(6.7%, 12) into currentValue
put currentvalue --> 21.775746
文法:
Cos関数
Behavior: パラメータの三角関数コサインを返します。このパラメータはラジアンで表現される角度です。
Syntax: cos( numExpr ) {the} cos of numFactor
例:
put cos(18) -- 0.660317を表示
関連項目:
Cosh 関数
Behavior: そのパラメータの双曲線余弦 (ラジアンで表される角度) を返します。
構文: cos( numExpr ) {the} exp1 of numFactor
例
put cosh(0) --> 1 (no units specified, so 0 radians assumed)
put cosh of 90 degrees --> 2.509178
関連:
Cube Root関数
Behavior: パラメータの立方根を計算します。
構文: cube root( number ) {the} cube root of number cbrt( numExpr )
例
put cube root (27)--3
関連項目:
Exp関数
Behavior: パラメータの自然指数(つまり、数学定数eをパラメータの冪に上げたもの)を返します。
構文: exp( numExpr ) {the} exp of numFactor
例:
put exp(2) -- 7.389056
put the exp of 1 --> 2.718282
関連:
Exp1関数
Behavior: パラメータの自然指数の1引いたものを返します(つまり、数学定数eをパラメータの冪に上げ、1を引いたもの)。
Syntax: exp1( numExpr ) {the} exp1 of numFactor
例:
put exp1(2) --> 6.389056
put the exp1 of 2 --> 6.389056
関連項目:
exp2関数
Behavior: パラメータの冪に2を上げたものを返します。
Syntax: exp2( numExpr )
{the} exp2 of numFactor
例:
put exp2(8) --> 256
put exp2 of 10 --> 1024
関連項目:
frac 関数
Behavior: 数値の小数部分を返します。値の整数部分を取得するには trunc 関数を使用します。trunc(x) + frac(x) は常に x と等しいように trunc と frac 関数が定義されています。
Syntax: frac( numExpr ) {the} frac of numFactor
例:
put frac(81.236) -- .236
関連:
Ln 関数
Behavior: パラメータの自然対数を返します。
Syntax:\ ln( numExpr )\ {the} ln of numFactor
例:
put ln(2) -- 0.693147
関連項目:
Ln1 関数
Behavior: パラメータに1を加えた自然対数を返します。
構文:
ln1( numExpr )
{the} ln1 of numFactor
例:
put ln1(2) --> 1.098612
関連項目:
Log10 関数
Behavior: パラメータのベース10の対数を返します。
Syntax:\ log2( numExpr ) (#log2)\ {the} log2 of numFactor
例:
put log10(100) --> 2
put the log10 of one million --> 6
関連:
Log2 関数
Behavior: パラメータのベース2の対数を返します。
構文: log2( numExpr )
{the} log2 of numFactor
Example
put log2(256) --> 8
put the log2 of 8 --> 3
関連項目:
Maximum, Max, HighestValue, LargestValue 関数
Behavior: パラメータの平均を返します。 _numList_は、数値のリスト、カンマで区切られた数値のリストを評価する式、またはこれらの組み合わせを任意の深さでネストしたものであることができます。
[max | maximum | highestValue | largestValue]( numExpr )
Syntax: [max | maximum | highestValue | largestValue]( numExpr ) {the} [max | maximum | highestValue | largestValue] of numFactor
パラメータ numList は、数値のリスト、カンマで区切られた数値のリストに評価される式、またはこれらの組み合わせで、任意の深さにネストされたものです。
例:
put max(4, 6, 5, 7, 3) -- 7