WaveDrom创建数字信号时序图

本文介绍了WaveDrom,一个用于在浏览器中绘制数字信号时序图的JavaScript应用。通过WaveJSON格式描述信号,包括时钟、信号状态变化、组合和自定义设置等,文章详细展示了如何使用WaveDrom生成和定制这些图表。
摘要由CSDN通过智能技术生成

Hitchhiker’s的WaveDrom使用指导(第一部分)

WaveDrom是一个Javascript应用程序。WaveJSON是一种描述数字信号时序图的格式。WaveDrom直接在浏览器中渲染图表。元素signalWaveLanes的组。每一个WaveLanes都有两个必不可少的域,namewave

第一步 信号

首先,我们用一个简单便捷的案例来开始。下面的代码将会生成一个名为Alfa的1bit的信号,并且展示了该信号的状态随时间的变化。

{signal: [{name: "Alfa", wave: "01.zx=ud.23.456789"}]}

每一个在wave字符串中的字符都代表了一个单独的时钟周期。
符号.代表了将上一个时钟周期的状态多保持一个时钟周期。
下面是这段代码渲染完之后的样子
在这里插入图片描述

第二步 添加时钟

数字时钟信号是一种特殊的信号。它在一个时钟周期内变化两次,拥有正、负两个极性。它可以选择是否显示触发边缘。时钟信号可以同其他信号状态混合来达到时钟门的效果。以下是它的代码:

{ signal: [
  { name: "pclk", wave: 'p.......' },
  { name: "Pclk", wave: 'P.......' },
  { name: "nclk", wave: 'n.......' },
  { name: "Nclk", wave: 'N.......' },
  {},
  { name: 'clk0', wave: 'phnlPHNL' },
  { name: 'clk1', wave: 'xhlhLHl.' },
  { name: 'clk2', wave: 'hpHplnLn' },
  { name: 'clk3', wave: 'nhNhplPl' },
  { name: 'clk4', wave: 'xlh.L.Hx' },
]}

渲染出来的图表是这样的
在这里插入图片描述

第三步 把所有的合在一起

典型的信号时序图拥有时钟和信号。多位的信号可以从data数组中提取标签。

{ signal: [
  { name: "clk",  wave: "P......" },
  { name: "bus",  wave: "x.==.=x", data: ["head", "body", "tail", "data"] },
  { name: "wire", wave: "0.1..0." }
]}

在这里插入图片描述

第四步 空格和间隙

{ signal: [
  { name: "clk",         wave: "p.....|..." },
  { name: "Data",        wave: "x.345x|=.x", data: ["head", "body", "tail", "data"] },
  { name: "Request",     wave: "0.1..0|1.0" },
  {},
  { name: "Acknowledge", wave: "1.....|01." }
]}

在这里插入图片描述

第五步 组

WaveLanes可以被规统一划到一个被命名的组当中。属于同一组的WaveLanes和组的名字一起放在一个数组中,["GroupName", {}, {},...]。这个数组的第一个元素必须是组的名字。组是可以嵌套使用的。

{ signal: [
  {    name: 'clk',   wave: 'p..Pp..P'},
  ['Master',
    ['ctrl',
      {name: 'write', wave: '01.0....'},
      {name: 'read',  wave: '0...1..0'}
    ],
    {  name: 'addr',  wave: 'x3.x4..x', data: 'A1 A2'},
    {  name: 'wdata', wave: 'x3.x....', data: 'D1'   },
  ],
  {},
  ['Slave',
    ['ctrl',
      {name: 'ack',   wave: 'x01x0.1x'},
    ],
    {  name: 'rdata', wave: 'x.....4x', data: 'Q2'},
  ]
]}

在这里插入图片描述

第六步 周期和相位

参数periodphase用来调整每一条WaveLane

{ signal: [
  { name: "CK",   wave: "P.......",                                              period: 2  },
  { name: "CMD",  wave: "x.3x=x4x=x=x=x=x", data: "RAS NOP CAS NOP NOP NOP NOP", phase: 0.5 },
  { name: "ADDR", wave: "x.=x..=x........", data: "ROW COL",                     phase: 0.5 },
  { name: "DQS",  wave: "z.......0.1010z." },
  { name: "DQ",   wave: "z.........5555z.", data: "D0 D1 D2 D3" }
]}

在这里插入图片描述

第七步 属性设置

config{...}是用来设置渲染效果的。

hecale

