-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Origin: http://intantech.com/files/IntanStimRecordController_source_code_v1_07.zip Version: 1.07 (July 6, 2020)
- Loading branch information
0 parents
commit 3a3a0b0
Showing
114 changed files
with
28,229 additions
and
0 deletions.
There are no files selected for viewing
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
Intan Stimulation/Recording Controller Software - Source Code (v1.07) | ||
--------------------------------------------------------------------- | ||
|
||
This directory contains the Intan Stimulation/Recording Controller C++/Qt source code and two supporting files: | ||
main.bit (the FPGA configuration file) and an operating system-specific Opal Kelly library file located | ||
in the 'Opal Kelly library files' directory. | ||
|
||
These two supporting files must reside in the directory with the executable file (i.e., the 'debug' | ||
or 'release' folder generated when the code is compiled). To find the executable directory on | ||
a Mac, right-click on the IntanRecordingController.app file generated by Qt, select "Show package contents", | ||
and open the "MacOS" directory. (Note: Some Mac users have reported that these two files must be | ||
placed in the in same directory as the application instead.) | ||
|
||
You should also download and install the USB drivers from the Intan Technologies website before | ||
connecting the Intan Recording Controller to a computer. (They are not included in this zip file.) | ||
However, you can run the Recording Controller software in demonstration mode without installing drivers | ||
or plugging in an interface board. | ||
|
||
The C++ source code uses a handful of C++11 features, so g++ users may need to add -std=c++11 to their | ||
command line or make file. | ||
|
||
This code was tested with Qt 4.8.1 and with Qt 5.7.0. | ||
|
||
For production code, you should compile a Release build (Visual Studio) or use the optimization flag | ||
-O3 (g++). Otherwise, the compiled code may not be fast enough to keep up with how fast data streams | ||
from the USB interface board. This will show up as the FIFO lag becoming very high for debug builds. | ||
|
||
(Thanks to Josh Siegle at MIT and Open-Ephys.org for tips on Mac and Linux compilation.) | ||
|
||
Other Linux tips | ||
---------------- | ||
Copy the libokFrontPanel.so file into the source folder. | ||
Add the following line to the .pro file: | ||
unix:LIBS += -L./ -l okFrontPanel -ldl | ||
Run qmake on the .pro file, and then make. | ||
|
||
|
||
Other tips on Mac compilation | ||
----------------------------- | ||
|
||
Intan now provides executables for MacOSX. However, some users may wish to modify and recompile the | ||
code on a Mac. This description is based on exprience using a MacBook Pro running MacOSX 12. | ||
|
||
1) Install XCode | ||
|
||
2) Install Qt Creator and Qt5 (Make sure to install XCode first) | ||
|
||
3) Open the project (.pro) file and click "run" in release mode (will not succeed). | ||
|
||
4) Inside the build directory, find the .app file that was generated. Right-click and select "Show | ||
Package Contents". Navigate to Contents->MacOS. Move the "main.bit" and "libokFrontPanel.dylib" | ||
files to this folder, alongside the executable. | ||
|
||
5) Qt Creator should now be able to fully run the program. | ||
|
||
|
||
------------------------------------------------------------------------- | ||
|
||
Some Windows users have reported that it is necessary to install Qt with 32-bit support for the | ||
okFrontPanel DLL to load properly. But this was with an older version of the Recording Controller source | ||
code that didn't support 64-bit, so it may not apply any more. | ||
|
||
|
||
|
||
License | ||
------- | ||
|
||
The Intan Stimulation/Recording Controller is free software, and is distributed under the terms of the GNU Lesser | ||
General Public License as published by the Free Software Foundation. See the license subdirectory | ||
for the complete license. | ||
|
||
|
||
Recommended C++/Qt Resources | ||
---------------------------- | ||
|
||
The source code is written entirely in C++ using the open-source Qt libraries for multi-platform GUI | ||
support. (The files composing the core RhythmStim API are written in straight C++ without using Qt.) | ||
|
||
There are countless books and other online resources related to C++ programming, so these will not | ||
be discussed here. For C++ programmers new to Qt, the best place to start is http://qt-project.org. | ||
We recommend downloading the Qt SDK (Software Design Kit) including Qt Creator, Qt Assistant, and the | ||
latest Qt libraries for the operating system of choice. | ||
|
||
The best book we have found for first-time Qt programmers is C++ GUI Programming with Qt 4, Second | ||
Edition, by Jasmin Blanchette and Mark Summerfield (ISBN 0-13-235416-0). Chapters 1-8 and 11-12, along | ||
with Appendices A and B, cover nearly all the aspects of Qt used in the RHD2000 interface GUI. The | ||
library documentation available in the Qt Assistant application is also excellent and indispensable. | ||
|
||
|
||
Related RHS2000 Documentation | ||
----------------------------- | ||
|
||
The following supporting datasheets provide detailed information on the operation of the Intan Technologies | ||
RHS2000 digital stimulation/amplifier chips and Rhythm Stim interface; they may be found on the Intan Technologies | ||
website, http://www.intantech.com: | ||
|
||
* Intan Stimulation/Recording Controller User Guide | ||
* RHS2000 Series Digital Stimulation/Amplifier Interface Chips | ||
* RHS2000 USB/FPGA Interface: RhythmStim | ||
* RHS2000 Stim SPI Cable/Connector Specification | ||
* RHS2000 Application Note: Data File Formats | ||
* RHS2000 Application Note: Adding Stim SPI Cables to a Commutator |
Oops, something went wrong.