Skip to content

Create WaveJSON from VCD file. WaveDrom can convert it to timing diagram.

License

Notifications You must be signed in to change notification settings

anders-code/vcd2json

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

vcd2json

This python module generates WaveJSON text string from VCD file. WaveJSON string can be converted to image file of timing diagram.

Usage

Here is an example. See also example.py.

from vcd2json import WaveExtractor

path_list = ['tb_timer/u_timer/clock',
             'tb_timer/u_timer/reset',
             'tb_timer/u_timer/pulse',
             'tb_timer/u_timer/count_eq11',
             'tb_timer/u_timer/count']

extractor = WaveExtractor('timer.vcd', 'timer.json', path_list)
extractor.execute()

The following JSON formatted text is generated.

{ head: {tock:1},
  signal: [
  {   name: 'clock'     , wave: 'p...................' },
  {},
  ['10',
    { name: 'reset'     , wave: '0...1....0..........' },
    { name: 'pulse'     , wave: 'x.....0.............' },
    { name: 'count_eq11', wave: 'x....0..............' },
    { name: 'count'     , wave: 'x....=....==========', data: '0 1 2 3 4 5 6 7 8 9 a' },
  ],
  {},
  ['410',
    { name: 'reset'     , wave: '0...................' },
    { name: 'pulse'     , wave: '010..........10.....' },
    { name: 'count_eq11', wave: '10..........10......' },
    { name: 'count'     , wave: '====================', data: 'b 0 1 2 3 4 5 6 7 8 9 a b 0 1 2 3 4 5 6' },
  ],
  {},
  ['810',
    { name: 'reset'     , wave: '0........' },
    { name: 'pulse'     , wave: '0....10..' },
    { name: 'count_eq11', wave: '0...10...' },
    { name: 'count'     , wave: '=========', data: '7 8 9 a b 0 1 2 3' },
  ],
  ],
}

You can create SVG image from WaveJSON by using JavaScript application WaveDrom.

timing diagram

Module Detail

NAME
    vcd2json - Create WaveJSON text string from VCD file.

CLASSES
    class WaveExtractor(builtins.object)
     |  Methods defined here:
     |
     |  __init__(self, vcd_file, json_file, path_list)
     |      Extract signal values from VCD file and output in JSON format.
     |      Specify VCD filename, JSON filename, and signal path list.
     |      If <json_file> is an empty string, standard output is used.
     |      Use slashes to separate signal path hierarchies.
     |      The first signal of the list is regarded as clock.
     |      Other signals are sampled on the negative edge of the clock.
     |
     |  print_props(self)
     |      Display the properties. If an empty path list is given to
     |      the constructor, display the list created from the VCD file.
     |
     |  wave_format(self, signal_path, fmt)
     |      Set the display format of the multi-bit signal. <fmt> is
     |      one of the following characters. The default is 'x'.
     |      'b' - Binary.
     |      'd' - Signed decimal.
     |      'u' - Unsigned decimal.
     |      'x' - Hexa-decimal, lowercase is used.
     |      'X' - Hexa-decimal, uppercase is used.
     |
     |  execute(self)
     |      Perform signal sampling and JSON generation.
     |
     |  ----------------------------------------------------------------------
     |  Data descriptors defined here:
     |
     |  wave_chunk
     |      Number of wave samples per time group.
     |
     |  start_time
     |      Sampling start time.
     |
     |  end_time
     |      Sampling end time.

About

Create WaveJSON from VCD file. WaveDrom can convert it to timing diagram.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 91.1%
  • Verilog 8.9%