ArtiSynth Quick Installation Guide

John Lloyd

Last updated: July, 2024

This describes how to quickly install one of the precompiled versions of ArtiSynth, which can be useful for users wanting to test the system and run the demonstration programs. Once you decide to use ArtiSynth to build models, we instead recommend installing the latest version from Github into the Eclipse IDE, as described here for Windows, MacOS, and Linux.

1 Instructions

1.1 To install ArtiSynth:

  1. 1.

    You need a 64 bit Windows, MacOS, or Linux system based on an Intel processor. MacOS systems based on the new Apple ARM processor (the M chips) implement a compatibility layer (called Rosetta) that should allow ArtiSynth to run as is, provided that you use a 64-bit Intel-based Java development kit (JDK).

  2. 2.

    A 64-bit Java development kit (JDK) should be installed. This should be an Intel-based JDK (containing x64 in its download name); on ARM-based MacOS machines, this should run using the Intel compatibility layer. You will need a full Java Development Kit (JDK), not simply a runtime environment (JRE), and it must have version 8 or higher. If you need a JDK, we recommend obtaining one from Oracle at www.oracle.com/java/technologies/downloads.

  3. 3.

    To verify that the Java JDK is visible to your system, open a terminal window (e.g., CMD on Windows), run the command javac -version, and check that the version matches the JDK. If it does not, follow the instructions in Section 2.

  4. 4.

    Download the latest precompiled ArtiSynth release (e.g., artisynth_core_3.8.zip) from www.artisynth.org/downloads.

  5. 5.

    Unzip the file into a folder, preferably one without spaces in the name.

1.2 To run ArtiSynth:

  • On Windows: click bin\artisynth.bat under the install folder.

  • On MacOS or Linux: use a terminal to run bin/artisynth under the install folder.

  •  

    To run demos, open the Models menu at the top and choose the model you would like. It will be loaded and displayed in the viewer. To start/stop simulation, use the play button at the top right.

    On MacOS, running a model may initially produce a security error because of untrusted ArtiSynth native libraries. See Section 4 for details on handling this.

1.3 To make changes to a demo:

  1. 1.

    If <AT> denotes the top-level folder of your ArtiSynth installation, then add <AT>\bin (Windows) or <AT>/bin (MacOS and Linux) to your system Path as described in Section 3.

  2. 2.

    Edit the .java file for the demo, which will be located in a folder under <AT>\src\artisynth\demos, using a plain text editor (e.g., notepad on Windows).

  3. 3.

    From within a terminal window (e.g., CMD on Windows), go to the demo folder and enter the command compile.

2 Making the JDK visible to your system

It is important to ensure that the JDK is visible to your system and supersedes any other Java installations.

2.1 Windows and Linux

If <JDK> denotes the top-level folder of your installed JDK, then add the folder <JDK>\bin (Windows) or <JDK>/bin (Linux) to your system Path, using the instructions given in Section 3. The folder should be added ahead of any other Java installations that might be specified on the Path.

On Windows, <JDK_DIR> is likely to be located under C:\Program Files\Java. For example, JDK 21 should be at

   C:\Program Files\Java\jdk-21

2.2 MacOS

On MacOS, you can set the “default” JDK by setting the JAVA_HOME environment variable. This can be done inside the initialization file for your command line shell. Assume that the desired JDK has version number 21 and that your home directory is <HOMEDIR>.

  • If your command line shell is bash (which it will be by default), then the initialization file is <HOMEDIR>/.bashrc. Use a plain text editor to edit (or create) this file and insert a line of the form

      export JAVA_HOME=‘/usr/libexec/java_home -v 21‘
  • If you have changed your shell to csh or tcsh, then the initialization file is <HOMEDIR>/.cshrc. Use a plain text editor to edit or create this file and insert a line of the form

      setenv JAVA_HOME ‘/usr/libexec/java_home -v 21‘