config{hscale:#}是用来控制图标的水平尺寸的。用户可以输入任意大于0的整数。

{ signal: [
  { name: "clk",     wave: "p...." },
  { name: "Data",    wave: "x345x",  data: ["head", "body", "tail"] },
  { name: "Request", wave: "01..0" }
  ],
  config: { hscale: 1 }
}
hecale=1(默认值)

在这里插入图片描述

hecale=2

在这里插入图片描述

hecale=3

在这里插入图片描述

skin

config{skin:'...'}是用来选择渲染风格的。这个选项只能存在于一个界面上的第一处时序图中。WaveDrom内提供了两种标准皮肤,defaultnarrow

head/foot

head:{...}foot:{...}是用来设置时序图上方和下方区域的文字内容用的。

  • tick
    • 在与垂直标记线对齐的位置添加时间线
  • tock
    • 在垂直标记线之间添加时间线
  • text
    • 添加标题文本
  • every
    • 每N个时间周期才显示一次ticktock
{signal: [
  {name:'clk',         wave: 'p....' },
  {name:'Data',        wave: 'x345x', data: 'a b c' },
  {name:'Request',     wave: '01..0' }
],
 head:{
   text:'WaveDrom example',
   tick:0,
   every:2
 },
 foot:{
   text:'Figure 100',
   tock:9
 },
}

在这里插入图片描述

head/foot具有SVG文本的所有属性。通过设置标准SVG属性tspan来修改文本的全部默认属性。可以使用JsonML标记语言来表示SVG文本的内容。同时,wavedrom提供了几种预设的格式,可以直接使用以及任意搭配:

  • h1 h2 h3 h4 h5 h6是预设的字体大小
  • muted warning error info success是预设的字体颜色

可以自由的搭配使用SVG属性tspan,如下所示:

{signal: [
  {name:'clk', wave: 'p.....PPPPp....' },
  {name:'dat', wave: 'x....2345x.....', data: 'a b c d' },
  {name:'req', wave: '0....1...0.....' }
],
head: {text:
  ['tspan',
    ['tspan', {class:'error h1'}, 'error '],
    ['tspan', {class:'warning h2'}, 'warning '],
    ['tspan', {class:'info h3'}, 'info '],
    ['tspan', {class:'success h4'}, 'success '],
    ['tspan', {class:'muted h5'}, 'muted '],
    ['tspan', {class:'h6'}, 'h6 '],
    'default ',
    ['tspan', {fill:'pink', 'font-weight':'bold', 'font-style':'italic'}, 'pink-bold-italic']
  ]
},
foot: {text:
  ['tspan', 'E=mc',
    ['tspan', {dy:'-5'}, '2'],
    ['tspan', {dy: '5'}, '. '],
    ['tspan', {'font-size':'25'}, 'B '],
    ['tspan', {'text-decoration':'overline'},'over '],
    ['tspan', {'text-decoration':'underline'},'under '],
    ['tspan', {'baseline-shift':'sub'}, 'sub '],
    ['tspan', {'baseline-shift':'super'}, 'super ']
  ],tock:-5
}
}

在这里插入图片描述

第八步 箭头

曲线

~ -~

<~> <-~>

~> -~> ~->

{ signal: [
  { name: 'A', wave: '01........0....',  node: '.a........j' },
  { name: 'B', wave: '0.1.......0.1..',  node: '..b.......i' },
  { name: 'C', wave: '0..1....0...1..',  node: '...c....h..' },
  { name: 'D', wave: '0...1..0.....1.',  node: '....d..g...' },
  { name: 'E', wave: '0....10.......1',  node: '.....ef....' }
  ],
  edge: [
    'a~b t1', 'c-~a t2', 'c-~>d time 3', 'd~-e',
    'e~>f', 'f->g', 'g-~>h', 'h~>i some text', 'h~->j'
  ]
}

在这里插入图片描述

折线

- -| -|-

<-> <-|> <-|->

-> -|> -|-> |->

+

{ signal: [
  { name: 'A', wave: '01..0..',  node: '.a..e..' },
  { name: 'B', wave: '0.1..0.',  node: '..b..d.', phase:0.5 },
  { name: 'C', wave: '0..1..0',  node: '...c..f' },
  {                              node: '...g..h' },
  {                              node: '...I..J',  phase:0.5 },
  { name: 'D', wave: '0..1..0',  phase:0.5 }
  ],
  edge: [
    'b-|a t1', 'a-|c t2', 'b-|-c t3', 'c-|->e t4', 'e-|>f more text',
    'e|->d t6', 'c-g', 'f-h', 'g<->h 3 ms', 'I+J 5 ms'
  ]
}

在这里插入图片描述

第九步 一些代码

(function (bits, ticks) {
  var i, t, gray, state, data = [], arr = [];
  for (i = 0; i < bits; i++) {
    arr.push({name: i + '', wave: ''});
    state = 1;
    for (t = 0; t < ticks; t++) {
      data.push(t + '');
      gray = (((t >> 1) ^ t) >> i) & 1;
      arr[i].wave += (gray === state) ? '.' : gray + '';
      state = gray;
    }
  }
  arr.unshift('gray');
  return {signal: [
    {name: 'bin', wave: '='.repeat(ticks), data: data}, arr
  ]};
})(5, 16)

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值