X-Authentication-Warning: delorie.com: mail set sender to geda-user-bounces using -f X-Recipient: geda-user AT delorie DOT com X-Original-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :content-type; bh=yJfICWIsVuWnM2++gbU0YigBajWkijtegHlGy1AtABU=; b=Q4TeB0drfyAqZ/WXCba/MlhlZH9Lf5ZUYcDvapRJxJrw7JL+9JS+kfKxtw6sQD3xp6 cKe3LoMlO4bgguAs/pX4SQcMPPIMsl45bvmEdhXsaZIpDr28AOZtIkLGtu+4s+zaIMx2 PHN6/2s6BZLODLsgL7dPReVdiz3zGmkzXli5/8lyT6ZDAr/MK5t/e3MY0fwHnGLtIf1n 2/aYuqs7XfAnn9iuNW7VT6B4lzeYjCHDMLQOuPazEgPMfOPJuuM4+l91pNXz9tl3RO6Z hz9GmXlj0ceBOAznITA+tDCoIDbm/P5utZEWo1yuAtOBISXqVETwsmNOL0nA5pTCPcrm Fc6A== MIME-Version: 1.0 X-Received: by 10.180.187.240 with SMTP id fv16mr8215921wic.57.1444012718365; Sun, 04 Oct 2015 19:38:38 -0700 (PDT) In-Reply-To: <1443997480.2068.32.camel@ssalewski.de> References: <20151003210701 DOT de392b925f54dadb0a5fedd8 AT gmail DOT com> <1443903758 DOT 1873 DOT 13 DOT camel AT ssalewski DOT de> <56104A0A DOT 9020507 AT xs4all DOT nl> <1443909591 DOT 1873 DOT 18 DOT camel AT ssalewski DOT de> <1443975731 DOT 671 DOT 52 DOT camel AT ssalewski DOT de> <20151004191717 DOT bf8223417541a9306bfbd9ea AT gmail DOT com> <1443997480 DOT 2068 DOT 32 DOT camel AT ssalewski DOT de> Date: Sun, 4 Oct 2015 18:38:38 -0800 Message-ID: Subject: Re: [geda-user] GTK3, Glade interface designer (router, auto?) From: "Britton Kerin (britton DOT kerin AT gmail DOT com) [via geda-user AT delorie DOT com]" To: geda-user AT delorie DOT com Content-Type: multipart/alternative; boundary=001a11c262d82121260521526935 Reply-To: geda-user AT delorie DOT com Errors-To: nobody AT delorie DOT com X-Mailing-List: geda-user AT delorie DOT com X-Unsubscribes-To: listserv AT delorie DOT com Precedence: bulk --001a11c262d82121260521526935 Content-Type: text/plain; charset=UTF-8 On Sun, Oct 4, 2015 at 2:24 PM, Stefan Salewski wrote: > On Sun, 2015-10-04 at 13:16 -0800, Britton Kerin ( > britton DOT kerin AT gmail DOT com) [via geda-user AT delorie DOT com] wrote: > > [...] > > > > Well I thought it was all really exciting, but it wasn't obvious how it > > could be integrated with pcb (being in Ruby). But now some serious > efforts > > are being considere to make a much more accessible file format (via sql > and > > YAML) so it could be provided as a stand-alone tool that would be useful > to > > pcb users. > > > > If the router could route all traces, we could simply import the traces. > That is what I did for the example picture. Better is a very basic GUI > tool, where we can move elements and grab rubberbands and move them. > > > > > > > People seem to prefer manually routing, and many seem to not like > > > > curved traces. > > > > > > > > I do not really understand your term "intra-layer". My router is > using > > > > arbitrary numbers of layers, and it connect the layers with > > > > automatically placed vias. Testing was done with two layers. I have > > > > some problems remembering details, have not touched it for more than > > > > too years. I think no crashes. The problem is, that there can remain > > > > > > > Great! I had the impression from pics on your site and something Kai > said > > that just the rubber band part was done. > > The layer assignment was described in detail in the thesis, it was easy > coding that, and it works not bad. But there is room for improvement, > but I forgot details. But I think I will be able to remember when I work > again on that. > > > > > > > > > unrouted traces due to space constraints. So some user interaction > > > > would be needed, for example for moving parts. Coding that part would > > > > be the fastest way to make that router useful, but coding that part > is > > > > not really much fun and take some time. And when no one is interested > > > > at all? Making the router working without user interaction may be > more > > > > interesting, that would include moving components. But that is more > > > > difficult and would need some time for coding. > > > > > > > I take it the remaining traces are really hard to subsequently add by > > hand? Are there options other than moving parts to make is useful, maybe > > somehow less ambitious or cost function rewards "ports" or something? > > Importing the traces in PCB program and then fixing it would be > generally possible, but not really nice. When we have curved traces from > autorouter, we generally do not want some straight manually inserted > once. For the example pictures I have painted the missing unrouted > traces in white color, you can see that generally manually fixing is not > hard -- insert some vias, rearrange some traces. But a tool that can > handle rubberbands well would be nice for that. > > Another unsolved task is feeding trace parameters like trace width and > clearance into the router. Generally that is not equal for all traces. > My initial idea was taking these parameters from the schematic, but an > editing option for the router would be fine, which may need GUI support. > I think pcb has defaults for these, and saves them in each file also as overrides. So they could be gotten from an existing pcb file. Or is making the router implement different parameters the hard part? > > > > > > > > But I think I will continue at some time. The code is easy, short, > and > > > > mostly based on that PhD thesis. But I have never cleaned it up > > > > unfortunately, and for latest CGAL and Ruby 2.2 some fixes may be > > > > necessary. Porting to Nim would be nice, but for that I would have to > > > > create bindings for CGAL first. Porting to C++ would be an option too > > > > of course, then I need no CGAL bindings, and integration in PCB > program > > > > is easier. But that would be no fun for me. > > > > > > > I would rather it stay Ruby, rather than be ported to any of those other > > things. In addition to not being fun it would make it less accessible I > > think. I looked at the Ruby at the time and it seemed quite nice. > > Ruby seems to be not that popular any more, most people prefer Python > now. With Nim the code would look similar nice, but speed would be at > least ten times faster. Routing the demos took a few seconds in Ruby, > but for really large boards speed can become important. > TIOBE showing Ruby still gaining http://www.tiobe.com/index.php/content/paperinfo/tpci/index.html I didn't mind it except it's error message are bad compared to perl (which desperately needs its smart error messages :). Carbon cycles are move valuable than silicon cycles, the Ruby implementation largely exists already, I think there is no reason to feel bad for not rewriting in any other language. --001a11c262d82121260521526935 Content-Type: text/html; charset=UTF-8 Content-Transfer-Encoding: quoted-printable