Note that in both examples above, the left quote character "`" is used instead of the more common right quote "". Also, for JDK 8, it may be necessary to specify the argument -v 1.8.0 to java_home.

Setting JAVA_HOME can also be done directly within the shell; doing it within the initialization file simply avoids the need to do so each time a new terminal window is opened.

3 Adding Directories to the System Path

The system “Path” is a list of directories which the system searches in order to find executables. Adding a directory to the path allows executables contained in that directory to be called directly from a command window (such as CMD on Windows).

3.1 Windows 10

  1. 1.

    Open the Start search, enter “env”, and choose “Edit the system environment variables”.

  2. 2.

    Click on Environment Variables.

  3. 3.

    Under User variables (the top window), click on Path and click Edit. If Path does not exist, click New.

  4. 4.

    In the Edit environment variable dialog, click New and enter the full path name for each directory you wish to add.

  5. 5.

    Close all dialogs by clicking OK and restart your command window.

3.2 Windows 8 and earlier

  1. 1.

    Right-click My Computer, and then click Properties.

  2. 2.

    Click the Advanced tab.

  3. 3.

    Click Environment variables.

  4. 4.

    In the top User variables window, click on Path and then Edit. If Path does not exist, click New.

  5. 5.

    In the edit window, add the full path name for each new directory, separated by semi-colons ’;’.

  6. 6.

    Close all dialogs by clicking OK and restart your command window.

For example, if ArtiSynth is installed at C:\artisynth\artisynth_core and the desired JDK is at C:\Program Files\Java\jdk-21, then we can add the bin directories for both by setting the User path to

  C:\artisynth\artisynth_core\bin;C:\Program Files\Java\jdk-21\bin

3.3 MacOS

Since MacOS is a Unix-based system, directories can be added to the path by editing the PATH environment variable directly in the initialization files for whichever command line shell you are using, in the same manner as described for Linux (Section 3.4). The default command line shell for MacOS is bash.

On MacOS 10.8 and greater, directories can also be added to the path by adding a text file containing the directories to /etc/paths.d. In particular, we can create a file called ArtiSynth in /etc/paths.d that contains the full path names of the desired directories.

  1. 1.

    Open a terminal window

  2. 2.

    Use sudo to create /etc/paths.d/ArtiSynth with a plain text editor. For example:

      sudo nano /etc/paths.d/ArtiSynth
    
  3. 3.

    Add the full path name of each desired directory, one per line, and save the file.

  4. 4.

    To test the revised PATH, open a new terminal window and enter the command: echo $PATH.

3.4 Linux

On Linux, directories can be added to the path by appending them to the PATH environment variable, which is a list of directories separated by colons ‘:’. The most direct way to do this is to redefine PATH inside one of the initialization files for whichever command line shell you are using.

Assume that your home folder is <HOMEDIR>. Then for the bash shell, one can edit <HOMEDIR>/.bashrc (or create the file if it does not already exist) and insert a line of the form

   export PATH=<DIR>:$PATH

while for the csh out tcsh shells, one can edit <HOMEDIR>/.cshrc and insert a line of the form

   setenv PATH <DIR>":"$PATH

4 Getting past MacOS security

On recent versions of MacOS, a problem that may occur when trying to run ArtiSynth models is that MacOS may complain about using a nonvalidated external library. This may take the form of a console error that looks like this:

 ...
 /Users/lloyd/git/artisynth_core/lib/MacOS64/libPardisoJNI.11.1.2.1.dylib)
 not valid for use in process using Library Validation: library load disallowed
 by system policy
 ...

and/or a popup notice like this:

The problem here is that one or more of the native libraries are not “known” to Apple and are therefore not trusted. Clicking the "?" on the popup will open a window containing more information about what to do.

The short version is to immediately open your Security and Privacy settings after the error occurs, and then, near the bottom of the General tab, you should see a notification about the blocked application with a button to the right labeled Open Anyway. Clicking that button will grant the application a security exception. You will then need to exit and restart ArtiSynth.