I worked with Altium and KiCad, to be honest I like KiCad more.
My location:
-Working with Kicad is much easier and faster
- KiCad has simple and understandable menus, unlike Altium which has nested and confusing menus.
-KiCad has a very good default library, in Altium I have to spend hours searching for a specific footprint or designing it myself. - (at least for me) designing and finishing a project in KiCad is much faster than Altium.
Of course, I agree that KiCad has disadvantages compared to Altium that can be fixed.
Please be more explicit with your comment. Devs. are reading this thread so any realistic comments may be of use for the development of Kicad.
“has disadvantages” is a totally useless comment with respect to improving Kicad.
Yes, one can do a lot of things manually in KiCAD. That’s the main pain - manually. With impedance profiles it is possible to go from layer to layer and Altium will change trace width and even via type to match the target impedance profile. Granted, for PCIe routing Altium can’t do proper layer transitions, with cutouts and via stitching But it’s a time saver non the less. And what is useful with the profiles is the possibility to update the traces if stackup is changed. It’s not always friction free updates, but 80%ish.
Yes, that issue has been there for some time I hope we get there some day. I so don’t want to use Altium anymore.
First, we need to solve problems that are 4-5 years old and are carried over from version to version.
You can do something very similar if you assign each net with an impedance requirement to a specific netclass. You can then set DRC rules like this:
(version 1)
(rule CLASS1_F
(condition "A.hasNetclass('CLASS1')")
(layer "F.Cu")
(constraint track_width (opt 50mil))
)
(rule CLASS1_In1
(condition "A.hasNetclass('CLASS1')")
(layer "In1.Cu")
(constraint track_width (opt 60mil))
)
(rule CLASS1_In2
(condition "A.hasNetclass('CLASS1')")
(layer "In2.Cu")
(constraint track_width (opt 70mil))
)
(rule CLASS1_B
(condition "A.hasNetclass('CLASS1')")
(layer "B.Cu")
(constraint track_width (opt 80mil))
)
And configure the router to ‘Use netclass width’, and disable ‘Track width from existing track’ (the drop-down and button shown here):
The router will then pick up the required track width every time you start a new segment. The same should work for vias, but I haven’t tried that in a while.
The biggest feature that KiCad has over Altium - the one that makes it a clear winner - is that it is cross-platform.
Until Altium has MacOS and Linux versions, it’s useless to me.
Interesting. I haven’t played with rules that much in KiCAD. I will give it a go. One thing that comes to mind right away is how I would manage all these rules for all the stackups I have.
I have about 10 common stackups for 10-16 layer PCBs and relatively frequently need custom stuff as well. Has anyone made some management system for rules already?
The KiCad way to do this is to make project templates for each thing you do commonly. You then do New from Template to get a project with all the design rules set up.
Many defects have been mentioned by other users in this thread.
However, if something new comes to my mind I will say it here.
I don’t want to be picky but I wouldn’t talk about ‘defects’ either.
Note that Altium is a commercial software while KiCad is not. This nuance is very important before making an x vs y comparison.
This is a common statement in various forms, but I don’t agree completely. What should count for business (company which designs PCB’s) is cost/benefit ratio. There price is important.
But if we are talking about planning KiCad’s direction, future development and features, the price of the software or commercial vs. non-commercial isn’t meaningful at all.
Yes, but the intention of the question was just that. Raw comparison of x vs y. It’s just to know about what features or capabilities one have over the other. It’s not like comparing the softwares taking into account the circumstances of each software from an economic point of view
I would interpret ‘defect’ as a synonym for ‘bug’. What I wouldn’t say is that “Altium does this but KiCad doesn’t” is a defect. It might be a missing feature, or it might be something KiCad does differently. It is not intended to be an Altium clone; far from it in fact.
It’s a fair point, and I don’t disagree. That said, I’ve used the feature in Altium for years, so… I miss it. If there was some vastly easier tool to make simple 3D bodies that didn’t have the overhead of FreeCAD I’d be interested. At the moment I don’t have the time to learn FreeCAD so… on a KiCAD project that I did, I went into Altium, made the 3D body I was after, exported the step, and got what I wanted in KiCAD. [I forget what it was, something with some extrusions, like a rubber bumpon that I couldn’t find an official step for.]
I would agree with you, simpler is better. Less menus, less buttons, less things to set wrong. Less of a learning curve.
I don’t know if Altium is trying to compete with KiCAD, but I don’t think it is. IMO they are aiming for big companies who can scoff at the bill. Altium wants to play with the big players on the cloud.
Agreed on the buggy code, that has always been a problem. On the flip side, as I look at your plugins, as a non-programmer I’m finding myself overwhelmed by trying to learn git and all the overhead there. Well done or not, Altium attempts to integrate these features. Going back to the FreeCAD comment, I don’t have to learn that tool to make simple 3D bodies–in minutes I can hack together a “good enough” solution. Inside of the tool I’m used to using. Time is money, and Altium is aiming at a market that lives and dies by that. It only has to do all the required things “good enough”, because most users will only work on something for a period of time before going off to the next project.
I do intrinsically safe layout with Altium from time to time and it has a lot more features to accomplish that, you wouldn’t have a hope of doing that with kicad.
The ERC/DRC is way, way better with Altium, much more complex and flexible, kicad is really poor in this area.
Altium is absolutely packed full of other features kicad doesn’t have.
BUT, and this is a big but, for most people they are features that you are unlikely to want or need for most boards. (DRC checking aside.)
Also, kicad’s user interface is light years ahead of Altium’s which is just terrible. Really atrociously bad, arcane, frustrating. It’s too complex for its own good at times. And it’s insanely expensive and only works on Windows.
If you are doing standard boards without HV tracks that want different DRC constraints, kicad is truly excellent. Even if you are wanting different rules for different tracks it is possible, but doesn’t work well like it does on Altium.
Altium also has a number of poor bugs that drive me potty at times and it’s slow, resource heavy whereas kicad is snappy and responsive. I enjoy routing with kicad, I generally hate routing with Altium.
I route boards with lots of different complex DRC rules in KiCad, and I think it works well. If there are parts that don’t work well for you, it would be useful to open bug reports or threads about them in more detail. From my point of view, there are very few relevant DRC things outside of some DFM checks and time-domain signal integrity that are possible in Altium but not in KiCad.
I think it’s pretty incredible that this thread exists at all.
I mean - comparing a free and open-source program with one that costs thousands of dollars per seat per year?
If this was KiCad vs. Fritzing, I could see it.
That said - KiCad comes out pretty well, doesn’t it?
On a multi lingual/national forum, I’d not too much importance on it.
To amplify @craftyjon’s reply - it would be really useful to know what you think is missing. The KiCad DRC engine is pretty powerful, but can always be improved if people have use-cases we’re missing. ERC is an interesting one; I’ve never found KiCad’s lacking, but it is a one-size-fits-all. It would be great to know what use-cases you have that it doesn’t cover. Putting these in a GitLab issue is the best way then we can track them.