On Sun, Oct 4, 2015 at 2:24 PM, Stefan Salewski <<= a href=3D"mailto:mail AT ssalewski DOT de" target=3D"_blank">mail AT ssalewski DOT de= > wrote:
On Sun, 2015-10-04 at 13:16 -0800, B= ritton Kerin (
britton DOT kerin AT gmail DOT com) [vi= a geda-user AT delorie DOT com] wrote= :

[...]


> Well I thought it was all really exciting, but it wasn't obvious h= ow it
> could be integrated with pcb (being in Ruby).=C2=A0 But now some serio= us efforts
> are being considere to make a much more accessible file format (via sq= l and
> YAML) so it could be provided as a stand-alone tool that would be usef= ul to
> pcb users.
>

If the router could route all traces, we could simply import the tra= ces.
That is what I did for the example picture. Better is a very basic GUI
tool, where we can move elements and grab rubberbands and move them.

>
> > > People seem to prefer manually routing, and many seem to not= like
> > > curved traces.
> > >
> > > I do not really understand your term "intra-layer"= . My router is using
> > > arbitrary numbers of layers, and it connect the layers with<= br> > > > automatically placed vias. Testing was done with two layers.= I have
> > > some problems remembering details, have not touched it for m= ore than
> > > too years. I think no crashes. The problem is, that there ca= n remain
> >
>
> Great!=C2=A0 I had the impression from pics on your site and something= Kai said
> that just the rubber band part was done.

The layer assignment was described in detail in the thesis, it was e= asy
coding that, and it works not bad. But there is room for improvement,
but I forgot details. But I think I will be able to remember when I work again on that.

>
>
> > > unrouted traces due to space constraints. So some user inter= action
> > > would be needed, for example for moving parts. Coding that p= art would
> > > be the fastest way to make that router useful, but coding th= at part is
> > > not really much fun and take some time. And when no one is i= nterested
> > > at all? Making the router working without user interaction m= ay be more
> > > interesting, that would include moving components. But that = is more
> > > difficult and would need some time for coding.
> >
>
> I take it the remaining traces are really hard to subsequently add by<= br> > hand?=C2=A0 Are there options other than moving parts to make is usefu= l, maybe
> somehow less ambitious or cost function rewards "ports" or s= omething?

Importing the traces in PCB program and then fixing it would be
generally possible, but not really nice. When we have curved traces from autorouter, we generally do not want some straight manually inserted
once. For the example pictures I have painted the missing unrouted
traces in white color, you can see that generally manually fixing is not hard -- insert some vias, rearrange some traces. But a tool that can
handle rubberbands well would be nice for that.

Another unsolved task is feeding trace parameters like trace width and
clearance into the router. Generally that is not equal for all traces.
My initial idea was taking these parameters from the schematic, but an
editing option for the router would be fine, which may need GUI support.

I think pcb has defaults for t= hese, and saves them in each file also as overrides.=C2=A0 So they could be= gotten from an existing pcb file.=C2=A0 Or is making the router implement = different parameters the hard part?
=C2=A0
>
>
> > > But I think I will continue at some time. The code is easy, = short, and
> > > mostly based on that PhD thesis. But I have never cleaned it= up
> > > unfortunately, and for latest CGAL and Ruby 2.2 some fixes m= ay be
> > > necessary. Porting to Nim would be nice, but for that I woul= d have to
> > > create bindings for CGAL first. Porting to C++ would be an o= ption too
> > > of course, then I need no CGAL bindings, and integration in = PCB program
> > > is easier. But that would be no fun for me.
> >
>
> I would rather it stay Ruby, rather than be ported to any of those oth= er
> things.=C2=A0 In addition to not being fun it would make it less acces= sible I
> think.=C2=A0 I looked at the Ruby at the time and it seemed quite nice= .

Ruby seems to be not that popular any more, most people prefer Pytho= n
now. With Nim the code would look similar nice, but speed would be at
least ten times faster. Routing the demos took a few seconds in Ruby,
but for really large boards speed can become important.

I didn't mind it except it's error message are bad compar= ed to perl (which desperately needs its smart error messages :).
Carbon cycles are move valuable than silicon cycles, the Ruby im= plementation largely exists already, I think there is no reason to feel bad= for not rewriting in any other language.
--001a11c262d82121260521526935--