Eugen Graf Posted June 10, 2008 Report Share Posted June 10, 2008 Is a data wire a node ? I think a node shoud have: Input Output Functionatity A wire has it (Funktionality is the tamporary saving of data value). What do you think about it? Link to comment
crelf Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (Eugen Graf @ Jun 9 2008, 08:45 AM) Is a data wire a node ? I think a node shoud have: Input, Output, Functionatity. A wire has it (Funktionality is the tamporary saving of data value). What do you think about it? No, it doesn't. I see it as a pointer back to the output of the last node. That said, LVOOP wires might be considered differently, as branches instantiate? Link to comment
Eugen Graf Posted June 10, 2008 Author Report Share Posted June 10, 2008 QUOTE (crelf @ Jun 9 2008, 03:01 PM) No, it doesn't. I see it as a pointer back to the output of the last node. That said, LVOOP wires might be considered differently, as branches instantiate? Ok, a pointer, not a "C-local variable"? Or is it like this? struct inputs1; struct inputs2; struct outputs1; struct outputs2; and if i call a SubVI, than VI2(inputs2) { return output2=0 } VI1(inputs1) { return output1 = VI2(inputs1); } and so on. I think you understand what I mean. Thank you Link to comment
shoneill Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (crelf @ Jun 9 2008, 03:01 PM) No, it doesn't. I see it as a pointer back to the output of the last node. That said, LVOOP wires might be considered differently, as branches instantiate? All branches can cause data copies. The only difference is that a LVOOP copy (By reference to its class) includes references to methods. Otherwise no different from any other branches really. Shane. Link to comment
crelf Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (Eugen Graf @ Jun 9 2008, 09:03 AM) Ok, a pointer, not a "C-local variable"? Can't help you there - it's be far too long since I've used C. If you want to make a point, I'd prefer it if you could without referencing other languages - try describing it instead. Link to comment
crelf Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (shoneill @ Jun 9 2008, 09:19 AM) All branches can cause data copies. The only difference is that a LVOOP copy (By reference to its class) includes references to methods. Otherwise no different from any other branches really. Good point. Link to comment
Aristos Queue Posted June 10, 2008 Report Share Posted June 10, 2008 A wire is equivalent to a C++ const variable declared on the stack. In other words, it is a variable that you can only assign to once. Nodes are the functions that read those variables and write new variables. Having said that, a wire that forks is a bit different. This NodeA ------------------+----------------NodeB | | | +----------------NodeC is equivalent to this: NodeA ------------- CopyNode--------------NodeB | | | +----------------NodeC Link to comment
crelf Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (Aristos Queue @ Jun 9 2008, 10:45 AM) Nodes are the functions that read those variables and write new variables. Having said that, a wire that forks is a bit different. This... is equivalent to this... So a wire isn't a node, but the act of branching can be considered a node? Link to comment
Aristos Queue Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (crelf @ Jun 9 2008, 10:15 AM) So a wire isn't a node, but the data associated to the act of branching can be considered a node? More exactly, the *act* of copying data can be considered a node. Wires are data. Nodes are actions. Specifically, nodes are actions on that data. Link to comment
LAVA 1.0 Content Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (Aristos Queue @ Jun 9 2008, 11:25 AM) More exactly, the *act* of copying data can be considered a node. Wires are data. Nodes are actions. Specifically, nodes are actions on that data. But not all branches are data copies. Ex: Get array size (does not mod data) can be scheduled before array is used. Ben Link to comment
crelf Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (Aristos Queue @ Jun 9 2008, 11:25 AM) More exactly, the *act* of copying data can be considered a node. Wires are data. Nodes are actions. Specifically, nodes are actions on that data. Right - that was what I was thinking, but not typing I appreciate your elloquence. Link to comment
Eugen Graf Posted June 10, 2008 Author Report Share Posted June 10, 2008 Thank you all for explanations. Regards, Eugen Link to comment
Justin Goeres Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (Aristos Queue @ Jun 9 2008, 08:25 AM) More exactly, the *act* of copying data can be considered a node. Wires are data. Nodes are actions. Specifically, nodes are actions on that data. So the dot at the junction (if you have show dots at wire junctions turned on) is (or can be) a node. How delightfully literal! Link to comment
Eugen Graf Posted June 10, 2008 Author Report Share Posted June 10, 2008 And what is with tunnels ? Link to comment
Yair Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (Eugen Graf @ Jun 9 2008, 10:51 PM) And what is with tunnels ? The wires on separate sides of the tunnel are not the same wire. Link to comment
Eugen Graf Posted June 10, 2008 Author Report Share Posted June 10, 2008 QUOTE (Yen @ Jun 9 2008, 09:56 PM) The wires on separate sides of the tunnel are not the same wire. So a tunnel will copy the data from one wire to other and is a node at all because of copy action ? Ok. Is a input or output of a subvi a node? Do it copy data? I think no, but I am not sure. Link to comment
crelf Posted June 10, 2008 Report Share Posted June 10, 2008 These are all great questions Eugen, but I'm interested in why you want to know - what are you up to? :ninja: Link to comment
Eugen Graf Posted June 10, 2008 Author Report Share Posted June 10, 2008 QUOTE (crelf @ Jun 9 2008, 11:17 PM) These are all great questions Eugen, but I'm interested in why you want to know - what are you up to? :ninja: I think you know it, I want to write my tutorial and have to know these things to be sure what I write. Link to comment
crelf Posted June 10, 2008 Report Share Posted June 10, 2008 QUOTE (Eugen Graf @ Jun 9 2008, 05:21 PM) I think you know it, I want to write my tutorial and have to know these things to be sure what I write. Oh - Okay - I didn't know that you were writing a tutorial. Good luck! Link to comment
Yair Posted June 11, 2008 Report Share Posted June 11, 2008 I'm not sure you should get so hung up about the term "node". Personally, I think of any structure, primitive or subVI as nodes, but if you take Stephen's C++ analogy ("Nodes are the functions that read those variables and write new variables") then the answer to your question is yes, because the wires are separate. Personally, I don't think this level of detail should go in most tutorials and you can probably find better terminology. As a side point, QUOTE (Eugen Graf @ Jun 9 2008, 11:46 PM) So a tunnel will copy the data from one wire to other and is a node at all because of copy action?Is a input or output of a subvi a node? Do it copy data? In both cases, a copy of the data may be made, but LabVIEW tries to optimize the memory usage and reuse existing buffers when possible instead of allocating new ones. This can happen both in case structures and in subVIs and is not always easy to predict. If you want more data, a search for "inplaceness" should reveal all kinds of stuff. Link to comment
Aristos Queue Posted June 11, 2008 Report Share Posted June 11, 2008 QUOTE (Eugen Graf @ Jun 9 2008, 04:21 PM) I think you know it, I want to write my tutorial and have to know these things to be sure what I write. This isn't the kind of information I would ever put into a tutorial for beginners. It's theoretical information for folks who are interested in language theory. I can pretty much guarantee -- based on almost a decade of teaching LV to programmers of C++ -- that it would be very unhelpful to get any programmer to actually think of wires as variables. It doesn't work to think of the dataflow that way. You'll end up with people dropping controls as a way of "instantiating" a variable (i.e. giving a wire a starting point). Trust me on this. I've seen it happen more than once. LV is best explained as data which flows from node to node, and noting the wires merely as connections between nodes. Don't try to get into any "a wire is a variable" nonsense. QUOTE (Eugen Graf @ Jun 9 2008, 03:46 PM) So a tunnel will copy the data from one wire to other and is a node at all because of copy action ? Ok. A tunnel is neither a node nor a wire. A tunnel is a tunnel. And depending upon what structure that tunnel is on, it has different behavior. A tunnel on a sequence structure is a no-op. A tunnel on a loop is not. But you cannot define a tunnel in terms of "variable" and "function". It is a director in the dataflow. QUOTE Is a input or output of a subvi a node? Do it copy data? I think no, but I am not sure. A subVI call does not copy data, though it may be what causes a forking wire to decide to copy of data. Link to comment
crelf Posted June 12, 2008 Report Share Posted June 12, 2008 QUOTE (Aristos Queue @ Jun 10 2008, 02:26 PM) You'll end up with people dropping controls as a way of "instantiating" a variable (i.e. giving a wire a starting point). Or enabling datasocket on FP controls as a method of passing data around its own BD... Link to comment
Rolf Kalbermatter Posted June 22, 2008 Report Share Posted June 22, 2008 QUOTE (Aristos Queue @ Jun 10 2008, 02:26 PM) LV is best explained as data which flows from node to node, and noting the wires merely as connections between nodes. Don't try to get into any "a wire is a variable" nonsense. I have an electrical engineering background and when I first encountered LabVIEW the similarity of it's diagrams with an electrical schemata was what made it very easy for me to grasp the idea and even like it very much. The rest was just getting used to specific LabVIEW ideas such as how loops, cases and such were done and here traditional programming theory from my Pascal days which used to be thought in rather formalistic ways back in those days helped of course. Thinking of wires as variables only occurred to me later when I tried to come up with explanations of how LabVIEW works but it never struck me as something elegant and I never really tried to push that idea much further. Rolf Kalbermatter Link to comment
crelf Posted June 22, 2008 Report Share Posted June 22, 2008 QUOTE (rolfk @ Jun 21 2008, 05:29 AM) I have an electrical engineering background and when I first encountered LabVIEW the similarity of it's diagrams with an electrical schemata was what made it very easy for me to grasp the idea and even like it very much. I used to use that analogy when I was introducing EEs to LabVIEW until one day when one of them really got hung up on what the voltage (value) was on a wire before the dataflow got to it. I tried in vein to explain it to him, but he just never got past that. Link to comment
Rolf Kalbermatter Posted June 22, 2008 Report Share Posted June 22, 2008 QUOTE (crelf @ Jun 21 2008, 07:14 AM) I used to use that analogy when I was introducing EEs to LabVIEW until one day when one of them really got hung up on what the voltage (value) was on a wire before the dataflow got to it. I tried in vein to explain it to him, but he just never got past that. Ahh well! Some people are sometimes so hung up about something they can't see that it's just a good or sometimes not so good analogy. Guess he wasn't into software at all, so that may explain it a bit. I did know programming as it was part of my study and I wasn't to bad in it either. Just never really liked it very much until I encountered LabVIEW. Rolf Kalbermatter Link to comment
Recommended Posts
Please sign in to comment
You will be able to leave a comment after signing in
Sign In Now