Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Define base primitives for digital back-end #117

Closed
mtrberzi opened this issue Jul 3, 2014 · 5 comments
Closed

Define base primitives for digital back-end #117

mtrberzi opened this issue Jul 3, 2014 · 5 comments

Comments

@mtrberzi
Copy link
Member

mtrberzi commented Jul 3, 2014

One point of contention will be how to represent these primitives in a way that the front-end can understand and that is compatible with how schematics are read.

I support keeping these separate from the back-end, in a JSON file similar to the schematic but that only defines node types/connection types/etc. The back-end would have a "hard-coded" representation of the types that it expects to see (and this could -- very possibly but not necessarily for our final demo -- result in automatic generation of this JSON file).

@mtrberzi mtrberzi added this to the Final Demo milestone Jul 3, 2014
@mtrberzi mtrberzi self-assigned this Jul 3, 2014
@mtrberzi
Copy link
Member Author

mtrberzi commented Jul 3, 2014

The primitives are probably going to be the following:

Node types:

  • register (ports: in, out, clock, reset) (attributes: initial value, reset polarity, reset asynchronous, clock polarity)
  • and (ports: in0, in1, out)
  • or
  • not (ports: in, out)
    (optionally: nand, nor, xor, xnor)
  • inputPin (ports: out)
  • outputPin (ports: in)

Connection types:

  • digitalWire

Port types:

  • digitalIn
  • digitalOut

@lucaswoj
Copy link
Contributor

lucaswoj commented Jul 4, 2014

I'm ok with everything except the exact of these primitives. At the risk of sounding pedantic, all the abbreviations and different naming conventions make this look bad.

A few high level points:

  • Do we really need to indicate within identifiers that wires, ports, and pins are "digital"? I would think that everything in the digital backend would be digital. Either everything should be prefixed with "digital" (undesirable) or nothing should be.
  • Register ports could be named "in", "out", "clock", and reset
  • Do we have to indicate the arity of our and/or/not/xor gates? Can we assume 2 until we see the need to support higher arity gates?
  • not1 ports could be named "in" and "out"
  • digitalInputPin could be renamed to inputPin (same for digitalWire, digitalIn, digitalOut)

@mtrberzi
Copy link
Member Author

mtrberzi commented Jul 4, 2014

This was a rough outline, but I appreciate the feedback. I'll definitely pick better naming conventions in release, and update that comment accordingly.

@mtrberzi
Copy link
Member Author

mtrberzi commented Jul 4, 2014

The reason wires and ports are called "digital" is because of potential namespace clashes with, for example, mixed-signal circuits that have both digital and microfluidic inputs and outputs.

@mtrberzi
Copy link
Member Author

Okay, I will provide JSON type definitions for these.

This issue was closed.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants