--- /dev/null
+;; GR1に格納された値を、10進数の符号付き小数値として表示
+OUTAQ15 START
+ RPUSH
+ LAD GR2,10 ; GR2に10進数の「10」を格納
+ XOR GR4,GR4 ; 整数値の長さ
+ XOR GR3,GR3 ; 出力する文字を一時的に格納
+ AND GR1,GR1 ; GR1の符号をチェック
+ JPL STDN ; ↓ GR1が正数の場合、STDNにジャンプ
+ LD GR3,='-' ; ↓ GR1が負数の場合、「-」をSTR領域に格納
+ ST GR3,STR ; ↓ ↓
+ LAD GR4,1,GR4 ; ↓ ↓ GR4 <- GR4 + 1
+ CPA GR1,=#8000 ; (GR1 = #8000)の場合、MINONEへジャンプ
+ JZE MINONE ; ↓
+ CALL ABS ; GR1を正数に変換
+STDN LD GR3,='0' ; 「0」をSTR領域に格納
+ ST GR3,STR,GR4 ; ↓
+ AND GR1,GR1 ; GR1が0の場合、PRTへジャンプ
+ JZE PRT ; ↓
+ LAD GR4,1,GR4 ; ↓ GR4 <- GR4 + 1
+ LD GR3,='.' ; 「.」をSTR領域に格納
+ ST GR3,STR,GR4 ; ↓
+ LAD GR4,1,GR4 ; ↓ GR4 <- GR4 + 1
+ SLL GR1,1 ; GR1を1回左シフト
+;; GR1の内容を小数値と見なし、10進数の文字列に変換してSTRに格納
+TODIG AND GR1,GR1 ; GR1が0の場合は、ループを脱出
+ JZE PRT ; ↓
+ CALL MULL ; GR1とGR2の、積をGR1、オーバーフロー値をGR3に格納
+ LD GR1,GR0 ; GR0をGR1にコピー
+ ADDA GR3,='0' ; GR1を文字に変換
+ ST GR3,STR,GR4 ; (STR + GR4) <- GR1
+ LAD GR4,1,GR4 ; GR4 <- GR4 + 1
+ JUMP TODIG ; ループ
+;; GR1 = -1の場合
+MINONE LD GR1,='1' ; GR1が#8000の場合、-1を出力
+ ST GR1,STR,GR4 ; (STR + GR4) <- GR1
+ LAD GR4,1,GR4 ; GR4 <- GR4 + 1
+ JUMP PRT ; ↓
+;; 値を出力
+PRT ST GR4,LEN ; LEN <- GR4
+ OUT STR,LEN ; ↓
+ RPOP
+ RET
+STR DS 20
+LEN DS 1
+ END
+