JP2020079943A - Program creation assisting system, method therefore, and program therefor - Google Patents

Program creation assisting system, method therefore, and program therefor Download PDF

Info

Publication number
JP2020079943A
JP2020079943A JP2020001314A JP2020001314A JP2020079943A JP 2020079943 A JP2020079943 A JP 2020079943A JP 2020001314 A JP2020001314 A JP 2020001314A JP 2020001314 A JP2020001314 A JP 2020001314A JP 2020079943 A JP2020079943 A JP 2020079943A
Authority
JP
Japan
Prior art keywords
program
image
chips
chip
curriculum
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2020001314A
Other languages
Japanese (ja)
Other versions
JP6815052B2 (en
Inventor
賢一 飛坐
Kenichi Hiza
賢一 飛坐
章 大木
Akira Oki
章 大木
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Office Zero LLC
Original Assignee
Office Zero LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Office Zero LLC filed Critical Office Zero LLC
Priority to JP2020001314A priority Critical patent/JP6815052B2/en
Publication of JP2020079943A publication Critical patent/JP2020079943A/en
Application granted granted Critical
Publication of JP6815052B2 publication Critical patent/JP6815052B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Stored Programmes (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Electrically Operated Instructional Devices (AREA)

Abstract

To enable program creation to be learned by a simple procedure.SOLUTION: When creating a program, there are prepared a start chip having visible characteristic and arranged at a start position and a plurality of operation chips that define operation. A user arranges the start chip and the plurality of operation chips in a row and form a chip array. A program creation assisting system comprises a table for managing instructions to the plurality of operation chips, an image processing unit for recognizing from the image of the chip array having been acquired by a camera, the images of the plurality of operation chips following the image of the start chip, and a program creation processing unit for specifying instructions on the basis of the table with respect to the images of the plurality of operation chips recognized by the image processing unit and creating a program composed of a plurality of specified instructions.SELECTED DRAWING: Figure 1

Description

本発明は、プログラム作成支援システム及びその方法並びにそのプログラムに係り、特にプログラミング学習に好適なプログラム作成の支援技術に関するものである。   The present invention relates to a program creation support system and method, and a program therefor, and more particularly to a program creation support technique suitable for programming learning.

AI(人工知能)や情報技術(IT)の発展に伴い、IT技術者の不足が予想され、プログラミング人材育成の重要性が叫ばれている。プログラミング人材育成ための対応の1つとして、我が国では、文部科学省が子供向けのプログラミング教育の重要性を提唱し、2020年から小学校でプログラミング教育が必須となった。既に、子供向けのプログラミング教育のシステムや教育治具、玩具等がいろいろと提案されており、なかには実用化されているものもある。   With the development of AI (artificial intelligence) and information technology (IT), a shortage of IT engineers is expected, and the importance of training human resources for programming is being emphasized. In Japan, the Ministry of Education, Culture, Sports, Science and Technology has advocated the importance of programming education for children as one of the measures for developing human resources for programming, and programming education became essential in elementary schools from 2020. Various programming education systems for children, educational jigs, toys, etc. have already been proposed, and some of them have been put to practical use.

その一つとして、コンピュータやインターネットを利用した初級者向けのプログラミング教育支援が提唱されている。例えば、特許文献1には、学習者用クライアントと、学習管理者用クライアントと、学習管理サーバを、ネットワークを通して接続して、学習者による課題の解答過程をオンラインでリアルタイムに把握してデータベース化し、記録したデータを基に任意の時間軸で解答過程を再現したりグラフによる可視化を行ったりして、各学習者のプログラミング習熟度を容易にかつ的確に把握できるプログラミング教育支援システムが開示されている。   As one of them, support for programming education for beginners using computers and the Internet has been proposed. For example, in patent document 1, a client for a learner, a client for a learning manager, and a learning management server are connected through a network, and a process of answering a task by a learner is grasped online in real time to form a database, A programming education support system that can easily and accurately grasp the programming proficiency of each learner by reproducing the answering process on any time axis based on the recorded data and visualizing it with a graph is disclosed. ..

また、非特許文献1には、文部科学省が開発した「プログラミン」と称する子供向けのサービスとして、表示装置の画面にマウスを操作しながら、複数の絵(ブロック)を組み合わせることでプログラムを組み上げる、コンピュータを利用した子供向けのプログラミングが開示されている。更に、非特許文献2には、ARマーカによる画像認識を用いてプログラムを作成してロボットを動作させる技術が開示されている。これは、ARマーカとなる画像が書かれた「どうさカード」と「じょうけんカード」を交互に並べたものを、タブレットで撮影することによりロボットにプログラムを自動転送する、としている。   Further, in Non-Patent Document 1, as a service for children called "programin" developed by the Ministry of Education, Culture, Sports, Science and Technology, a program is assembled by combining a plurality of pictures (blocks) while operating a mouse on the screen of a display device. , Programming for children using a computer is disclosed. Further, Non-Patent Document 2 discloses a technique of operating a robot by creating a program using image recognition by an AR marker. This is to automatically transfer the program to the robot by taking a picture of a tablet in which "Dosa card" and "Joken card" on which an image serving as an AR marker is written are alternately arranged.

特開2006−227218公報JP, 2006-227218, A

文部科学省「プログラミン」2013年10月22日 http://www.mext.go.jp/programin/Ministry of Education, Culture, Sports, Science and Technology "Programin" October 22, 2013 http://www.mext.go.jp/programin/ 原槙稔幸,「子ども向け科学実験教室におけるプログラミング体験への拡張現実の導入に関する検討」,情報処理学会第75回(平成25年)全国大会講演論文集(4),一般社団法人情報処理学会,2013年3月6日,第385〜386頁Toshiyuki Hara, “Study on introducing augmented reality into programming experience in science experiment classroom for children”, Proc. of the 75th IPSJ National Congress (4), IPSJ, March 6, 2013, pp. 385-386

上記特許文献1に記載の技術は、学習管理サーバが学習者のプログラミング習熟度を容易にかつ的確に把握することを主題としており、如何にして学習者にプログラムを作成させるか、については詳述されていない。   The technique described in the above-mentioned Patent Document 1 is intended for the learning management server to easily and accurately grasp the degree of programming proficiency of the learner, and a detailed description will be given on how the learner creates a program. It has not been.

また、非特許文献1で紹介されているプログラミングは画面上で操作するため、パソコン(PC)等の使用が前提となる。学校の授業でプログラミング学習を行うとなると、生徒数に応じたPCが必要となるので相当の費用がかかり、更に生徒はPCの画面を操作するための基本的な操作を習得する必要がある。また、非特許文献2にはARマーカが記載されたカードをタブレットで撮影してプログラミングするという概念が開示されているが、子供たちがプログラミングし易くするための具体的な課題や技術的手段の示唆がない。
そこで、余り費用がかからず、とりわけ子供が簡便にプログラムの作成を学習することができる仕組みないし教材が望まれる。
In addition, since the programming introduced in Non-Patent Document 1 is operated on the screen, use of a personal computer (PC) or the like is a prerequisite. When programming learning is performed in a school class, a PC corresponding to the number of students is required, which requires a considerable amount of cost. Further, the student needs to learn a basic operation for operating the screen of the PC. Further, Non-Patent Document 2 discloses a concept of photographing a card on which an AR marker is described with a tablet and programming the card. However, there are specific problems and technical means for facilitating programming by children. There is no suggestion.
Therefore, there is a demand for a mechanism or teaching material that can be easily learned by children, at a low cost.

本発明の目的は、簡便な手法によってプログラムの作成ができるプログラム作成支援システム及びその方法並びにそのプログラムを提供することにある。   An object of the present invention is to provide a program creation support system, a method therefor, and a program therefor capable of creating a program by a simple method.

本発明に係るプログラム作成支援システムは、好ましくは、コンピュータを用いて、プログラムの作成を支援するプログラム作成支援システムであって、
それぞれ視認特性を有する、開始位置に配置されるスタートチップと、動作を規定する複数の動作チップと、を含む複数のチップと、
前記複数の動作チップに対応する命令を管理するテーブルと、
並べられた、前記スタートチップと、前記複数の動作チップにより形成されるチップ配列の画像を取得する画像取得手段と、
前記画像取得手段で取得される前記チップ配列の画像から、前記スタートチップの画像以降にある、前記複数の動作チップの画像を認識する画像処理部と、
前記画像処理部で認識される前記複数の動作チップの画像について、前記テーブルを参照して命令を特定し、特定された複数の命令から構成されるプログラムを生成するプログラム作成処理部と、を有することを特徴とするプログラム作成支援システム、として把握される。
本発明はまた、上記プログラム作成支援システムで実現されるプログラム作成支援方法、及びプログラム作成支援用プログラムとしても把握される。
The program creation support system according to the present invention is preferably a program creation support system for supporting the creation of a program using a computer,
A plurality of chips each including a start chip arranged at a start position and having a plurality of operation chips that define an operation, each chip having a visual characteristic;
A table for managing instructions corresponding to the plurality of operation chips;
An image acquisition unit that acquires an image of a chip array formed by the start chips and the plurality of operation chips that are arranged,
From the image of the chip array acquired by the image acquisition means, an image processing unit that recognizes images of the plurality of operation chips, which are subsequent to the image of the start chip,
A program creation processing unit that specifies an instruction with respect to the images of the plurality of operation chips recognized by the image processing unit and refers to the table, and generates a program including the plurality of specified instructions. It is understood as a program creation support system characterized by that.
The present invention is also understood as a program creation support method and a program creation support program realized by the above program creation support system.

本発明によれば、簡便な手法によってプログラムの作成が可能となる。   According to the present invention, it is possible to create a program by a simple method.

実施例1によるプログラム作成支援システムの構成を示す図である。FIG. 1 is a diagram showing a configuration of a program creation support system according to a first embodiment. 携帯端末の構成例を示す図である。It is a figure which shows the structural example of a portable terminal. プログラムシートの例を示す図である。It is a figure which shows the example of a program sheet. プログラムの作成に用いられるチップの例を示す図である。It is a figure which shows the example of the chip used for creation of a program. プログラム命令の例を示す図である。It is a figure which shows the example of a program instruction. プログラム命令の例を示す図である。It is a figure which shows the example of a program instruction. プログラム作成におけるチップの配列例を示す図である。It is a figure which shows the example of arrangement|positioning of the chip in program creation. プログラム作成におけるチップの配列例を示す図である。It is a figure which shows the example of arrangement|positioning of the chip in program creation. プログラム作成におけるチップの配列例を示す図である。It is a figure which shows the example of arrangement|positioning of the chip in program creation. カリキュラム管理テーブルの構成例を示す図である。It is a figure which shows the structural example of a curriculum management table. ユーザ管理テーブルの構成例を示す図である。It is a figure which shows the structural example of a user management table. 先生管理テーブルの構成例を示す図である。It is a figure which shows the structural example of a teacher management table. プログラム管理テーブルの構成例を示す図である。It is a figure which shows the structural example of a program management table. プログラム作成の概略的な動作を示すフローチャートである。It is a flow chart which shows a rough operation of program creation. プログラム作成の処理動作を示すフローチャートである。It is a flow chart which shows processing operation of program creation. プログラム作成の処理動作を示すフローチャートである。It is a flow chart which shows processing operation of program creation. 携帯端末の画面表示の例を示す図である。It is a figure which shows the example of a screen display of a portable terminal. プログラム作成支援システムの接続構成を示す図である。It is a figure which shows the connection structure of a program creation assistance system. 実施例3によるプログラム作成の概略的な動作を示すフローチャートである。9 is a flowchart showing a schematic operation of creating a program according to the third embodiment. 実施例7において用いられる課題シートの例を示す図である。FIG. 13 is a diagram showing an example of a task sheet used in Example 7. 実施例7において用いられるプログラムシートの例を示す図である。FIG. 16 is a diagram showing an example of a program sheet used in Example 7. 実施例8において用いられるチップの例を示す図である。FIG. 16 is a diagram showing an example of a chip used in Example 8. 実施例8におけるチップの配列例を示す図である。FIG. 16 is a diagram showing an example of the arrangement of chips in Example 8. 実施例8におけるチップの配列例を示す図である。FIG. 16 is a diagram showing an example of the arrangement of chips in Example 8.

本発明の好ましい例は、コンピュータを用いたプログラム作成支援システムにより実現される。予め命令の定義された、絵柄の描かれた複数のチップと、チップを並べる所定のシートが用意される。ユーザは、目的に従って複数のチップを選択的にシート上に並べる。このチップの配列を、スマートフォンのような携帯端末が備えるカメラで撮影する。プログラム作成支援システムにおける処理装置(例えばサーバ)が、カメラで取得されたチップの配列の画像から各チップの絵柄の画像を認識してプログラムを構成する命令コードを特定し、命令コードの配列からプログラムデータを作成する。作成されたプログラムデータは携帯端末へ送信されて実行される。プログラムの実行は例えば携帯端末の表示部の画面にキャラクタの動画として表示される。   A preferred example of the present invention is realized by a program creation support system using a computer. A plurality of chips on which pictures are drawn, in which commands are defined in advance, and a predetermined sheet on which the chips are arranged are prepared. The user selectively arranges the plurality of chips on the sheet according to the purpose. The chip array is photographed by a camera provided in a mobile terminal such as a smartphone. A processing device (for example, a server) in the program creation support system recognizes an image of a picture of each chip from an image of an array of chips acquired by a camera, identifies an instruction code that constitutes the program, and the program from the array of instruction codes. Create the data. The created program data is transmitted to the mobile terminal and executed. The execution of the program is displayed as a moving image of the character on the screen of the display unit of the mobile terminal, for example.

好ましい例によれば、ユーザが多数の生徒から成る学校の授業において、先生が所持する1台の携帯端末があればプログラム作成の授業が可能となる。即ち、各生徒がチップの配列を終了する度に、携帯端末のカメラでチップの配列を撮影して、その画像をサーバへ送信して、サーバでプログラムを作成する。そして、プログラムの実行はその都度、携帯端末の画面で動画として見ることができるので、生徒ごとにプログラムの出来ばえが確認できる。   According to a preferred example, in a class at a school where the user is composed of a large number of students, if there is one mobile terminal possessed by the teacher, a class for creating a program becomes possible. That is, each time each student finishes the chip arrangement, the camera of the mobile terminal photographs the chip arrangement, the image is transmitted to the server, and the server creates the program. Each time the program is executed, it can be viewed as a video on the screen of the mobile terminal, so that the performance of the program can be confirmed for each student.

本発明の好ましい例によれば、ユーザが1人でPCの画面を操作しながらプログラムを作成するというプログラム作成作業に比べて、シート上にチップを並べるという簡単な作業によってプログラムを作成することができる。そのため、プログラムの作成手順の習得が容易であり、プログラムの作成を教える先生も生徒も過度の負担が少ない。また、ユーザ1人1人にPCを用意する必要がないので多人数が同時に学習する場面に向いている。また、ユーザ毎にチップとシートのセットを用意することで対応できるので、低コストで実現できる。   According to a preferred example of the present invention, a program can be created by a simple operation of arranging chips on a sheet, as compared with a program creating operation in which a user creates a program while operating a screen of a PC alone. it can. Therefore, it is easy to learn the procedure for creating the program, and the teacher and the student who teach the program are not overloaded. Moreover, since it is not necessary to prepare a PC for each user, it is suitable for a situation in which a large number of people study at the same time. Further, since it is possible to deal with this by preparing a set of chips and sheets for each user, it is possible to realize at low cost.

以下、図面を参照して、本発明の一実施例について詳細に説明する。
図1は、プログラム作成支援システムの全体構成例を示す。
プログラム作成支援システムは、プログラムの作成を支援するサーバ1と、ユーザが使用する複数の携帯端末2とが、通信ネットワーク9を介して接続して構成される。
An embodiment of the present invention will be described in detail below with reference to the drawings.
FIG. 1 shows an example of the overall configuration of a program creation support system.
The program creation support system is configured by connecting a server 1 that supports the creation of a program and a plurality of mobile terminals 2 used by a user via a communication network 9.

サーバ1は、利用者の情報を管理し、携帯端末との間でデータ通信し、プログラムを作成し実行する等、の種々のデータ処理を行うコンピュータである。その機能及び処理の詳細については後述する。なお、サーバ1のハードウェア構成は図示していないが、プログラムを実行する処理装置(プロセッサ)、メモリ、ハードディスクのような外部記憶装置、入力器、表示器等のハードウェア資源を有する。   The server 1 is a computer that manages user information, performs data communication with a mobile terminal, creates and executes programs, and performs various types of data processing. Details of the function and processing will be described later. Although the hardware configuration of the server 1 is not shown, the server 1 has hardware resources such as a processing device (processor) that executes a program, a memory, an external storage device such as a hard disk, an input device, and a display device.

プログラムの作成を支援するために、サーバ1は、携帯端末2のユーザや作業者の情報を登録して管理する情報管理部102と、プログラムを作成するプログラム作成処理部103と、プログラムの作成に際してチップの画像を認識する画像処理部104を有する。また、データベース(DB)として、ユーザの情報やプログラミング学習の利用に関する種々の管理情報を登録する管理情報DB105と、プログラム作成に関する情報を記憶するプログラムDB106を有する。これらの処理部及びDBの構成や機能については後で詳述する。なお図示の例では、管理情報DB105とプログラムDB106とを別のDBとして構成しているが、これらは1つのDBで構成してもよい。   In order to support the creation of the program, the server 1 includes an information management unit 102 that registers and manages information about users and workers of the mobile terminal 2, a program creation processing unit 103 that creates the program, and a program creation process unit 103. It has an image processing unit 104 that recognizes an image of a chip. Further, as a database (DB), it has a management information DB 105 for registering user information and various management information regarding the use of programming learning, and a program DB 106 for storing information regarding program creation. The configurations and functions of these processing units and DBs will be described later in detail. Although the management information DB 105 and the program DB 106 are configured as separate DBs in the illustrated example, they may be configured as a single DB.

サーバ1はプログラム作成支援のためのサイトを有しており、携帯端末2からこのサイトに接続することで、プログラム作成支援を受けることができる。
携帯端末2は、例えばスマートフォン(以下単にスマホという)のような端末である。携帯端末2のハードウェア構成については、図2を参照して後述する。
The server 1 has a site for supporting program creation, and by connecting to this site from the mobile terminal 2, it is possible to receive program creation support.
The mobile terminal 2 is a terminal such as a smartphone (hereinafter simply referred to as a smartphone). The hardware configuration of the mobile terminal 2 will be described later with reference to FIG.

図2は、携帯端末2のハードウェア構成を示す。
携帯端末2は、例えばスマートフォン(以下単にスマホという)のような携帯端末であり、種々のアプリケーションプログラム等を実行するプロセッサ(CPU)202と、データやプログラムを格納するメモリ203と、画面タッチ式の入力部204と、画面を表示する表示部205と、撮影機能であるカメラ206と、二次元バーコードを読み取るバーコードリーダ207と、ネットワーク9を通してサーバ1とデータ通信を行うネットワーク接続部208とを有する。スマホはインターネットを通して多くのサイトと接続することができて、ユーザが希望するアプリケーションをCPU202が実行する。また、スマホは上記以外に例えば音声入出力機能を始め種々の機能を有している。
FIG. 2 shows a hardware configuration of the mobile terminal 2.
The mobile terminal 2 is a mobile terminal such as a smartphone (hereinafter, simply referred to as a smartphone), and includes a processor (CPU) 202 that executes various application programs, a memory 203 that stores data and programs, and a screen touch type. An input unit 204, a display unit 205 that displays a screen, a camera 206 that is a photographing function, a barcode reader 207 that reads a two-dimensional barcode, and a network connection unit 208 that performs data communication with the server 1 through the network 9. Have. The smartphone can connect to many sites via the Internet, and the CPU 202 executes an application desired by the user. In addition to the above, the smartphone has various functions such as a voice input/output function.

[プログラムシート及びチップ]
図3は、プログラムシートの例を示す。
プログラムシート(以下単にシートという)30は、プログラムの作成に用いられる、例えばA4サイズの用紙である。学校の授業では、予め印刷されたシート30を先生が各生徒に配布する。シート30は普通の紙製というよりも、生徒が何回も使用できて、チップの配置に耐えられるように、プラスチック製が好ましい。
[Program sheets and chips]
FIG. 3 shows an example of a program sheet.
The program sheet (hereinafter simply referred to as a sheet) 30 is, for example, an A4 size sheet used for creating a program. In school lessons, the teacher distributes the preprinted sheet 30 to each student. The sheet 30 is preferably made of plastic rather than plain paper so that it can be used multiple times by the student and can withstand the placement of chips.

シート30の中央の広いスペースにはプログラムエリア302が確保される。シート30の上端にはタイトル301が印刷され、右上端には二次元バーコードを含む識別部305が印刷されている。タイトル301は例えばカリキュラムの名称である。識別部305の二次元バーコードはカリキュラムを識別するための識別情報を含んでいる。   A program area 302 is secured in a large space in the center of the seat 30. A title 301 is printed on the upper end of the sheet 30, and an identification unit 305 including a two-dimensional barcode is printed on the upper right end. The title 301 is, for example, the name of a curriculum. The two-dimensional barcode of the identification unit 305 includes identification information for identifying the curriculum.

プログラムエリア302には、複数の縦線と横線によりマトリクス状の罫線が印刷され、更にその左上端には、「スタート」マーク303が印刷され、そこから下へ向かって太い縦線のガイドライン304が印刷されている。マトリックス線やガイドライン304はチップを配列する案内となる。マトリクス状の縦線と横線はチップ絵柄の画像処理においてX/Y座標となる。シート30の原情報は画像としてプログラムDB106に記憶されている。   In the program area 302, a matrix of ruled lines is printed by a plurality of vertical lines and horizontal lines, and a "start" mark 303 is printed at the upper left corner of the program line 302. It is printed. The matrix line and the guideline 304 serve as a guide for arranging the chips. The vertical and horizontal lines in a matrix form the X/Y coordinates in the image processing of the chip pattern. The original information of the sheet 30 is stored as an image in the program DB 106.

作業者である生徒は、ガイドライン304に沿って上から下へ向かってチップを配置していく。またある時は、マトリックス線に沿って左から右へチップを配置していく。図7Aから図7Cに、シート30に複数のチップ40を配置した例を示す。   The student who is the worker arranges the chips from the top to the bottom along the guideline 304. At other times, the chips are arranged from left to right along the matrix line. 7A to 7C show an example in which a plurality of chips 40 are arranged on the sheet 30.

図4は、プログラムの作成に用いられるチップの例を示す。
チップ40は、プログラムの命令が定義付けられた表示子である。例えば、命令の動作を絵柄で表現(印刷)した、縦2cm×横5cmほどのプラスチック製矩形片である。それぞれの絵柄は命令ごとに相違する。チップ40は、シート30上に容易に固定できて容易に剥がれるように、その裏面に簡易的な粘着材が形成されているのが好ましい。なお、チップ40の絵柄の原情報は画像としてプログラムDB106に記憶されている。
FIG. 4 shows an example of a chip used for creating a program.
The chip 40 is an indicator in which the instructions of the program are defined. For example, it is a plastic rectangular piece measuring about 2 cm in length and 5 cm in width, which expresses (prints) the operation of the command by a pattern. Each picture differs for each command. The chip 40 is preferably formed with a simple adhesive material on its back surface so that it can be easily fixed on the sheet 30 and easily peeled off. The original information of the design of the chip 40 is stored in the program DB 106 as an image.

図4には17種類のチップの例が示されているが、命令の種類に応じてチップを更に増やすことができる。配布用の複数のチップ40をチップセットということにする。シート30やチップセット40は、ユーザからの要求に応じてユーザへ販売、発送される。なお、携帯端末2からの要求に応じて、サーバ1が、指定されたプリンタにシート30やチップセット40を印刷するサービスとすることもできる。   Although FIG. 4 shows an example of 17 types of chips, the number of chips can be further increased according to the type of instruction. The plurality of chips 40 for distribution will be referred to as a chip set. The sheet 30 and the chip set 40 are sold and shipped to the user in response to the request from the user. It should be noted that the server 1 may be a service for printing the sheet 30 or the chipset 40 on a designated printer in response to a request from the mobile terminal 2.

[プログラム命令の例]
図5は、プログラム命令の例(命令リスト)を示す。
プログラム命令は、表示・動きを表す9つの命令(動作命令)と、制御文を表す2つの命令(制御命令)と、入出力を表す4つの命令(入出力命令)と、パラメータ即ち1から9までの数値を表す命令(パラメータ)と、その他の4つの命令から構成される。
[Example of program instruction]
FIG. 5 shows an example of program instructions (instruction list).
The program commands include nine commands (motion commands) that represent display/motion, two commands (control commands) that represent control statements, four commands (input/output commands) that represent input/output, and parameters, that is, 1 to 9 It is composed of commands (parameters) representing the numerical values up to and other four commands.

各チップと命令は一意に対応しており、チップの絵柄と、命令の名称、命令動作、パラメータの関係は図示の通りである。備考は参考的な説明を表す。例えば、動作命令において、右向きの絵(図5の一番目にある「動く:方向付き」命令)は、「指定された方向へ移動」を表す命令であり、この矢印が右へ向いているときは右へ移動、左を向いているときは左へ移動、を表す。パラメータは動作命令の回数や向き、番号等を表す。命令との関係において、パラメータの指定が可能な命令についてパラメータの設定を可能とする。例えば、「動く:方向付き」命令はパラメータの回数設定が可能であるが、「拾う」命令はパラメータの設定ができない。   Each chip uniquely corresponds to an instruction, and the relationship between the picture of the chip, the instruction name, the instruction operation, and the parameter is as shown in the drawing. Remarks represent reference explanations. For example, in the motion command, the picture pointing to the right (the “move: with direction” command at the first position in FIG. 5) is a command indicating “move in the specified direction”, and when this arrow points to the right Indicates moving to the right and moving to the left when facing left. The parameter represents the number, direction, number, etc. of operation commands. In relation to the instruction, the parameter can be set for the instruction for which the parameter can be specified. For example, the "move: with direction" command can set the number of parameters, but the "pick up" command cannot set the parameter.

図6に例示するように、右向きの絵「動く:方向付き」命令で、パラメータが「3」のときは、「右へ3回動く」を意味する。ここで、ある命令を表す1つのチップ401の配列は必須であり、パラメータ402の配列は任意である。パラメータ402は命令の種類やその実行レベルに応じて変わる。   As illustrated in FIG. 6, a rightward picture “move: with direction” command means that “3 turns to the right” when the parameter is “3”. Here, the arrangement of one chip 401 representing a certain instruction is indispensable, and the arrangement of the parameter 402 is arbitrary. The parameter 402 changes depending on the type of instruction and its execution level.

なお、「その他」の命令において、「START」の命令は、シート30に「スタート」が印刷されている場合は使用されない。「END」の命令は、チップ配列の最後に配置される。演算子や条件文の命令は用意されているが、カリキュラムの内容によっては使用されない場合がある。   Note that, in the “other” command, the “START” command is not used when the “start” is printed on the sheet 30. The “END” instruction is placed at the end of the chip array. Instructions for operators and conditional statements are provided, but may not be used depending on the content of the curriculum.

これら命令の、チップの絵柄(即ち絵柄の画像)と、動作等を示す名称と、動作の関係は、対応表である命令テーブル(符号50で示す)に定義されてプログラムDB106に記憶されている。ここで、命令テーブル50の画面表示の例は図5のようになるが、プログラムDB106に保管される命令テーブル50には、絵柄の画像に対応した固有のコードデータ(命令コード)が含まれる。   The relationship between the pattern of the chip (namely, the image of the pattern), the name indicating the motion, and the motion of these commands is defined in a command table (indicated by reference numeral 50) which is a correspondence table and stored in the program DB 106. .. Here, an example of the screen display of the command table 50 is as shown in FIG. 5, but the command table 50 stored in the program DB 106 includes unique code data (command code) corresponding to the image of the picture.

一例では、カリキュラムに応じてこの命令テーブル50から複数の命令(命令セットという)が選択される。また、新たなチップの絵柄や新たな命令を規定した場合や、既定の絵柄を削除又は変更したい場合には、命令テーブル50の内容を変更することができる。それは、サーバ1が有する入力器(図示せず)又は携帯端末2からの管理者の入力指示によって、命令テーブル50におけるチップの絵柄と命令との対応関係を変更することができる。   In one example, a plurality of instructions (referred to as an instruction set) are selected from the instruction table 50 according to the curriculum. Further, the content of the instruction table 50 can be changed when a new pattern of a chip or a new command is specified, or when a predetermined pattern is to be deleted or changed. It is possible to change the correspondence relationship between the pattern of the chip and the command in the command table 50 by an input instruction (not shown) of the server 1 or an administrator's input instruction from the mobile terminal 2.

[各種のテーブルの説明]
次に、図8乃至図11を参照して、プログラム作成支援のために使用される各種のテーブルの構成について説明する。各テーブル80〜110は、管理情報DB105に記憶される。
[Description of various tables]
Next, the configurations of various tables used for supporting the program creation will be described with reference to FIGS. The tables 80 to 110 are stored in the management information DB 105.

図8は、カリキュラム管理テーブルの構成例を示す。
カリキュラム管理テーブル80は、ユーザに提供するプログラム作成のカリキュラム、及び当該カリキュラムに使用される命令を管理するテーブルである。ここで、カリキュラムとはユーザがプログラミングするための課題或いは問題と言ってもよい。カリキュラムと、カリキュラムに対応する具体的な課題内容と、当該カリキュラムにおいて使用されるシートとは関連付けられている。これについては、図15を参照して後述する。
FIG. 8 shows a configuration example of the curriculum management table.
The curriculum management table 80 is a table that manages a curriculum for creating a program to be provided to the user and a command used for the curriculum. Here, the curriculum may be called a task or a problem for the user to program. The curriculum, the specific content of the tasks corresponding to the curriculum, and the sheets used in the curriculum are associated with each other. This will be described later with reference to FIG.

カリキュラム管理テーブル80は、カリキュラムを識別するカリキュラム番号と、当該カリキュラムによるアプリケーションを実行するアドレスと、当該アプリケーションにおいて使用されるキャラクタを表すキャラクタセットと、命令テーブル50から選択された、当該カリキュラムで使用する全ての命令の参照番号(命令テーブル50の参照番号)とを登録する。ここで、アプリケーションとは、カリキュラムの選択から始まって、携帯端末2によってシート及びチップ配列の画像を取り込む処理、及びプログラムの作成処理に至る一連の処理を行うプログラムである。キャラクタとは、プログラムの実行において動画として使用される登場者であり例えばウサギや亀の画像、有名なアニメの画像である。   The curriculum management table 80 is used in the curriculum selected from the instruction table 50, a curriculum number for identifying the curriculum, an address for executing an application according to the curriculum, a character set representing a character used in the application. The reference numbers (reference numbers of the instruction table 50) of all instructions are registered. Here, the application is a program that performs a series of processes starting from the selection of the curriculum, the process of capturing the image of the sheet and the chip array by the mobile terminal 2, and the process of creating the program. The character is a person who is used as a moving image in the execution of the program, and is, for example, an image of a rabbit or a turtle, or an image of a famous anime.

また、当該カリキュラムで使用する全ての命令の参照番号を命令セットに登録する理由はプログラム作成処理を速くするためである。即ち、プログラム作成処理に際して、命令テーブル50を参照しながらチップ配列の画像から個々のチップの画像を認識する処理を行うが、このときに命令テーブル50に登録された全てのチップ画像をスキャンすると多大な時間がかかる。これに対して、命令セットに登録された参照番号に対応する命令を対象にスキャンすれば、画像の認識にかかる時間は大幅に短くなる。   The reason why the reference numbers of all the instructions used in the curriculum are registered in the instruction set is to speed up the program creation process. That is, in the program creation process, the image of each chip is recognized from the image of the chip array while referring to the instruction table 50. However, if all the chip images registered in the instruction table 50 are scanned at this time, it is very difficult. It takes a long time. On the other hand, if the instruction corresponding to the reference number registered in the instruction set is scanned, the time required for image recognition is significantly shortened.

図9は、ユーザ管理テーブルの構成例を示す。
ユーザ管理テーブル90は、プログラムを作成するユーザの情報を管理するテーブルである。ユーザ管理テーブル90は、ユーザの識別IDである識別情報と、ユーザの名前と、プログラムデータを記憶しているアドレスを示すプログラムデータ格納先インデックス(ID)と、カリキュラム識別情報として、カリキュラム管理テーブル80から選択されて利用されるカリキュラム番号と、更新日時と、個人情報としてユーザが所有する携帯端末のメールアドレス等、を登録する。カリキュラム識別情報には、過去に利用したカリキュラム番号がログとして逐次登録されていく。この例では、プログラムデータ格納先IDは、作成されたプログラムデータを管理するプログラム管理テーブル110のアドレス或いはプログラム管理テーブル110を指定する情報を表す。
FIG. 9 shows a configuration example of the user management table.
The user management table 90 is a table for managing information on users who create programs. The user management table 90 includes identification information which is an identification ID of the user, a name of the user, a program data storage index (ID) indicating an address storing program data, and a curriculum management table 80 as curriculum identification information. The curriculum number selected and used from, the update date and time, and the mail address of the mobile terminal owned by the user as personal information are registered. The curriculum number used in the past is sequentially registered as a log in the curriculum identification information. In this example, the program data storage destination ID represents the address of the program management table 110 that manages the created program data or information that specifies the program management table 110.

学校の授業や団体でプログラム学習をする場合には、先生が所持する携帯端末2を用いてサーバ1とデータ通信するので、先生管理テーブル100が主に使用される。そのため、ユーザとしては、ユーザ管理テーブル90に生徒を識別するIDを含む生徒に関する情報を登録しなくてもよい。これに対して全ての生徒が携帯端末2を有していて、各人が独立してプログラム作成を行う場合にはユーザ管理テーブル90に全ての生徒のユーザ情報を登録する。   When conducting a program study in a school class or in a group, the teacher management table 100 is mainly used because data communication is performed with the server 1 using the mobile terminal 2 owned by the teacher. Therefore, the user does not have to register the information about the student including the ID for identifying the student in the user management table 90. On the other hand, when all the students have the mobile terminal 2 and each person independently creates a program, the user information of all the students is registered in the user management table 90.

図10は、先生管理テーブルの構成例を示す。
先生管理テーブル100は、学校の授業でプログラム学習をする場合、先生及びクラスを構成する生徒に関する情報を管理するテーブルである。先生管理テーブル100は、先生を識別する先生IDと、先生の名前と、プログラムデータを記憶しているアドレスを示すプログラムデータ格納先インデックス(ID)と、カリキュラム識別情報として、カリキュラム管理テーブルから選択されて利用されるカリキュラム番号と、ユーザ識別情報としてクラスの生徒識別IDと、個人情報としての先生が所有する携帯端末のメールアドレス等、を登録する。ユーザ識別情報にはクラスを構成する全ての複数の生徒IDが登録される。カリキュラム識別情報には、過去に利用したカリキュラム番号がログとして逐次登録されていく。
FIG. 10 shows a configuration example of the teacher management table.
The teacher management table 100 is a table for managing information about teachers and students who make up classes when conducting program learning in a school lesson. The teacher management table 100 is selected from the teacher ID for identifying the teacher, the teacher's name, the program data storage index (ID) indicating the address storing the program data, and the curriculum management table as the curriculum identification information. A curriculum number used as a user ID, a student identification ID of a class as user identification information, and an e-mail address of a mobile terminal owned by a teacher as personal information are registered. All the plurality of student IDs constituting the class are registered in the user identification information. The curriculum number used in the past is sequentially registered as a log in the curriculum identification information.

図11は、プログラム管理テーブルの構成例を示す。
プログラム管理テーブル110は、作成されたプログラムに関する情報を管理するテーブルである。プログラム管理テーブル110は、プログラムを作成したユーザ識別IDと、カリキュラム番号と、作成されたプログラムデータと、プログラムの登録日時と、その修正日時と、を登録する。本実施例では、ユーザ識別IDには生徒識別IDが登録されることになる。プログラムデータとは、作成されたプログラムそのものであり、複数行のプログラムステップの場合その行数分が登録される。
FIG. 11 shows a configuration example of the program management table.
The program management table 110 is a table that manages information about created programs. The program management table 110 registers the user identification ID of the program, the curriculum number, the created program data, the program registration date and time, and the modification date and time. In this embodiment, the student identification ID is registered as the user identification ID. The program data is the created program itself, and in the case of a program step of a plurality of lines, the number of lines is registered.

[プログラム作成の概略動作]
次に、図12を参照して、プログラム作成の概略的な動作について説明する。
この例は、携帯端末2を所持している先生が、複数の生徒に対してプログラミングの授業を行う場合のフローを示している。図中、実線で示すステップは携帯端末又はサーバによる処理動作を表し、点線で示すステップは人間(先生又は生徒)の動作を表す。
[Outline of program creation]
Next, with reference to FIG. 12, a schematic operation of creating a program will be described.
This example shows a flow in the case where a teacher who has the mobile terminal 2 gives a programming lesson to a plurality of students. In the figure, steps indicated by solid lines represent processing operations by the mobile terminal or the server, and steps indicated by dotted lines represent human (teacher or student) operations.

まず、先生は携帯端末2を操作してアカウントとパスワードを入力してログインを行う(S1201)。そして、携帯端末2はネットワーク9を介してサーバ1と接続され、本件のプログラム作成のサイトに接続される。すると、携帯端末2にはカリキュラム選択用の画面が表示部205に表示される。先生は、表示された画面から目的のカリキュラムを選択する(S1202)。   First, the teacher operates the mobile terminal 2 to input an account and a password to log in (S1201). Then, the mobile terminal 2 is connected to the server 1 via the network 9 and is connected to the program creation site of the present case. Then, a screen for curriculum selection is displayed on the display unit 205 of the mobile terminal 2. The teacher selects a desired curriculum from the displayed screen (S1202).

ここで、カリキュラムの選択からシート30の用意までの動作について説明する。カリキュラムの選択は、図15(A)に示すような、カリキュラム一覧表の画面が携帯端末2の表示部205に表示される。先生は、表示されたカリキュラム一覧表から目的とするカリキュラム(課題)を選択する。すると、図15(B)に示すように、選択された課題の詳細を表す画面が表示される。先生は課題の詳細内容を確認して了解ならば、その画面の下にある「シート」を選択する。すると、図15(C)に示すような、当該カリキュラムに対応したシートが印刷される。シートの印刷は予め指定されたプリンタを用いて行うことができる。なお、学校の授業でプログラミングを行う場合には、授業内容を予め理解しておく必要があるので、ここまでの動作を予め完了しておき、シートを事前に準備することができる。
なお、図15(A)〜(C)に示すような、画面の情報は管理情報DB105に記憶されていて、携帯端末2の入力指示に応じて携帯端末2へ送信されて表示される。
Here, the operation from the selection of the curriculum to the preparation of the sheet 30 will be described. To select a curriculum, a screen of a curriculum list as shown in FIG. 15A is displayed on the display unit 205 of the mobile terminal 2. The teacher selects the desired curriculum (task) from the displayed curriculum list. Then, as shown in FIG. 15B, a screen showing details of the selected task is displayed. If the teacher confirms the detailed content of the assignment and is satisfied, he or she selects "Sheet" at the bottom of the screen. Then, a sheet corresponding to the curriculum as shown in FIG. 15C is printed. The printing of the sheet can be performed using a printer designated in advance. In addition, when programming is performed in a school class, it is necessary to understand the content of the class in advance. Therefore, the operation up to this point can be completed in advance and the seat can be prepared in advance.
Information on the screen as shown in FIGS. 15A to 15C is stored in the management information DB 105, and is transmitted to and displayed on the mobile terminal 2 in response to an input instruction from the mobile terminal 2.

実際のプログラミンングの授業に際して、先生は、用意されたシート30とチップセット40を複数の生徒に配布して(S1203)、プログラミングの出題をする(S1204)。出題とは、図15(B)に示された課題を説明することである。例えば、カリキュラムの「トレーニング1」に対応する設題「りんごをテーブルに置いて部屋から出ましょう」のような題目である。少し高度な出題(例えば「入門3」)としては、諸動作を一つ一つ言わずに「ウサギさんとカメさんが競争する運動会」というような設題もあり得る。   In the actual programming class, the teacher distributes the prepared sheet 30 and chipset 40 to a plurality of students (S1203) and gives a programming question (S1204). The question is to explain the problem shown in FIG. For example, a subject corresponding to “Training 1” of the curriculum, “put apples on the table and leave the room”. As a slightly more advanced question (for example, “Introduction 3”), there may be a topic such as “A sports meet where Rabbit and Turtle compete” without saying each action.

生徒は、プログラミング即ち、配布されたシート30上にチップ40を配列する作業を行う(S1211)。チップ40の配列作業の結果、例えば図7A〜図7Cのように、シート30上にチップが配列される。実験例によれば、図7A〜図7Cは、課題「りんごをテーブルに置いて部屋から出ましょう」について、複数の異なるチップの配列によって解答した例である。   The student performs programming, that is, the work of arranging the chips 40 on the distributed sheet 30 (S1211). As a result of the arrangement work of the chips 40, the chips are arranged on the sheet 30 as shown in FIGS. 7A to 7C, for example. According to the experimental example, FIGS. 7A to 7C are examples in which the problem “let's leave the apple on the table and leave the room” is solved by a plurality of different chip arrangements.

シート30上におけるチップ40の配列作業が終了すると、先生は携帯端末2のカメラ206で作業済みのチップ配列シート40を撮影して、その撮影した画像をサーバ1へ送信する(S1205)。   When the work of arranging the chips 40 on the sheet 30 is completed, the teacher takes a picture of the worked chip arrangement sheet 40 with the camera 206 of the mobile terminal 2 and sends the taken image to the server 1 (S1205).

サーバ1では、受信した画像を基にプログラム作成処理を行う(S1206)。この処理については後で詳述する。サーバ1で作成されたプログラムは携帯端末2で実行される(S1207)。   The server 1 performs a program creation process based on the received image (S1206). This processing will be described later in detail. The program created by the server 1 is executed by the mobile terminal 2 (S1207).

[プログラム作成処理]
次に、図13及び図14を参照して、プログラムの作成処理について説明する。
図13は、プログラムの作成処理の全体のフローチャートを示す。
この処理に先立って、先生の携帯端末2からサーバ1が運営するサイトをアクセスして、ユーザ管理テーブル90にはユーザ(生徒)の名前等を含む個人情報が登録されている。また、先生管理テーブル100には、先生の名前や携帯端末2のメールアドレス、及びプログラミング授業に関わるクラスの生徒(ユーザ)の識別IDが登録されている。
[Program creation processing]
Next, a program creating process will be described with reference to FIGS. 13 and 14.
FIG. 13 shows an overall flowchart of the program creating process.
Prior to this processing, the teacher's mobile terminal 2 accesses the site operated by the server 1, and personal information including the name of the user (student) is registered in the user management table 90. Further, in the teacher management table 100, the name of the teacher, the mail address of the mobile terminal 2, and the identification ID of the student (user) of the class related to the programming class are registered.

更に、図12のカリキュラム選択処理(S1202)により、カリユラム選択画面(図15)を用いてカリキュラムを選択して、カリキュラム管理テーブル80から選択されたカリキュラム番号が、先生管理テーブル100に登録される。なお、本例の処理では、生徒個人毎に異なるカリキュラムを選択しないので、ユーザ管理テーブル90には選択されてカリキュラム番号を登録する必要がない。
また、図12に示すように、シート30と、選択されたカリキュラム番号に対応するチップセットが複数の生徒に配布され、プログラミング授業において生徒はシート30上にチップ40を配列する作業を完了した、とする。
Further, by the curriculum selection processing (S1202) of FIG. 12, the curriculum is selected using the curriculum selection screen (FIG. 15), and the curriculum number selected from the curriculum management table 80 is registered in the teacher management table 100. In the process of this example, since a different curriculum is not selected for each student, it is not necessary to register the selected curriculum number in the user management table 90.
Further, as shown in FIG. 12, the sheet 30 and the chip set corresponding to the selected curriculum number are distributed to a plurality of students, and the students have completed the work of arranging the chips 40 on the sheet 30 in the programming class. And

ここで、図7A〜図7Cを参照して、チップの配列の例について説明しておきたい。
このチップ配列の例は、課題「りんごをテーブルに置き部屋から出ましょう」に対して、3人の生徒がそれぞれ別のチップ配列を行った例である。図7A〜図7Cの何れも同じ動作を行い、正解となる。因みに、図示のチップの配列に基づくプログラム命令による動作は、以下の通りになる。
・右に2歩
・下に3歩
・拾う
・左に2歩
・置く
・下に2歩
・扉を開ける。
Here, an example of the chip arrangement will be described with reference to FIGS. 7A to 7C.
The example of this chip arrangement is an example in which three students perform different chip arrangements for the task “put apples on the table and leave the room”. The same operation is performed in all of FIGS. 7A to 7C, and the answer is correct. Incidentally, the operation by the program instruction based on the arrangement of the illustrated chips is as follows.
・Two steps to the right ・Three steps below ・Pickup ・Two steps to the left ・Place ・Two steps below ・Open the door.

説明を図13に戻す。先生は、携帯端末2を操作してログインを行う(S1301)。この場合、サーバ1の情報管理部102は、先生管理テーブル100を参照して、先生識別IDを確認し、もしカリキュラム番号が登録されていない場合には、携帯端末1の表示部に、カリキュラムの選択を促す画面を表示して、図12に基づく画面から上記のような処理を行わせる。そして、情報管理部102は、先生管理テーブル100に登録されたカリユラム番号を基にカリユラム管理テーブル80を参照して、カリユラム管理テーブル80に登録されているアプリケーションを起動する(S1302)。アプリケーションが起動されると、選択されたカリキュラム番号を登録したカリユラム管理テーブル80の情報が携帯端末2のメモリに取り込まれて記憶される。   Description is returned to FIG. The teacher operates the mobile terminal 2 to log in (S1301). In this case, the information management unit 102 of the server 1 refers to the teacher management table 100, confirms the teacher identification ID, and if the curriculum number is not registered, the curriculum number is displayed on the display unit of the mobile terminal 1. A screen prompting selection is displayed, and the above-described processing is performed from the screen based on FIG. Then, the information management unit 102 refers to the curriculum management table 80 based on the curriculum number registered in the teacher management table 100 and activates the application registered in the curriculum management table 80 (S1302). When the application is activated, the information of the curriculum management table 80 in which the selected curriculum number is registered is captured and stored in the memory of the mobile terminal 2.

先生は、携帯端末2のバーコードリーダ207を用いてシート2の識別部305を読ませる。更に、カメラ206を用いてチップ40が配列されたシート(チップ配列シート)30を撮影する。識別部305の情報及びチップ配列シートの撮影された画像(チップ配列シート画像)は一時、メモリ203に格納される(S1303)。チップ配列シート画像をメモリ203に登録する場合、当該画像が特定のユーザ(生徒)によって作成された旨を表示するために、先生は入力部204からユーザ識別ID(この場合、生徒識別ID)を入力する。チップ配列シート画像にはユーザ識別IDが付与されてメモリ203に格納される。   The teacher uses the barcode reader 207 of the mobile terminal 2 to read the identification unit 305 of the sheet 2. Further, the sheet (chip array sheet) 30 on which the chips 40 are arrayed is photographed using the camera 206. The information of the identification unit 305 and the captured image of the chip arrangement sheet (chip arrangement sheet image) are temporarily stored in the memory 203 (S1303). When registering the chip array sheet image in the memory 203, the teacher inputs the user identification ID (in this case, the student identification ID) from the input unit 204 in order to display that the image is created by a specific user (student). input. A user identification ID is added to the chip array sheet image and stored in the memory 203.

識別部305からの情報にはカリキュラムを識別する情報が含まれており、CPU202がその識別情報とカリユラム管理テーブル80に登録されたカリキュラム番号と比較する。比較の結果、両者が一致すると、使用されたシート30が正しいと判断して、その後の処理を継続させる。一方、比較の結果正しくないと判断すると、CPU202は表示部205にその旨を表示して、シート30及びカリキュラム番号の確認を促す。   The information from the identification unit 305 includes information for identifying the curriculum, and the CPU 202 compares the identification information with the curriculum number registered in the curriculum management table 80. As a result of the comparison, if the two match, it is determined that the used sheet 30 is correct, and the subsequent processing is continued. On the other hand, if the CPU 202 determines that the result is not correct, the CPU 202 displays a message to that effect on the display unit 205 to prompt confirmation of the sheet 30 and the curriculum number.

カリキュラム番号に対応した正規のシート30が使用された場合、CPU202はネットワーク接続部208を介して、チップ配列シート画像をサーバ1へ送信する(S1303)。チップ配列シート画像のサーバ1への送信は、生徒ごとのチップ配列シート画像を取得する度に行ってもよいし、複数の生徒のチップ配列シート画像がメモリ203に蓄積された時に行ってもよい。チップ配列シート画像には、先生識別ID、カリキュラム番号及びユーザ識別ID(この例では生徒識別ID)が付与されてサーバ1へ送信される。   When the regular sheet 30 corresponding to the curriculum number is used, the CPU 202 transmits the chip array sheet image to the server 1 via the network connection unit 208 (S1303). The transmission of the chip arrangement sheet image to the server 1 may be performed each time the chip arrangement sheet image for each student is acquired, or may be transmitted when the chip arrangement sheet images of a plurality of students are accumulated in the memory 203. . A teacher identification ID, a curriculum number, and a user identification ID (student identification ID in this example) are added to the chip array sheet image and transmitted to the server 1.

サーバ1がチップ配列シート画像を受信すると、情報管理部102は、送信元のアドレスが先生管理テーブル100に登録されたメールアドレスかを確認する。更に、受信したチップ配列シート画像に付与された生徒識別ID及び先生識別IDを取得して、先生管理テーブル100に登録されたものかを確認する。この確認の結果正しければ、画像処理及びプログラム作成処理に移る。(なお、ユーザ個人が自らの携帯端末からチップ配列シート画像をサーバへ送信する場合には、情報管理部102はユーザ管理テーブル90を参照して、正規に登録されたメールアドレスかを確認することになる。)
プログラム作成処理に際して、まず画像処理部104が、取得した上記画像からチップの有する絵柄の画像を認識する処理を行う(S1304)。その後、プログラム作成処理部103が、認識結果に基づいてプログラムの生成処理を行う(S1305)。これらの処理については、図14を参照して後述する。
When the server 1 receives the chip array sheet image, the information management unit 102 confirms whether the source address is a mail address registered in the teacher management table 100. Further, the student identification ID and the teacher identification ID given to the received chip array sheet image are acquired, and it is confirmed whether or not they are registered in the teacher management table 100. If the result of this confirmation is correct, the processing moves to image processing and program creation processing. (Note that when the user individually sends the chip array sheet image from his/her own mobile terminal to the server, the information management unit 102 refers to the user management table 90 and confirms whether the mail address is properly registered. become.)
In the program creation process, first, the image processing unit 104 performs a process of recognizing the image of the design of the chip from the acquired image (S1304). After that, the program creation processing unit 103 performs program generation processing based on the recognition result (S1305). These processes will be described later with reference to FIG.

プログラム作成処理部103で作成されたプログラムデータは、情報管理部102の処理に従って、プログラム管理テーブル110に格納される。即ち、プログラム管理テーブル110において、「ユーザID」には当該プログラムを作成したユーザである生徒IDが、「カリキュラム番号」には先生管理テーブル100に登録されたカリキュラム番号が、「プログラム」には作成されたプログラムデータが、「プログラムの登録日時」にはプログラムを格納した日時が、それぞれ登録される。   The program data created by the program creation processing unit 103 is stored in the program management table 110 according to the processing of the information management unit 102. That is, in the program management table 110, the “user ID” is the student ID of the user who created the program, the “curriculum number” is the curriculum number registered in the teacher management table 100, and the “program” is the created The date and time when the program is stored is registered in the “program registration date and time” of the created program data.

その後、プログラム管理テーブル110に登録されたプログラムを実行することができる(S1307)。一例では、プログラムの実行はその前段にプログラムのテスト及びその確認の処理を含んでいる。それは、チップ40の配列において、制御文のチップやパラメータのチップが所定の規則に従って配列されていないとか、「END」が無い等の場合があり、これらはプログラムの実行上エラーとしなければならないからである。テスト及び確認の処理においてそのようなエラーが発見されると、プログラムデータの修正作業に移る。   After that, the program registered in the program management table 110 can be executed (S1307). In one example, the execution of a program includes the process of testing the program and its verification before it. In the arrangement of the chips 40, there are cases where the control statement chips and the parameter chips are not arranged according to a predetermined rule, or there is no "END", and these must be regarded as an error in the execution of the program. Is. When such an error is found in the test and confirmation process, the work of correcting the program data is started.

すなわち、プログラムのテスト及び確認のために、プログラム管理テーブル110に格納されたプログラムデータはネットワーク9を介して、送信元の携帯端末2へ送信され、CPU202で実行される。CPU202によるプログラムの実行は、例えばカリキュラム管理テーブル80に登録されたキャラクタの動画として、表示部205に表示される。先生は、表示部205に表示される動画を見て、当初設定した「課題」とカメラで取得されたチップ配列シート画像におけるチップ配列を基に、表示された動画が正しいか、を判断する。その結果、正しくないと判断した場合には、そのプログラムを作成した生徒に対して口頭でプログラミングの修正を指示する。併せて、入力部204より当該プログラムの修正を指示すると、その指示はサーバ1へ送信されて、プログラム管理テーブル110に修正中のフラグ(図示せず)が記憶される。生徒によるプログラミングの修正が終わると、上述した動作と同様にして、修正されたチップ配列シート画像がサーバ1へ送信される。この場合、同様にして、プログラム管理テーブル110に修正された(修正版)プログラムデータが格納される。併せてプログラム管理テーブル110の修正日時が登録される。   That is, in order to test and confirm the program, the program data stored in the program management table 110 is transmitted to the mobile terminal 2 as the transmission source via the network 9 and executed by the CPU 202. The execution of the program by the CPU 202 is displayed on the display unit 205 as a moving image of the character registered in the curriculum management table 80, for example. The teacher looks at the moving image displayed on the display unit 205 and determines whether the displayed moving image is correct based on the “task” initially set and the chip arrangement in the chip arrangement sheet image acquired by the camera. As a result, when it is determined that the program is incorrect, the student who created the program is verbally instructed to correct the programming. At the same time, when an instruction to modify the program is issued from the input unit 204, the instruction is transmitted to the server 1 and a flag (not shown) being modified is stored in the program management table 110. When the student finishes modifying the programming, the modified chip array sheet image is transmitted to the server 1 in the same manner as the above-described operation. In this case, similarly, the modified (modified version) program data is stored in the program management table 110. At the same time, the modification date and time of the program management table 110 is registered.

修正版プログラムは、上記と同様にして、先生が所持する携帯端末2で実行される。その結果、エラーが無ければ、その旨がサーバ1へ送信されて、プログラム完成を示すフラグ(図示せず)がプログラム管理テーブル110に登録される。
なお、完成後のプログラムの実行の例については、図16を参照して後述する。
The modified program is executed on the mobile terminal 2 owned by the teacher in the same manner as described above. As a result, if there is no error, a message to that effect is transmitted to the server 1, and a flag (not shown) indicating program completion is registered in the program management table 110.
An example of executing the program after completion will be described later with reference to FIG.

次に、図14のフローチャートを参照して、画像処理(S1304)と、プログラム作成処理(S1304)を詳しく説明する。
画像処理(S1304)は、チップ配列シート画像から、個々のチップ40に描かれた絵柄の画像を認識して切り出す処理である。カメラ206で撮影された画像が傾いていることがあるので、まず、画像補正(S1401)の処理において、シート30の画像を基に画像の傾きを補正する。例えば、縦軸(Y軸)対してシート30のガイドライン304がある角度θ傾いていると判断したら、取得した画像全体を角度θ回転させて縦軸とガイドライン304を合せる。
Next, the image processing (S1304) and the program creation processing (S1304) will be described in detail with reference to the flowchart in FIG.
The image processing (S1304) is processing for recognizing and cutting out the image of the pattern drawn on each chip 40 from the chip array sheet image. Since the image captured by the camera 206 may be tilted, first, in the image correction (S1401) process, the tilt of the image is corrected based on the image on the sheet 30. For example, when it is determined that the guideline 304 of the sheet 30 is inclined at an angle θ with respect to the vertical axis (Y axis), the entire acquired image is rotated by the angle θ and the vertical axis is aligned with the guideline 304.

次に、画像パターマッチング(S1402)において、命令テーブル50を参照しながら、チップ配列を構成する各チップ40が有する絵柄の画像が、命令テーブル50に登録された絵柄と一致するかを判断する。この処理により、命令テーブル50に登録された絵柄の画像に対応するコードデータが選択される。仮にもし、シート30上に消しゴムやごみ等があっても、それらの画像は選択されない(除外される)。画像パターンマッチングにおいては、取得されたチップ配列画像について、命令テーブル50に登録された全ての画像と比較することは行わず、カリユラム管理テーブル80に当初登録された命令参照番号に対応するチップ画像のみを対象として比較することで、処理時間の高速化を図っている。画像パターンマッチングの結果出力されるコードデータ(命令コード)には、当該絵柄画像が認識された場所の座標情報(シート30上のX/Y座標情報)が付加される。   Next, in the image pattern matching (S1402), referring to the instruction table 50, it is determined whether or not the image of the pattern included in each chip 40 forming the chip array matches the pattern registered in the instruction table 50. By this processing, the code data corresponding to the image of the pattern registered in the command table 50 is selected. Even if there is an eraser or dust on the sheet 30, those images are not selected (excluded). In the image pattern matching, the acquired chip array image is not compared with all the images registered in the instruction table 50, but only the chip image corresponding to the instruction reference number originally registered in the calibration management table 80. The processing time is shortened by comparing the above items. The code information (command code) output as a result of the image pattern matching is added with the coordinate information (X/Y coordinate information on the sheet 30) of the place where the pattern image is recognized.

プログラム作成処理(S1304)おいては、上記画像処理により特定された絵柄の画像に対応する命令コードを整列させる(S1403)。命令コードを整列する理由は、パターンマッチングで認識された絵柄の画像は命令コードには変換されたが、その配列は未だチップ40が配列された状態のままであるため、命令コードを並び直して整列させるためである。この整列は、命令コードに付加された座標情報を基に例えばY座標を基準として揃える。更にプログラムの生成に際して、命令テーブル50を参照して命令コードの並び方が正しいかを確認する。例えば、上記画像処理の結果、「動く」の命令コードの右隣りにパラメータ「回数」の命令コードが並ぶ場合は正しいが、「拾う」や「置く」の命令コードの右隣りにパラメータ「回数」が並ぶ場合は、命令テーブル50で許可していないので正しくないと判断する。並び方が正しくない場合、一例ではそのパラメータを無視する。また、命令コードに対するパラメータの並び方が正しい場合であっても、パラメータの命令コードが許容範囲を超えて右側にずれている場合には、その命令コードを左側に移動させて、例えば「動く」命令コードの右隣りに整列させる。   In the program creating process (S1304), the instruction codes corresponding to the image of the picture specified by the image process are aligned (S1403). The reason for aligning the instruction codes is that the image of the pattern recognized by the pattern matching is converted into the instruction codes, but the arrangement is still in the state in which the chips 40 are arranged. Therefore, the instruction codes are rearranged. This is to align them. In this alignment, for example, the Y coordinate is used as a reference based on the coordinate information added to the instruction code. Further, when the program is generated, the instruction table 50 is referred to and it is confirmed whether the arrangement of the instruction codes is correct. For example, as a result of the image processing described above, it is correct when the instruction code of the parameter “number of times” is lined up to the right of the instruction code of “moving”, but the parameter “number of times” is placed to the right of the instruction code of “pick up” or “put”. In the case where "" is lined up, it is determined that it is not correct because it is not permitted in the instruction table 50. If the alignment is incorrect, the parameter is ignored in one example. Even if the parameters are arranged correctly with respect to the instruction code, if the instruction code of the parameter deviates to the right beyond the allowable range, the instruction code is moved to the left to Align to the right of the cord.

命令コードの整列及び確認が終了すると、整列された命令コードの順にプログラムコード化してプログラムデータを生成する(S1404)。作成されたプログラムのデータは、プログラム管理テーブル110の「プログラム」エリアに格納される。プログラム管理テーブル110には、ユーザ識別ID、カリキュラム番号、プログラム登録日時も併せて登録される。   When the alignment and confirmation of the instruction codes are completed, the aligned instruction codes are converted into program codes to generate program data (S1404). The data of the created program is stored in the “program” area of the program management table 110. The user identification ID, curriculum number, and program registration date and time are also registered in the program management table 110.

上記の処理動作によりチップ40の絵柄の配列に基づくプログラムが作成される。例えば、図7Aから図7Cに示すように、同じ設題でありながらチップの配列が異なると、命令コードの配列も異なるので、プログラムとしては別のものとなる。然し、プログラムの実行によって表示部205の画面に表示されるキャラクタの動作は同じになる。   A program based on the pattern arrangement of the chip 40 is created by the above processing operation. For example, as shown in FIGS. 7A to 7C, if the arrangement of chips is different while the subject is the same, the arrangement of instruction codes is also different, so that the program is different. However, the action of the character displayed on the screen of the display unit 205 becomes the same by executing the program.

[プログラムの実行]
実施例1では、作成されたプログラムは、先生が所持する携帯端末2のCPU202で実行される。プログラムの実行は、キャラクタの動作を伴う動画として表示部205の画面に表示される、とした。しかし、これに限らず、プログラムは種々の機器で実行される。
[Run the program]
In the first embodiment, the created program is executed by the CPU 202 of the mobile terminal 2 owned by the teacher. The execution of the program is assumed to be displayed on the screen of the display unit 205 as a moving image accompanied by the motion of the character. However, the program is not limited to this, and is executed by various devices.

図16は、プログラム作成支援システムにおいてサーバ1に接続される機器(接続機器という)を示す。例えば、サーバ1にはネットワーク9を介して、スクリーンに動画や映像を投影するプロジェクタや大型表示装置151、音響機器152、ロボットやミニカー等の動作機器153、を含む機器が接続される。   FIG. 16 shows devices (referred to as connected devices) connected to the server 1 in the program creation support system. For example, the server 1 is connected via the network 9 with a device including a projector for projecting a moving image or video on a screen, a large display device 151, an audio device 152, and an operating device 153 such as a robot or a minicar.

プログラムが実行される接続機器は1つの限らず、複数の機器で可能である。例えば、図5に示す命令リストの入出力命令の中から「音を鳴らす」が用いられる場合、表示装置151にキャラクタの動作が表示され、さらに音響機器152から音声が発生される。他の例として、音声を発するロボットを使用する場合、図5に示す命令リストの入出力命令の中から、「音を鳴らす」と「接続機器を制御」が用いられると、指定された先のロボットがプログラムの実行通りに動作し、かつロボットが備えるスピーカから音声が発せられる。   The number of connected devices on which the program is executed is not limited to one, and a plurality of devices can be used. For example, when “Make a sound” is used from the input/output commands of the command list shown in FIG. 5, the motion of the character is displayed on the display device 151, and the sound is generated from the audio device 152. As another example, when a robot that emits a voice is used, if “play a sound” and “control a connected device” are used from the input/output instructions of the instruction list shown in FIG. The robot operates according to the execution of the program, and a voice is emitted from a speaker included in the robot.

接続機器はインターネットに接続可能な、IPアドレスを有する全ての機器が対象となり得る。接続機器の管理は、サーバ1の管理情報DB105に、接続可能な機器のIPアドレス又はURLを登録する接続機器管理テーブルを用意しておき、接続機器管理テーブルを参照して出力先の接続機器を選択することで、プログラムが実行される機器への接続が可能である。接続機器の選択は、予め決めておいてもよいし、プログラムの完成した後に先生が所持する携帯端末2又は他の携帯端末から選択することができる。   The connected device can be any device that has an IP address and can be connected to the Internet. For management of the connected device, a connected device management table for registering the IP address or URL of the connectable device is prepared in the management information DB 105 of the server 1, and the connected device of the output destination is referred to by referring to the connected device management table. By selecting, it is possible to connect to the device on which the program is executed. The connection device may be selected in advance or can be selected from the mobile terminal 2 owned by the teacher or another mobile terminal after the program is completed.

[視覚障害者向けのプログラム作成支援システム]
上記実施例1は視覚正常者によるプログラム作成を前提としているが、本発明は視覚障害者がプログラム作成を行う場合にも有用である。その一例をあげれば、視覚障害者のためにシート30及び各チップ40には点字が施される。即ち、シート30のマトリックス線やガイドライン304、及びタイトル301や「スタート」マーク303は、上記した印刷の他に点字が形成される。また、各チップ40の所定の位置には上記した絵柄の他にチップの「名称」を表す点字が施される。さらに、命令テーブル50には、図5に示す構成に加えて、各チップの「名称」に対応して音符データが登録される。
[Program creation support system for the visually impaired]
Although the first embodiment is premised on the creation of a program by a visually impaired person, the present invention is also useful when a visually impaired person creates a program. For example, Braille is applied to the sheet 30 and each chip 40 for the visually impaired. That is, the matrix lines and guidelines 304 of the sheet 30, the title 301, and the "start" mark 303 are formed in Braille in addition to the above-described printing. In addition to the above-mentioned pattern, Braille representing the "name" of the chip is provided at a predetermined position of each chip 40. In addition to the configuration shown in FIG. 5, note data is registered in the instruction table 50 in correspondence with the “name” of each chip.

ユーザはシート30及び各チップ40の点字を頼りにして、シート30上にチップ40を並べてプログラミングする。チップ配列シート画像をカメラで取得してからプログラムデータの生成までの動作は上記実施例1と同様である。プログラムの実行においては、携帯端末2の表示機能と音声出力機能を有効にして、或いは図16に示す音響機器152に接続して、プログラムを実行させることができる。プログラムの実行において、複数チップの配列の状態は音符による音の変化として出力されるので、視覚障害者はその音の変化を基にプログラムの出来ばえを把握することができる。   The user relies on the braille of the sheet 30 and each chip 40 to arrange and program the chips 40 on the sheet 30. The operation from the acquisition of the chip array sheet image by the camera to the generation of the program data is the same as in the first embodiment. In executing the program, the display function and the voice output function of the mobile terminal 2 can be enabled, or the program can be executed by connecting to the audio device 152 shown in FIG. When the program is executed, the state of arrangement of a plurality of chips is output as a change in sound due to a note, so that a visually impaired person can grasp the performance of the program based on the change in the sound.

[他の例によるプログラム作成支援システム]
実施例1によるプログラム作成支援システムは、プログラム作成処理部103、画像処理部104、及び関連するテーブルや情報を記憶する管理情報DB105、プログラムDB106を全てサーバ1が有する。しかし、実施例2によるプログラム作成支援システムは、これらの処理機能やDBの全部又は一部を携帯端末2に持たせることができる。
[Program creation support system by another example]
In the program creation support system according to the first embodiment, the server 1 includes a program creation processing unit 103, an image processing unit 104, a management information DB 105 that stores related tables and information, and a program DB 106. However, the program creation support system according to the second embodiment can allow the mobile terminal 2 to have all or part of these processing functions and DB.

例えば、全ての処理機能及び関連するテーブルや情報を携帯端末2に持たせる場合、最初にプログラミング作成のサービスを行うサイト(例えばサーバ1が運営するサイト)にアクセスして、関係するアプリケーション(プログラム作成機能や関連する管理情報)をダウンロードして、携帯端末2に保持させる。あとは、上記実施例と同様にしてプログラムを作成することができる。この場合、シート30やチップ40は携帯端末2からの印刷指示により指定したプリンタで印刷して作成することができる。図13及び図14に示す処理は、携帯端末2が有するCPU202においてプログラムで実行される。   For example, in the case where the mobile terminal 2 has all the processing functions and related tables and information, first, access the site (for example, the site operated by the server 1) that provides the programming creation service, and execute the related application (program creation). Functions and related management information) are downloaded and stored in the mobile terminal 2. After that, the program can be created in the same manner as in the above embodiment. In this case, the sheet 30 and the chip 40 can be printed by the printer specified by the print instruction from the mobile terminal 2 and created. The processing shown in FIGS. 13 and 14 is executed by a program in the CPU 202 included in the mobile terminal 2.

また、一部の処理機能やDBを携帯端末2に持たせる例として、例えば、サーバ1には命令テーブル50を保持させて、携帯端末2にはカリキュラム管理テーブル80や、画像処理機能やプログラム作成機能を持たせることができる。この場合、カリキュラムに応じて用いられる命令と画像の対を、命令テーブル50から取得してカリキュラム管理テーブル80に記憶しておく。プログラム作成機能は、当該カリキュラム管理テーブル80を参照して、チップの画像に対応する命令を特定する処理を行うことができる。通常、サーバ1には、多くのユーザの携帯端末2が接続可能である。そこで、命令テーブル50には全ての命令と画像の対を母集団として管理しておき、ユーザの携帯端末2から要求で指定されたカリキュラムに応じて、命令テーブル50から選択された命令と画像の対のみを当該携帯端末2へ提供するのは有意義である。   In addition, as an example in which the mobile terminal 2 has some processing functions and DB, for example, the server 1 holds an instruction table 50, and the mobile terminal 2 holds a curriculum management table 80, image processing functions, and program creation. It can have a function. In this case, a pair of an instruction and an image used according to the curriculum is acquired from the instruction table 50 and stored in the curriculum management table 80. The program creation function can refer to the curriculum management table 80 and perform a process of identifying a command corresponding to the image of the chip. Usually, the mobile terminals 2 of many users can be connected to the server 1. Therefore, all pairs of commands and images are managed in the command table 50 as a population, and the commands and images selected from the command table 50 according to the curriculum specified by the user's mobile terminal 2 are requested. It is meaningful to provide only the pair to the mobile terminal 2.

[他の例によるプログラム作成の動作]
実施例1では、図12に示すように、先生が所持する携帯端末2を使用して、生徒が作成したシート30上のチップ40の配列を撮影するとした。しかし、プログラムの学習は学校の授業のみで行なわれるわけはなく、ユーザが自ら1人で行うこともできる。実施例3によれば、ユーザが携帯端末を所持していて、自分でログイン動作等の基本的な操作ができる。
[Program creation operation by another example]
In the first embodiment, as shown in FIG. 12, it is assumed that the mobile terminal 2 carried by the teacher is used to photograph the array of the chips 40 on the sheet 30 created by the student. However, the learning of the program is not limited to the school lessons alone, and the user can perform the learning by himself/herself. According to the third embodiment, the user has the mobile terminal and can perform basic operations such as a login operation by himself.

図17に示すように、ユーザは自ら携帯端末を用いてログインし(S1201)、カリキュラム選択(S1202)、シート及びチップセットの準備をして、プログラミングする(S1211´)。この場合、先生管理テーブル100は使用されずに、ユーザ管理テーブル90が使用される。それ以外の主な処理動作は実施例1と同様である。   As shown in FIG. 17, the user logs in by using the mobile terminal (S1201), selects a curriculum (S1202), prepares a sheet and a chipset, and performs programming (S1211′). In this case, the teacher management table 100 is not used, but the user management table 90 is used. The other main processing operations are the same as in the first embodiment.

また、このプログラム作成支援システムは、プログラム作成の学習以外にも、プログラムを作成するゲーム装置や、プログラムによる制御装置や玩具の制御のためのプログラム作成、等にも適用可能である。   Further, the program creation support system can be applied to a game device for creating a program, a program for controlling a control device and a toy by the program, and the like in addition to learning for creating the program.

[他の例によるプログラム作成支援処理フロー]
実施例1では、図13を参照する処理フローにおいて、画像の取込み、送信(S1303)からプログラムの作成処理(S1305)、プログラムの実行(S1307)、を一連の処理として行うように説明した。実施例4によれば、これらの処理ステップを複数に分けてそれぞれ別のタイミングで行うことも可能である。例えば、学校の授業において、第1回目では、シート30上にチップ40を並べるまでを学習させ、複数の生徒がそれぞれ作成したチップ配列をカメラ206で撮影して、複数のチップ配列シート画像をメモリ203に格納するまでとし、第2回目でメモリ203に格納されたチップ配列シート画像をサーバ1へ送信して、サーバでプログラム作成処理して、作成されたプログラムを携帯端末2へ送信させてメモリ203に格納して、1人の生徒のプログラムをテスト実行させるまでとし、3回目で残りの生徒の作成したプログラムをテスト実行させて、その後、プログラムの修正作業をさせる等、複数回に分けて実施することが可能である。特に学校の授業では、全体の生徒の進捗を見ながら進めることが重要なので、上記のように、プログラムの作成過程を幾つかに分けて進めることが有意義である。
[Program creation support processing flow according to another example]
In the first embodiment, in the process flow shown in FIG. 13, the process of capturing and transmitting an image (S1303) to creating a program (S1305) and executing the program (S1307) is performed as a series of processes. According to the fourth embodiment, it is possible to divide these processing steps into a plurality of steps and perform them at different timings. For example, in the first lesson in a school lesson, learning up to arranging the chips 40 on the sheet 30 is performed, the chip arrays created by a plurality of students are photographed by the camera 206, and a plurality of chip array sheet images are stored in the memory. Up to storing in 203, the chip array sheet image stored in the memory 203 in the second time is transmitted to the server 1, the server performs a program creation process, and the created program is transmitted to the mobile terminal 2 to be stored in the memory. It is stored in 203 and the program of one student is run as a test. The program created by the remaining students is run as a test for the third time, and then the program is modified. It is possible to carry out. Especially in school lessons, since it is important to proceed while watching the progress of all students, it is meaningful to divide the process of creating the program into several parts as described above.

[他の例による管理テーブル]
実施例1では、カリキュラム管理テーブル80には当該カリキュラムで使用される全ての命令の参照番号(図5の命令テーブル50から選択された命令の参照番号)が登録されるとした。実施例5においては、命令テーブル50から選択された命令の、チップの画像、名称、動作、パラメータ、及び命令コードの各データを登録するようにしてもよい。さらに、携帯端末2にプログラム作成支援のためのアプリケーションをサーバ1からダウンロードしておくことで、チップ配列画像を基にプログラムを作成する処理を携帯端末2のCPU202で行える。
[Management table according to another example]
In the first embodiment, the reference numbers of all the instructions used in the curriculum (the reference numbers of the instructions selected from the instruction table 50 in FIG. 5) are registered in the curriculum management table 80. In the fifth embodiment, each data of the image of the instruction, the name, the operation, the parameter, and the instruction code of the instruction selected from the instruction table 50 may be registered. Further, by downloading the application for supporting the program creation to the mobile terminal 2 from the server 1, the CPU 202 of the mobile terminal 2 can perform the process of creating the program based on the chip array image.

実施例5の他の例として、ユーザの要求に応じて、命令テーブル50から選択された複数の命令と、シート30と、チップ40を提供して、最終的にユーザによるプログラムの作成を支援するビジネスが考えられる。この場合、カリキュラム管理テーブル80はユーザ毎の契約管理テーブルとなり、カリキュラム番号はユーザに固有の契約識別コードとなる。例えば、サーバ1の情報管理部102は、上記他の例を踏襲した、選択された命令の、チップの画像、名称、動作、パラメータ、及び命令コードの各データを登録した契約管理テーブルと、ユーザ管理テーブルと、プログラム管理テーブル、及びプログラム作成支援のためのアプリケーションをユーザの携帯端末2へ提供する。携帯端末2では、取得されたチップ配列画像を基にCPU202で、図13及び図14に示す処理によりプログラムの作成が行える。   As another example of the fifth embodiment, a plurality of instructions selected from the instruction table 50, a sheet 30, and a chip 40 are provided in response to a user's request, and finally a user can create a program. Business can be considered. In this case, the curriculum management table 80 becomes a contract management table for each user, and the curriculum number becomes a contract identification code unique to the user. For example, the information management unit 102 of the server 1 follows the above-described other examples, and a contract management table in which each data of the image, name, operation, parameter, and command code of the chip of the selected command is registered, and the user. A management table, a program management table, and an application for supporting program creation are provided to the user's mobile terminal 2. In the mobile terminal 2, the CPU 202 can create a program based on the acquired chip array image by the processing shown in FIGS. 13 and 14.

[他の例によるシート]
シート30は、図3に示したものに限定されない。チップ40の配列の容易性、簡便性を考慮すれば、プログラムエリア302に「スタート」マークや罫線やガイドライン304が印刷されている方が好ましいが、代案によれば、それらは必ずしも必要とされない。チップ40の配列の開始位置や配列方向が分れば、或いはある程度習熟したユーザならば、プログラムエリア302に罫線やガイドライン304は無くてもよいであろう。また、「スタート」マーク303は、「START」のチップで代用できる。
[Sheet according to another example]
The seat 30 is not limited to the one shown in FIG. Considering the easiness and simplicity of the arrangement of the chips 40, it is preferable that the "start" mark, ruled line, or guideline 304 is printed in the program area 302, but according to the alternative, they are not always necessary. If the start position of the arrangement of the chips 40 and the arrangement direction are known, or if the user is familiar with it to some extent, the program area 302 may not need the ruled lines or the guidelines 304. Further, the “start” mark 303 can be replaced with a “START” chip.

また、他の例によれば、シート30は必ずしも必要としない。要するに、チップ40の配列の規則に従って開始位置や配列方向、終了位置を明確にして、チップ40を白紙や机やテーブル上に配列し、その配列をカメラで撮影することで、上記実施例1と同様の作用ないし効果を得ることができる。カメラで取得される画像は、シート無しのチップ配列画像である。例えば、机上にチップを配列する場合、仮に机上に消しゴムや鉛筆等の異物があっても問題はない。それは、カメラで撮影した画像を基にした画像認識の過程において消しゴムや鉛筆の画像は除外されて、チップ固有の画像のみを認識して抽出することができるからである。   Further, according to another example, the sheet 30 is not always necessary. In short, the start position, the arrangement direction, and the end position are clarified in accordance with the arrangement rule of the chips 40, the chips 40 are arranged on a blank sheet of paper, a desk, or a table, and the arrangement is photographed by a camera, so that the above-mentioned first embodiment is obtained. The same action or effect can be obtained. The image acquired by the camera is a chip array image without a sheet. For example, when arranging the chips on a desk, there is no problem even if foreign matter such as an eraser or a pencil is on the desk. This is because the eraser or pencil image is excluded in the process of image recognition based on the image captured by the camera, and only the image unique to the chip can be recognized and extracted.

また、シートを用いない他の例として、例えば、チップ40を縦横1〜2m程の四辺形の厚紙カードで作成して、このカードを校庭に並べることでプログラミングして、そのカードの配列を、ドローンに搭載した無線通信機能付きのカメラで高所から撮影することで、チップ配列の画像を取得することも可能である。   As another example of not using a sheet, for example, the chip 40 is made of a cardboard of a quadrilateral shape having a length and width of 1 to 2 m, and programming is performed by arranging this card in the school yard, and the arrangement of the card is It is also possible to acquire an image of the chip array by shooting from a high place with a camera equipped with a wireless communication function installed in the drone.

[課題シートの例]
実施例7は、図15(B)に示した、課題(カリキュラム)シートの具体例である。図18に示すように、課題シート70には主に、課題文702と、絵図が記載されており、課題(又は課題シート)を管理するために、課題番号701と、識別部705を有する。識別部705は、課題を識別するための識別情報(課題識別情報)を含む二次元バーコードで形成される。課題識別情報は、カリキュラム管理テーブル80に登録されるカリキュラム番号と対応付けられる。
[Example of assignment sheet]
Example 7 is a specific example of the task (curriculum) sheet shown in FIG. As shown in FIG. 18, the assignment sheet 70 mainly includes assignment sentences 702 and pictorial diagrams, and has an assignment number 701 and an identification unit 705 for managing assignments (or assignment sheets). The identification unit 705 is formed of a two-dimensional barcode including identification information (issue identification information) for identifying an issue. The task identification information is associated with the curriculum number registered in the curriculum management table 80.

実施例1に照らして言えば、先生(又はユーザ)は、課題が変わる度にその課題に対応した課題シート70を生徒に配布する。そして、先生(又はユーザ)は課題シート70を配布(使用)するとき(例えばS1204のとき)に、携帯端末2のバーコードリーダ207を用いて課題シート70の識別部705を読ませる。また、プログラム作成処理(図13)においては、アプリケーションの起動(ステップS1302)した後に、(実施例1における)シート3の識別部305をバーコードリーダ207で読ませる代わりに、課題シート70の識別部705をバーコードリーダ207で読ませる。これにより、課題シート70とカリキュラム管理テーブル80に登録されたカリキュラム番号と対応付けられる。他の動作は、実施例1と同様であり、図13における識別部305を、識別部705と読み替えれば理解できるであろう。   According to the first embodiment, the teacher (or the user) distributes the task sheet 70 corresponding to the task to the students each time the task changes. Then, when the teacher (or the user) distributes (uses) the task sheet 70 (for example, in S1204), the teacher (or the user) uses the barcode reader 207 of the mobile terminal 2 to read the identification unit 705 of the task sheet 70. In the program creation process (FIG. 13), after the application is started (step S1302), the identification sheet 305 of the sheet 3 (in the first embodiment) is not read by the barcode reader 207, but the identification of the task sheet 70 is performed. The section 705 is read by the barcode reader 207. As a result, the assignment sheet 70 is associated with the curriculum number registered in the curriculum management table 80. Other operations are similar to those of the first embodiment, and it can be understood by replacing the identifying unit 305 in FIG. 13 with the identifying unit 705.

この課題シート70を使用する場合、チップ40を配列するシートには識別部305が無くてよい。図19にこのシート30´の例を示す。つまり、実施例1によれば、カリキュラムが変わる度にシート30を替えているが、実施例7によれば、課題が変わるときに課題シート70を替えればよく、識別部305を有しないシート30´を変える必要がない。このため、シート30´はチップ40を配列する専用シート(例えば机上の台紙)として使用することができる。   When the task sheet 70 is used, the sheet on which the chips 40 are arranged may not have the identification unit 305. FIG. 19 shows an example of this sheet 30'. That is, according to the first embodiment, the sheet 30 is changed every time the curriculum changes, but according to the seventh embodiment, the problem sheet 70 may be changed when the problem changes, and the sheet 30 having no identification unit 305 may be changed. There is no need to change ´. Therefore, the sheet 30' can be used as a dedicated sheet (for example, a mount on a desk) on which the chips 40 are arranged.

実施例7の応用例として、複数ページに亘る課題シート70を含む冊子をユーザに有償又は無償で提供する。この場合、識別部705は、課題識別情報の他に、プログラム作成サービスを行うサーバ1のサイト情報を含むのがよい。ユーザは、携帯端末2のバーコードリーダ207で、目的の課題シート70の識別部705を読ませて、その読取り情報を基にプログラム作成サービスのサイトへアクセスして、当該課題シート70に対応するカリキュラム管理テーブル80に登録された情報を取得して、プログラム作成のサービスを受けることができる。   As an application example of the seventh embodiment, a booklet including the task sheet 70 extending over a plurality of pages is provided to the user for a fee or for free. In this case, the identification unit 705 may include site information of the server 1 that provides the program creation service, in addition to the assignment identification information. The user causes the barcode reader 207 of the mobile terminal 2 to read the identification unit 705 of the target task sheet 70, accesses the site of the program creation service based on the read information, and responds to the task sheet 70. It is possible to obtain the information registered in the curriculum management table 80 and receive the program creation service.

[他の例によるチップ]
実施例8においては、チップ40を配列し易くするために、チップ40の外周部に凹凸が設けられる。図20に示すように、平板状のチップ40には、上辺と左辺に三角形状の凹部411,412が形成され、右辺と下辺には三角形状の凸部421,422が形成される。チップ40に凹凸を設けた理由は、チップ401の配列を規制するため、換言すればチップの配列の簡便化のためである。図21に示すように、ユーザは、あるチップの凸部を、他のチップの凹部に係合するようにして、複数のチップ40を順に容易に配列(或いは組合せと言ってもよい)することができる。具体例として、図22に示すように、「動く:方向付き」命令はパラメータを付加することができるので(図5参照)、「動く:方向付き」命令のチップ401は右辺に凸部422を持ち、パラメータのチップ402は左辺にのみ凹部412を有する。図22には示していないが、図5を参照したチップの凹凸の他の例として、例えば、「拾う」命令にはパラメータが付加されないので、「拾う」命令のチップの右辺には凸部が無い。また、全てのパラメータは、動作命令や制御命令等に付加されるので、パラメータのチップの左辺にのみ凹部412を有し、他の辺には凹部や凸部を有しない。また、図22に示すように、「終了」命令のチップ401は、上辺にのみ凹部411を有する。
[Chip according to another example]
In the eighth embodiment, in order to facilitate the arrangement of the chips 40, unevenness is provided on the outer periphery of the chips 40. As shown in FIG. 20, the flat plate-shaped chip 40 has triangular concave portions 411 and 412 formed on the upper side and the left side, and triangular convex portions 421 and 422 formed on the right side and the lower side. The reason for providing the unevenness on the chip 40 is to regulate the array of the chips 401, in other words, to simplify the array of the chips. As shown in FIG. 21, a user can easily arrange a plurality of chips 40 in order (or may be called a combination) by engaging a convex portion of one chip with a concave portion of another chip. You can As a specific example, as shown in FIG. 22, since the “moving: with direction” instruction can add a parameter (see FIG. 5), the chip 401 of the “moving: with direction” instruction has a convex portion 422 on the right side. The parameter chip 402 has a recess 412 only on the left side. Although not shown in FIG. 22, as another example of the unevenness of the chip with reference to FIG. 5, for example, since a parameter is not added to the “pick up” command, a convex portion is formed on the right side of the chip of the “pick up” command. There is no. Further, since all parameters are added to operation commands, control commands, etc., the concave portion 412 is provided only on the left side of the parameter chip, and the concave portion or convex portion is not provided on the other sides. Further, as shown in FIG. 22, the chip 401 of the “end” command has the recess 411 only on the upper side.

実施例8によれば、矩形状のチップ40の辺に適宜凹凸を形成し、それら複数のチップを配列させることで、命令やパラメータのチップの配列を管理することができる。これにより、チップの配列を一様に管理できるので、チップを配列するためのシート30を省略することが可能である。   According to the eighth embodiment, irregularities are appropriately formed on the sides of the rectangular chip 40, and a plurality of these chips are arrayed, so that the array of commands and parameters can be managed. As a result, the arrangement of the chips can be managed uniformly, so that the sheet 30 for arranging the chips can be omitted.

また、チップの配列を管理できるので、画像処理における画像補正機能(S1401(図14))や、プログラム作成処理コードデータ整列機能(S1403)を実行するための時間や負荷を軽減することができ、全体としてプログラム作成のための時間を高速化できる。例えば、実施例1のように、凹凸が無いチップ40をシート30上に配列する場合、ガイドライン304があったとしても、複数のチップの左右の辺がデコボコとなったり、偏ったり、傾いて、配列されることが多々ある。このような場合には、画像補正機能(S1401)により正規に補正することができるが、そのための処理時間ないし負荷がかかる。一方、実施例8によれば、チップに設けた凹凸によりチップの配列が管理されるので、ユーザによるチップの配列のデコボコや傾き等が防止できる。そのため、画像処理プログラムによる画像補正機能(S1401)等の処理は殆ど不要となり、プログラム作成処理を高速化できる。   Further, since the chip arrangement can be managed, it is possible to reduce the time and load for executing the image correction function (S1401 (FIG. 14)) and the program creation processing code data alignment function (S1403) in the image processing, As a whole, the time required to create a program can be shortened. For example, when the chips 40 having no unevenness are arranged on the sheet 30 as in the first embodiment, even if the guideline 304 is provided, the left and right sides of the plurality of chips are uneven, uneven, or tilted. Often arranged. In such a case, the image correction function (S1401) can be used to make a correct correction, but the processing time or load is required for that. On the other hand, according to the eighth embodiment, since the chip array is managed by the unevenness provided on the chip, it is possible to prevent the chip array from being uneven or tilted by the user. Therefore, the processing such as the image correction function (S1401) by the image processing program is almost unnecessary, and the program creation processing can be speeded up.

実施例8によれば、矩形状のチップの辺に三角形状の凹凸を形成しているが、凹凸形状は三角形状に限らず、半円形、四角、など種々適用できる。また、特定の命令には特定のパラメータしか適合しないような場合には、両者のチップには特定形状の凹凸を適用することができる。例えば、「ジャンプ」命令には、「向き、高さ」のパラメータのみが付加されるので、両者のチップは特定の関係にある。そのため、大多数の命令のチップに三角形状の凹凸が適用される中、「ジャンプ」命令のチップの右辺と、「向き、高さ」のパラメータのチップの左辺には、特別な凹凸(例えば半円形状の凹凸)を適用することができる。このようにすれば、「向き、高さ」のパラメータのチップが他の動作命令のチップのために選択されることを防止できる。   According to the eighth embodiment, triangular irregularities are formed on the sides of a rectangular chip, but the irregularities are not limited to triangular shapes, and various shapes such as semicircles and squares can be applied. Further, in the case where only specific parameters are adapted to a specific instruction, it is possible to apply irregularities of a specific shape to both chips. For example, since only the "direction, height" parameters are added to the "jump" command, both chips have a specific relationship. Therefore, while the triangle-shaped unevenness is applied to the majority of the instruction chips, special unevenness (for example, half Circular irregularities) can be applied. In this way, it is possible to prevent the chip of the "direction, height" parameter from being selected for another operation command chip.

[他の例によるチップ]
チップ40に関する他の例として、チップ40に施した絵柄や形状、大きさは、図4乃至図5に示したものに限定されない。絵柄に関して言えば、図4に示したような抽象的な絵や文字に限らず、例えば、ウサギが走ったり、回転したり、物を拾うような具体的な絵でもよい。その方が幼児にとっては絵と命令の意味との関係が理解し易いであろう。他の例としてトランプやカルタでもよい。また、チップの形状は四辺形に限らず、種々の形状であってよい。例えばウサギが走ったり、寝たり、飛んだりする絵を切り抜いた形状でもよい。
[Chip according to another example]
As another example of the chip 40, the design, shape, and size of the chip 40 are not limited to those shown in FIGS. 4 to 5. Regarding the design, it is not limited to the abstract pictures and characters shown in FIG. 4, and for example, a concrete picture in which a rabbit runs, rotates, or picks up an object may be used. It will be easier for infants to understand the relationship between the picture and the meaning of the command. Other examples include playing cards and cartes. Further, the shape of the chip is not limited to the quadrilateral, and may be various shapes. For example, the shape in which a rabbit runs, sleeps, or flies may be cut out.

また、チップ40の呼び名に関して実施例1ではチップ40と言ったが、これに限らない。例えば、カード、パーツ(part)、ピース(piece)、小片、紙片、エレメント(element)、総称して部品とか物品と呼んでもよい。
チップは、配列しその後に片付けて収納する都合上平面状カードが好ましいが、必ずしも平面状部材に限らない。要は、配列することができる物品であって、物品が持つ絵柄や形状の特性(視認特性という)と命令とが一意に対応付けられるものであれば実現可能である。なお、視認特性を有する物品を、固有の表示を有する部品と呼んでもよいであろう。
Although the chip 40 is called as the chip 40 in the first embodiment, the name is not limited to this. For example, a card, a part, a piece, a small piece, a paper piece, and an element may be collectively referred to as a part or an article.
The chip is preferably a flat card for the sake of convenience in that it is arranged and then put away and stored, but it is not necessarily limited to a flat member. In short, it is feasible as long as the articles can be arranged, and the characteristics of the pattern or shape of the articles (referred to as visual recognition characteristics) and the command are uniquely associated with each other. It should be noted that an article having visual recognition characteristics may be referred to as a component having a unique display.

また、上記実施例ではチップ40の絵柄を画像認識することで命令と関係つけているが、これに限定されない。例えば、各チップ40に絵柄に加えて固有の数字やバーコードを付しておき、その数字やバーコードを認識することで、命令と対応付けすることも可能である。その場合、図5に示す命令テーブルには数字又はバーコードと命令との関係が登録されることになる。   Further, in the above embodiment, the pattern of the chip 40 is associated with the command by image recognition, but the invention is not limited to this. For example, it is also possible to associate each chip 40 with a command by attaching a unique number or barcode to each chip 40 and recognizing the number or barcode. In that case, the relationship between numbers or barcodes and commands is registered in the command table shown in FIG.

また、チップ40に関する他の例として、チップはユーザが自ら作成して使用することが可能である。例えば、ユーザは、図4と同じ形状及び絵柄のチップ40を手製で又はコピーにより作成してチップの数を増やすことができる。この場合、ユーザが作製したチップの絵柄が予め決められたものと同じ又は許容の範囲であれば、サーバ1の画像処理においてユーザが作成したチップ40の絵柄も同様の画像として認識するので問題はない。   As another example of the chip 40, the chip can be created and used by the user. For example, the user can increase the number of chips by making the chips 40 having the same shape and pattern as those in FIG. 4 by hand or by copying. In this case, if the design of the chip produced by the user is the same as the predetermined one or within an allowable range, the design of the chip 40 produced by the user in the image processing of the server 1 is recognized as a similar image. Absent.

[その他の例]
上記実施例では、携帯端末2が有するバーコードリーダ207によって、シート30の識別部305を読み取るとした。代案では、カメラ206で識別部305を読み取って、画像認識機能により識別部305が有する識別情報を認識するようにすることもできる。
[Other examples]
In the above embodiment, the identification section 305 of the sheet 30 is read by the barcode reader 207 of the mobile terminal 2. Alternatively, the identification unit 305 can be read by the camera 206 and the identification information included in the identification unit 305 can be recognized by the image recognition function.

また、上記実施例では、携帯端末2が持つカメラ206でシートに並べられたチップの配列を撮影するとした。代替例によれば、携帯端末のカメラに限らず、通信機能を有するカメラや、或いは通常のデジタルカメラで撮影したチップ配列の画像をUSBメモリやSDメモリに格納しておき、このメモリをプログラム作成用のサーバや端末に装填することでチップ配列の画像を取得することも可能である。
本発明は上記実施例ないし代替例以外にも、種々変形、応用して実施することができる。
Further, in the above-described embodiment, it is assumed that the camera 206 of the portable terminal 2 photographs the array of chips arranged on the sheet. According to an alternative example, not only the camera of the mobile terminal but also a camera having a communication function or an image of a chip array taken by a normal digital camera is stored in a USB memory or an SD memory, and this memory is programmed. It is also possible to acquire an image of the chip array by loading it on a server or terminal for use in the game.
The present invention can be carried out by variously modifying and applying other than the above-mentioned embodiments or alternatives.

1:サーバ 2:携帯端末 9:ネットワーク
102:情報管理部 103:プログラム作成処理部
104:画像処理部 105:管理情報DB 106:プログラムDB
202:CPU 203:メモリ 204:入力部
205:表示部 206:カメラ 207:バーコードリーダ
208:ネットワーク接続部
30:シート 301:タイトル 302:プログラムエリア
303:スタートマーク 304ガイドライン 305:識別部
40:チップ 50:命令テーブル 70:課題シート
80:カリキュラム管理テーブル 90:ユーザ管理テーブル
100:先生管理テーブル 110:プログラム管理テーブル
1: server 2: mobile terminal 9: network 102: information management unit 103: program creation processing unit 104: image processing unit 105: management information DB 106: program DB
202: CPU 203: Memory 204: Input unit 205: Display unit 206: Camera 207: Bar code reader 208: Network connection unit 30: Sheet 301: Title 302: Program area 303: Start mark 304 Guidelines 305: Identification unit 40: Chip 50: instruction table 70: assignment sheet 80: curriculum management table 90: user management table 100: teacher management table 110: program management table

Claims (13)

コンピュータを用いて、プログラムの作成を支援するプログラム作成支援システムであって、
それぞれ視認特性を有する、開始位置に配置されるスタートチップと、動作を規定する複数の動作チップと、を含む複数のチップと、
前記複数の動作チップに対応する命令を管理するテーブルと、
並べられた、前記スタートチップと、前記複数の動作チップにより形成されるチップ配列の画像を取得する画像取得手段と、
前記画像取得手段で取得される前記チップ配列の画像から、前記スタートチップの画像以降にある前記複数の動作チップの画像を認識する画像処理部と、
前記画像処理部で認識される前記複数の動作チップの画像について、前記テーブルを参照して命令を特定し、特定された複数の命令から構成されるプログラムを生成するプログラム作成処理部と、
を有することを特徴とするプログラム作成支援システム。
A program creation support system for supporting the creation of a program using a computer,
A plurality of chips each including a start chip arranged at a start position and having a plurality of operation chips that define an operation, each chip having a visual characteristic;
A table for managing instructions corresponding to the plurality of operation chips;
An image acquisition unit for acquiring an image of a chip array formed by the start chips and the plurality of operation chips that are arranged,
From the image of the chip array acquired by the image acquisition means, an image processing unit for recognizing images of the plurality of operating chips after the image of the start chip,
A program creation processing unit that identifies an instruction with respect to the images of the plurality of operation chips recognized by the image processing unit, refers to the table, and generates a program including the plurality of identified instructions.
A program creation support system having:
前記コンピュータは、サーバと、端末を含み、
前記サーバは、前記テーブルと、前記画像処理部と、前記プログラム作成処理部を有し、
前記端末は、前記画像取得手段と、入力部と、表示部と、プログラムを実行するプロセッサと、記憶部と、を有し、
前記サーバにある前記プログラム作成処理部により作成された前記プログラムは、該端末へ送信されて、該端末の該プロセッサは受信した前記プログラムを実行し、該表示部は前記プログラムの実行の様子を表示する、請求項1のプログラム作成支援システム。
The computer includes a server and a terminal,
The server includes the table, the image processing unit, and the program creation processing unit,
The terminal includes the image acquisition unit, an input unit, a display unit, a processor that executes a program, and a storage unit,
The program created by the program creation processing unit in the server is transmitted to the terminal, the processor of the terminal executes the received program, and the display unit displays a state of execution of the program. The program creation support system according to claim 1.
前記コンピュータは、端末を含み、
前記端末は、前記画像取得手段と、入力部と、表示部と、プログラムを実行するプロセッサと、記憶部と、を有し、
該プロセッサは、前記画像処理部と、前記プログラム作成処理部を有し、
前記記憶部は前記テーブルを記憶し、
前記プログラム作成処理部により作成された前記プログラムは、該プロセッサで実行され、該実行の様子を該表示部に表示する、請求項1のプログラム作成支援システム。
The computer includes a terminal,
The terminal includes the image acquisition unit, an input unit, a display unit, a processor that executes a program, and a storage unit,
The processor has the image processing unit and the program creation processing unit,
The storage unit stores the table,
The program creation support system according to claim 1, wherein the program created by the program creation processing unit is executed by the processor, and a state of the execution is displayed on the display unit.
プログラミングのためにユーザに提示される、少なくとも、カリキュラムと、カリキュラムを識別するカリキュラム識別情報の表示を有するカリキュラムシートが用いられ、
前記テーブルは、プログラミングのためのカリキュラムを識別する前記カリキュラム識別情報と、該カリキュラムに基づくプログラミングに使用される、複数の各チップが有する視認特性と該視認特性に対応付けられるプログラムの命令とを管理するカリキュラム管理テーブルであり、
前記チップ配列は、前記カリキュラムシートの前記カリキュラムに従ってユーザにより並べられたものであり、
前記プログラム作成処理部は、前記カリキュラム管理テーブルで管理される前記視認特性と前記命令の関係を基に、該画像処理部で認識された該チップの該視認特性の画像に対応する命令を特定する、請求項1のプログラム作成支援システム。
A curriculum sheet having at least a curriculum presented to a user for programming and a display of curriculum identification information identifying the curriculum is used,
The table manages the curriculum identification information for identifying a curriculum for programming, the visual characteristic of each of the plurality of chips used for programming based on the curriculum, and the command of the program associated with the visual characteristic. Curriculum management table
The chip array is arranged by a user according to the curriculum of the curriculum sheet,
The program creation processing unit identifies a command corresponding to the image of the visual recognition property of the chip recognized by the image processing unit, based on the relationship between the visual recognition property managed by the curriculum management table and the command. The program creation support system according to claim 1.
前記カリキュラム管理テーブルは、該カリキュラムにおいて実行されるアプリケーションに使用されるキャラクタセットに関する情報を登録する、請求項4のプログラム作成支援システム。 The program creation support system according to claim 4, wherein the curriculum management table registers information regarding a character set used for an application executed in the curriculum. コンピュータを用いて、プログラムの作成を支援するプログラム作成支援システムであって、
それぞれ視認特性を有する複数のチップと、
所定の位置に特定のマークを有する、前記複数のチップが配列されるシートと、
前記複数のチップの前記視認特性に対応する命令を管理するテーブルと、
前記マークを起点として、前記シート上に並べられた前記複数のチップを撮影する画像取得手段と、
該画像取得手段で取得される前記複数のチップの画像から、前記複数のチップが有する前記視認特性の画像を認識する画像処理部と、
前記テーブルを参照して、該画像処理部で認識された前記視認特性の画像に対応する命令を特定して、特定された複数の該命令から構成されるプログラムを生成するプログラム作成処理部と、を有することを特徴とするプログラム作成支援システム。
A program creation support system for supporting the creation of a program using a computer,
A plurality of chips each having visual recognition characteristics,
A sheet in which the plurality of chips are arranged, having a specific mark at a predetermined position,
A table for managing commands corresponding to the visual recognition characteristics of the plurality of chips;
Image acquisition means for photographing the plurality of chips arranged on the sheet, starting from the mark,
An image processing unit that recognizes an image of the visual recognition characteristics of the plurality of chips from images of the plurality of chips acquired by the image acquiring unit;
A program creation processing unit that refers to the table, identifies a command corresponding to the image of the visual recognition characteristic recognized by the image processing unit, and generates a program composed of the plurality of identified commands; A program creation support system having:
前記テーブルは、ユーザに提供される、前記視認特性を有する前記複数のチップに対応する命令を管理する管理テーブルである、請求項1または6のプログラム作成支援システム。 7. The program creation support system according to claim 1, wherein the table is a management table for managing a command provided to a user and corresponding to the plurality of chips having the visual recognition characteristic. 前記テーブルにおける、前記チップが有する視認特性と該プログラムの命令との対応は、コンピュータへの入力指示によって変更可能である、請求項1または6のプログラム作成支援システム。 7. The program creation support system according to claim 1, wherein the correspondence between the visual recognition characteristic of the chip and the command of the program in the table can be changed by an input instruction to a computer. 前記プログラム作成処理部により作成されたプログラムのデータを管理するプログラム管理テーブルと、前記コンピュータに接続可能な複数の機器の情報を管理する接続機器管理テーブルと、を有し、
前記プログラム作成処理部は、前記プログラム管理テーブルに登録された前記プログラムを、前記接続機器管理テーブルを参照して選択された該機器において実行させる、
請求項1または6のプログラム作成支援システム。
A program management table that manages data of a program created by the program creation processing unit; and a connected device management table that manages information of a plurality of devices connectable to the computer,
The program creation processing unit causes the program registered in the program management table to be executed by the device selected by referring to the connected device management table,
The program creation support system according to claim 1 or 6.
コンピュータを用いて、プログラムの作成を支援するプログラム作成支援方法であって、
それぞれ視認特性を有する、開始位置に配置されるスタートチップと、動作を規定する複数の動作チップと、を含む複数のチップを用意するステップと、
前記複数の動作チップに対応する命令を、記憶手段に記憶されたテーブルで管理するステップと、
並べられた、前記スタートチップと、前記複数の動作チップにより形成されるチップ配列の画像を画像取得手段が取得するステップと、
前記画像取得手段で取得される前記チップ配列の画像から、前記スタートチップの画像以降にある、前記複数の動作チップの画像を認識する画像処理ステップと、
前記画像処理ステップで認識される前記複数の動作チップの画像について、前記テーブルに基づいて命令を特定し、特定された複数の命令から構成されるプログラムを生成するプログラム作成処理ステップと、
を有するプログラム作成支援方法。
A program creation support method for supporting the creation of a program using a computer,
A step of preparing a plurality of chips each including a start chip arranged at a start position and having a plurality of operating chips that define an operation, each chip having a visual characteristic;
Managing a command corresponding to the plurality of operating chips in a table stored in a storage means;
A step in which the image acquisition means acquires an image of a chip array formed by the start chips and the plurality of operating chips that are arranged,
From the image of the chip array acquired by the image acquisition means, an image processing step of recognizing images of the plurality of operation chips, which are subsequent to the image of the start chip,
Program creation processing steps for specifying an instruction based on the table for the images of the plurality of operation chips recognized in the image processing step, and generating a program including the plurality of specified instructions.
A method for supporting the creation of a program.
コンピュータを用いて、プログラムの作成を支援するプログラム作成支援方法であって、
複数の動作チップに対応する命令を、記憶手段に記憶されたテーブルで管理するステップと、
並べられた、それぞれ視認特性を有する、開始位置に配置されるスタートチップと、動作を規定する複数の動作チップにより形成されるチップ配列の画像から、前記スタートチップの画像以降にある、前記複数の動作チップの画像を認識する画像処理ステップと、
前記画像処理ステップで認識された前記複数の動作チップの画像について、前記テーブルに基づいて命令を特定し、特定された複数の命令から構成されるプログラムを生成するプログラム作成処理ステップと、
を有するプログラム作成支援方法。
A program creation support method for supporting the creation of a program using a computer,
Managing a command corresponding to a plurality of operating chips in a table stored in a storage means;
From the image of the chip array formed by the start chips arranged in the starting position and having the respective visual recognition characteristics and the plurality of operation chips that define the operation, An image processing step for recognizing the image of the operating chip,
A program creation processing step for specifying an instruction based on the table for an image of the plurality of operation chips recognized in the image processing step, and generating a program including the plurality of specified instructions;
A method for supporting the creation of a program.
コンピュータを用いて、プログラムの作成を支援するプログラム作成支援システムであって、
それぞれ視認特性を有する複数のチップと、所定の位置に特定のマークを有し、前記複数のチップが配列されるシートと、が用いられ、
前記複数のチップの前記視認特性に対応する命令を、記憶手段に記憶されたテーブルで管理するステップと、
前記マークを起点として、前記シート上に並べられた前記複数のチップの画像を、画像取得手段が取得するステップと、
該画像取得手段で取得される前記複数のチップの画像から、前記複数のチップが有する前記視認特性の画像を認識する画像処理ステップと、
前記テーブルを参照して、該画像処理ステップで認識された前記視認特性の画像に対応する命令を特定して、特定された複数の該命令から構成されるプログラムを生成するプログラム作成処理ステップと、を有することを特徴とするプログラム作成支援方法。
A program creation support system for supporting the creation of a program using a computer,
A plurality of chips each having a visual recognition characteristic, a sheet having a specific mark at a predetermined position, the plurality of chips are arranged, is used,
Managing a command corresponding to the visual recognition characteristics of the plurality of chips in a table stored in a storage unit;
From the mark as a starting point, the image of the plurality of chips arranged on the sheet, a step of acquiring an image,
An image processing step of recognizing an image of the visual recognition characteristic of the plurality of chips from the images of the plurality of chips acquired by the image acquiring means;
A program creation processing step of referring to the table, specifying a command corresponding to the image of the visual recognition characteristic recognized in the image processing step, and generating a program composed of the plurality of specified commands; A method for supporting program creation, comprising:
コンピュータに、プログラムの作成を支援する処理を実行させるプログラム作成支援用プログラムであって、
複数の動作チップに対応する命令を、記憶手段に記憶されたテーブルで管理するステップと、
並べられた、それぞれ視認特性を有する、開始位置に配置されるスタートチップと、動作を規定する複数の動作チップとにより形成されるチップ配列の画像から、前記スタートチップの画像以降にある、前記複数の動作チップの画像を認識する画像処理ステップと、
前記画像処理ステップで認識された前記複数の動作チップの画像について、前記テーブルに基づいて命令を特定し、特定された複数の命令から構成されるプログラムを生成するプログラム作成処理ステップと、
を含む処理をコンピュータに実行させるプログラム作成支援用プログラム。
A program creation support program that causes a computer to execute processing for supporting the creation of a program,
Managing a command corresponding to a plurality of operating chips in a table stored in a storage means;
From the image of the chip array formed by the start chips arranged in the starting position and having the respective visual recognition characteristics and the plurality of operation chips that define the operation, the plurality of images that are after the image of the start chip An image processing step for recognizing the image of the operating chip of
A program creation processing step for specifying an instruction based on the table for an image of the plurality of operation chips recognized in the image processing step, and generating a program including the plurality of specified instructions;
A program creation support program that causes a computer to execute processing including.
JP2020001314A 2020-01-08 2020-01-08 Program creation support system and its method Active JP6815052B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2020001314A JP6815052B2 (en) 2020-01-08 2020-01-08 Program creation support system and its method

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2020001314A JP6815052B2 (en) 2020-01-08 2020-01-08 Program creation support system and its method

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2017224577A Division JP6651148B2 (en) 2017-11-22 2017-11-22 Program creation support system and method, and program therefor

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2020206879A Division JP7284516B2 (en) 2020-12-14 2020-12-14 Program creation support system, its method, and its program

Publications (2)

Publication Number Publication Date
JP2020079943A true JP2020079943A (en) 2020-05-28
JP6815052B2 JP6815052B2 (en) 2021-01-20

Family

ID=70802431

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2020001314A Active JP6815052B2 (en) 2020-01-08 2020-01-08 Program creation support system and its method

Country Status (1)

Country Link
JP (1) JP6815052B2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP6993531B1 (en) 2021-07-12 2022-01-13 ダイコク電機株式会社 Teaching materials for programming learning and programming learning system

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS6087043U (en) * 1983-11-16 1985-06-15 島田 喜郎 Card for creating computer program drawings
JPS6491169A (en) * 1987-10-02 1989-04-10 Mitsuhiko Yamada Learning apparatus for computer
JPH07104661A (en) * 1993-09-30 1995-04-21 Hitachi Software Eng Co Ltd Courseware generating method
US20140170606A1 (en) * 2012-12-18 2014-06-19 Neuron Fuel, Inc. Systems and methods for goal-based programming instruction
JP2017517030A (en) * 2014-05-07 2017-06-22 ジンウック キム Algorithm education device using blocks
JP2017161770A (en) * 2016-03-10 2017-09-14 株式会社デザイニウム Device, method, and program for programming learning

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS6087043U (en) * 1983-11-16 1985-06-15 島田 喜郎 Card for creating computer program drawings
JPS6491169A (en) * 1987-10-02 1989-04-10 Mitsuhiko Yamada Learning apparatus for computer
JPH07104661A (en) * 1993-09-30 1995-04-21 Hitachi Software Eng Co Ltd Courseware generating method
US20140170606A1 (en) * 2012-12-18 2014-06-19 Neuron Fuel, Inc. Systems and methods for goal-based programming instruction
JP2017517030A (en) * 2014-05-07 2017-06-22 ジンウック キム Algorithm education device using blocks
JP2017161770A (en) * 2016-03-10 2017-09-14 株式会社デザイニウム Device, method, and program for programming learning

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
原槙稔幸: "子ども向け科学実験教室におけるプログラミング体験への拡張現実の導入に関する検討", 情報処理学会第75回(平成25年)全国大会講演論文集(4), JPN6017030570, 6 March 2013 (2013-03-06), JP, pages 385 - 386, ISSN: 0004311114 *
夛田 一貴: "紙の配置や書き込みを活用したプログラミング環境の開発", 筑波大学大学院博士課程システム情報工学研究科修士論文, JPN6020026484, pages 8 - 14, ISSN: 0004311115 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP6993531B1 (en) 2021-07-12 2022-01-13 ダイコク電機株式会社 Teaching materials for programming learning and programming learning system
JP2023011299A (en) * 2021-07-12 2023-01-24 ダイコク電機株式会社 Teaching material for learning programming and system for learning programming

Also Published As

Publication number Publication date
JP6815052B2 (en) 2021-01-20

Similar Documents

Publication Publication Date Title
JP6253170B1 (en) Program creation support system and method
JP6911432B2 (en) Information display device, control method of information display device, and control program of information display device
CN105825732A (en) Auxiliary system for Chinese language and literature teaching
Desierto et al. GoonAR: A bilingual children storybook through augmented reality technology using unity with Vuforia framework
JP6957918B2 (en) Information display device, information display method, and program
US6626677B2 (en) Method for enhancing work related creative thinking and team building skills
JP6651148B2 (en) Program creation support system and method, and program therefor
JP6815052B2 (en) Program creation support system and its method
JP2021056286A (en) Programming learning support system and programming learning support method
JP7284516B2 (en) Program creation support system, its method, and its program
Rice et al. E-Learning and the academic library: Essays on innovative initiatives
JP2006154691A (en) Calligraphy animation teaching material and calligraphy educational system
Stapleton et al. Girls tech camp: Librarians inspire adolescents to consider STEM careers
JP6633115B2 (en) Program creation support system and method, and program therefor
Heffernan et al. Augmented reality gamifies the library: A ride through the technological frontier
JP2005173348A (en) Terminal device for content operation, content display control method and program therefor, and content distribution system
JP7184402B2 (en) Program creation support system and its method
Chung et al. Building Bitmoji Art Rooms Amid the COVID-19 Pandemic
TWM524977U (en) Intelligent device of remotely controlling electronic book
TWI596582B (en) Teaching method of remote control operation ebook and its intelligent device
JP7031173B2 (en) Information processing equipment, image forming equipment and programs
Johnson Advanced Crime Scene Mapping and Technology Course Design
WO2018184109A1 (en) Method and system for missions and mission building
Reshad et al. Reflections on the virtual boardroom: Business presentations in the holodeck
González López et al. Atenea: Digitalizing Educational Games with Light Tables

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20200108

A871 Explanation of circumstances concerning accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A871

Effective date: 20200108

A975 Report on accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A971005

Effective date: 20200310

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20200317

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20200512

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20200728

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20200909

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20201117

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20201215

R150 Certificate of patent or registration of utility model

Ref document number: 6815052

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150