[ 前へ | 目次 | 次へ ]

変数や関数を定義する

ここでは、独自の変数や定数を定義し、数式中で使用する方法について解説します。


「 LIBRARY 」エリア

リニアンプロセッサーでは、独自の変数や関数を、いくつでも自由に定義し、数式中で使用する事ができます。それらは「 LIBRARY 」エリアに定義します。

LIBRARYエリアには、INPUTエリアの上にある「 LIBRARY 」と書かれたタブをクリックすると書き込めます。

「 import Math ; 」 は消してはいけない

LIBRARYエリアの先頭には、すでに以下の一行が記述されているはずです。

- LIBRARY -
import Math ;

この行は、sinやcosなど、リニアンプロセッサーで最初から使える関数を読み込むためのものです。従って、この行を消してはいけません。消してしまうとsinやcosが使えなくなります。

変数を定義する

それでは、変数を定義してみましょう。変数の定義は、以下のような1行を書き加えて行います。

- 変数定義の形式 -
float 変数名 = 値 ; 

最初の「 float 」というのは、ここではまだ詳しく扱いません。とりあえず、今は変数を定義するための用語だと思ってください。 また、行末の「 ; 」記号はついつい忘れがちなので、注意が必要です。

実際に、xという名前で、1.0の値を持つ変数を定義してみましょう。LIBRARYエリアに一行だけ追記し、以下のようにします。

- LIBRARY -
import Math ;

float x = 1.0 ; // xという名前で、1.0という値の変数を定義

追記された最終行の、 // ( ダブルスラッシュ )以降はコメントであり、無視されます。これで、xという名前で、1.0の値を持つ変数が定義できました。

定義した変数xを使って、実際に計算を行ってみましょう。「 INPUT 」タブをクリックしてINPUTエリアに戻り、以下の数式を計算してみてください。

- INPUT -

1 + x

この計算の結果は以下の通りです。

- OUTPUT -

2.000000000

このように、正しい値が得られました。

関数を定義する

続いて、関数を定義してみましょう。関数は、以下のような形で定義します。

- 関数定義の形式 -
float 関数名( float 引数名 ) {
    return 計算内容 ;
}

ここでも「 float 」というキーワードが登場していますが、とりあえず今は気にしないでください。「 引数(ひきすう) 」という耳慣れない言葉も登場していますが、これは関数を使う際、 ( ) の中に記述した値が格納される、特別な変数です。

それでは例として、「 half 」という名前で、受け取った値を2で割って返す関数を定義してみましょう。ライブラリに内容を追記し、以下のようにします。

- LIBRARY -
import Math ;

// 値を2で割って返す関数
float half( float a ) {
  return a / 2.0 ;
}

ここで、a/2ではなく、a/2.0としている事に注意が必要です。ここではとりあえず、「 LIBRARYエリアでは、数値には必ず小数点を付けておく 」と覚えておいてください。詳しい説明は割愛しますが、小数点のない値同士で割り算を行った場合、余りが切り捨てられます。

これは不具合ではなく、様々な事情により、そういうルールになっているのです。そして、余りが切り捨てられるのを防ぐために、数値には必ず小数点を付けるクセを付けておきましょう。

それでは、実際にhalf関数を使用してみましょう。

- INPUT -

half( 1 )

この計算の結果は以下の通りです。

- OUTPUT -

0.500000000

このように正しい値が得られました。

引数が複数ある関数

関数では、引数を複数使用する事もできます。それには、引数をカンマ記号で区切って定義します。例として、2つの値の積を返す関数 mul を定義してみましょう。LIBRARYエリアに以下のように記述します。

- LIBRARY -
import Math ;

// 2つの値の積を返す関数
float mul( float a, float b ) {
  return a * b ;
}

それではINPUTエリアに戻り、以下の数式を計算してみましょう。

- INPUT -

mul( 2, 8 )

この計算の結果は以下の通りです。

- OUTPUT -

16.00000000

このように正しい値が得られました。

VFモードON時に使用する変数と関数

ここまでで扱ってきた変数と関数の定義は、原則として、VFモードOFF時にしか使用できません。もしも無理に使用すると、その部分だけVFモードOFF、つまり16桁程度で処理されるため、全体で望んだ精度が出なくなってしまいます。それでは、VFモードON時に使用する変数と関数の定義は、どうすればよいのでしょうか。

それにはまず、これまで何度も登場した「 float 」というキーワードの代わりに、「 varfloat 」というキーワードを使用する必要があります( ※ 実はVFモードの「 VF 」は、「 VarFloat 」の略です )。そして、1.0や2.0などの数字の末尾に、vfの2文字を付けるようにします。

実際に、上で定義した変数 x と half 関数を、VFモードON時に使用するために書き直してみましょう。内容は以下のようになります。

- LIBRARY -
import Math ;

varfloat x = 1.0vf ; // 値が1.0の変数 x を定義(VFモードON用)

// 値を2で割って返す関数(VFモードON用)
varfloat half( varfloat a ) {
  return a / 2.0vf ;
}

これらの変数と関数は、VFモードON時に、正確な精度で使用できます。



スポンサーリンク



この階層の目次
新しいお知らせ

Vnanoがオープンベータ版に移行、VCSSLの実行環境で標準で実行可能に
2021年04月07日 - ソフト内組み込み用スクリプトエンジン&言語「 Vnano 」がオープンベータ版に移行し、併せて、VCSSLの実行環境でもVnanoコードの実行が可能になりました。詳細をお知らせします。

リニアングラフの最新版をリリース、2D版でも描画エンジンの直接操作が可能に
2021年04月03日 - リニアングラフ2D/3Dの最新版をリリースしました。それぞれのアップデート内容をお知らせします。今回から、2D版でもJava言語APIによる描画エンジンの直接操作が可能になりました。

RINPn のオープンベータ版をリリース! 詳細な公式ガイドも同梱&公開
2021年03月08日 - 2019年より開発進行中のプログラム関数電卓「 RINPn(りんぷん)」が、正式リリースに向けた最終準備段階として、オープンベータ版へと移行しました。その詳細をお知らせします。

コードアーカイブ新着
[公式ガイドサンプル] 引き算の結果を画面に表示する

「VCSSLスタートアップガイド」内のサンプルコードです。引き算を行って、結果を画面に表示します。
2021年07月08日
[公式ガイドサンプル] 式を複数行にわたって書く

「VCSSLスタートアップガイド」内のサンプルコードです。足し算を行う式を、複数行にわたって記述します。
2021年07月07日
[公式ガイドサンプル] 足し算の結果を画面に表示する

「VCSSLスタートアップガイド」内のサンプルコードです。足し算の結果を求めて、画面に表示します。
2021年07月06日
Vnano版 | ローレンツ方程式を数値的に解くプログラム

ローレンツ方程式を4次ルンゲ=クッタ法によって解き、グラフ描画用のデータを出力するプログラムです。
2021年02月12日
Vnano版 | 積分値のグラフ描画用データを出力するプログラム

数値的に積分を行い、結果の関数をグラフに描くためのデータを出力するコードです。
2020年12月20日
新着・お知らせ配信用Twitter