Machsupport Forum
		Mach Discussion => General Mach Discussion => Topic started by: CWare on March 12, 2016, 04:49:07 PM
		
			
			- 
				Trying to figure out if mach is the right choice. Tldr in bold^^
 Not exactly a hobby mill i'm running its a fast cutting machine (F15000) with a toolchanger...
 
 
 Because of a limited step frequency (125khz) of the controller i'm using (EdingCnc) I'm considering switching to Mach3/4 on a VitalSystem DSPMC 7762 controller.
 
 I would need to control mach from an external cam like program though.
 I can alter that program if needed (c++).
 
 I want mach just to launch on startup(thats no problem) sit in the background shut up and execute gcode when it recieves it.
 
 The way I achieved this on the EdingCnc controller...
 EdingCnc watches for filechange on a specified path.
 When it detects a filechange you have the option in setup that it refreshes and starts execution immediately.
 
 Is that possible with mach? If not i'll have to write something like mach for the DSPMC 7762   T.T (would take a while)
 Or any tips on a real time fast controller  which is highly configurable? DSPMC  seemed to be the closest, idk what a siemens  costs or if it is better.
 
 Also is there some conditional statement that can't be realized with macros?Is it burdensome to use?
 
 
 
 
 
 
 
 
 
 
 
 
- 
				KFlop with Kmotion might be a better choice? At least maybe easier? 
			
- 
				I prefer ethernet stability is really important there is a lot of stuff running that generates noise on the line.
 2.5 MHz step dir should be faste enough.
 also 1 MHz encoder freq seems low.
 
 Have you programmed for it?
 The support of vitalsystem seems to be great though.
 
 
 
 
 
- 
				Was browsing the mach4 forum and founs something abt scripting 
 
 http://www.machsupport.com/wp-content/uploads/2014/05/Mach4%20Scripting%20Manual.pdf
 
 Can I use a plc script to look for filechange?
 Or am I completely wrong.
 
 Never used lua is it possible to do file io with it?
- 
				I prefer ethernet stability is really important there is a lot of stuff running that generates noise on the line.
 2.5 MHz step dir should be faste enough.
 also 1 MHz encoder freq seems low.
 
 Have you programmed for it?
 
 
 
 No, but I know of a few people that have written new front ends for it.
- 
				seems like my spec was wrong it should be 500Khz max step frequency
 http://www.dynomotion.com/Help/SpecificationKStep.htm
 
 So Kflop is no option thanks for your reply though.
 I shouldve made 2 threads i guess.
- 
				So it isn't possible?
 Any of the devs I could pm?
- 
				Try asking on the Yahoo group.
			
- 
				Shall do thanks.
			
- 
				Yes you can control Mach3 from another program.  Mach3 exposes a COM interface that allows you to access just about anything.  Attached is a pascal file that shows the calls available.
			
- 
				Thanks a lot for replying,
 I guess its the
 procedure LoadRun(const FileName: WideString);
 
 I havent done anything in pascal though its not familiar.
 
 where can i find documentation for it or a sample program would be awesome?
- 
				The mach3 sdk can be downloaded here:
 
 
 http://www.machsupport.com/software/downloads-updates/ (http://www.machsupport.com/software/downloads-updates/)
 
 Contains .h files and some examples but I don't know of any manuals.
 
 If your development environment has the ability to import a type library that will create the wrapper for you.
