迷走の果て・Tiny Objects

迷走する日々の覚え書きです。自分で分かってることは省略してますので、念のため。

オシロで謹賀新年(3)drawToを書き直す

1月も半ばだというのに、いまだに正月ネタかと言われそうですが^^;;
前の実験では描画速度が30.9mSでしたが、drawToルーチンを書き直すことによって高速化できました。
ラジオペンチさんのdrawToルーチンは巧妙かつシンプルなのですが、計算量が多くなります。
そこで泥臭く条件分けして計算量を減らしました。私の苦手なif-elseの入れ子状態(^^;;)なので頭が混乱してしまいます。
結果、描画速度は17.5mSになりました。これなら画面のちらつきはありません。
オシロで正月drawTo書き直し
数字の”1”の字体をちょっと変えてます。

74HC595を手に入れたのでR-2Rラダーで8BitDACを作ってもうちょっと高速化を試してみます。

一応スケッチを載せておきます。


/*
オシロに文字を書く。 2015 正月
オリジナル:ラジオペンチさんのブログ
http://radiopench.blog96.fc2.com/blog-entry-524.html

2015/01/07 シリアル接続DACに変更
http://edycube.blog2.fc2.com/blog-entry-728.html

2015/01/15 drawTo()を書き直す。
 */
 
#include <SPI.h>

const int CS_X = 5; //chip select
const int CS_Y = 6; //chip select
const int LDAC = 7; //load DAC
const int TEST = 8;
const int GAIN_1 = 0x1;
const int GAIN_2 = 0x0;
int xNow=0;
int yNow=0;
double count=0;

void setup(){
  pinMode(CS_X, OUTPUT);
  pinMode(CS_Y, OUTPUT);
  pinMode(LDAC, OUTPUT);
  pinMode(TEST, OUTPUT);
  pinMode(9,OUTPUT);
  digitalWrite(CS_X, HIGH);
  digitalWrite(CS_Y, HIGH);
  digitalWrite(LDAC, HIGH);
  digitalWrite(TEST, HIGH);
  Serial.begin(9600);
  SPI.begin();
  SPI.setDataMode(SPI_MODE0);
  SPI.setBitOrder(MSBFIRST) ;
  SPI.setClockDivider(SPI_CLOCK_DIV2);
}

void loop(){
  digitalWrite(TEST, LOW);
  digitalWrite(9, LOW); // CRT ON
  //count=0;
  moveTo(0,90);     // 2
  drawTo(5,100);
  drawTo(15,100);
  drawTo(20,90);
  drawTo(0,55);
  drawTo(20,55);

  moveTo(25,90);    // 0
  drawTo(30,100);
  drawTo(40,100);
  drawTo(45,90);
  drawTo(45,65);
  drawTo(40,55);
  drawTo(30,55);
  drawTo(25,65);
  drawTo(25,90);
  //drawTo(25,90);

  moveTo(55,95);   // 1
  drawTo(60,100);
  drawTo(60,55);
  moveTo(55,55);
  drawTo(65,55);

  moveTo(75,60);    // 5
  drawTo(80,55);
  drawTo(90,55);
  drawTo(95,60);
  drawTo(95,75);
  drawTo(90,80);
  drawTo(75,80);
  drawTo(75,100);
  drawTo(95,100);

  moveTo(15,40);  // 正
  drawTo(45,40);   // 上の線
  moveTo(30,40);   // 縦の線
  drawTo(30,0);
  moveTo(15,0);
  drawTo(45,0);
  moveTo(20,20);
  drawTo(20,0);
  moveTo(30,20);
  drawTo(40,20);

  moveTo(60,0);    // 月
  drawTo(60,40);  
  drawTo(80,40);
  drawTo(80,0);
  moveTo(60,25);
  drawTo(80,25);
  moveTo(60,15);
  drawTo(80,15);
  digitalWrite(9, HIGH); // オシロをブランキング
  digitalWrite(TEST, HIGH);
}

/*void drawTo(int x, int y){       // 指定座標まで線を描く
 int leng,xx,yy;
 leng = sqrt((x - xNow)*(x - xNow) + (y - yNow)*(y - yNow));
 for( int n=0; n<=leng; n++){
 xx=xNow + ((x-xNow)*n/leng);
 yy=yNow + ((y-yNow)*n/leng);
 plot(xx,yy);
 }
 xNow=x;
 yNow=y;
 }
 */

