Drexel dragonThe Math ForumDonate to the Math Forum



Search All of the Math Forum:

Views expressed in these public forums are not endorsed by Drexel University or The Math Forum.


Math Forum » Discussions » Software » comp.soft-sys.math.mathematica

Topic: Overriding the single quote (')
Replies: 2   Last Post: May 23, 2013 3:50 AM

Advanced Search

Back to Topic List Back to Topic List Jump to Tree View Jump to Tree View   Messages: [ Previous | Next ]
David Bailey

Posts: 714
Registered: 11/7/08
Re: Overriding the single quote (')
Posted: May 19, 2013 5:46 AM
  Click to see the message monospaced in plain text Plain Text   Click to reply to this topic Reply

On 17/05/2013 09:34, Lawrence Walker wrote:
> The Verilog "programming" language provide a compact way to describe and work with digital circuits. The language features a nifty syntax for representing bits. For example 3'b101 is the 3 bit unsigned binary number 101. 3'd5 is the same binary number but represented as the decimal 5.
>
> I wanted to set up an expression in Mathematica such as f[3'b101] rather than the more verbose f["3'b101"].
>
> I thought I could simply set f to hold all its arguments using SetAttributes[f,HoldAll]. But FullForm[f[3'b101]] results in f[Times[Derivative[1][2], b101]].
>
> I tried to "control the evaluation" using $PreRead and $Pre. I observed that Mathematica replaces the single-quote with Derivative sometime between $PreRead and $Pre. The closest I got to the solution is that I've managed to assign $PreRead a purefunction that will convert f[3'b101] to f["3'b101"]. (With 3'b101 as a string, Mathematica will not convert to Derivative.) But then, how do I set $Post to convert f["3'b101"] to f[3'b101]?
>
> Does anyone know how to set Mathematica to avoid replacing single-quote with a Derivative under special circumstances?
>
> Thanks,
> Lawrence
>
>

On 17/05/2013 09:34, Lawrence Walker wrote:> The Verilog "programming"
language provide a compact way to describe and work with digital
circuits. The language features a nifty syntax for representing bits.
For example 3'b101 is the 3 bit unsigned binary number 101. 3'd5 is the
same binary number but represented as the decimal 5.
>
> I wanted to set up an expression in Mathematica such as f[3'b101]

rather than the more verbose f["3'b101"].
>
> I thought I could simply set f to hold all its arguments using

SetAttributes[f,HoldAll]. But FullForm[f[3'b101]] results in
f[Times[Derivative[1][2], b101]].
>
> I tried to "control the evaluation" using $PreRead and $Pre. I

observed that Mathematica replaces the single-quote with Derivative
sometime between $PreRead and $Pre. The closest I got to the solution
is that I've managed to assign $PreRead a purefunction that will convert
f[3'b101] to f["3'b101"]. (With 3'b101 as a string, Mathematica will
not convert to Derivative.) But then, how do I set $Post to convert
f["3'b101"] to f[3'b101]?
>
> Does anyone know how to set Mathematica to avoid replacing

single-quote with a Derivative under special circumstances?
>
> Thanks,
> Lawrence
>
>

If you want to process a language that is not Mathematica friendly, it
is probably best to store the text in a file, and read it in through a
simple parser written in Mathematica.

Alternatively, you could write a simple translator to take Verilog into
something more Mathematica friendly - perhaps 3'b101' could become "101"
or "b101" if there were no ambiguity with strings of other information.
You could pad with leading zeros if necessary to specify the bit length
- e.g. 5'b101 would be "b00101" .

My gut feeling is that fooling about with $Pre and $PreRead, etc. is a
recipe for wasting time handling too many gotcha's!

David Bailey
http://www.dbaileyconsultancy.co.uk




Point your RSS reader here for a feed of the latest messages in this topic.

[Privacy Policy] [Terms of Use]

© Drexel University 1994-2014. All Rights Reserved.
The Math Forum is a research and educational enterprise of the Drexel University School of Education.