将棋で学ぶプログラミング基礎 | Programming for beginners: Learning basics with computer Shogi
Offered By: Tokyo Institute of Technology via edX
Course Description
Overview
将棋を題材にプログラミングの基礎と様々な工夫を学びます。
プログラムの実行環境として、MATLAB版の将棋プログラム「MT将棋(※)」を使用します。MATLABは数値計算を扱うことが得意なプログラミング言語で,MATLAB版の「MT将棋」は、その特徴を生かしながらコーディングされています。
本コースでは「MT将棋」のすべてのコードを詳細に説明することはしませんが、コードの要点をピックアップした解説を通してプログラミングの基本や考え方の一端を学ぶことができます。
MATLABの実行環境をお持ちの受講者の方は、実際に「MT将棋」を実行したり、修正したりしながら学ぶことができます。MATLABの実行環境をお持ちでない受講者の方には、MATLAB開発元のMathWorks社の協力により、本コースの受講者限定で、WebブラウザーからMATLABを使用できるMATLAB Onlineの期間限定(約9週間)ライセンスが発行されます。
(※)MT将棋:約50の関数ファイルからなる、合計で約2100行、約9500単語、ファイルサイズ約86KBのMATLABコードです。2018年に実施された「小学生向け将棋プログラミング講習会」(主催:東京工業大学工学院、共同主催:電子情報通信学会東京支部、後援:日本将棋連盟、協力:大田区立清水窪小学校・東工大将棋部)に向けて開発が開始され、その後、更新されてきました。
本コースは東京工業大学超スマート社会卓越教育院が制作し、提供しています。
----------
In this course, you will learn the basics of programming and various techniques of coding with computer Shogi. The course uses "MT Shogi(*)", a Shogi program that runs on MATLAB. MATLAB is a programming language that excels at handling numerical calculations, and "MT Shogi" was implemented to take advantage of such high computational power of MATLAB.
In this course, we will not explain all the code of "MT Shogi" in detail, but you will learn fundamental concepts of programming through easy-to-understand explanations on the key points of "MT Shogi".
Participants who have a MATLAB environment can learn by actually running and revising "MT Shogi". For participants who do not have a MATLAB environment, MathWorks, the developer of MATLAB, will provide a limited time (approximately 9 weeks) license for MATLAB Online, which allows participants to use MATLAB from a web browser, exclusively for this course.
(*) MT Shogi: MATLAB code consisting of about 50 function files with a total of about 2100 lines, about 9500 words, and a file size of about 86KB. This program was first developed for a "Shogi programming workshop for elementary school students" in 2018, and has been updated since then.
This course is produced and offered by Tokyo Tech Academy for Super Smart Society (WISE-SSS).
Syllabus
Week 1:駒の表示
- 駒の表示
- MT関数:駒表示
- MT変数:駒
- 配列
- 関数
- 制御文:for
- MATLAB関数・演算子
Week 2:駒の動き
- 駒の動き
- MT関数:周り候補マス
- 駒移動ベクトル
- MT関数:候補マス
- 制御文:while, if, switch
- MATLABの特徴
- MATLAB関数
- MATLABの演算
Week 3:人対人の対局
- 人対人の対局
- 対局の流れ
- MT将棋盤
- MT関数:選択と駒移動
- MATLAB関数:入出力
- 変数値の様々な設定方法
Week 4:コンピュータ対局[概要]
- コンピュータ対局
- 局面評価
- コンピュータ対局の流れ
- コンピュータによる局面評価
Week 5: コンピュータ対局[実装]
- MT関数:自動選択
- MT変数:点数行列・動き配列
- 関数解説:自動選択
- MATLAB関数:ソート・乱数・ファイル入出力
- 関数の様々な記述方法
----------
Week 1: Board representation
- Board representation
- MT function: placing pieces
- MT variable: pieces
- Array
- Function
- Control statement: for
- MATLAB functions and operators
Week 2: Piece movement
- Movement of pieces
- MT function: possible adjacent squares for piece movement
- Piece movement vector
- MT function: possible squares for piece movement
- Control statements: while, if, switch
- Features of MATLAB
- MATLAB functions
- MATLAB operations
Week 3: Human vs. human game
- Human vs. human game
- Flow of the game
- MT Shogi board
- MT function: selection and movement of a piece
- MATLAB function: input/output
- Various ways to set variable values
Week 4: Computer vs. computer game [Overview]
- Computer vs. computer game
- Board state evaluation methods
- Flow of computer vs. computer game
- Board state evaluation by computers
Week 5: Computer vs. computer game [Implementation]
- MT function: automatic selection of moves
- MT variables: score matrix and movement array
- Explanation on functions: automatic selection of moves
- MATLAB functions: sorting, generating random numbers, file input/output
- Various ways of coding functions
Taught by
Atsushi Takahashi
Tags
Related Courses
Scientific ComputingUniversity of Washington via Coursera Dynamical Modeling Methods for Systems Biology
Icahn School of Medicine at Mount Sinai via Coursera Elements of Structures
Massachusetts Institute of Technology via edX Analyse numérique pour ingénieurs
École Polytechnique Fédérale de Lausanne via Coursera Dynamics
Massachusetts Institute of Technology via edX