void drawTo(int xTo, int yTo){ // 指定座標まで線を描く
  int xx,yy,dx,dy,absdx,absdy;
  dx=xTo-xNow;
  dy=yTo-yNow;
  absdx=abs(dx);
  absdy=abs(dy);
  /*
  if ((absdx>=absdy) && (dx>=0)) {
   for(xx=xNow ; xx<xTo ; xx++) { yy=(xx-xNow)*dy/dx+yNow; plot(xx,yy);  }
   }
   if ((absdx>=absdy) && (dx<0)) {
   for(xx=xNow ; xx>xTo ; xx--) { yy=(xx-xNow)*dy/dx+yNow; plot(xx,yy); }
   }
   if ((absdx<absdy) && (dy>=0)) {
   for(yy=yNow ; yy<yTo ; yy++) { xx=(yy-yNow)*dx/dy+xNow; plot(xx,yy); }
   }
   if ((absdx<absdy) && (dy<0)) {
   for(yy=yNow ; yy>yTo ; yy--) { xx=(yy-yNow)*dx/dy+xNow; plot(xx,yy); }
   }
   */
  if (absdx>=absdy) {
    if (dx>=0) {
      for(xx=xNow ; xx<xTo ; xx++) {
        yy=(xx-xNow)*dy/dx+yNow; 
        plot(xx,yy); 
      }
    } 
    else { // dx<0
      for(xx=xNow ; xx>xTo ; xx--) {
        yy=(xx-xNow)*dy/dx+yNow; 
        plot(xx,yy); 
      }
    }
  } 
  else { // absdx<absdy
    if (dy>=0) {
      for(yy=yNow ; yy<yTo ; yy++) {
        xx=(yy-yNow)*dx/dy+xNow; 
        plot(xx,yy); 
      }
    }
    else { // dy<0
      for(yy=yNow ; yy>yTo ; yy--) {
        xx=(yy-yNow)*dx/dy+xNow; 
        plot(xx,yy); 
      }
    }
  }
  xNow=xTo;
  yNow=yTo;
}

void moveTo(int x, int y){ // 線の開始点を移動(線は書かない)
  digitalWrite(9, HIGH); // オシロをブランキング
  xNow=x;
  yNow=y;
  plot(xNow,yNow);
  digitalWrite(9, LOW); // CRT ON
}

void plot(unsigned int valX, unsigned int valY)
{
  byte lowByteX = (valX)<<4;
  byte highByteX = ((valX >> 4) ) | 0x10; //gain=2

  byte lowByteY = (valY)<<4;
  byte highByteY = ((valY >> 4) ) | 0x10;

  // digitalWrite(CS_X, LOW);
  PORTD=0B11000000;

  SPI.transfer(highByteX);
  SPI.transfer(lowByteX);

  //digitalWrite(CS_X, HIGH);
  PORTD=0B11100000;

  //digitalWrite(CS_Y, LOW);
  PORTD=0B10100000;

  SPI.transfer(highByteY);
  SPI.transfer(lowByteY);

  //digitalWrite(CS_Y, HIGH);
  PORTD=0B11100000;

  //digitalWrite(LDAC, LOW);
  PORTD=0B01100000;

  //digitalWrite(LDAC, HIGH);
  PORTD=0B11100000;
}


関連記事
スポンサーサイト

コメント

コメントの投稿

管理者にだけ表示を許可する

トラックバック

この記事へのトラックバックURL
http://edycube.blog.fc2.com/tb.php/731-93316b4c

 | HOME | 

文字サイズの変更

プロフィール

edy

最新記事一覧(サムネイル画像付き)

DABP発振回路を使ってキャパシタのESRを測定する構想(2)断念 2018/02/15
Androidアプリ:Resonance Calculator LC共振回路の計算に便利 2018/02/03
DABP発振回路を使ってキャパシタのESRを測定する構想(1)追記あり 2018/01/27
スマホとmicro:bitをBluetoothでつなぎたいのだが・・・。 2018/01/27
Androidアプリ:Signal Generator 2017/12/31
エレコム EHP-AHR192 を試す。(1) 2017/12/17
AliExpressでお買い物:TPS60403テスト 2017/12/02
AliExpressでお買い物:スイッチトキャパシタ電圧コンバータ三種(1) 2017/11/29
ATmega328 Maximum Frequency vs. VCC 2017/11/26
AC電力計(2) 2017/11/19

全記事表示リンク

全ての記事を表示する

リンク

このブログをリンクに追加する

月別アーカイブ

02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  04  03  02  12  11  10  09  07  05  04  03  04  03  01  12  11  10  08  07  06  05  03  02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  04  02  01  12  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  03  02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  10  09  08  07  06  05  04  03  02  01 

カテゴリ

プログラミング (0)
freescale (1)
AVR (3)
テルミン (16)
緊急警報放送 (3)
78K (1)
PSoC (295)
地上デジタル放送 (2)
電子工作 (434)
HX711 (2)
ACS712 (6)
数学 (6)
パソコン (12)
PLC (14)
未分類 (39)
ブログ関係 (20)
スカイプ (37)
ロボット (1)
LTSpice (8)
OCXO (0)
arduino (32)
maxima (1)
フランクリン発振回路 (3)
GPS (3)
DTMF (1)
Linux (1)
KOMAINO (7)
Android (1)

タグリスト

最近のコメント

最近のトラックバック

メールフォーム

名前:
メール:
件名:
本文:

検索フォーム

アクセス

RSSリンクの表示

ブログリンク

FC2Ad

まとめ

Template by たけやん