- 
				Ok seems this is a bit above my experience level.
 I'm not familiar with the way vs creates dialogs. I use qt for gui's if needed.
 Writing to registry is also something unfamiliar.
 Well eh you get the picture.
 I was hoping to be able to use the methods in the headers to establish communication.
 
 I found your thread
 https://www.machsupport.com/forum/index.php?topic=11240.0
 Installed it.
 unfortunately it's expired?
 
 Saw on your yt channel what it does...
 
 You've done exactly what I look for .
 I'm still a bit confused though to how you did it and how this works.
 
 
 Installed vs2010  yesterday which isn't the right one but at least I see the project tree of the sdk plugin.
 Watched the video of I believe Jerry on creating a plugin.
 
 
 You didn't seem to need a plugin.
 Your program asks for the mach.exe and the xml?
 
 
 Found this online
 COM clients are applications that make use of a COM object implemented by another application Automation Servers (Automation controllers) and applications that host an ActiveX control (ActiveX containers).
 
 To make information about the COM server available to your client application, you must import the information about the server that is stored in the server's type library. Your application can then use the resulting generated classes to control the server object.
 
 You wrote
 "If your development environment has the ability to import a type library that will create the wrapper for you."
 searched wrapper
 so you took the mach. exe and wrapped it in a class?
 
 I haven't done anything like that
 Also what is that machremote example doing.
 This seems to connect
 
 void CMachRemoteDlg::OnBnClickedConnect()
 {
 LPUNKNOWN lpUnk;
 LPDISPATCH lpDispatch;
 COleException e;
 HRESULT res;
 
 if (CLSIDFromProgID(OLESTR("Mach4.Document"), &clsid) != NOERROR)
 {
 return;
 }
 if (res = GetActiveObject( clsid, NULL, &lpUnk) == NOERROR)
 {
 HRESULT hr = lpUnk->QueryInterface(IID_IDispatch,
 (LPVOID*)&lpDispatch);
 lpUnk->Release();
 if (hr == NOERROR)
 {
 mach4.AttachDispatch(lpDispatch, TRUE);
 lpDispatch = mach4.GetScriptDispatch();
 scripter.AttachDispatch(lpDispatch, TRUE);
 }
 connected = true;
 m_Status = "Connected to Mach3.";
 UpdateData(false);
 SetTimer( 1, 200, NULL );
 return ;
 }
 
 m_Status = "No Connection to Mach3.";
 UpdateData(false);
 
 }
 
 Am I correct that there are 3ways to do something similar.
 
 1 plugin.
 2 some remote access.
 3 wrapper com
 
 trying to figure out which one the easiest is to implement without using vs.
 
 
 
- 
				Figured out something more
 
 plugin = a dll that loads at runtime. The code in the dll is executed in the update loop of mach I guess.
 
 That MachRemote application uses OLE https://en.wikipedia.org/wiki/Object_Linking_and_Embedding  to communicate.
 I guess that means mach must be active in the background.
 
 Could you show me how to make a wrapper for mach?
 You showed mach's dro's updated when you changed values from from machme. What is going on there? Was machme altering some files which mach also reads or was it the mach gui and machme gui loaded together.
 Later when you closed mach machme was still operational?
 
 
- 
				Ok, that's a lot of questions!  Many of the answers depend upon what your are really trying to do and what programming environment you will use.  You stated that you wanted to be able to control monitor a file for changes.  This can be done with a plugin.  Mach polls your plugin every so often and your plugin(dll) could be checking to see if the date changed and tell mach to load and run a file.
 
 The code (C or C++) that you referenced above shows how to create a connection to Mach and get a reference to a mach object that connects to the running Mach3 program.  Once  you have that object you can query and set various properties and objects within the running Mach3 program.  The Programmer Reference pdf has all of the calls and their parameters and returns.  It has been years since I programmed in C and each IDE has different capabilites so I can't help you there.
 
 My program (Delphi Object Pascal) checks to see if Mach is a running and if not loads it.  My program initially asks for the Mach3.exe file location and saves that to an ini file.  It also asks for the mach profile you want to load (mach3mill.xml or turn.xml or whatever you named your active profile) so that it can load the program with the appropriate profile and saves that as well.
 
 It then creates a IMyScriptObject that connects to Mach.  I extended the class by creating an inherited class object (wrapper) that does all of this and simplifies certain tasks.  For example have a property xDro that so that I can program xDro:=2.5 or set a variable myVar:=xDro instead of setOEMdro(800,2.5) or myVar:=getOEMdro(800).
 
 The gui is the most complicated item to implement including threads that must be syncronized to update my displays.  So to answer your question I am simply reading the values and updating my gui just as mach is updating its gui.  Possible but not necessary for what you are trying to do.  MachMe has to have a running version of Mach to operate on, it just hid Mach's GUI.
 
- 
				Thanks a bunch for clearing that up.
 I should be able to manage with that much info.
 I'll take it from here and try to write a console application in code::blocks if I manage i'll post it here.
 
 cheers
- 
				I made a tut on how to do this 
 
 http://www.machsupport.com/forum/index.php/topic,32199.0.html